@charset "utf-8";

body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,p,blockquote,th,td,main,figure{margin:0;padding:0}table{font-size:100%;font-family:inherit}fieldset,img{border:0}img,svg,video{vertical-align:middle}address,caption,cite,code,dfn,em,th,var{font-style:normal;font-weight:400}ol,ul{list-style:none}caption,th{text-align:left}h1,h2,h3,h4,h5,h6{font-size:100%}q:before,q:after{content:''}abbr,acronym{border:0}select,input,textarea{font-size:100%}header,footer,nav,main,section,article,figure,aside,picture{display:block}.clearfix:after,.row:after{content:"";display:table;clear:both}.fl{float:left}.fr{float:right}@media screen and (min-width: 768px),print{.pc_fl{float:left}.pc_fr{float:right}}@media screen and (max-width: 767px){.sp_fl{float:left}.sp_fr{float:right}}.tal{text-align:left!important}.tac{text-align:center!important}.tar{text-align:right!important}@media screen and (min-width: 768px),print{.pc_tal{text-align:left!important}.pc_tac{text-align:center!important}.pc_tar{text-align:right!important}}@media screen and (max-width: 767px){.sp_tal{text-align:left!important}.sp_tac{text-align:center!important}.sp_tar{text-align:right!important}}.m00{margin:0!important}.mb00{margin-bottom:0!important}.mb05{margin-bottom:5px!important}.mb08{margin-bottom:8px!important}.mb10{margin-bottom:10px!important}.mb15{margin-bottom:15px!important}.mb20{margin-bottom:20px!important}.mb25{margin-bottom:25px!important}.mb30{margin-bottom:30px!important}.mb35{margin-bottom:35px!important}.mb40{margin-bottom:40px!important}.mb45{margin-bottom:45px!important}.mb50{margin-bottom:50px!important}.mt00{margin-top:0!important}.mt05{margin-top:5px!important}.mt08{margin-top:8px!important}.mt10{margin-top:10px!important}.mt15{margin-top:15px!important}.mt20{margin-top:20px!important}.mt25{margin-top:25px!important}.mt30{margin-top:30px!important}.mt35{margin-top:35px!important}.mt40{margin-top:40px!important}.mt45{margin-top:45px!important}.mt50{margin-top:50px!important}@media screen and (min-width: 768px),print{.pc_m00{margin:0!important}.pc_mb00{margin-bottom:0!important}.pc_mb05{margin-bottom:5px!important}.pc_mb08{margin-bottom:8px!important}.pc_mb10{margin-bottom:10px!important}.pc_mb15{margin-bottom:15px!important}.pc_mb20{margin-bottom:20px!important}.pc_mb25{margin-bottom:25px!important}.pc_mb30{margin-bottom:30px!important}.pc_mb35{margin-bottom:35px!important}.pc_mb40{margin-bottom:40px!important}.pc_mb45{margin-bottom:45px!important}.pc_mb50{margin-bottom:50px!important}.pc_mt00{margin-top:0!important}.pc_mt05{margin-top:5px!important}.pc_mt08{margin-top:8px!important}.pc_mt10{margin-top:10px!important}.pc_mt15{margin-top:15px!important}.pc_mt20{margin-top:20px!important}.pc_mt25{margin-top:25px!important}.pc_mt30{margin-top:30px!important}.pc_mt35{margin-top:35px!important}.pc_mt40{margin-top:40px!important}.pc_mt45{margin-top:45px!important}.pc_mt50{margin-top:50px!important}}@media screen and (max-width: 767px){.sp_m00{margin:0!important}.sp_mb00{margin-bottom:0!important}.sp_mb05{margin-bottom:5px!important}.sp_mb08{margin-bottom:8px!important}.sp_mb10{margin-bottom:10px!important}.sp_mb15{margin-bottom:15px!important}.sp_mb20{margin-bottom:20px!important}.sp_mb25{margin-bottom:25px!important}.sp_mb30{margin-bottom:30px!important}.sp_mb35{margin-bottom:35px!important}.sp_mb40{margin-bottom:40px!important}.sp_mb45{margin-bottom:45px!important}.sp_mb50{margin-bottom:50px!important}.sp_mt00{margin-top:0!important}.sp_mt05{margin-top:5px!important}.sp_mt08{margin-top:8px!important}.sp_mt10{margin-top:10px!important}.sp_mt15{margin-top:15px!important}.sp_mt20{margin-top:20px!important}.sp_mt25{margin-top:25px!important}.sp_mt30{margin-top:30px!important}.sp_mt35{margin-top:35px!important}.sp_mt40{margin-top:40px!important}.sp_mt45{margin-top:45px!important}.sp_mt50{margin-top:50px!important}}.p00{padding:0!important}.pb00{padding-bottom:0!important}.pb05{padding-bottom:5px!important}.pb08{padding-bottom:8px!important}.pb10{padding-bottom:10px!important}.pb15{padding-bottom:15px!important}.pb20{padding-bottom:20px!important}.pb25{padding-bottom:25px!important}.pb30{padding-bottom:30px!important}.pb35{padding-bottom:35px!important}.pb40{padding-bottom:40px!important}.pb45{padding-bottom:45px!important}.pb50{padding-bottom:50px!important}.pt00{padding-top:0!important}.pt05{padding-top:5px!important}.pt08{padding-top:8px!important}.pt10{padding-top:10px!important}.pt15{padding-top:15px!important}.pt20{padding-top:20px!important}.pt25{padding-top:25px!important}.pt30{padding-top:30px!important}.pt35{padding-top:35px!important}.pt40{padding-top:40px!important}.pt45{padding-top:45px!important}.pt50{padding-top:50px!important}@media screen and (min-width: 768px),print{.pc_p00{padding:0!important}.pc_pb00{padding-bottom:0!important}.pc_pb05{padding-bottom:5px!important}.pc_pb08{padding-bottom:8px!important}.pc_pb10{padding-bottom:10px!important}.pc_pb15{padding-bottom:15px!important}.pc_pb20{padding-bottom:20px!important}.pc_pb25{padding-bottom:25px!important}.pc_pb30{padding-bottom:30px!important}.pc_pb35{padding-bottom:35px!important}.pc_pb40{padding-bottom:40px!important}.pc_pb45{padding-bottom:45px!important}.pc_pb50{padding-bottom:50px!important}.pc_pt00{padding-top:0!important}.pc_pt05{padding-top:5px!important}.pc_pt08{padding-top:8px!important}.pc_pt10{padding-top:10px!important}.pc_pt15{padding-top:15px!important}.pc_pt20{padding-top:20px!important}.pc_pt25{padding-top:25px!important}.pc_pt30{padding-top:30px!important}.pc_pt35{padding-top:35px!important}.pc_pt40{padding-top:40px!important}.pc_pt45{padding-top:45px!important}.pc_pt50{padding-top:50px!important}}@media screen and (max-width: 767px){.sp_p00{padding:0!important}.sp_pb00{padding-bottom:0!important}.sp_pb05{padding-bottom:5px!important}.sp_pb08{padding-bottom:8px!important}.sp_pb10{padding-bottom:10px!important}.sp_pb15{padding-bottom:15px!important}.sp_pb20{padding-bottom:20px!important}.sp_pb25{padding-bottom:25px!important}.sp_pb30{padding-bottom:30px!important}.sp_pb35{padding-bottom:35px!important}.sp_pb40{padding-bottom:40px!important}.sp_pb45{padding-bottom:45px!important}.sp_pb50{padding-bottom:50px!important}.sp_pt00{padding-top:0!important}.sp_pt05{padding-top:5px!important}.sp_pt08{padding-top:8px!important}.sp_pt10{padding-top:10px!important}.sp_pt15{padding-top:15px!important}.sp_pt20{padding-top:20px!important}.sp_pt25{padding-top:25px!important}.sp_pt30{padding-top:30px!important}.sp_pt35{padding-top:35px!important}.sp_pt40{padding-top:40px!important}.sp_pt45{padding-top:45px!important}.sp_pt50{padding-top:50px!important}}


/* ========================================================
	template.css => テンプレート用CSS
======================================================== */
html {
	font-size: 62.5%;
}
body {
	background-color: #fff;
	font-size: 10px;
	font-size: 1rem;
	line-height: 1.8;
	color: #000000;
	word-wrap: break-word;
	overflow-wrap: break-word;

	font-family: 'M PLUS 1p', sans-serif;
	font-weight: 400;
	-webkit-text-size-adjust: 100%;
	text-size-adjust: 100%;
}
*,
*::before,
*::after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}

table {
	border-collapse: collapse;
	border-spacing: 0;
	line-height: 1.8;
}
a[href] {
	color: #000000;
	text-decoration: underline;
	outline: none;
}
a[href]:hover {
	text-decoration: none;
}
a[href].a_reverse,
.a_reverse a[href] {
	text-decoration: none;
}
@media screen and (min-width: 768px) {
	a[href].a_reverse:hover,
	.a_reverse a[href]:hover {
		text-decoration: underline;
	}
}

label {
	cursor: pointer;
}
input, select, textarea, button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	max-width: 100%;
	margin: 0;
	border-radius: 0;
	vertical-align: middle;
	font-family: inherit;
	outline: none;
	font-size: 100%;
}
::-webkit-input-placeholder {
	color: #ccc;
}
:-ms-input-placeholder {
	color: #ccc;
}
::-moz-placeholder {
	color: #ccc;
}
select::-ms-expand {
	display: none;
}

button {
	cursor: pointer;
}
iframe {
	max-width: 100%;
	vertical-align: middle;
}

