@charset "utf-8";
/*
	Last Update: 2025/8/19
	Auther: 大嶋
*/
/*===================================================================
	page layout
===================================================================*/
/*
* 【このコメントは編集時に必ず削除してください】--------------------------------------------------------------------------------
*
* デザインに合わせて変更してください。
*
* ----------------------------------------------------------------------------------------------------------------------
*/
#page_title { position:relative; }
#page_title .img_back { height:35vw; max-height:370px; }
#page_title .title_wrap { text-align:center; }
#page_title .main { font-weight:bold; }
#page_title .sub {}
	@media (max-width: 767px){
		#page_title .img_back { height:250px; }
		#page_title .main { font-size:2em; }
	}
	@media (min-width: 768px) and (max-width: 991px){
		#page_title .img_back { height:50vw; max-height:370px; }
		#page_title .main { font-size:2.25em; letter-spacing:3px; }
	}
	@media (min-width: 992px){
		#page_title .img_back { height:35vw; max-height:370px; }
		#page_title .main { font-size:2.5em; letter-spacing:3px; }
	}

#pankuzu { font-size:13px; padding-top:10px; padding-bottom:10px; }
#pankuzu a {}
#pankuzu li, #pankuzu li:before { vertical-align:baseline; line-height:100%; }
#pankuzu li:before { display:inline-block; }
#pankuzu ul > li:not(:first-child):before { content:"/"; margin:0 8px; color:#D9D9D9; }
body.pc #pankuzu a:hover { text-decoration:underline; }
	@media (max-width: 575px){
		#pankuzu ul { text-overflow:ellipsis; overflow:hidden; white-space:nowrap; }
		#pankuzu li { display:inline; }
	}
	@media (min-width: 576px){
		#pankuzu li { display:inline-block; }
	}


/*===================================================================
	entry
===================================================================*/
/*
* 【このコメントは編集時に必ず削除してください】--------------------------------------------------------------------------------
*
* お知らせのcomment等用のカラー設定です
* デザインに合わせて必ず設定してください。
*
* ----------------------------------------------------------------------------------------------------------------------
*/
/*
.entry a { color:; }
*/
.entry ul > li:before { content:"●"; color:; }
.entry ul > li > ul > li:before { content:"■"; color:; }
.entry ol > li:before { color:; }
.entry ol > li > ol > li:before { color:; }
.entry table thead th { background:; color:; }
.entry table thead td { background:; color:; }
.entry table tbody th { background:; color:; }
.entry table tbody td { background:; color:; }


/*=============================
mypage_login
================================*/
#mypage,html{
	height: 100%;
}
#mypage{
	padding-bottom: 0 !important;
}
#mypage .unit_login{
	height: 100%;
}
#mypage_login .login_wrap{
	padding-top: 40px;
    padding-bottom: 40px;
}
#mypage_login .unit_title{
	text-align: center;
	font-size: 1.2rem;
}
#mypage_login .input_content{
	padding: 0 25px;
}
#mypage_login .input_content label{
	color: #797979;
	font-size: 0.9rem;
}
#mypage_login .input_content input{
	margin-top: 5px;
}
#mypage_login .button{
	width: 100%;
}
#mypage_login .error_box {
	background-color: #FFF0F0;
	border: 1px solid #D62827;
	color: #D62827;
	padding: 5px;
  	margin-top: 10px;
	margin-bottom: 20px;
}
/*=============================
mypage_registration
================================*/
#mypage,html{
	height: 100%;
}
#mypage{
	padding-bottom: 0 !important;
}
#mypage .unit_registration{
	height: 100%;
}
#mypage_registration .registration_wrap{
	padding-top: 40px;
    padding-bottom: 40px;
}
#mypage_registration .input_content{
	padding: 0 25px;
}
#mypage_registration .input_content label,
#mypage_registration .input_content p{
	color: #797979;
	font-size: 0.9rem;
	font-weight: 500;
}
#mypage_registration .input_content input{
	margin-top: 5px;
}
#mypage_registration .button{
	width: 100%;
}
#mypage_registration span.unit_required{
	border: 1px solid #D62827;
	color: #D62827;
	padding: 0 5px;
	border-radius: 3px;
	margin-left: 10px;
	font-size: 0.6rem;
}
#mypage_registration a{
	color: #D5272A;
	text-decoration: underline;
}
#mypage_registration .unit_consent{
	display: flex;
	align-items: center;
	justify-content: center;
}
input[type="checkbox"]{
	margin: 0 5px 0 0 !important;
	width: 15px;
	height: 15px;
}
#mypage_registration .error_box {
	background-color: #FFF0F0;
	border: 1px solid #D62827;
	color: #D62827;
	padding: 5px;
  margin-top: 10px;
	margin-bottom: 20px;
}
/*=============================
application_form
=============================*/

