@charset "UTF-8";

/*=============================================================
　subarea
=============================================================*/

.subarea {
	width: 100%;
 min-height: 500px;
	position: relative;
	margin: 0 0 60px 0; 
}
@media (max-width: 640px) {
.subarea {
 min-height: auto;
	margin: 0 0 40px 0;
}
}

.sub_text_en{
	color: rgba(255,255,255,0.70);
	font-size: clamp(35px, 8vw, 80px);
	line-height: 1em;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 3;
	font-weight: 300;
}
.sub_text {
 width: 100%;
	min-height: 450px;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.sub_text::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 80%;
	height: 100%;
	/*background: #6bc7ac;*/
	clip-path: polygon(0 0, 100% 0, 80% 100%, 0% 100%);
	z-index: -1;
	background-image: 
	linear-gradient(rgba(107,199,172,0.7), rgba(107,199,172,0.7)),
	url("/img/subtitle_green_haikei.jpg");
	background-position: right bottom;
 background-size: cover;
}
.sub_text_inner {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	max-width: 1200px;
	width: 90%;
	z-index: 2;
}
.sub_text_jp{
	font-size: 230%;
	line-height: 1.3em;
	font-weight: bold;
	color: #fff;
	margin: 0 0 15px 0;
	padding: 0;
	letter-spacing: 0.1em;
}
.sub_text_jp span{
	color: #fffada;
}
.sub_text_inner p{
	font-size: 110%;
	color: #fff;
 margin: -10px 0 20px 3px;
}
@media (max-width: 640px) {
.sub_text {
	position: relative;
	top: auto;
	left: auto;
	transform: none;
	margin: 0 auto;
	padding: 30px 0;
	min-height: auto;
}
.sub_text::before {
	width: 100%;
	background-position: center;
}
.sub_text_inner {
	position: relative;
	top: auto;
	left: auto;
	transform: none;
	text-align: center;
	padding: 20px 0;
	width: 100%;
}
.sub_text_jp{
	font-size: 150%;
	margin: 0 0 5px 0;
}
.sub_text_inner p{
	font-size: 90%;
 margin: -5px 0 20px 0;
}
}