.hidden {
	display: none;
}
.slick-slider * {
	outline: none;
}
@media screen and (min-width: 768px), print {
}
@media screen and (max-width: 767px) {
	img {
		max-width: 100%;
		height: auto;
	}
}


/* pc / sp
============================================================================================================ */
@media screen and (min-width: 768px), print {
	.sp {
		display: none !important;
	}
	.pc_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
	.pc_hidden {
		position: relative;
		overflow: hidden;
		display: block;
		height: 0;
	}
}
@media screen and (max-width: 767px) {
	.pc {
		display: none !important;
	}
	.sp_break {
		position: relative;
		display: block;
		height: 0;
		overflow: hidden;
	}
}
@media screen and (min-width: 371px) {
	.sps {
		display: none !important;
	}
}
@media screen and (max-width: 370px) {
	.sps_non {
		display: none !important;
	}
}

/* transition
============================================================================================================ */
@media screen and (min-width: 768px) {
	body.init a[href],
	body.init a[href]::before,
	body.init a[href]::after,
	body.init button,
	body.init button::before,
	body.init button::after,
	body.init .basic_trs,
	body.init .basic_trs::before,
	body.init .basic_trs::after,
	body.init .basic_trs *,
	body.init .basic_trs *::before,
	body.init .basic_trs *::after {
		transition: color 0.2s ease-in-out, background 0.2s ease-in-out, border 0.2s ease-in-out, opacity 0.2s ease-in-out;
	}
	body.init a svg {
		transition: fill 0.2s ease-in-out;
	}
}


/* font family
============================================================================================================ */
.ff_en {
	font-family: 'Montserrat', sans-serif;
	font-weight: 700;
}

/* color
============================================================================================================ */
.c_theme {
	color: #3fc6ea;
}
.c_green {
	color: #3aaf40;
}

/* font
============================================================================================================ */
.fwb {
	font-weight: bold;
}
.fwn {
	font-weight: normal;
}


/* display
============================================================================================================ */
.db {
	display: block;
}
.dib {
	display: inline-block;
}

/* position
============================================================================================================ */
.pos-r {
	position: relative;
}

/* object-fit
============================================================================================================ */
img.of {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}
img.of.bg {
	pointer-events: none;
	user-select: none;
	z-index: -1;
}

/* hover
============================================================================================================ */
@media screen and (min-width: 768px), print {
	a.hv_wh,
	button.hv_wh,
	a .hv_wh,
	.hv_wh a {
		position: relative;
		display: inline-block;
		vertical-align: middle;
		overflow: hidden;
	}
	a.hv_wh::after,
	button.hv_wh::after,
	a .hv_wh::after,
	.hv_wh a::after {
		content: "";
		position: absolute;
		left: 0;
		right: 0;
		top: 0;
		bottom: 0;
		background-color: rgba(255,255,255,0);
		z-index: 3;
	}
	body.init a.hv_wh::after,
	body.init button.hv_wh::after,
	body.init a .hv_wh::after,
	body.init .hv_wh a::after {
		transition: background 0.2s ease-in-out;
	}
	a[href].hv_wh:hover::after,
	button.hv_wh:hover::after,
	a[href]:hover .hv_wh::after,
	.hv_wh a[href]:hover::after {
		background-color: rgba(255,255,255,0.3);
	}
	a[href].hv_wh.a20:hover::after,
	button.hv_wh.a20:hover::after,
	a[href]:hover .hv_wh.a20::after,
	.hv_wh.a20 a[href]:hover::after {
		background-color: rgba(255,255,255,0.2);
	}
	a[href].hv_wh.a10:hover::after,
	button.hv_wh.a10:hover::after,
	a[href]:hover .hv_wh.a10::after,
	.hv_wh.a10 a[href]:hover::after {
		background-color: rgba(255,255,255,0.1);
	}

	body.init a[href] .hv_op {
		transition: opacity 0.2s ease-in-out;
	}
	a[href].hv_op:hover,
	a[href]:hover .hv_op,
	button.hv_op:hover,
	.hv_op a[href]:hover {
		opacity: 0.7;
	}
	a[href].hv_op.a20:hover,
	a[href]:hover .hv_op.a20,
	.hv_op.a20 a[href]:hover {
		opacity: 0.8;
	}
	a[href].hv_op.a10:hover,
	a[href]:hover .hv_op.a10,
	.hv_op.a10 a[href]:hover {
		opacity: 0.9;
	}
	a[href].hv_op.a50:hover,
	a[href]:hover .hv_op.a50,
	.hv_op.a50 a[href]:hover {
		opacity: 0.5;
	}
}

.hv_zoom {
	position: relative;
	display: block;
	overflow: hidden;
}
.hv_zoom > * {
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	bottom: 0;
	background-repeat: no-repeat;
	background-position: 50%;
	background-size: cover;
}
@media screen and (min-width: 768px), print {
	body.init a[href].hv_zoom > *,
	body.init a[href] .hv_zoom > * {
		transition: transform 0.6s, opacity .3s;
	}
	a[href]:hover .hv_zoom.s > * {
		transform: scale(1.03);
	}
	a[href]:hover.hv_zoom > *,
	a[href]:hover .hv_zoom > * {
		transform: scale(1.05);
	}
}


/* target
============================================================================================================ */
.target {
	display: block;
	position: relative;
	width: 1px;
	top: -90px;
}
.target.pt {
	top: -110px;
}
@media screen and (max-width: 767px) {
	.target {
		top: 0;
	}
	.target.pt {
		top: -30px;
	}
}



/* w
============================================================================================================ */
.w {
	position: relative;
}
@media screen and (min-width: 768px), print {
	.w {
		width: 1040px;
		margin: 0 auto;
	}
	.mw {
		min-width: 1140px;
	}
	.lw {
		position: relative;
		max-width: 1200px;
		padding-left: 40px;
		padding-right: 40px;
		margin: 0 auto;
	}
	.xw {
		position: relative;
		max-width: 1320px;
		padding-left: 20px;
		padding-right: 20px;
		margin: 0 auto;
	}
}
@media screen and (max-width: 767px) {
}


/* spパディング
============================================================================================================ */
@media screen and (max-width: 767px) {
	.sp_pd {
		padding-left: 5vw !important;
		padding-right: 5vw !important;
	}
	.sp_full {
		margin-left: -5vw !important;
		margin-right: -5vw !important;
	}
	.sp_full_l {
		margin-left: -5vw !important;
	}
	.sp_full_r {
		margin-right: -5vw !important;
	}
}


/* header
============================================================================================================ */
#header {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	background-color: #fff;
	z-index: 1000;
}
@media screen and (min-width: 768px) {
	#header {
		position: fixed;
	}
}
@media screen and (min-width: 768px), print {
	#header .logo {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
	#header .logo a {
		display: block;
	}
	#header .logo a img {
		width: auto;
		height: 70px;
	}
	#header nav .gnav {
		display: flex;
		align-items: center;
		max-width: 1340px;
		height: 90px;
		margin: 0 auto;
		padding: 0 10px;
	}
	#header nav .gnav li {
		max-width: calc((100% - 240px) / 4);
		min-width: calc((100% - 320px) / 4);
		width: calc((100% - (320px - (1300px - 100vw) * .55)) / 4);
	}
	#header nav .gnav li:nth-child(3) {
		margin-left: auto;
	}
	#header nav .gnav a {
		position: relative;
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		height: 80px;
		text-align: center;
		text-decoration: none;
		font-weight: 700;
		font-size: 1.8rem;
		line-height: 1.3;
		color: #000;
	}
	#header nav .gnav a .ja {
		transform: rotate(0.05deg);
	}
	#header nav .gnav a .ff_en {
		position: relative;
		margin-top: 4px;
		padding: 3px 10px;
		font-size: 1.3rem;
		z-index: 2;
	}
	#header nav .gnav a .ff_en::after {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background-color: #3fc6ea;
		transform: scale(.8);
		opacity: 0;
		z-index: -1;
	}
	body.init #header nav .gnav a .ff_en {
		transition: color .2s ease-in-out;
	}
	body.init #header nav .gnav a .ff_en::after {
		transition: transform .2s ease-in-out, opacity .2s ease-in-out;
	}