#application_form .form_wrap{
	padding: 40px 60px;
	box-shadow: 0 0 5px #ccc;
	border-radius: 3px;
}
#application_form .form_wrap .attention{
	background-color: #FFF2F0;
	padding: 10px;
}
#application_form .form_wrap .attention span{
	color: #9F0310;
}
#application_form .input_content .unit_name{
	color: #414141;
	font-size: 1rem;
	font-weight: bold;
	margin-bottom: 5px;
	display: inline-block;
}
#application_form .input_content .unit_name2{
	color: #797979;
	font-size: 0.8rem;
	margin-bottom: 5px;
}
#application_form .button{
	width: 100%;
}
#application_form span.unit_required{
	border: 1px solid #D62827;
	color: #D62827;
	padding: 0 5px;
	border-radius: 3px;
	margin-left: 10px;
	font-size: 0.6rem;
	height: 18px;
    line-height: 18px;
	display: inline-block;
	font-weight: normal;
}
#application_form a{
	color: #D5272A;
	text-decoration: underline;
}
#application_form .unit_consent{
	display: flex;
	align-items: center;
	justify-content: center;
}
input[type="checkbox"]{
	margin: 0 5px 0 0 !important;
	width: 15px;
	height: 15px;
}
#application_form .unit_disp_fl{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
}
#application_form .unit_disp_fl2{
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
#application_form .unit_disp_fl2 p{
	margin: 0 10px;
}
#application_form .unit_wd10{
	width: 10%;
}
#application_form .unit_wd15{
	width: 15%;
}
#application_form .unit_wd20{
	width: 20%;
}
#application_form .unit_wd35{
	width: 35%;
}
#application_form .unit_wd50{
	width: 49%;
}
#application_form textarea{
	height:15vw;
}
#application_form .unit_line{
	width: 48%;
	height: 60px;
	border: 1px solid #D9D9D9;
	display: flex;
    align-items: center;
	border-radius:5px;
}
#application_form input[type="text"]{
	height: 50px;
}
select {
  appearance: none;     
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: #fff;   
  color: #5F5F5F;             
  padding: 10px;
  padding-right: 30px;       
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 18px;
  background: url("../image/top/arrow.png")no-repeat;
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 16px;
}
#application_form .unit_line input[type="radio"]{
	margin: 0 10px;
	accent-color:#9F0310;
}
#application_form .unit_line.is-checked{
	border: 1px solid #9F0310 !important;
}
#application_form .unit_line_gray{
	border-bottom: 1px solid #E0E0E0;
	padding-bottom: 20px;
}
#application_form .unit_button{
	border: 1px solid #9F0310;
	color: #9F0310;
	font-weight: bold;
	background-color: #FFFFFF;
	border-radius: 50px;
	width: 180px;
	height: 40px;
	position: relative;
}
#application_form .unit_button::before{
	position: absolute;
	content: "";
	background: url(../image/top/plus.png)no-repeat;
	background-size: 15px 15px;
	width: 15px;
	height: 15px;
	top: 50%;
	transform: translateY(-50%);
	left: 25px;
}
#application_form .next_wrap{
	display: flex;
	justify-content: center;
}
#application_form .next_wrap button{
	width: 200px;
	margin: 0 20px;
}
#application_form .next_wrap button span{
	font-size: 1.2rem;
}
#application_form .progress{
	border: 1px solid #3C3C3C;
	border-radius: 5px;
	display: flex;
	flex-wrap: wrap;
	background-color: #FFFFFF;
	margin-bottom: 40px;
}
#application_form .progress .progress_detail{
	border-right: 1px solid #3C3C3C;
	width: 16.6666666%;
	text-align: center;
	padding: 10px 2px;
	display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
}
#application_form .progress .progress_detail.active{
	background-color: #9F0310;
	color: #FFFFFF;
}
#application_form .progress .progress_detail span{
	font-size: 0.75rem;
}
#application_form .progress .progress_detail p{
	font-size: 0.8rem;
}
#application_form .progress .progress_detail:last-child{
	border-right: none;
}

