@charset "utf-8";

/* ==========================================================================
   info
   ========================================================================== */
@media (min-width: 960px){
#page_info .contents_wrap .wrap{
	max-width: calc(1000px + 10vw + 10vw);
	padding: 0 10vw;
}
}

/* entry_list */
#page_info .entry_list ul{
	width: 100%;
	border-top: 1px solid #ddd;
}

#page_info .entry_list ul li{
	width: 100%;
	border-bottom: 1px solid #ddd;
}

#page_info .entry_list ul li a{
	width: 100%;
	display: flex;
  flex-direction: row;
	align-items: center;
	position: relative;
	box-sizing: border-box;
	padding: 12px 30px 12px 0;
}
@media (min-width: 960px){
#page_info .entry_list ul li a{
	padding: 28px 30px 28px 0;
}
}

#page_info .entry_list ul li a::after{
	content: "";
  width: 14px;
	height: 14px;
  background-image: url(../img/common/icon-arrow-r.svg);
  background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
  position: absolute;
	top: 50%;
  right: 2px;
  margin: -7px 0 0 0;
}
@media (min-width: 960px){
#page_info .entry_list ul li a::after{
	right: 6px;
	margin: -7px 0 0 0;
}
}

#page_info .entry_list ul li .data_block{
	display: flex;
  flex-direction: column;
	align-items: center;
  justify-content: center;
	margin: 0 18px 0 -3px;
}
@media (min-width: 960px){
#page_info .entry_list ul li .data_block{
  flex-direction: row;
	align-items: center;
	justify-content: flex-start;
	margin: 0 50px 0 0;
}
}

#page_info .entry_list ul li .category{
	color: #4f926d;
	width: 50px;
	font-size: 1.0rem;
	font-family: "Prompt", sans-serif;
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.08em;
	text-align: center;
	border: 1px solid #ccc;
	border-radius: 100px;
	background-color: #fff;
	padding: 3px 2.4px 2px 4px;
}
@media (min-width: 960px){
#page_info .entry_list ul li .category{
	width: 54px;
	font-size: 1.3rem;
	letter-spacing: 0.12em;
	padding: 4.5px 7px 3px 8px;
}
}

#page_info .entry_list ul li .data{
	color: #444;
	width: 72px;
	font-size: 1.0rem;
	font-family: "Prompt", sans-serif;
	font-weight: 400;
	letter-spacing: 0.06em;
	line-height: 1;
	text-align: center;
	margin: 0 0 6px 0;
}
@media (min-width: 960px){
#page_info .entry_list ul li .data{
	width: 90px;
	font-size: 1.5rem;
	text-align: left;
	margin: 0 18px 0 0;
}
}

#page_info .entry_list ul li h3.title{
	font-size: 1.3rem;
	line-height: 1.3;
	font-weight: 500;
	font-feature-settings: "palt" 1;
	letter-spacing: 0.06em;
	transition: all 0.2s ease;
}
@media (min-width: 960px){
#page_info .entry_list ul li h3.title{
	font-size: 1.7rem;
	letter-spacing: 0.08em;
}
}

@media (min-width: 960px){
#page_info .entry_list ul li a:hover .title{
	color: #4f926d;
}
}


/* ==========================================================================
   pagenavi
   ========================================================================== */
.wp-pagenavi{
	width: 100%;
	overflow: hidden;
	font-size: 1.5rem;
	font-family: "Prompt", sans-serif;
  font-weight: 300;
	text-align: center;
  margin: 20px 0 0 0;
}
@media (min-width: 960px){
.wp-pagenavi{
	font-size: 1.5rem;
  margin: 50px 0 0 0;
}
}

.wp-pagenavi a,
.wp-pagenavi .current{
	color: #222;
	height: 22px;
	text-align: center;
	line-height: 22px;
  border-radius: 3px;
  background-color: rgba(0, 101, 179, 0.1);
	background-color: rgba(79, 146, 109, 0.1);
	background-color: #FFF5F5;
	margin: 0 1px;
  padding: 1px 11px 0 11px;
	display: inline-block;
	transition: all 0.2s ease;
}
@media (min-width: 960px){
.wp-pagenavi a,
.wp-pagenavi .current{
	height: 22px;
  line-height: 22px;
	margin: 0 2px;
  padding: 1px 11px 0 11px;
}
}