/*
	#header nav .gnav a:hover,
	#header nav .gnav a.current {
		color: #3fc6ea;
	}
*/
	#header nav .gnav a:hover .ff_en,
	#header nav .gnav a.current .ff_en {
		color: #fff;
	}
	#header nav .gnav a:hover .ff_en::after,
	#header nav .gnav a.current .ff_en::after {
		transform: scale(1);
		opacity: 1;
	}
}
@media screen and (min-width: 768px) {
	#header::after {
		content: "";
		position: absolute;
		right: 0;
		left: 0;
		bottom: -1px;
		border-bottom: 1px solid #e5e5e5;
		opacity: 0;
	}
	body.init #header,
	body.init #header .logo a {
		transition: transform 0.5s ease-in-out;
	}
	body.init #header nav .gnav {
		transition: height 0.5s ease-in-out;
	}
	body.init #header::after {
		transition: opacity 0.5s ease-in-out;
	}
	.head-min #header nav .gnav {
		height: 70px;
	}
	.head-min #header::after {
		opacity: 1;
	}
	.head-min #header .logo a {
		transform: scale(.7);
	}
}
@media screen and (max-width: 767px) {
	#header {
		height: 80px;
	}
	#header .logo {
		position: absolute;
		top: 10px;
		left: 25px;
	}
	#header .logo a {
		display: block;
		width: 92px;
		height: 60px;
		background: url(../images/logo.svg) no-repeat 50%;
		background-size: 100% 100%;
	}
	#header .logo a img {
		display: none;
	}

	/* nav_btn */
	#header .nav_btn {
		position: fixed;
		right: 12px;
		top: 12px;
		width: 50px;
		height: 50px;
		background-color: #442407;
		border-radius: 100%;
		z-index: 1000;
	}
	#header .nav_btn a {
		position: relative;
		display: block;
		height: 100%;
	}
	#header .nav_btn::before,
	#header .nav_btn a::before,
	#header .nav_btn a::after {
		content: "";
		position: absolute;
		left: 50%;
		top: 50%;
		width: 24px;
		margin-top: -2px;
		margin-left: -12px;
		border-top: 3px solid #fff;
		pointer-events: none;
	}
	body.init #header .nav_btn::before,
	body.init #header .nav_btn a::before,
	body.init #header .nav_btn a::after {
		transition: all 0.3s ease-in-out;
	}
	#header .nav_btn a::before {
		transform: translateY(-9px);
	}
	#header .nav_btn a::after {
		transform: translateY(9px);
	}

	/* nav_btn open */
	#header.open .nav_btn::before {
		opacity: 0;
	}
	#header.open .nav_btn a::before {
		transform: translateY(0) rotate(45deg);
	}
	#header.open .nav_btn a::after {
		transform: translateY(0) rotate(-45deg);
	}

	/* nav */
	#header nav {
		position: fixed;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		display: flex;
		justify-content: center;
		align-items: center;
		text-align: center;
		padding: 120px 0 40px;
		background-color: #fff;
		opacity: 0;
		pointer-events: none;
		z-index: 999;
	}
	#header nav > div {
		width: 100%;
		max-height: calc(100% - 160px);
		max-height: 100%;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		transform: scale(1.3);
	}
	body.init #header nav {
		transition: opacity 0.4s ease-in-out;
	}
	body.init #header nav > div {
		transition: transform 0.4s ease-in-out;
	}
	/* open */
	#header.open nav {
		opacity: 1;
		pointer-events: all;
	}
	#header.open nav > div {
		transform: scale(1);
	}

	#header nav .gnav li + li {
		margin-top: 4.5vh;
	}
	#header nav .gnav a {
		position: relative;
		display: block;
		padding: 20px 0;
		text-align: center;
		text-decoration: none;
		font-size: 2rem;
		line-height: 1.5;
		color: #442407;
		font-weight: 700;
		z-index: 2;
	}
	#header nav .gnav a .ff_en {
		position: absolute;
		left: 50%;
		top: 50%;
		font-size: 6rem;
		line-height: 1;
		opacity: 0.18;
		color: #442407;
		white-space: nowrap;
		transform: translate(-50%, -50%);
	}
	#header nav .sns {
		display: flex;
		justify-content: center;
		align-items: center;
		margin-top: 9vh;
		font-size: 1.8rem;
	}
	#header nav .sns ul {
		display: flex;
		margin-left: 40px;
	}
	#header nav .sns ul li + li {
		margin-left: 20px;
	}

	/* copyright */
	#header small {
		position: absolute;
		bottom: 10px;
		right: 0;
		left: 0;
		text-align: center;
		color: #040404;
		font-size: 1rem;
	}
}


/* footer
============================================================================================================ */
#footer {
	position: relative;
	margin-top: 160px;
}
@media screen and (min-width: 768px), print {
}
@media screen and (max-width: 767px) {
	#footer {
		margin-top: 80px;
	}
}

/* pagetop
------------------------------------------------------------- */
#pagetop {
	position: fixed;
	overflow: hidden;
	bottom: 30px;
	right: 30px;
	width: 80px;
	height: 80px;
	display: flex;
	justify-content: center;
	align-items: center;
	border: 5px solid #3aaf40;
	background-color: #fff;
	border-radius: 100%;
	pointer-events: none;
	opacity: 0;
	z-index: 98;
}
#pagetop svg {
	width: 30px;
	height: 28px;
	fill: #3aaf40;
	transform: rotate(-90deg);
}
.init #pagetop {
	transition: opacity 0.3s, background .2s;
}
#pagetop.show {
	opacity: 1;
	pointer-events: auto;
}
#pagetop.abs {
	position: absolute;
	bottom: calc(100% + 30px);
}
@media print {
	#pagetop {
		display: none;
	}
}
@media screen and (min-width: 768px) {
	#pagetop:hover {
		background-color: #3aaf40;
	}
	#pagetop:hover svg {
		fill: #fff;
	}
}
@media screen and (max-width: 767px) {
	#pagetop {
		bottom: 10px;
		right: 10px;
		transform-origin: 100% 100%;
		transform: scale(.8);
	}
	#pagetop.abs {
		bottom: calc(100% + 10px);
	}
}


/* logo
------------------------------------------------------------- */
#footer .logo {
	overflow: hidden;
	position: relative;
}
#footer .logo .img {
	position: relative;
	width: 100%;
	height: auto;
	pointer-events: none;
	user-select: none;
	z-index: -1;
}
@media screen and (min-width: 768px), print {
	#footer .logo p {
		position: absolute;
		top: 0;
		right: 0;
		left: 0;
		text-align: center;
	}
	#footer .logo p img {
		width: 206px;
		height: auto;
	}
	#footer .logo .img {
		left: 50%;
		min-width: 1440px;
		transform: translateX(-50%);
	}
}
@media screen and (max-width: 767px) {
	#footer .logo p {
		margin-bottom: 40px;
		text-align: center;
	}
	#footer .logo p img {
		width: 180px;
	}
	#footer .logo .img {
		width: 123%;
		max-width: none;
	}
}

/* foot
------------------------------------------------------------- */
#footer .foot {
	position: relative;
	background-color: #442407;
	color: #fff;
}
#footer .foot .nav a {
	color: #fff;
	font-size: 1.2rem;
	font-weight: 700;
}
#footer .foot .nav a .ico_blank {
	position: relative;
	display: inline-block;
	margin-left: 8px;
	width: 10px;
	height: 8px;
	border: 1px solid #fff;
	vertical-align: 2px;
}
#footer .foot .nav a .ico_blank::after {
	content: "";
	position: absolute;
	top: 2px;
	left: -4px;
	width: 10px;
	height: 8px;
	background-color: #442407;
	border: 1px solid #fff;
}
#footer small {
	font-size: 1rem;
}
@media screen and (min-width: 768px), print {
	#footer .foot {
		padding: 45px 60px 45px 40px;
	}
	#footer .foot .nav {
		display: flex;
	}
	#footer .foot .nav li:nth-child(2) {
		margin-left: 80px;
	}
	#footer .foot .nav li:last-child {
		margin-left: auto;
	}
	#footer small {
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
}
@media screen and (max-width: 767px) {
	#footer .foot {
		margin-top: -1px;
		padding: 30px 0 20px;
		text-align: center;
	}
	#footer .foot .nav {
		margin-bottom: 15px;
	}
	#footer .foot .nav a {
		display: block;
		padding: 10px 0;
	}
}

/* container
============================================================================================================ */
#container {
	position: relative;
	padding-top: 90px;
	padding-bottom: 40px;
	font-size: 1.6rem;
	line-height: 2;
}
#container::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	height: 900px;
	width: 8px;
	background: #43afe8;
	background: -moz-linear-gradient(top, #3aaf40 20%, #40afab 50%, #43afe8 50%);
	background: -webkit-linear-gradient(top, #3aaf40 20%,#40afab 50%,#43afe8 50%);
	background: linear-gradient(to bottom, #3aaf40 20%,#40afab 50%,#43afe8 50%);
	z-index: 1001;
}
@media screen and (max-width: 767px) {
	#container {
		padding-top: 80px;
	}
	#container::before {
		height: 810px;
		width: 4px;
	}
}


/* ===================================================================================================================

	パーツ

=================================================================================================================== */

/* foot_contact
============================================================================================================ */
.foot_contact a {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: #fff;
	border: 10px solid #3aaf40;
	color: #3aaf40;
	font-size: 2rem;
	line-height: 1.5;
	font-weight: 700;
	text-decoration: none;
}
.foot_contact a .ff_en {
	display: block;
	font-size: 3.6rem;
}
@media screen and (min-width: 768px), print {
	.foot_contact a {
		width: 880px;
		height: 200px;
		margin: 0 auto;
		border-radius: 100px;
	}
	.foot_contact a .arrow {
		position: absolute;
		top: 40px;
		right: 85px;
		width: 100px;
		height: 100px;
		display: flex;
		justify-content: center;
		align-items: center;
		background-color: #3aaf40;
		border-radius: 100px;
	}
	.foot_contact a .arrow svg {
		width: 30px;
		height: 28px;
		fill: #fff;
	}
	.foot_contact a:hover {
		background-color: #3aaf40;
		color: #fff;
	}
	body.init .foot_contact a:hover .arrow {
		transition: background 0.2s ease-in-out;
	}
	.foot_contact a:hover .arrow {
		background-color: #fff;
	}
	.foot_contact a:hover .arrow svg {
		fill: #3aaf40;
	}
}
@media screen and (max-width: 767px) {
	.foot_contact a {
		height: 120px;
		border-width: 8px;
		border-radius: 60px;
		font-size: 1.6rem;
		text-align: center;
	}
	.foot_contact a .ff_en {
		font-size: 2.4rem;
	}
	.foot_contact a .arrow {
		display: none;
	}
}