.sub_picture {
	clip-path: polygon(17% 0, 100% 0, 100% 100%, 0% 100%);
	width: 60%;
	height: 450px;
	position: absolute;
	bottom: 0;
	right: 0;
	z-index: 2;
}
.sub_picture img{
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media (max-width: 640px) {
.sub_picture {
	width: 95%;
	height: 150px;
	clip-path: polygon(12% 0, 100% 0, 100% 100%, 0% 100%);
	position: relative;
 margin: -30px 0 0 auto;
}
}

.pankuz {
	padding: 0 0 0 5px;
 font-size: 90%;
	color: #fff;
}
.pankuz a{
	color: #fff;
}
@media (max-width: 640px) {
.pankuz {
 font-size: 70%;
	padding: 0;
	line-height: 1.5em;
}
}

/*=============================================================
　sub_box
=============================================================*/

.box_area {
	padding: 100px 0;
	margin: 0 auto;
	max-width: 1200px;
}
.box_area_ex {
	padding: 0;
	margin: 0 auto;
	max-width: 1200px;
}
.box_area_half {
	padding: 50px 0 100px 0;
	margin: 0 auto;
	max-width: 1200px;
}
.box_area_all {
	padding: 100px 0;
	margin: 0 auto;
	max-width: 100%;
}
.box_area_all_half {
	padding: 50px 0 100px 0;
	margin: 0 auto;
	max-width: 100%;
}
@media (max-width: 640px) {
.box_area {
	width: 100%;
	padding: 60px 0;
}
.box_area_ex {
	width: 100%;
}
.box_area_half,
.box_area_all,
.box_area_all_half {
	padding: 30px 0 60px 0;
}
}

.box_line {
	position: relative;
}
.box_line::before {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 1px;
	background: rgba(107,199,172,1);
}
.box_line::after {
	content: "";
	position: absolute;
	left: 50%;
	bottom: -40px;
	transform: translateX(-50%);
	width: 2px;
	height: 40px;
	background: rgba(107,199,172,0.5);
}


/*=============================================================
　subtitle
=============================================================*/

.subtitle {
	padding: 0;
	text-align: center;
	margin: 0 0 40px 0;
}
.subtitle_jp {
	font-size: 200%;
	font-weight: bold;
	margin: 0 0 5px 0;
	padding: 0;
	letter-spacing: 0.1em;
	line-height: 1.4em;
}
.subtitle_jp_min {
	font-size: 110%;
	letter-spacing: 0.1em;
	line-height: 0.8em;
	margin-bottom: 15px;
}
.subtitle_en {
	color: #6bc7ac;
	padding: 0;
	margin: 0 0 10px 0;
	text-align: center;
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1;
}
.subtitle_icon {
	padding: 0;
	margin: 0;
}
.subtitle_icon img{
	display: block;
	margin: 0 auto;
}
@media (max-width: 640px) {
.subtitle {
	width: 95%;
	margin: 0 auto 30px auto;
}
.subtitle_jp {
	font-size: 160%;
}
.subtitle_jp_min {
	font-size: 100%;
}
.subtitle_en {
	font-size: 90%;
}
}

.sub_top_gd {
background: linear-gradient(120deg,#fef9fb 0%,#faf6f1 60%,#eef8f2 100%);
}

.title_01 {
font-size: 150%;
font-weight: bold;
color: #fff;
margin: 0 0 40px 0;
background-color: #6bc7ac;
width: 100%;
position: relative;
padding: 15px 15px 15px 40px;
letter-spacing: 0.1em;
}
.title_01::before {
  content: "";
  position: absolute;
  top: 20%;
  bottom: 20%;
  left: 0.8em;
  width: 5px;
  background-color: #fff;
}
@media (max-width: 640px) {
.title_01 {
font-size: 130%;
padding: 15px 15px 15px 35px;
margin: 0 0 30px 0;
}
}

.title_02 {
	font-size: 130%;
	font-weight: bold;
	color: #6bc7ac;
	width: 100%;
	margin: 0 0 30px 0;
	padding: 12px 15px 12px 30px;
	border-bottom: 1px solid #6bc7ac;
	border-top: 1px solid #6bc7ac;
	background-color: #FFFFFF;
	position: relative;
}
.title_02::before {
  content: "";
  position: absolute;
  top: 20%;
  bottom: 20%;
  left: 0.5em;
  width: 5px;
  background-color: #6bc7ac;
  border-radius: 2px;
}

/*=============================================================
　sub_tp
=============================================================*/

.sub_tp {
	margin: 0px;
	display: flex;
 justify-content: space-between;
	align-items: center;
	gap:50px;
}
@media (max-width: 900px) {
.sub_tp {
	flex-direction: column;
 align-items:center;
	gap:30px;
	width: 90%;
	margin: 0 auto;
}
}

.sub_tp_picture {
	margin: 0px;
	padding: 0px;
	flex-shrink: 0;
}
.sub_tp_inner {
	margin: 0;
	padding: 0;
}
.sub_tp_read {
	font-size: 160%;
	line-height: 1.8em;
	font-weight: bold;
	padding: 0;
	margin: 0 0 20px 0;
}
.sub_tp_text {
	margin: 0;
	padding: 0;
	line-height: 2em;
}
@media (max-width: 640px) {
.sub_tp_read {
	font-size: 130%;
	margin: 0 0 10px 0;
}
}

/*=============================================================
　sub_title_box
=============================================================*/

.title_box{
text-align: center;
margin: 0 0 40px 0;
}
.title_box_inner {
display: inline-block;
padding: 15px 30px;
border: 2px solid #6bc7ac;
position: relative;
font-size: 150%;
font-weight: bold;
color: #6bc7ac;
background-color: #fff;
}
.title_box_inner:after{
  content: "";
  position: absolute;
  right: 0;
  bottom: -25px;
  left: 0;
  width: 0px;
  height: 0px;
  margin: auto;
  border-style: solid;
  border-color: #6bc7ac transparent transparent transparent;
  border-width: 25px 15px 0 15px;
}
@media (max-width: 640px) {
.title_box_inner {
display: block;
width: 90%;
margin: 0 auto;
font-size: 120%;
}
}

/*=============================================================
　pagelink
=============================================================*/

.pagelink {
	margin: 0;
	padding: 0;
	width: 100%;
	background-color:rgba(107,199,172,1.00);
}
.pagelink_inner {
	margin: 0px;
	text-align: center;
	padding: 40px 0;
}
.pagelink_inner_title {
	color: #FFFFFF;
	font-size: 140%;
	font-weight: bold;
	line-height: 1.5em;
	letter-spacing: 0.1em;
}
.pagelink_inner_txt {
	color: #FFFFFF;
	margin: 0 0 15px 0;
}
@media (max-width: 640px) {
.pagelink_inner {
	width: 90%;
	margin: 0 auto;
	padding: 30px 0;
}
.pagelink_inner_title {
	font-size: 120%;
}
.pagelink_inner_txt {
	font-size: 90%;
	line-height: 1.8em;
}
}

/*=============================================================
　contentslink
=============================================================*/

.contents_links {
	margin: 0;
	padding: 0;
	width: 100%;
	background: linear-gradient(120deg, #fdf6f0 0%, #f0f7f2 100%);
}
.contents_links_inner {
	padding: 40px 0 30px 0;
	text-align: center;
}
.contents_links_picture {
	margin: 0 0 20px 0;
}
.contents_links_txt {
	margin: 0 0 15px 0;
	font-weight: bold;
}
@media (max-width: 640px) {
.contents_links_inner {
	width: 90%;
	margin: 0 auto;
}
.contents_links_title {
	font-size: 120%;
}
.contents_links_txt {
	font-size: 90%;
	line-height: 1.8em;
	text-align: left!important;
}
}

.sub_title_kakoi {
  position: relative;
  display: inline-block;
  padding: 15px 20px;
		margin: 0 0 20px 0;
  font-size: 130%;
  font-weight: bold;
  letter-spacing: 0.15em;
  color: #333;
  border: 1px solid #333;
  /*background-color:rgba(107,200,170,0.80);*/
  z-index: 1;
}
.sub_title_kakoi::after {
  content: '';
  position: absolute;
  top: -2px;
  bottom: -2px;
  left: -2px;
  right: -2px;
  border: 1px solid #333;
  opacity: 0.80;
  transform: translate(-6px, -6px);
  z-index: -1;
}
@media (max-width: 640px) {
.sub_title_kakoi {
  font-size: 120%;
}
}