@media (max-width: 768px){
	#application_form .progress .progress_detail span{
		font-size: 0.65rem;
		line-height: 1.5;
	}
	#application_form .progress .progress_detail p{
		font-size: 0.7rem;
		line-height: 1.5;
	}
}
@media (max-width: 575px){
	#application_form .form_wrap{
		padding: 60px 30px;
	}
	#application_form .unit_wd15{
		width: 25%;
	}
	#application_form .unit_wd20{
		width: 30%;
	}
	#application_form .unit_wd35{
		width: 50%;
	}
	#application_form .next_wrap button{
		width: 150px;
		margin: 0 10px;
	}
	#application_form .next_wrap button span{
		font-size: 1rem;
	}
	#application_form .progress .progress_detail{
		width: 33.3333%;
	}
	#application_form .progress .progress_detail:nth-child(1),
	#application_form .progress .progress_detail:nth-child(2),
	#application_form .progress .progress_detail:nth-child(3){
		border-bottom: 1px solid #3C3C3C;
	}
	#application_form .progress .progress_detail:last-child,
	#application_form .progress .progress_detail:nth-child(3){
		border-right: none;
	}
}
@media (max-width: 425px){
	#application_form .form_wrap{
		padding: 60px 15px;
	}
	#application_form .next_wrap button{
		width: 110px;
	}
	#application_form .unit_fs,
	#application_form select{
		font-size: 0.7rem;
	}
	#application_form .unit_disp_fl2 p{
		font-size: 0.8rem;
	}
}