.wp-pagenavi .current{
	color: #fff;
	background-color: rgba(79, 146, 109, 1);
}

@media (min-width: 960px){
.wp-pagenavi a:hover{
	color: #fff;
  background-color: rgba(79, 146, 109, 1);
}
}

.wp-pagenavi .pages{
	height: 22px;
	font-size: 1.3rem;
	text-align: center;
	line-height: 22px;
	/*border-right: 1px solid #aaa;*/
	/*margin: 0 20px 0 0;*/
	display: inline-block;
	padding: 1px 30px 0 0;
}

.wp-pagenavi .extend{
	color: #222;
	height: 22px;
	text-align: center;
	line-height: 22px;
  border-radius: 2px;
  background-color: #fff;
	margin: 0 1px;
	display: inline-block;
	padding: 1px 11px 0 11px;
}
@media (min-width: 960px){
.wp-pagenavi a,
.wp-pagenavi .current{
	padding: 1px 11px 0 11px;
}
}


/* ==========================================================================
   single
   ========================================================================== */
@media (min-width: 960px){
#page_single .contents_wrap .wrap{
	max-width: calc(800px + 10vw + 10vw);
	padding: 0 10vw;
}
}

.single_entry .title-wrap .category{
	color: #4f926d;
	font-size: 1.2rem;
	line-height: 1;
	font-family: "Prompt", sans-serif;
	font-weight: 500;
	line-height: 1;
	letter-spacing: 0.08em;
	text-align: center;
	display: inline-block;
	border: 1px solid #ccc;
	border-radius: 100px;
	background-color: #fff;
	padding: 3px 12.4px 2px 14px;
	margin: 0 0 14px 0;
}
@media (min-width: 960px){
.single_entry .title-wrap .category{
	font-size: 1.3rem;
	padding: 4.5px 12.4px 3px 14px;
	margin: 0 0 24px 0;
}
}

.single_entry .title-wrap .title{
	color: #4f926d;
	font-size: 2.0rem;
	line-height: 1.4em;
	letter-spacing: 0.06em;
	font-weight: 500;
	font-feature-settings: "palt";
	border-bottom: 2px solid #4f926d;
	padding: 0 0 8px 0;
}
@media (min-width: 960px){
.single_entry .title-wrap .title{
	font-size: 2.8rem;
	padding: 0 0 16px 0;
}
}

.single_entry .title-wrap .data{
	color: #222;
	font-size: 1.3rem;
	font-family: "Prompt", sans-serif;
	font-weight: 400;
	letter-spacing: 0.1em;
	line-height: 1;
	margin: 10px 0 0 0;
}
@media (min-width: 960px){
.single_entry .title-wrap .data{
	font-size: 1.5rem;
	margin: 14px 0 0 0;
}
}

.single_entry .entry{
	margin: 50px 0 0 0;
}
@media (min-width: 960px){
.single_entry .entry{
	margin: 60px 0 0 0;
}
}

.single_entry .entry h2{
	font-size: 1.8rem;
	line-height: 1.4em;
	font-weight: 600;
	border-left: 5px solid #55708e;
	padding: 0 0 0 14px;
	margin: 50px 0 25px 0!important;
}
@media (min-width: 440px){
.single_entry .entry h2{
	font-size: 1.8rem;
	margin: 50px 0 25px 0!important;
}
}
@media (min-width: 960px){
.single_entry .entry h2{
	font-size: 2.3rem;
	margin: 70px 0 25px 0!important;
}
}

.single_entry .entry h3{
	font-size: 1.8rem;
	line-height: 1.4em;
	font-weight: 600;
	margin: 50px 0 25px 0!important;
}
@media (min-width: 440px){
.single_entry .entry h3{
	font-size: 1.8rem;
	margin: 50px 0 25px 0!important;
}
}
@media (min-width: 960px){
.single_entry .entry h3{
	font-size: 2.3rem;
	margin: 70px 0 25px 0!important;
}
}

.single_entry .entry h4{
	font-size: 1.6rem;
	line-height: 1.4em;
	font-weight: 600;
	margin: 50px 0 25px 0!important;
}
@media (min-width: 440px){
.single_entry .entry h4{
	font-size: 1.6rem;
	margin: 50px 0 25px 0!important;
}
}
@media (min-width: 960px){
.single_entry .entry h4{
	font-size: 1.8rem;
	margin: 70px 0 25px 0!important;
}
}