/* foot_sns
============================================================================================================ */
.foot_sns {
	position: relative;
	overflow: hidden;
	margin-top: 120px;
	padding: 60px;
	background-color: #006837;
	border-radius: 20px;
	text-align: center;
	color: #fff;
}
.foot_sns h2 {
	margin-bottom: 30px;
	font-size: 2.4rem;
	line-height: 1.5;
}
.foot_sns ul {
	display: flex;
	justify-content: center;
}
.foot_sns li {
	margin: 0 35px;
}
@media screen and (max-width: 767px) {
	.foot_sns {
		margin: 80px 5vw 0;
		padding: 80px 0 60px;
	}
	.foot_sns h2 {
		position: relative;
		margin-bottom: 60px;
		font-size: 3rem;
	}
	.foot_sns h2::before {
		content: "FOLLOW";
		position: absolute;
		top: 50%;
		left: 50%;
		font-size: 7rem;
		font-family: 'Montserrat', sans-serif;
		font-weight: 700;
		opacity: 0.15;
		white-space: nowrap;
		pointer-events: none;
		user-select: none;
		transform: translate(-50%, -50%);
		color: #fff;
	}
	.foot_sns li {
		margin: 0 10px;
	}
}

/* breadcrumbs
============================================================================================================ */
.breadcrumbs {
	font-size: 1.4rem;
	line-height: 1.4;
	text-align: center;
	color: #000;
}
.breadcrumbs ol li::after {
	content: ">";
	margin: 0 .5em;
}
.breadcrumbs ol li a {
	color: #000;
	text-decoration: none;
}
.breadcrumbs ol li:last-child a {
	color: #3fc6ea;
	text-decoration: underline;
}
.breadcrumbs ol li:last-child::after {
	content: none;
}
@media screen and (min-width: 768px), print {
	.breadcrumbs ol {
		white-space: nowrap;
		overflow: hidden;
		text-overflow: ellipsis;
	}
	.breadcrumbs li {
		display: inline;
	}
}
@media screen and (max-width: 767px) {
	.breadcrumbs {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
	}
	.breadcrumbs ol {
		display: table;
		white-space: nowrap;
		margin: 0 auto;
	}
	.breadcrumbs ol li {
		display: table-cell;
		white-space: nowrap;
	}
}

/* page_title
============================================================================================================ */
.page_title {
	overflow: hidden;
	position: relative;
	height: 400px;
	text-align: center;
	font-size: 4rem;
	line-height: 1.2;
	color: #fff;
	z-index: 1;
}
.page_title h1,
.page_title .ff_en {
	position: absolute;
	top: 110px;
}
.page_title h1 {
	right: 0;
	left: 0;
	transform: translateY(-50%);
	z-index: 3;
}
.page_title .ff_en {
	left: 50%;
	font-size: 16rem;
	padding-left: 0.05em;
	letter-spacing: 0.05em;
	opacity: 0.3;
	white-space: nowrap;
	pointer-events: none;
	user-select: none;
	transform: translate(-50%, -50%);
}
.page_title::after {
	content: "";
	position: absolute;
	right: 0;
	left: 0;
	bottom: 0;
	height: 200px;
	background: url(../images/bg_round.svg) no-repeat 50%;
	background-size: 100% 100%;
	z-index: 2;
}
.page_title .breadcrumbs {
	position: absolute;
	right: 0;
	left: 0;
	bottom: 90px;
	z-index: 3;
}
@media screen and (min-width: 768px), print {
}
@media screen and (max-width: 767px) {
	.page_title {
		height: 130px;
		font-size: 3rem;
	}
	.page_title h1,
	.page_title .ff_en {
		top: 40px;
	}
	.page_title .ff_en {
		font-size: 8rem;
	}
	.page_title::after {
		height: 50px;
	}
	.page_title .breadcrumbs {
		bottom: 0;
	}
}

/* contents_box
============================================================================================================ */
.contents_box {
	position: relative;
	padding-bottom: 260px;
	z-index: 2;
}
.contents_box.bottom_semicircle {
	margin-bottom: 280px;
	padding-bottom: 80px;
}
.contents_box.bottom_semicircle::after {
	content: "";
	position: absolute;
	right: 0;
	left: 0;
	bottom: -200px;
	height: 200px;
	background: url(../images/bg_round.svg) no-repeat 50%;
	background-size: 100% 100%;
	transform: scaleY(-1);
	z-index: 2;
}
@media screen and (max-width: 767px) {
	.contents_box.bottom_semicircle {
		margin-bottom: 160px;
		padding-bottom: 50px;
		padding-top: 20px;
	}
	.contents_box.bottom_semicircle::after {
		bottom: -80px;
		height: 80px;
	}
}

/* entry_ph
============================================================================================================ */
.entry_ph {
	overflow: hidden;
	position: relative;
	padding-top: 72.727%;
	border-radius: 20px;
	z-index: 2;
}
.entry_ph.wide {
	padding-top: 56.25%;
}
.entry_ph .no-img {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #f3f3f3;
}
.entry_ph .no-img img {
	width: 50%;
	opacity: 0.3;
}
@media screen and (max-width: 767px) {
}

/* entry_list
============================================================================================================ */
.entry_list a {
	position: relative;
	display: block;
	height: 100%;
	text-decoration: none;
	color: #000;
	line-height: 1.5;
}
.entry_list a .ph_wrap {
	position: relative;
}
.entry_list a .ph_wrap .pr {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 8px;
	background-color: #006600;
	border-radius: 0 0 20px 20px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	z-index: 3;
}
.entry_list a .time {
	display: flex;
	padding: 11px 0;
	font-size: 2rem;
}
.entry_list a .time time {
	flex-shrink: 0;
	margin-right: 20px;
	padding-top: 0.1em;
}
.entry_list a .category {
	display: flex;
	flex-wrap: wrap;
}
.entry_list a .category li {
	margin: 2px 8px 2px 0;
	padding: 4px 18px;
	background-color: #3aaf40;
	font-size: 1.5rem;
	color: #fff;
	font-weight: 700;
	border-radius: 100px;
}
.entry_list a .title {
	font-size: 2.2rem;
}
.entry_list a h3::before {
	content: "";
	display: block;
	border-top: 8px solid #3aaf40;
	margin-bottom: 20px;
}
@media screen and (min-width: 768px), print {
	.entry_list {
		display: flex;
		flex-wrap: wrap;
	}
	.entry_list a:hover .title {
		text-decoration: underline;
	}
}
@media screen and (max-width: 767px) {
	.entry_list article + article {
		margin-top: 50px;
	}
	.entry_list a h3::before {
		border-top-width: 4px;
	}
	.entry_list.sp_mini article + article {
		margin-top: 20px;
	}
	.entry_list.sp_mini a {
		height: auto;
	}
	.entry_list.sp_mini a::after {
		content: "";
		display: table;
		clear: both;
	}
	.entry_list.sp_mini a .ph_wrap {
		float: left;
		width: 30vw;
	}
	.entry_list.sp_mini a .entry_ph {
		padding-top: 82%;
		border-radius: 10px;
	}
	.entry_list.sp_mini a .ph_wrap .pr {
		padding: 4px;
		border-radius: 0 0 10px 10px;
		font-size: 1.3rem;
	}
	.entry_list.sp_mini a .ph_wrap ~ * {
		margin-left: 34vw;
	}
	.entry_list.sp_mini a .time {
		padding: 0 0 2px;
		font-size: 1.3rem;
	}
	.entry_list.sp_mini a .time time {
		margin-right: 10px;
		padding-top: 0;
	}
	.entry_list.sp_mini a .category li {
		margin: 0 4px 2px 0;
		padding: 0 10px;
		font-size: 1.1rem;
	}
	.entry_list.sp_mini a .title {
		font-size: 1.3rem;
		display: -webkit-box;
		-webkit-line-clamp: 3;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}
	.entry_list.sp_mini a h3::before {
		border-top-width: 3px;
		margin-bottom: 6px;
	}
}

/* title
============================================================================================================ */
/* en_title */
.en_title {
	margin-bottom: 30px;
	text-align: center;
	line-height: 1.3;
	font-size: 1.2rem;
	letter-spacing: 0.1em;
	color: #A9A9A9;
}
.en_title .ff_min {
	margin-bottom: 15px;
	font-size: 2.6rem;
	color: #000;
}

/* para_section (paragraph section)
============================================================================================================ */
.para_section > * + * {
	margin-top: 1.2em;
}


/* table
============================================================================================================ */
.basic_table {
	width: 100%;
	table-layout: fixed;
}
.basic_table tr:nth-child(odd) {
	background-color: #f0f4f7;
}
.basic_table th,
.basic_table td {
	padding: 8px 30px;
	vertical-align: top;
}
.basic_table th {
	padding-right: 0;
}
.basic_table.th15 th {
	width: 15%;
}
.basic_table.th20 th {
	width: 20%;
}
.basic_table.th25 th {
	width: 25%;
}
.basic_table.th30 th {
	width: 30%;
}
@media screen and (max-width: 767px) {
	.basic_table th,
	.basic_table td {
		padding: 8px 20px;
	}
	.basic_table th {
		padding-right: 0;
	}
	.basic_table.sp_th15 th {
		width: 15%;
	}
	.basic_table.sp_th20 th {
		width: 20%;
	}
	.basic_table.sp_th25 th {
		width: 25%;
	}
	.basic_table.sp_th30 th {
		width: 30%;
	}
}