/*===========================
recruitment
============================*/
#recruitment .sp_table_wrap{
	width: 100%;
}
#recruitment .graph_wrap{
	width: 100%;
	margin-bottom: 40px;
}
#recruitment .graph_wrap table{
	border: 1px solid #D1D1D1;
	width: 100%;
}
#recruitment .graph_wrap table tr,
#recruitment .graph_wrap table th{
	border: none;
}
#recruitment .graph_wrap table th{
	border-bottom: 1px solid #FFFFFF;
	/* background-color: #9F0310; */
	color: #FFFFFF;
	width: 150px;
	min-height: 60px;
	height: 60px;
	padding: 10px 20px;
}
#recruitment .graph_wrap table th.v2{
	 vertical-align: top;
}
#recruitment .graph_wrap table td{
	border-bottom: 1px solid #D1D1D1;
	background-color: #ffffff;
	color: #4D4D4D;
	padding: 20px;
}
#recruitment .btn_wrap_center{
	text-align: center;
	border-bottom: 1px solid #c7c7c7;
    margin-bottom: 30px;
    padding-bottom: 30px;
}
#recruitment .color_change{
	justify-content: center;
}
#recruitment .history_wrap{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
#recruitment .history_wrap .history_detail{
	background-color: #ffffff;
	width: 49%;
	box-shadow: 1px 1px 5px #ccc;
	margin-bottom: 20px;
	padding: 30px;
	text-align: center;
}
#recruitment .history_wrap .history_detail .name_title{
	display: flex;
	justify-content: center;
    align-items: center;
	margin-bottom: 15px;
	font-size: 1.3rem;
}
#recruitment .history_wrap .history_detail .name_title img{
	margin-right: 10px;
}
#recruitment .history_wrap .history_detail .name_title .ruby{
	font-size: 0.8rem;
}
#recruitment .history_wrap .history_detail h3{
	font-size: 1.5rem;
	color: #4D4D4D;
	margin-bottom: 20px;
}
#recruitment .history_wrap .history_detail .unit_button_wrap{
	text-align: center;
}
#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button{
	width: 90%;
	padding: 10px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
    align-items: center;
	border-radius: 50px;
	font-size: 0.85rem;
	margin: 0 auto 15px auto;
}
#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button.v1{
	background-color: #9F0310;
	color: #ffffff;
	font-weight: bold;
}
#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button.v2{
	background-color: #3C3C3C;
	color: #ffffff;
	font-weight: bold;
}
#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button.v3{
	background-color: #EDEDED;
	color: #3C3C3C;
	font-weight: bold;
}
#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button.v4{
	background-color: #FFDEE8;
	color: #9F0310;
	font-weight: bold;
	border-radius: 5px;
}
#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button.v5{
	background-color: #CBCBCB;
	color: #151515;
	font-weight: bold;
	border-radius: 5px;
}
@media (max-width: 767px){
	.graph_wrap table{
		white-space: normal;
		width: 767px;
	}
	#recruitment .history_wrap{
		justify-content: center;
	}
	#recruitment .history_wrap .history_detail{
		padding: 20px 10px;
		width: 90%;
	}
	#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button{
		width: 95%;
	}
}
@media (max-width: 575px){
	#recruitment .graph_wrap table th{
		width: 90px;
		padding: 10px 10px;
	}
	.graph_wrap table{
		white-space: normal;
		width: 500px;
	}
	#recruitment .history_wrap .history_detail{
		width: 100%;
	}
}
@media (max-width: 425px){
	#recruitment .history_wrap .history_detail .name_title{
		font-size: 1rem;
	}
	#recruitment .history_wrap .history_detail h3{
		font-size: 1.2rem;
	}
	#recruitment .history_wrap .history_detail .unit_button_wrap .unit_button{
		font-size: 0.7rem;
	}
}
/*===============================
news
===============================*/
#event .event_list{
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-start;
	gap: 30px 2%;
}
#event .event_list .event_detail{
	width: 32%;
	box-shadow: 1px 1px 5px #ccc;
}
#event .event_list .event_detail a{
	background-color: #FFFFFF;
	height: 100%;
    display: block;
}
#event .event_list .event_detail .image{
	aspect-ratio: 14 / 9;
}
#event .event_list .event_detail .image img{
	width: 100%;
	height: 100%;
    object-fit: cover;
}
#event .event_list .event_detail .unit_text{
	background-color: #ffffff;
	padding: 10px;
}
#event .event_list .event_detail .unit_text span{
	color: #7C7C7C;
	font-size: 0.7rem;
}
#event .event_list .event_detail .unit_text h3{
	font-size: 0.9rem;
}
.pagination {
  display: flex;
  list-style: none;
  gap: 6px;
  padding: 0;
  align-items: center;
  justify-content: center;
}

.pagination li a {
  display: block;
  padding: 6px 12px;
  text-decoration: none;
  border: 1px solid #ddd;
  color: #666;
  background-color: #ffffff;
  font-size: 1rem;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 40px;
}

.pagination li.active a {
  background-color: #8b0000; 
  color: #fff;
  border-color: #8b0000;
}