.single_entry .entry h5{
	font-size: 1.5rem;
	line-height: 1.4em;
	font-weight: 600;
	margin: 25px 0 25px 0;
}

.single_entry .entry h6{
	font-size: 1.5rem;
	line-height: 1.4em;
	font-weight: 500;
	margin: 25px 0 25px 0;
}

.single_entry .entry p{
	font-size: 1.4rem;
	line-height: 1.9em;
	margin: 20px 0 0 0;
}
@media (min-width: 960px){
.single_entry .entry p{
	font-size: 1.5rem;
	line-height: 2.0em;
	margin: 20px 0 0 0;
}
}

.single_entry .entry p:first-child{
	margin: 0;
}

.single_entry .entry ul,
.single_entry .entry ol{
  font-size: 1.5rem;
  margin: 25px 0 25px 0;
}

.single_entry .entry ul li{
  list-style: disc;
  margin: 0 0 0 1.8rem;
}

.single_entry .entry ul li ul li{
  list-style: disc;
  margin: 0 0 0 3.4rem;
}

.single_entry .entry ol li{
  list-style: decimal;
  margin: 0 0 0 2.0rem;
}

.single_entry .entry ol li ol li{
  list-style: disc;
  margin: 0 0 0 3.4rem;
}

.single_entry .entry blockquote{
  border-left: 3px solid #CCD4DD;
  padding: 0 0 3px 30px;
  margin: 60px 0 0 0;
}

.single_entry .entry hr{
  height: 1px;
  padding: 0;
  border: 0;
  margin: 40px 0 0 0;
  background-color: rgba(85, 112, 142, 1);
}
@media (min-width: 440px){
.single_entry .entry hr{
  margin: 40px 0 0 0;
}
}
@media (min-width: 960px){
.single_entry .entry hr{
  margin: 60px 0 0 0;
}
}

.single_entry .entry figure{
  margin: 40px 0 0 0;
}
@media (min-width: 440px){
.single_entry .entry figure{
  margin: 40px 0 0 0;
}
}
@media (min-width: 960px){
.single_entry .entry figure{
  margin: 60px 0 5px 0;
}
}

.single_entry .entry figure img,
.single_entry .entry p img{
  width: 100%;
  height: auto;
  max-height: 360px;
  object-fit: contain;
	display: block;
	border-radius: 0;
	overflow: hidden;
	padding: 0 0 20px 0;
	margin: 0 auto;
}
@media (min-width: 960px){
.single_entry .entry figure img,
.single_entry .entry p img{
	max-width: 640px;
  max-height: 640px;
}
}

.single_entry .entry figure figcaption{
  font-size: 1.3rem;
  text-align: center;
  margin: 10px 0 0 0;
}

.single_entry .entry a{
  transition: all 0.2s ease;
  text-decoration: underline;
}

@media (min-width: 960px){
.single_entry .entry a:hover{
	opacity: 0.3;
}
}

.single_entry .entry .wp-block-button{
  margin: 60px 0 0 0;
}

.single_entry .entry .wp-block-button a{
  color: #fff;
	width: auto;
  height: 48px;
	font-size: 1.4rem;
	line-height: 1em;
  font-weight: 500;
	font-feature-settings: "palt";
	letter-spacing: 0.11em;
	border-radius: 24px;
	background-color: #272d36;
	box-sizing: border-box;
	float: left;
	display: flex;
	align-items: center;
  transition: all 0.2s ease;
	position: relative;
	z-index: 10;
  text-decoration: none;
}
@media (min-width: 440px){
.single_entry .entry .wp-block-button a{
  height: 56px;
	border-radius: 28px;
	font-size: 1.4rem;
}
}
@media (min-width: 960px){
.single_entry .entry .wp-block-button a{
  height: 56px;
	border-radius: 28px;
	font-size: 1.5rem;
  padding: 0 80px 1px 28px;
}
}

@media (min-width: 960px){
.single_entry .entry .wp-block-button a:hover{
	color: #fff;
	background-color: #21adfa;
}
}

.single_entry .entry .wp-block-button a::after{
  content: "";
	width: 17px;
  height: 17px;
	background-image: url(./assets/images/arrow-r-w.svg);
	background-size: 17px 17px;
	background-repeat: no-repeat;
  position: absolute;
  top: 50%;
  right: 20px;
	margin: -8.5px 0 0 0;
}