/* box_btn
============================================================================================================ */
button.box_btn,
a.box_btn,
a .box_btn {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	max-width: 100%;
	height: 120px;
	margin: auto;
	background-color: #3aaf40;
	border: 8px solid #3aaf40;
	border-radius: 60px;
	text-decoration: none;
	text-align: center;
	color: #fff;
	font-weight: 700;
	font-size: 2.4rem;
	line-height: 1.4;
}
.box_btn svg {
	position: absolute;
	top: 50%;
	right: 66px;
	width: 30px;
	height: 28px;
	margin-top: -14px;
	fill: #fff;
}
.box_btn.blue {
	background-color: #0099cc;
	border-color: #0099cc;
}
.box_btn.white_blue {
	background-color: #fff;
	border-color: #fff;
	color: #3fc6ea;
}
.box_btn.white_blue svg {
	fill: #3fc6ea;
}
.box_btn.wl {
	max-width: 700px;
}
@media screen and (min-width: 768px), print {
	button.box_btn:hover,
	a[href].box_btn:hover,
	a[href]:hover .box_btn {
		background-color: #fff;
		color: #3aaf40;
	}
	button.box_btn:hover svg,
	a[href].box_btn:hover svg,
	a[href]:hover .box_btn svg {
		fill: #3aaf40;
	}
	button.box_btn.blue:hover,
	a[href].box_btn.blue:hover,
	a[href]:hover .box_btn.blue {
		color: #0099cc;
	}
	button.box_btn.blue:hover svg,
	a[href].box_btn.blue:hover svg,
	a[href]:hover .box_btn.blue svg {
		fill: #0099cc;
	}
	button.box_btn.white_blue:hover,
	a[href].box_btn.white_blue:hover,
	a[href]:hover .box_btn.white_blue {
		background-color: #3fc6ea;
		color: #fff;
	}
	button.box_btn.white_blue:hover svg,
	a[href].box_btn.white_blue:hover svg,
	a[href]:hover .box_btn.white_blue svg {
		fill: #fff;
	}
}
@media screen and (max-width: 767px) {
	button.box_btn,
	a.box_btn,
	a .box_btn {
		height: 100px;
		font-size: 2rem;
	}
	.box_btn svg {
		right: 30px;
	}
}


/* back_link
============================================================================================================ */
.back_link {
	display: flex;
	justify-content: center;
	margin-top: 80px;
	font-size: 1.4rem;
	font-weight: bold;
}
.back_link a {
	display: flex;
	align-items: center;
	color: #3AAF40;
}
.back_link a .arrow {
	position: relative;
	width: 40px;
	height: 40px;
	margin-right: 25px;
	background-color: #3aaf40;
	border-radius: 20px;
	transform: rotate(180deg);
}
.back_link a .arrow::before {
	content: "";
	position: absolute;
	top: 50%;
	right: 15px;
	width: 11px;
	height: 11px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	transform-origin: 100% 0;
	transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
	.back_link {
		margin-top: 50px;
	}
	.back_link a .arrow {
		margin-right: 20px;
	}
}

/* ul / ol
============================================================================================================ */
.dot_li > li {
	position: relative;
	padding-left: 1em;
}
.dot_li > li::before {
	content: "・";
	position: absolute;
	top: 0;
	left: 0;
}

.circle_li > li {
	position: relative;
	padding-left: 1.1em;
}
.circle_li > li::before {
	content: "●";
	position: absolute;
	top: 0;
	left: 0;
	color: #005f8b;
	transform-origin: 0;
	transform: scale(0.8);
}

.parentheses_li > li {
	position: relative;
	padding-left: 2.8em;
}
.parentheses_li > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.parentheses_li_h > li {
	position: relative;
	padding-left: 1.6em;
}
.parentheses_li_h > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}
.parentheses_li_hh > li {
	position: relative;
	padding-left: 2.2em;
}
.parentheses_li_hh > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.point_li > li {
	position: relative;
	padding-left: 1.2em;
}
.point_li > li > span:first-child {
	position: absolute;
	top: 0;
	left: 0;
}

.square_li > li {
	position: relative;
	padding-left: 0.8em;
}
.square_li > li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .8em;
	width: 5px;
	height: 5px;
	background-color: #14143c;
}
@media screen and (max-width: 767px) {
	.square_li > li::before {
		top: 0.6em;
	}
}

.num_li {
	margin-left: 1.8em;
	list-style: decimal;
}
.alphabet_li {
	margin-left: 1.8em;
	list-style: lower-latin;
}

.mt_li > li + li {
	margin-top: 0.8em;
}
@media screen and (max-width: 767px) {
	.sp_mt_li > li + li {
		margin-top: 0.8em;
	}
}

.inline_li > li {
	display: inline-block;
	margin-right: 0.3em;
}



/* .wp-pagenavi
============================================================================================================ */
.wp-pagenavi {
	position: relative;
	margin-top: 140px;
	padding: 0 70px;
	text-align: center;
	display: flex;
	justify-content: center;
	color: #1c1c1c;
	font-family: 'Montserrat', sans-serif;
	font-weight: 700;
}
.wp-pagenavi > * {
	position: relative;
	display: block;
	min-width: 60px;
	margin: 5px 10px;
	color: #000000;
	font-size: 4rem;
	line-height: 1;
	text-decoration: none;
}
.wp-pagenavi a {
	color: #1c1c1c;
	text-decoration: none;
}
.wp-pagenavi .extend {
	width: auto;
	margin: 5px 0;
}
.wp-pagenavi .current {
	color: #3AAF40;
}
.wp-pagenavi .previouspostslink,
.wp-pagenavi .nextpostslink {
	position: absolute;
	overflow: hidden;
	top: 50%;
	width: 50px;
	height: 50px;
	margin: 0;
	background-repeat: no-repeat;
	background-position: 50%;
	background-image: url(../images/arrow_green.svg);
	background-size: 100%;
	text-indent: -1000px;
	transform: translateY(-50%);
}
.wp-pagenavi .nextpostslink {
	right: 0;
}
.wp-pagenavi .previouspostslink {
	left: 0;
	transform: translateY(-50%) rotate(180deg);
}
@media screen and (min-width: 768px), print {
	.wp-pagenavi a:hover {
		color: #3AAF40;
	}
	.wp-pagenavi .previouspostslink:hover,
	.wp-pagenavi .nextpostslink:hover {
		opacity: 0.5;
	}
}
@media screen and (max-width: 767px) {
	.wp-pagenavi {
		margin-top: 80px;
		padding: 0 40px;
		flex-wrap: wrap;
	}
	.wp-pagenavi > * {
		min-width: 30px;
		margin: 5px 10px;
		font-size: 3rem;
	}
	.wp-pagenavi .previouspostslink,
	.wp-pagenavi .nextpostslink {
		width: 30px;
		height: 30px;
	}
	.wp-pagenavi .last,
	.wp-pagenavi .first {
		display: none;
	}
}


/* .column_contents
============================================================================================================ */
@media screen and (min-width: 768px), print {
	.column_contents {
		display: flex;
		justify-content: space-between;
	}
	.column_contents.center {
		justify-content: center;
	}
	.column_contents .column_main {
		width: 720px;
	}
	.column_contents .column_side {
		width: 320px;
	}
}
@media screen and (max-width: 767px) {
	.column_contents .column_side {
		margin-top: 90px;
	}
}


/* ========================================================

	ブログ一覧

======================================================== */
.page-blog #container {
	padding-bottom: 120px;
	background-color: #3aaf40;
}
.page-blog #container .foot_contact a {
	border-color: #fff;
}
.page-blog .page_title::after {
	background-image: url(../images/bg_round_beige.svg);
}
.page-blog .contents_box {
	background-color: #f6f5ec;
}
.page-blog .contents_box.bottom_semicircle::after {
	background-image: url(../images/bg_round_beige.svg);
}
.page-blog .column_main .entry_ph .no-img,
.page-blog .column_side .entry_ph .no-img {
	background-color: #fff;
}
@media screen and (min-width: 768px), print {
	.page-blog .contents_box {
		margin-bottom: 320px;
	}
	.page-blog .column_main .entry_list {
		justify-content: space-between;
	}
	.page-blog .column_main .entry_list article {
		width: 320px;
	}
	.page-blog .column_main .entry_list article:nth-child(n + 3) {
		margin-top: 70px;
	}
}
@media screen and (max-width: 767px) {
	.page-blog #container {
		padding-bottom: 60px;
	}
	.page-blog .contents_box {
		margin-bottom: 160px;
	}
}

@media screen and (min-width: 768px), print {
	.blog_bg {
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		overflow: hidden;
		z-index: -1;
	}
	.blog_bg::before {
		content: "";
		position: absolute;
		top: 130px;
		right: 50%;
		margin-right: 565px;
		width: 290px;
		height: 1544px;
		background: url(../images/blog_point1.svg) no-repeat 50%;
		background-size: 100%;
	}
	.blog_bg::after {
		content: "";
		position: absolute;
		top: 650px;
		left: 50%;
		margin-left: 565px;
		width: 354px;
		height: 1850px;
		background: url(../images/blog_point2.svg) no-repeat 50%;
		background-size: 100%;
	}
}