.pagination li.disabled a {
  color: #ccc;
  pointer-events: none;
}
@media (max-width: 575px){
	#event .event_list .event_detail{
		width: 49%;
	}
}
@media (max-width: 425px){
	#event .event_list .event_detail{
		width: 100%;
	}
}
/*==============================
イベント情報の詳細
===============================*/
#event_detail .event_detail_text{
	background-color: #FFFFFF;
	padding: 40px;
}
#event_detail .event_detail_text .text_title{
	border-bottom: 1px solid #cbcbcb;
	padding-bottom: 20px;
	margin-bottom: 20px;
	color: #7C7C7C;
}
#event_detail .event_detail_text .text_title h3{
	font-size: 1.4rem;
}
#event_detail .event_detail_text .text_detail{
	color: #565656;
}
#event_detail .detail_image_wrap{
	display: flex;
}
#event_detail .detail_image_wrap .detail_image{
	margin: 0 5px;
}
#event_detail .event_detail_text .detail_image img{
	width: 100%;
}
#event_detail .next_wrap{
	display: flex;
	justify-content: center;
	align-items: center;
}
#event_detail .next_wrap button{
	margin: 0 20px;
}
@media (max-width:767px) {
	#event_detail .event_detail_text{
		padding: 30px;
	}
	#event_detail .next_wrap button{
		width: 180px;
	}
	#event_detail .event_detail_text .text_title h3{
		font-size: 1.2rem;
	}
	#event_detail .detail_image_wrap{
		justify-content: center;
		flex-wrap: wrap;
	}
	#event_detail .detail_image_wrap .detail_image{
		width: 46%;
	}
}
@media (max-width: 575px){
	#event_detail .event_detail_text{
		padding: 20px;
	}
	#event_detail .next_wrap button{
		width: 140px;
		margin: 0 10px;
	}
	#event_detail .event_detail_text .text_title{
	padding-bottom: 10px;
	margin-bottom: 10px;
}
	#event_detail .event_detail_text .text_title h3{
		font-size: 1rem;
	}
	#event_detail .detail_image_wrap .detail_image{
		width: 100%;
	}
}
@media (max-width: 425px){
	#event_detail .next_wrap button{
		width: 120px;
	}
	#event_detail .event_detail_text .text_title h3{
		font-size: 0.9rem;
	}
}
/*======================
problem
========================*/
#problem .unit_link_list{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
}
#problem .unit_link_list .link_detail{
	background-color: #FFFFFF;
	box-shadow: 0 0 5px #00000009;
	border-radius: 5px;
	margin-bottom: 20px;
	width: 48%;
}
#problem .unit_link_list .link_detail a{
	display: flex;
	align-items: center;
	padding: 20px;
	height: 100%;
}
#problem .unit_link_list .link_detail a p{
	font-size: 0.9rem;
}
#problem .unit_link_list .link_detail.v2{
	width: 100% !important;
}
#problem .unit_link_list .link_detail.v2 span{
	background-color: #9F0310;
	color: #FFFFFF;
	font-size: 0.8rem;
	max-height: 20px;
	line-height: 20px;
	padding: 0 5px;
	margin-right: 10px;
}
#problem .unit_link_list .link_detail.question{
	border: 1px solid #ccc;
}
#problem .unit_link_list .link_detail.answer{
	border: 1px solid #E8ABB0;
	background-color: #FFF0F0;
}
#problem .unit_link_list .link_detail.question span{
	background-color: #ffffff;
	border: 2px solid #9F0310;
	color: #9F0310;
	border-radius: 50px;
	font-weight: bold;
	width: 25px;
	min-width: 25px;
    height: 25px;
	min-height: 25px;
	line-height: 1;
    font-size: 0.8rem;
    text-align: center;
	margin-right: 10px;
	display: flex;
    align-items: center;
    justify-content: center;
}
#problem .unit_link_list .link_detail.answer span{
	background-color: #9F0310;
	color: #ffffff;
	border-radius: 50px;
	font-weight: bold;
	width: 25px;
	min-width: 25px;
    height: 25px;
	min-height: 25px;
    font-size: 0.8rem;
	line-height: 1;
    text-align: center;
	margin-right: 10px;
	display: flex;
    align-items: center;
    justify-content: center;
}
@media (max-width:768px) {
	#problem .unit_link_list .link_detail a{
		padding: 15px 10px;
	}
	#problem .unit_link_list .link_detail a p{
		font-size: 0.7rem;
	}
	#problem .unit_link_list .link_detail.question span,
	#problem .unit_link_list .link_detail.answer span{
		margin-right: 5px;
	}
}
@media (max-width: 575px){
	#problem .unit_link_list .link_detail{
		width: 100%;
	}
}