.single_entry .btn{
  margin: 100px 0 0 0;
}

.single_entry .btn a{
  font-size: 1.5rem;
  letter-spacing: 0.08em;
  text-decoration: none;
	padding: 0 90px 1px 28px;
}

.page_nav{
	width: 100%;
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	box-sizing: border-box;
}

.btn-back,
.btn-next,
.btn-prev{
	margin: 0 3px!important;
}
@media (min-width: 960px){
.btn-back,
.btn-next,
.btn-prev{
	margin: 0 6px!important;
}
}

.btn-back a,
.btn-next a,
.btn-prev a{
	color: #4f926d;
	width: 100%;
	height: 50px;
	font-size: 1.4rem;
  font-weight: 500;
	line-height: 1;
  letter-spacing: 0.06em;
	text-align: center;
  display: flex;
	align-items: center;
	justify-content: center;
  position: relative;
	background-color: #fff;
	border: 1px solid #4f926d;
	border-radius: 6px;
	box-sizing: border-box;
	transition: all 0.2s ease;
	padding: 0 14px;
}
@media (min-width: 960px){
.btn-back a,
.btn-next a,
.btn-prev a{
	width: auto;
	height: 58px;
  font-size: 1.6rem;
	border-radius: 7px;
	padding: 0 32px;
}
}

.btn-back a::after{
	content: "";
	width: 13px;
	height: 13px;
	background-image: url(../img/common/icon_arrow_r.svg);
	background-size: 13px 13px;
	background-repeat: no-repeat;
	position: absolute;
	top: 50%;
	left: 0;
	transform: scale(-1, 1);
	margin: -6.5px 0 0 0;
}
@media (min-width: 960px){
.btn-back a::after{
	width: 13px;
	height: 13px;
	background-size: 13px 13px;
  margin: -6.5px 0 0 0;
}
}

@media (min-width: 960px){
.btn-back a:hover,
.btn-next a:hover,
.btn-prev a:hover{
	color: rgba(0, 101, 179, 0.6);
	color: rgba(90, 170, 125, 1);
}
}


/* ==========================================================================
   single case
   ========================================================================== */
.case-list{

}
.case-list ul{
	width: 100%;
	list-style: none!important;
}

.case-list ul li{
	width: 100%;
	border-radius: 10px;
	border: 1px solid #ddd;
	margin-top: 8px;
}

.case-list ul li a{
	width: 100%;
	display: flex;
	font-size: 1.3rem;
	line-height: 1.3;
	font-weight: 500;
	font-feature-settings: "palt" 1;
	letter-spacing: 0.06em;
	transition: all 0.2s ease;
  flex-direction: row;
	align-items: center;
	position: relative;
	box-sizing: border-box;
	padding: 18px 30px 18px 20px;
	list-style: none!important;
}
@media (min-width: 960px){
.case-list ul li a{
	font-size: 1.5rem;
	letter-spacing: 0.08em;
	padding: 28px 30px 28px 20px;
}
}

.case-list ul li a::after{
	content: "";
  width: 14px;
	height: 14px;
  background-image: url(../img/common/icon-arrow-r.svg);
  background-size: cover;
	background-position: center;
	background-repeat: no-repeat;
  position: absolute;
	top: 50%;
  right: 16px;
  margin: -7px 0 0 0;
}
@media (min-width: 960px){
.case-list ul li a::after{
	right: 16px;
	margin: -7px 0 0 0;
}
}

@media (min-width: 960px){
.case-list ul li a:hover{
	color: #4f926d;
}
}

.case-list ul li:last-child,
.case-list ul li:last-child a{
	display: none;
}

.aioseo-breadcrumb{

}


/* ==========================================================================
	 membership
   ========================================================================== */
#page_members .contents_wrap{
	width: 100%!important;
	font-family: "Noto Sans JP", sans-serif!important;
	box-sizing: border-box;
	display: flex;
  flex-direction: column;
	align-items: center;
  justify-content: center;
	padding: 0 5.5vw;
	margin: 0 auto 60px;
}
@media (min-width: 960px){
#page_members .contents_wrap{
	max-width: 600px;
	padding: 0;
	margin: 0 auto 100px;
}
}

#page_members .contents_wrap ul{
	display: flex;
  flex-direction: column;
	align-items: center;
  justify-content: center;
}