.category_search {
	margin-bottom: 50px;
	padding: 60px 70px;
	background-color: #fff;
	border: 5px solid #3aaf40;
	border-radius: 20px;
}
.category_search dl + dl {
	margin-top: 20px;
}
.category_search dt {
	margin-bottom: 15px;
	padding: 8px;
	background-color: #3aaf40;
	border-radius: 100px;
	color: #fff;
	text-align: center;
	font-size: 2.4rem;
	line-height: 1.2;
	font-weight: 700;
}
.category_search ul {
	display: flex;
	flex-wrap: wrap;
	margin-left: -1.5em;
	font-size: 1.4rem;
	font-weight: bold;
}
.category_search ul li {
	margin-left: 1.5em;
}
.category_search ul a.current {
	color: #3AAF40;
}
.category_search .more {
	display: flex;
	justify-content: flex-end;
	margin-top: 10px;
	font-size: 1.4rem;
	font-weight: bold;
}
.category_search .more a {
	display: flex;
	align-items: center;
	color: #3AAF40;
}
.category_search .more a .arrow {
	position: relative;
	width: 40px;
	height: 40px;
	margin-left: 34px;
	background-color: #3aaf40;
	border-radius: 20px;
}
.category_search .more a .arrow::before {
	content: "";
	position: absolute;
	top: 50%;
	right: 15px;
	width: 11px;
	height: 11px;
	border-top: 3px solid #fff;
	border-right: 3px solid #fff;
	transform-origin: 100% 0;
	transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
	.category_search {
		margin-bottom: 30px;
		padding: 0;
		border-width: 3px;
	}
	.category_search dl + dl {
		margin-top: 30px;
	}
	.category_search dt {
		font-size: 1.9rem;
	}
	.category_search ul li {
		margin-bottom: 0.3em;
	}
	.category_search .more a .arrow {
		margin-left: 20px;
	}

	.category_search .acc_title a {
		position: relative;
		display: block;
		padding: 10px 35px;
		text-decoration: none;
		text-align: center;
		font-size: 1.7rem;
		color: #3aaf40;
		line-height: 1.2;
		font-weight: 700;
	}
	.category_search .acc_title a .arrow {
		position: absolute;
		right: 10px;
		top: 50%;
		width: 30px;
		height: 30px;
		margin-top: -15px;
		border-radius: 100%;
	}
	.category_search .acc_title a .arrow::before,
	.category_search .acc_title a .arrow::after {
		content: "";
		position: absolute;
		top: 50%;
		right: 6px;
		left: 6px;
		margin-top: -2px;
		border-top: 4px solid #3aaf40;
	}
	.category_search .acc_title a .arrow::after {
		transform: rotate(90deg);
	}
	.init .category_search .acc_title a .arrow::after {
		transition: transform .3s, opacity .3s;
	}
	.category_search .acc_title a.open .arrow::after {
		transform: rotate(0);
		opacity: 0;
	}
	.category_search_acc {
		position: relative;
		height: 0;
		overflow: hidden;
	}
	.init .category_search_acc {
		transition: height .3s;
	}
	.category_search_acc > * {
		padding: 10px 35px 25px;
	}
}
.category_search.tag_all {
	margin-bottom: 0;
}
@media screen and (min-width: 768px), print {
	.category_search.tag_all {
		padding: 90px 90px 70px;
	}
	.category_search.tag_all dt {
		margin: 0 65px 40px;
	}
	.category_search.tag_all ul {
		margin-left: -2em;
	}
	.category_search.tag_all ul li {
		margin-left: 2em;
		margin-bottom: 0.8em;
	}
}
@media screen and (max-width: 767px) {
	.category_search.tag_all {
		padding: 35px;
	}
	.category_search.tag_all dt {
		margin-bottom: 20px;
	}
}

.column_side > * + * {
	margin-top: 80px;
}
@media screen and (max-width: 767px) {
	.column_side > * + * {
		margin-top: 50px;
	}
}
.column_side .side_ad_bnr img {
	max-width: 100%;
	height: auto;
}
.column_side .side_ad_bnr {
	text-align: center;
}
.column_side .side_ad_bnr li + li {
	margin-top: 40px;
}
.column_side h2 {
	margin-bottom: 20px;
	padding-bottom: 10px;
	border-bottom: 4px solid;
	font-size: 3rem;
	line-height: 1.5;
}
.column_side h2.ranking {
	color: #442407;
}
.column_side .side_entry li + li {
	margin-top: 40px;
}
.column_side .side_entry a {
	position: relative;
	display: block;
	color: #000;
	line-height: 1.5;
}
.column_side .side_entry a > * {
	display: block;
}
.column_side .side_entry a .ph_wrap {
	position: relative;
}
.column_side .side_entry a .pr {
	position: absolute;
	right: 0;
	bottom: 0;
	left: 0;
	padding: 8px;
	background-color: #006600;
	border-radius: 0 0 20px 20px;
	color: #fff;
	text-align: center;
	font-weight: bold;
	z-index: 3;
}
.column_side .side_entry a .title {
	margin-top: 20px;
	font-size: 2.2rem;
	font-weight: bold;
}
@media screen and (min-width: 768px), print {
}
@media screen and (max-width: 767px) {
	.column_side .side_entry li + li {
		margin-top: 20px;
	}
	.column_side .side_entry a {
		display: flex;
		justify-content: space-between;
		font-size: 1.3rem;
	}
	.column_side .side_entry a .ph_wrap {
		width: 50%;
	}
	.column_side .side_entry a .entry_ph {
		margin-bottom: 0;
		border-radius: 10px;
	}
	.column_side .side_entry a .pr {
		padding: 4px;
		border-radius: 0 0 10px 10px;
		font-size: 1.3rem;
	}
	.column_side .side_entry a .title {
		width: calc(50% - 18px);
		margin-top: 0;
		font-size: 1.3rem;
	}
	.column_side .side_entry a .title > span {
		display: -webkit-box;
		-webkit-line-clamp: 5;
		-webkit-box-orient: vertical;
		overflow: hidden;
	}
}
.column_side .side_ranking {
	counter-reset: side_ranking;
}
.column_side .side_ranking a {
	position: relative;
	display: flex;
	justify-content: space-between;
	margin-top: 35px;
	font-size: 1.2rem;
	line-height: 1.5;
	color: #442407;
	font-weight: bold;
}
.column_side .side_ranking a::before {
	counter-increment: side_ranking;
	content: counter(side_ranking);
	position: absolute;
	left: 0;
	top: -12px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 24px;
	height: 24px;
	background-color: #fff;
	border: 2px solid;
	border-radius: 12px;
	font-family: 'Montserrat', sans-serif;
	font-weight: 700;
	font-size: 1.4rem;
	line-height: 1;
	z-index: 3;
}
.column_side .side_ranking a .ph {
	width: 50%;
}
.column_side .side_ranking a .entry_ph {
	margin-bottom: 0;
	border-radius: 10px;
}
.column_side .side_ranking a .title {
	width: calc(50% - 18px);
	padding: 7px 0;
	border-top: 2px solid;
	border-bottom: 2px solid;
}
.column_side .side_ranking a .title > span {
	display: -webkit-box;
	-webkit-line-clamp: 4;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
@media screen and (min-width: 768px), print {
	.column_side .side_ranking_section {
		position: sticky;
		top: 90px;
	}
}

/* ========================================================

	ブログ詳細

======================================================== */

.blog_detail {
	margin-bottom: 140px;
	padding-top: 70px;
	background: url(../images/bg_pattern.png) 50% 0;
	background-size: 284px;
	z-index: -1;
}
.blog_detail .blog_detail_header {
	overflow: hidden;
	position: relative;
	margin-bottom: 30px;
	background-color: #3aaf40;
	border-radius: 10px;
	text-align: center;
	color: #fff;
	font-weight: bold;
	z-index: 1;
}
.blog_detail .blog_detail_header .pr {
	padding: 10px;
	background-color: #006600;
	font-size: 1.8rem;
}
.blog_detail .blog_detail_header .time {
	padding-top: 40px;
	font-size: 2rem;
	line-height: 1.2;
}
.blog_detail .blog_detail_header .pr + .time {
	padding-top: 20px;
}
.blog_detail .blog_detail_header .time .category {
	display: flex;
	flex-wrap: wrap;
}
.blog_detail .blog_detail_header .time .category li a {
	display: block;
	text-decoration: none;
	margin: 2px 8px 2px 0;
	padding: 6px 18px;
	background-color: #fff;
	border: 3px solid #fff;
	font-size: 1.5rem;
	color: #3AAF40;
	font-weight: 700;
	border-radius: 100px;
}
.blog_detail .blog_detail_header .time time.modified {
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 80%;
}
.blog_detail .blog_detail_header h1 {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 20px 60px 40px;
	font-size: 4rem;
	line-height: 1.4;
}
.blog_detail .blog_detail_header .tags {
	display: flex;
	justify-content: center;
	margin-top: -10px;
	padding: 0 60px 50px;
	line-height: 1.2;
}
.blog_detail .blog_detail_header .tags a {
	display: block;
	margin: 2px 8px 2px 0;
	padding: 4px 16px;
	border: 2px solid #fff;
	font-size: 1.4rem;
	color: #fff;
	text-decoration: none;
	font-weight: 700;
	border-radius: 100px;
}
.blog_detail .blog_detail_header .ph {
	text-align: center;
}
.blog_detail .blog_detail_header .ph img {
	max-width: 100%;
	height: auto;
}
@media screen and (min-width: 768px), print {
	.blog_detail .blog_detail_header .time {
		display: flex;
		justify-content: center;
		align-items: center;
		flex-wrap: wrap;
	}
	.blog_detail .blog_detail_header .time time {
		flex-shrink: 0;
		margin-right: 20px;
		padding-top: 0.1em;
	}
	.blog_detail .blog_detail_header .time .category li a:hover {
		background-color: #3AAF40;
		color: #fff;
	}
	.blog_detail .blog_detail_header .time time.modified {
		order: 3;
		width: 100%;
		margin: 10px 0 0;
		text-align: center;
	}
	.blog_detail .blog_detail_header .tags a:hover {
		background-color: #fff;
		color: #3AAF40;
	}
	.blog_detail .blog_detail_header .ph {
		margin-top: -10px;
	}
}
@media screen and (max-width: 767px) {
	.blog_detail {
		margin-bottom: 60px;
		padding-top: 30px;
		background-size: 220px;
	}
	.blog_detail .blog_detail_header {
		margin-bottom: 20px;
	}
	.blog_detail .blog_detail_header .pr {
		padding: 5px;
		font-size: 1.6rem;
	}
	.blog_detail .blog_detail_header .time {
		padding-top: 20px;
		text-align: center;
		font-size: 1.8rem;
	}
	.blog_detail .blog_detail_header .time .category {
		justify-content: center;
		margin-top: 8px;
	}
	.blog_detail .blog_detail_header .time .category li a {
		margin: 2px 5px;
		border-width: 2px;
		font-size: 1.2rem;
	}
	.blog_detail .blog_detail_header .time time.modified {
		margin-top: 5px;
	}
	.blog_detail .blog_detail_header h1 {
		padding: 10px 20px 20px;
		font-size: 2.1rem;
	}
	.blog_detail .blog_detail_header .tags {
		margin-top: -5px;
		padding: 0 20px 20px;
	}
	.blog_detail .blog_detail_header .tags a {
		margin: 2px 5px;
		padding: 4px 16px;
		font-size: 1.1rem;
	}
}

.blog_detail .column_contents {
	margin-top: 70px;
	padding-bottom: 140px;
}
@media screen and (max-width: 767px) {
	.blog_detail .column_contents {
		margin-top: 40px;
		padding-bottom: 70px;
	}
}

.relation_entry {
	padding: 160px 0;
	background-color: #3aaf40;
}
.relation_entry h2 {
	margin-bottom: 20px;
	text-align: center;
	font-size: 3rem;
	line-height: 1.5;
	color: #3AAF40;
}
@media screen and (min-width: 768px), print {
	.relation_entry .box {
		padding: 70px 0 60px;
		background-color: #fff;
		border-radius: 20px;
	}
	.relation_entry .entry_list {
		justify-content: center;
	}
	.relation_entry .entry_list article {
		width: 320px;
		margin: 0 20px;
	}
}
@media screen and (max-width: 767px) {
	.relation_entry {
		padding: 40px 0;
	}
	.relation_entry h2 {
		font-size: 2.4rem;
		color: #fff;
	}
	.relation_entry .entry_list article + article {
		margin-top: 40px;
	}
	.relation_entry .entry_list.sp_mini article + article {
		margin-top: 20px;
	}
	.relation_entry .entry_list a {
		color: #fff;
	}
	.relation_entry .entry_list a .category li {
		background-color: #fff;
		color: #3aaf40;
	}
	.relation_entry .entry_list a h3::before {
		border-color: #fff;
	}
}


/* ========================================================

	アクティビティ一覧

======================================================== */

.page-activity .page_title::after {
	background-image: url(../images/bg_round_blue.svg);
}
.page-activity .contents_box {
	background-color: #ccecff;
}
.page-activity .contents_box.bottom_semicircle::after {
	background-image: url(../images/bg_round_blue.svg);
}
.page-activity .wp-pagenavi .current {
	color: #3FC6EA;
}
.page-activity .wp-pagenavi .previouspostslink,
.page-activity .wp-pagenavi .nextpostslink {
	background-image: url(../images/arrow_blue.svg);
}
@media screen and (min-width: 768px), print {
	.page-activity .wp-pagenavi a:hover {
		color: #3FC6EA;
	}
}
@media screen and (max-width: 767px) {
	.page-activity .page_title .ff_en {
		font-size: 6rem;
	}
	.page-activity .wp-pagenavi {
		margin-right: 7.33vw;
		margin-left: 7.33vw;
	}
}

@media screen and (min-width: 768px), print {
	.activity_bg {
		position: relative;
		overflow: hidden;
	}
	.activity_bg::before,
	.activity_bg::after {
		content: "";
		position: absolute;
		width: 206px;
		height: 88px;
		background: url(../images/activities_point.svg) no-repeat 50%;
		background-size: 100%;
	}
	.activity_bg::before {
		top: 160px;
		right: 50%;
		margin-right: 525px;
	}
	.activity_bg::after {
		bottom: 100px;
		left: 50%;
		margin-left: 465px;
		transform-origin: 50% 100%;
		transform: scale(1.56);
	}
}

.activities_category {
	margin-bottom: 80px;
	padding-top: 60px;
}
.activities_category dt {
	color: #38C3EC;
	font-weight: 700;
	font-size: 4rem;
	line-height: 1;
}
.activities_category ul {
	display: flex;
}
.activities_category ul a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 80px;
	height: 80px;
	background-color: #fff;
	border-radius: 100%;
	color: #000;
	font-size: 2rem;
	line-height: 1.3;
	font-weight: 700;
	text-decoration: none;
}
.activities_category ul a.current {
	color: #3FC6EA;
}
@media screen and (min-width: 768px), print {
	.activities_category {
		display: flex;
		align-items: center;
	}
	.activities_category dt {
		width: calc((100% - 960px) / 2 + 320px);
	}
	.activities_category li {
		margin-right: 40px;
	}
	.activities_category ul a:hover {
		color: #3FC6EA;
	}
}
@media screen and (max-width: 767px) {
	.activities_category {
		padding-top: 0;
	}
	.activities_category dt {
		margin-bottom: 25px;
		text-align: center;
		font-size: 3rem;
	}
	.activities_category ul {
		justify-content: center;
		flex-wrap: wrap;
	}
	.activities_category li {
		margin: 0 6px;
	}
	.activities_category li:first-child {
		width: 100%;
		margin: 0 0 20px;
	}
	.activities_category ul a {
		margin: 0 auto;
	}
}