/*======================
basic_form
========================*/
#basic_form .form_wrap{
	padding: 40px 60px;
	box-shadow: 0 0 5px #ccc;
	border-radius: 3px;
}
#basic_form .form_wrap .attention{
	background-color: #FFF2F0;
	padding: 10px;
}
#basic_form .form_wrap .attention span{
	color: #9F0310;
}
#basic_form .input_content .unit_name{
	color: #414141;
	font-size: 1rem;
	font-weight: bold;
	margin-bottom: 10px;
	display: inline-block;
}
#basic_form .input_content .unit_name2{
	color: #797979;
	font-size: 0.8rem;
	margin-bottom: 5px;
}
#basic_form .button{
	width: 100%;
}
#basic_form span.unit_required{
	border: 1px solid #D62827;
	color: #D62827;
	padding: 0 5px;
	border-radius: 3px;
	margin-left: 10px;
	font-size: 0.6rem;
	height: 18px;
    line-height: 18px;
	display: inline-block;
	font-weight: normal;
}
#basic_form a{
	color: #D5272A;
	text-decoration: underline;
}
#basic_form .unit_consent{
	display: flex;
	align-items: center;
	justify-content: center;
}
input[type="checkbox"]{
	margin: 0 5px 0 0 !important;
	width: 15px;
	height: 15px;
}
#basic_form .unit_disp_fl{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;
}
#basic_form .unit_disp_fl2{
	display: flex;
	align-items: center;
	flex-wrap: wrap;
}
#basic_form .unit_disp_fl2 p{
	margin: 0 10px;
}
#basic_form .unit_wd10{
	width: 10%;
}
#basic_form .unit_wd15{
	width: 15%;
}
#basic_form .unit_wd20{
	width: 20%;
}
#basic_form .unit_wd35{
	width: 35%;
}
#basic_form .unit_wd50{
	width: 49%;
}
#basic_form textarea{
	height:15vw;
}
#basic_form .unit_line{
	width: 48%;
	height: 60px;
	border: 1px solid #D9D9D9;
	display: flex;
    align-items: center;
	border-radius:5px;
}
#basic_form input[type="text"]{
	height: 50px;
}
select {
  appearance: none;     
  -webkit-appearance: none;
  -moz-appearance: none;
  background-color: #fff;   
  color: #5F5F5F;             
  padding: 10px;
  padding-right: 30px;       
  border: 1px solid #ccc;
  border-radius: 6px;
  font-size: 18px;
  background: url("../image/top/arrow.png")no-repeat;
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 16px;
}
#basic_form .unit_line input[type="radio"]{
	margin: 0 10px;
	accent-color:#9F0310;
}
#basic_form .unit_line.is-checked{
	border: 1px solid #9F0310 !important;
}
#basic_form .unit_line_gray{
	border-bottom: 1px solid #E0E0E0;
	padding-bottom: 20px;
}
#basic_form .unit_button{
	border: 1px solid #9F0310;
	color: #9F0310;
	font-weight: bold;
	background-color: #FFFFFF;
	border-radius: 50px;
	width: 180px;
	height: 40px;
	position: relative;
	line-height: 40px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
}
#basic_form .unit_button::before{
	position: absolute;
	content: "";
	background: url(../image/top/plus.png)no-repeat;
	background-size: 15px 15px;
	width: 15px;
	height: 15px;
	top: 50%;
	transform: translateY(-50%);
	left: 25px;
}
#basic_form .next_wrap{
	display: flex;
	justify-content: center;
}
#basic_form .next_wrap button{
	width: 200px;
	margin: 0 20px;
}
#basic_form .next_wrap button span{
	font-size: 1.2rem;
}
	@media (max-width: 575px){
		#basic_form .form_wrap{
			padding: 60px 30px;
		}
		#basic_form .unit_wd15{
			width: 25%;
		}
		#basic_form .unit_wd20{
			width: 30%;
		}
		#basic_form .unit_wd35{
			width: 50%;
		}
		#basic_form .next_wrap button{
			width: 150px;
			margin: 0 10px;
		}
		#basic_form .next_wrap button span{
			font-size: 1rem;
		}
	}
	@media (max-width: 425px){
		#basic_form .form_wrap{
			padding: 60px 15px;
		}
		#basic_form .next_wrap button{
			width: 110px;
		}
		#basic_form .unit_fs,
		#basic_form select{
			font-size: 0.7rem;
		}
		#basic_form .unit_disp_fl2 p{
			font-size: 0.8rem;
		}
	}