#page_members .contents_wrap li a,
#page_members .contents_wrap .login_status a{
	color: #fff;
	width: 300px!important;
	height: 48px;
	line-height: 48px;
	font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.06em;
	text-align: center;
	display: inline-block;
	background-color: #4f926d;
	outline: none;
	border: 0;
  border-radius: 7px;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	box-sizing: border-box;
	transition: all 0.2s ease;
	padding: 0;
	margin: 6px 0;
}
@media (min-width: 960px){
#page_members .contents_wrap li a,
#page_members .contents_wrap .login_status a{
	width: 320px!important;
	height: 50px;
	font-size: 1.5rem;
	padding: 0;
}
}

@media (min-width: 960px){
#page_members .contents_wrap li a:hover,
#page_members .contents_wrap .login_status a:hover{
	color: rgba(255, 255, 255, 0.6);
}
}

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

#wpmem_restricted_msg,
.wpmem_msg{
	width: 100%!important;
	font-size: 1.4rem!important;
	font-family: "Noto Sans JP", sans-serif!important;
	font-weight: 400!important;
	box-sizing: border-box;
	padding: 0 5.5vw;
	margin: 0 auto;
}
@media (min-width: 960px){
#wpmem_restricted_msg,
.wpmem_msg{
	max-width: 600px;
	font-size: 1.4rem!important;
	padding: 0;
}
}

.wpmem_msg{
	color: #4f926d;
	margin: 0 auto 15px!important;
}
@media (min-width: 960px){
.wpmem_msg{
}
}

#wpmem_login,
#wpmem_reg{
	width: 100%!important;
	font-size: 1.4rem!important;
	font-family: "Noto Sans JP", sans-serif!important;
	font-weight: 400!important;
	box-sizing: border-box;
	padding: 0 5.5vw;
	margin: 0 auto;
}
@media (min-width: 960px){
#wpmem_login,
#wpmem_reg{
	max-width: 600px;
	font-size: 1.4rem!important;
	padding: 0;
}
}

#wpmem_login legend,
#wpmem_reg legend{
	font-size: 20px;
	line-height: 1;
	font-weight: 600!important;
	margin-bottom: 30px!important;
}

#wpmem_login .div_text,
#wpmem_reg .div_checkbox,
#wpmem_reg .div_date,
#wpmem_reg .div_file,
#wpmem_reg .div_image,
#wpmem_reg .div_membership,
#wpmem_reg .div_multicheckbox,
#wpmem_reg .div_multiselect,
#wpmem_reg .div_number,
#wpmem_reg .div_radio,
#wpmem_reg .div_select,
#wpmem_reg .div_text,
#wpmem_reg .div_textarea,
#wpmem_reg .div_url {
	margin: 6px 0 14px 0!important;
	box-sizing: border-box!important;
}

#wpmem_login .div_text input,
#wpmem_login input[password],
#wpmem_login input[email],
#wpmem_reg .div_text input,
#wpmem_reg input[password],
#wpmem_reg input[email]{
	width: 100%!important;
	box-sizing: border-box!important;
}

#wpmem_login input[type="submit"],
#wpmem_reg input[type="submit"]{
	color: #fff;
	width: auto!important;
	height: 38px;
	line-height: 36px;
	font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.06em;
	text-align: center;
	display: inline-block;
	background-color: #4f926d;
	outline: none;
	border: 0;
  border-radius: 7px;
	cursor: pointer;
	-webkit-appearance: none;
	appearance: none;
	box-sizing: border-box;
	transition: all 0.2s ease;
	padding: 0 20px;
	padding: 2px 20px 0 20px;
	margin-left: 10px;
}
@media (min-width: 960px){
#wpmem_login input[type="submit"],
#wpmem_reg input[type="submit"]{
	height: 40px;
	font-size: 1.5rem;
}
}

@media (min-width: 960px){
#wpmem_login input[type="submit"]:hover,
#wpmem_reg input[type="submit"]:hover{
	color: rgba(255, 255, 255, 0.6);
}
}

#wpmem_login .button_div,
#wpmem_reg .button_div {
	width: 100%!important;
	box-sizing: border-box;
}

#wpmem_login .link-text a,
#wpmem_reg .link-text a{
	text-decoration: underline;
}

.mypage a{
	display: block;
	text-decoration: underline;
	margin: 20px 0 0 0;
}
@media (min-width: 960px){
.mypage a{
	margin: 30px 0 0 0;
}
}