.activities_list {
	position: relative;
}
.activities_list::before {
	position: relative;
}
.activities_list a {
	display: block;
	border-radius: 20px;
	background-color: #fff;
	text-decoration: none;
	font-size: 2rem;
	line-height: 1.5;
	font-weight: 700;
}
.activities_list a .ph_wrap {
	position: relative;
	border-radius: 20px 20px 0 0;
}
.activities_list a .ph {
	overflow: hidden;
	position: relative;
	padding-top: 75%;
	border-radius: 20px 20px 0 0;
	z-index: 2;
}
.activities_list a .no-img {
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: #f3f3f3;
}
.activities_list a .no-img img {
	width: 50%;
	opacity: 0.3;
}
.activities_list a .content {
	padding: 15px 20px 35px;
}
.activities_list a .more {
	position: absolute;
	top: 50%;
	left: 0;
	right: 0;
	text-align: center;
	font-size: 1.6rem;
	color: #fff;
	transform: translateY(-40%);
	opacity: 0;
	z-index: 3;
}
.activities_list a .more svg {
	display: inline-block;
	width: 8px;
	height: 100%;
	fill: #fff;
}
.activities_list a .cat {
	display: flex;
}
.activities_list a .cat li {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 40px;
	height: 40px;
	margin-right: 10px;
	background-color: #3fc6ea;
	border-radius: 100%;
	color: #fff;
	font-size: 1.8rem;
	line-height: 1.3;
	font-weight: 700;
	text-decoration: none;
}
.activities_list a .title {
	margin-top: 15px;
}
@media screen and (min-width: 768px), print {
	.activities_list {
		display: flex;
		flex-wrap: wrap;
	}
	.activities_list article {
		width: 320px;
		margin-left: calc((100% - 960px) / 2);
	}
	.activities_list article:nth-child(3n + 1) {
		margin-left: 0;
	}
	.activities_list article:nth-child(n + 4) {
		margin-top: 80px;
	}
	.activities_list a {
		height: 100%;
	}
	body.init .activities_list a .ph_wrap {
		transition: background-color 0.2s ease-in-out;
	}
	.activities_list a .ph_wrap {
		background-color: #fff;
	}
	.activities_list a:hover .ph_wrap {
		background-color: #000;
	}
	.activities_list a:hover .ph {
		opacity: .56;
	}
	body.init .activities_list a .more {
		transition: opacity 0.2s ease-in-out;
	}
	.activities_list a:hover .more {
		opacity: 1;
	}
	.activities_list a:hover .title {
		text-decoration: underline;
	}
}
@media screen and (max-width: 767px) {
	.activities_list {
		padding: 0 7.33vw;
	}
	.activities_list article + article {
		margin-top: 40px;
	}
}

.coming_entry {
	padding: 40px 0 0;
	text-align: center;
	font-size: 10rem;
	color: #fff;
	line-height: 1;
}
@media screen and (max-width: 767px) {
	.coming_entry {
		padding: 0 0 0;
		text-align: center;
		font-size: 5rem;
	}
}


/* ========================================================

	アクティビティ詳細

======================================================== */