/*=============================
password_reset
================================*/
#password_reset .color_change.v2{
	    justify-content: center;
}
.color_change.v2 a{
	height: auto;
	margin-left: 0;
}
#password_reset{
	height: calc(100vh - 155px);
	display: flex;
    align-items: center;
}
#password_reset .form_wrap{
	padding: 40px 60px;
	box-shadow: 0 0 5px #ccc;
	border-radius: 3px;
}
#password_reset .form_wrap .attention{
	background-color: #FFF2F0;
	padding: 10px;
}
#password_reset .form_wrap .attention span{
	color: #9F0310;
}
#password_reset .input_content .unit_name{
	color: #414141;
	font-size: 1rem;
	font-weight: bold;
	margin-bottom: 10px;
	display: inline-block;
}
#password_reset span.unit_required{
	border: 1px solid #D62827;
	color: #D62827;
	padding: 0 5px;
	border-radius: 3px;
	margin-left: 10px;
	font-size: 0.6rem;
	height: 18px;
    line-height: 17px;
	display: inline-block;
	font-weight: normal;
}
#password_reset .unit_line_gray{
	border-bottom: 1px solid #E0E0E0;
	padding-bottom: 20px;
}
#password_reset input[type="text"]{
	height: 50px;
}
@media (min-width: 1200px){
	#password_reset{
		height: calc(100vh - 180px);
	}
}
@media (min-width: 992px) and (max-width: 1199px){
	#password_reset{
		height: calc(100vh - 165px);
	}
}
@media (max-width: 575px){
	#password_reset .form_wrap{
		padding: 60px 30px;
	}
	#password_reset{
		height: calc(100vh - 180px);
	}
	}
	@media (max-width: 425px){
		#password_reset .form_wrap{
			padding: 60px 15px;
		}
		#password_reset .attention p{
			font-size: 0.8rem;
		}
	}
/*=======================
unsubscribe
=========================*/
#unsubscribe .form_wrap{
	padding: 40px 60px;
	box-shadow: 0 0 5px #ccc;
	border-radius: 3px;
}
#unsubscribe .form_wrap .attention{
	background-color: #FFF2F0;
	padding: 10px;
}
#unsubscribe .form_wrap .attention span{
	color: #9F0310;
}
#unsubscribe .input_content .unit_name{
	color: #414141;
	font-size: 1rem;
	font-weight: bold;
	margin-bottom: 10px;
	display: inline-block;
}
#unsubscribe span.unit_required{
	border: 1px solid #D62827;
	color: #D62827;
	padding: 0 5px;
	border-radius: 3px;
	margin-left: 10px;
	font-size: 0.6rem;
	height: 18px;
    line-height: 17px;
	display: inline-block;
	font-weight: normal;
}
#unsubscribe .unit_line_gray{
	border-bottom: 1px solid #E0E0E0;
	padding-bottom: 20px;
}
#unsubscribe input[type="text"]{
	height: 50px;
}
@media (max-width: 575px){
		#unsubscribe .form_wrap{
			padding: 60px 30px;
		}
	}
	@media (max-width: 425px){
		#unsubscribe .form_wrap{
			padding: 60px 15px;
		}
		#unsubscribe .attention p{
			font-size: 0.8rem;
		}
	}