.activities_detail {
	position: relative;
}
.activities_detail > header {
	overflow: hidden;
	position: relative;
	margin-top: 110px;
	text-align: center;
	z-index: 1;
}
.activities_detail > header h1 {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 4rem;
	line-height: 1.2;
	color: #3FC6EA;
	height: 180px;
}
.activities_detail > header .ff_en {
	position: absolute;
	top: 50%;
	right: 0;
	left: 0;
	transform: translateY(-50%);
	color: #3FC6EA;
	font-size: 16rem;
	padding-left: 0.05em;
	letter-spacing: 0.05em;
	opacity: 0.3;
	white-space: nowrap;
	pointer-events: none;
	user-select: none;
}
@media screen and (min-width: 768px), print {
}
@media screen and (max-width: 767px) {
	.activities_detail > header {
		margin-top: 60px;
	}
	.activities_detail > header h1 {
		font-size: 3rem;
		line-height: 1.4;
		height: 180px;
	}
	.activities_detail > header .ff_en {
		letter-spacing: 0;
		padding-left: 0;
		font-size: 6rem;
	}
}

.activities_detail_contents {
	position: relative;
	margin-top: 40px;
	margin-bottom: 180px;
	z-index: 3;
}
.activities_detail_contents .activities_detail_bg {
	content: "";
	position: absolute;
	top: 310px;
	bottom: 480px;
	left: 0;
	right: 0;
	background-color: #ccecff;
	z-index: -1;
}
.activities_detail_contents .activities_detail_bg::before,
.activities_detail_contents .activities_detail_bg::after {
	content: "";
	position: absolute;
	right: 0;
	left: 0;
	height: 200px;
	background: url(../images/bg_round_blue.svg) no-repeat 50%;
	background-size: 100% 100%;
}
.activities_detail_contents .activities_detail_bg::before {
	top: -200px;
}
.activities_detail_contents .activities_detail_bg::after {
	bottom: -200px;
	transform: scaleY(-1);
}
.activities_detail_contents .main_ph {
	overflow: hidden;
	position: relative;
	padding-top: 56.25%;
	border-radius: 20px 20px 0 0;
	z-index: 2;
}
.activities_detail_contents .contents {
	padding: 80px;
	background-color: #fff;
	border-radius: 0 0 20px 20px;
}
@media screen and (max-width: 767px) {
	.activities_detail_contents {
		margin-bottom: 80px;
	}
	.activities_detail_contents .activities_detail_bg {
		top: 160px;
		bottom: 300px;
	}
	.activities_detail_contents .activities_detail_bg::before,
	.activities_detail_contents .activities_detail_bg::after {
		height: 100px;
	}
	.activities_detail_contents .activities_detail_bg::before {
		top: -100px;
	}
	.activities_detail_contents .activities_detail_bg::after {
		bottom: -100px;
	}
	.activities_detail_contents .main_ph {
		padding-top: 71.85%;
	}
	.activities_detail_contents .contents {
		padding: 40px 5vw;
	}
}

.activities_detail_contents .category {
	display: flex;
	justify-content: center;
	margin-bottom: 40px;
}
.activities_detail_contents .category li {
	margin: 0 20px;
}
.activities_detail_contents .category li a {
	display: block;
	text-decoration: none;
	padding: 6px 18px;
	background-color: #3fc6ea;
	font-size: 1.5rem;
	color: #fff;
	font-weight: 700;
	border-radius: 100px;
}
@media screen and (max-width: 767px) {
	.activities_detail_contents .category {
		margin-bottom: 20px;
	}
	.activities_detail_contents .category li {
		margin: 0 10px;
	}
	.activities_detail_contents .category li a {
		font-size: 1.2rem;
	}
}

.activities_detail_contents .information {
	margin-bottom: 60px;
}
.activities_detail_contents .information .info dl {
	padding-bottom: 5px;
	border-bottom: 2px solid #0099CC;
}
.activities_detail_contents .information .info dl + dl {
	padding-top: 20px;
}
.activities_detail_contents .information .info dt {
	font-size: 1.8rem;
	font-weight: bold;
	color: #0099CC;
}
@media screen and (min-width: 768px), print {
	.activities_detail_contents .information {
		display: flex;
		justify-content: space-between;
	}
	.activities_detail_contents .information .desc {
		width: calc(50% - 70px);
	}
	.activities_detail_contents .information .info {
		width: 50%;
	}
	.activities_detail_contents .information .info dl {
		padding-bottom: 5px;
		border-bottom: 2px solid #0099CC;
	}
	.activities_detail_contents .information .info dd {
		width: calc(100% - 150px);
	}
}
@media screen and (max-width: 767px) {
	.activities_detail_contents .information {
		margin-bottom: 40px;
		font-size: 1.4rem;
	}
	.activities_detail_contents .information .desc {
		margin-bottom: 60px;
	}
	.activities_detail_contents .information .info dl {
		padding-bottom: 10px;
	}
	.activities_detail_contents .information .info dt {
		font-size: 1.6rem;
		color: #0099CC;
	}
}
.activities_detail_contents .site_link {
	text-align: center;
	font-weight: bold;
	font-size: 1.4rem;
}
@media screen and (max-width: 767px) {
	.activities_detail_contents .site_link {
		font-size: 1.2rem;
	}
}
.activities_detail_contents .company_box {
	margin-top: 40px;
	padding: 40px 80px 80px;
	border: 6px solid #3FC6EA;
	border-radius: 20px;
	font-size: 1.4rem;
}
.activities_detail_contents .company_box h2 {
	margin-bottom: 30px;
	text-align: center;
	font-size: 3rem;
	line-height: 1.2;
	color: #3FC6EA;
}
.activities_detail_contents .company_box h3,
.activities_detail_contents .company_box dt {
	margin-bottom: 10px;
	font-size: 2rem;
	line-height: 1.5;
	font-weight: 700;
}
.activities_detail_contents .company_box dl {
	margin-top: 20px;
}
.activities_detail_contents .company_box .logo > span {
	position: relative;
	display: block;
	border: 1px solid #000;
}
@media screen and (min-width: 768px), print {
	.activities_detail_contents .company_box .content {
		display: flex;
		justify-content: space-between;
	}
	.activities_detail_contents .company_box .content > * {
		width: calc(50% - 40px);
	}
	.activities_detail_contents .company_box .logo > span {
		width: 320px;
		height: 210px;
		margin-left: auto;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.activities_detail_contents .company_box .logo img {
		max-width: 82%;
		height: auto;
	}
}
@media screen and (max-width: 767px) {
	.activities_detail_contents .company_box {
		padding: 40px 5vw;
		border-width: 4px;
	}
	.activities_detail_contents .company_box h2 {
		margin-bottom: 15px;
		font-size: 2.4rem;
	}
	.activities_detail_contents .company_box h3,
	.activities_detail_contents .company_box dt {
		font-size: 1.6rem;
	}
	.activities_detail_contents .company_box .logo {
		margin-bottom: 20px;
	}
	.activities_detail_contents .company_box .logo > span {
		padding-top: 65.625%;
	}
	.activities_detail_contents .company_box .logo img {
		position: absolute;
		top: 50%;
		left: 50%;
		max-width: 82%;
		transform: translate(-50%, -50%);
	}
}

.activities_detail_contents .reserve_link {
	margin-top: 100px;
	text-align: center;
	font-size: 1.4rem;
}
.activities_detail_contents .reserve_link a {
	height: 130px;
	margin-bottom: 10px;
	font-size: 3rem;
}
.activities_detail_contents .reserve_link a span {
	position: relative;
	padding: 0 45px;
}
.activities_detail_contents .reserve_link a span::before,
.activities_detail_contents .reserve_link a span::after {
	content: "";
	position: absolute;
	right: 8px;
	top: 50%;
	width: 26px;
	height: 24px;
	margin-top: -10px;
	border: 4px solid #fff;
}
.activities_detail_contents .reserve_link a span::after {
	border-width: 4px 4px 0 0;
	transform: translate(8px, -8px);
}
@media screen and (min-width: 768px), print {
	.init .activities_detail_contents .reserve_link a span::before,
	.init .activities_detail_contents .reserve_link a span::after {
		transition: border 0.2s ease-in-out;
	}
	.activities_detail_contents .reserve_link a:hover span::before,
	.activities_detail_contents .reserve_link a:hover span::after {
		border-color: #3aaf40;
	}
}
@media screen and (max-width: 767px) {
	.activities_detail_contents .reserve_link {
		margin-top: 60px;
	}
	.activities_detail_contents .reserve_link a {
		height: 100px;
		margin-bottom: 30px;
		font-size: 2.4rem;
	}
	.activities_detail_contents .reserve_link a svg {
		display: none;
	}
	.activities_detail_contents .reserve_link a span {
		padding: 0 34px 0 0;
	}
	.activities_detail_contents .reserve_link a span::before,
	.activities_detail_contents .reserve_link a span::after {
		width: 20px;
		height: 20px;
	}
}

.activities_detail_contents .entry_body {
	margin-top: 120px;
}
@media screen and (max-width: 767px) {
	.activities_detail_contents .entry_body {
		margin-top: 80px;
	}
}

.activity_relation_entry {
	margin-top: 75px;
	padding: 75px 0 80px;
	background-color: #3fc6ea;
	border-radius: 20px;
}
.activity_relation_entry h2 {
	margin-bottom: 30px;
	text-align: center;
	font-size: 3rem;
	line-height: 1.5;
	color: #fff;
}
@media screen and (min-width: 768px), print {
	.activity_relation_entry .activities_list {
		justify-content: center;
	}
	.activity_relation_entry .activities_list article {
		margin: 0 20px;
	}
}
@media screen and (max-width: 767px) {
	.activity_relation_entry {
		margin-top: 80px;
		padding: 40px 0;
	}
	.activity_relation_entry h2 {
		margin-bottom: 30px;
		font-size: 2.6rem;
	}
	.activity_relation_entry .activities_list {
		padding: 0;
	}
}