/*============================
uniform
============================*/
#uniform .unit_small{
	font-size: 0.8rem;
	color: #797979;
}
#uniform .background_white{
	background-color: #FFFFFF;
	padding: 30px 40px;
	margin-bottom: 20px;
}
#uniform .background_white p{
	color: #777777;
	font-size: 0.8rem;
	line-height: 1.5;
}
#uniform .background_white .ju_co{
	justify-content: center;
}
#uniform .background_white .image_list p{
	font-size: 0.8rem;
}
#uniform .background_white .image_list span{
	font-size: 0.6rem;
	color: #797979;
}
@media (max-width:575px) {
	#uniform .background_white{
		padding: 20px 20px;
	}
	#uniform .background_white p{
		font-size: 0.7rem;
	}
	#uniform .background_white .image_list h3{
		font-size: 0.8rem;
	}
}
@media (max-width:425px){
	#uniform .background_white .image_list h3{
		font-size: 0.7rem;
	}
	#uniform .background_white .image_list p{
		font-size: 0.7rem;
	}
}
/*==========================
privacy_policy
=============================*/
#privacy_policy .unit_disp{
	display: flex;
}
#privacy_policy .background_white{
	background-color: #FFFFFF;
	padding: 35px 40px;
}
#privacy_policy .unit_disp span{
	text-wrap: nowrap;
}
#privacy_policy p{
	font-size: 0.9rem;
}
@media (max-width:575px){
	#privacy_policy p{
		font-size: 0.8rem;
	}
	#privacy_policy .background_white{
	padding: 35px 20px;
}
}


/*==========================
 WEB出願
==========================*/
#application_form .toggle_relation { display: none; }
#application_form .js-family-row.hidden { display: none; }
#application_form .switch_off { display: none; }
#application_form .popup-overlay,
#child-select-popup { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0, 0, 0, 0.5); z-index: 9999; display: flex; align-items: center; justify-content: center; }
#application_form .popup-content,
#child-select-popup .popup-content { background: #fff; padding: 20px; border-radius: 8px; max-width: 500px; width: 90%; max-height: 80vh; overflow-y: auto; }
#application_form .popup-header,
#child-select-popup .popup-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; border-bottom: 1px solid #ddd; padding-bottom: 10px; }
#application_form .popup-close,
#child-select-popup .popup-close { background: none; border: none; font-size: 24px; cursor: pointer; color: #999; }
#application_form .popup-close:hover,
#child-select-popup .popup-close:hover { color: #333; }
#application_form .child-list,
#child-select-popup .child-list { display: flex; flex-direction: column; gap: 10px; }
#application_form .child-item,
#child-select-popup .child-item { border: 1px solid #ddd; border-radius: 4px; }
#application_form .btn-select-child-item,
#child-select-popup .btn-select-child-item { width: 100%; padding: 15px; text-align: left; background: #fff; border: none; cursor: pointer; transition: background 0.3s; }
#application_form .btn-select-child-item:hover,
#child-select-popup .btn-select-child-item:hover { background: #f5f5f5; }
#application_form .child-name,
#child-select-popup .child-name { font-weight: bold; margin-bottom: 5px; }
#application_form .child-details,
#child-select-popup .child-details { font-size: 14px; color: #666; }
#application_form .btn_select_child { padding: 8px 16px; background: #4CAF50; color: white; border: none; border-radius: 4px; cursor: pointer; }
#application_form .btn_select_child:hover { background: #45a049; }


