@charset "utf-8";

/*  www.kyoko-toyama.jp
-----------------------------------------------------*/
@import url('https://fonts.googleapis.com/css2?family=Kosugi+Maru&display=swap');
/* ==============================================
    universal reset
============================================== */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

/* ==============================================
    html,body and base
============================================== */
html,body {
	height:100%;
}

/* general params
------------------*/
table {
	empty-cells: show;
	font-size: 100%;
	border-collapse: collapse;
}

img {
	border: none;
	height: auto;
	vertical-align: top;
    image-rendering: -webkit-optimize-contrast;
	max-width: 100%;
}

h1,h2,h3,h4,h5,h6 {
	font-weight: bold;
	font-size: 100%;
}

ul {
	letter-spacing: -.40em;
}
ul li {
	letter-spacing: normal;
}
/* acronyms and abbreviations styles 
-------------------------------------*/
acronym,abbr {
	cursor: help;
}

/* ==============================================
    clear
============================================== */
.cbox {
	zoom: 100%;
}
.cbox::after {
	content: "";
	clear: both;
	height: 0;
	display: block;
}
.clear {
	clear: both;
	height: 1px;
	font-size: 1px;
}
.clear hr {
	display: none;
}

hr.clear {
	zoom: 1;
	clear: both;
	height: 0;
	border: none;
	font-size: 0;
}
*:first-child+html hr.clear {/* for IE7 */
	border-top: 1px solid;
} 

/* ==============================================
    body
============================================== */
body {
	font-size: 16px;
	line-height: 1.6;
	color: #604e44;
	text-align: center;
	background: #fff url("image/bg.gif") no-repeat top center;
	-webkit-text-size-adjust: 100%;
}
@media screen and (max-width: 700px) {
	body {
		min-width: 300px;
		font-size: 14px;
		background: none;
	}
}
@media print {
	body {
		min-width: 950px;
	}
}
body,
input,
select,
textarea {
	font-family: 'Kosugi Maru', Meiryo, Arial, Roboto, sans-serif;
}
form input[type="submit"],
form input[type="reset"],
form input[type="button"] {
	-webkit-appearance: none;
}

/* ==============================================
    link
============================================== */
a {
	color: #604e44;
	transition: all .4s;
	text-decoration: none;
	outline: none;
}
a:hover {
	text-decoration: underline;
}

@media screen and (min-width: 701px) {
	a:hover,
	#pagetop img:hover {
		opacity: 0.7;
		filter: alpha(opacity=70);
		-ms-filter: "alpha( opacity=70 )";
	}
	a img.rollover:hover {
		opacity: 1;
		filter: alpha(opacity=100);
		-ms-filter: "alpha( opacity=100 )";
	}
}

/* ==============================================
    
============================================== */
#container,
.inner {
	zoom: 1;
	margin: 0 auto;
	text-align: left;
}
#container:after {
	content: "";
	clear: both;
	height: 0;
	display: block;
}
.inner {
	width: 1200px;
}

.sp {
	display: none;
}
.switch {}
.call {}


@media screen and (max-width: 1200px) {
	.inner {
		width: 96%;
	}
}

@media screen and (max-width: 700px) {
	.pc {
		display: none;
	}
	.sp {
		display: block;
	}

}


/* ==============================================
    container
============================================== */
#container {
	position:relative;
	margin: 0 auto;
	overflow-x: hidden;
}

nav ul {
	list-style: none;
}

/* ==============================================
    globalheader
============================================== */
#globalheader {
	margin: 0px;
	padding: 16px 0;
	background: #fff;
	box-shadow: 0px 3px 0px 0px rgba(0, 0, 0, 0.15);
}
#globalheader a:hover {
	text-decoration: none;
}
#globalheader .inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
}

#globalheader #siteid {
	display: block;
}
#globalheader #h-menu {

}
#globalheader #h-info {
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin-bottom: 12px;
}
#globalheader #h-info li {
	margin-left: 20px;
}
#globalheader #h-info li:first-child {
	margin-left: 0px;
}
#globalheader #h-info li.tel {
	font-size: 28px;
	font-weight: bold;
}
#globalheader #h-info li.tel::before {
	content: "";
	display: inline-block;
	background: url("image/icon_tel.svg") no-repeat 0 0 / contain;
	width: 22px;
	height: 22px;
	margin-right: 10px;
}

#globalheader #h-info li.time {
	font-size: 14px;
}
#globalheader #h-info li.inquiry {

}
#globalheader #h-info li.inquiry a {
	font-size: 18px;
	display: block;
	background: url("image/btn_inquiry_bg.svg") no-repeat center center / contain;
	width: 200px;
	height: 44px;
	color: #fff;
	text-align: center;
	line-height: 44px;
}

@media screen and (max-width: 1200px) {
	#globalheader #siteid {
		width: 30%;
	}
	#globalheader #h-info li.tel {
		font-size: 24px;
	}
	#globalheader #h-info li.time span {
		display: block;
	}
	#globalheader #h-info li.inquiry a {
		font-size: 16px;
		width: 180px;
		height: 44px;
	}
}

@media screen and (max-width: 900px) {
	#globalheader {
		padding: 10px 0;
	}
	#globalheader #h-info li.tel {
		font-size: 18px;
	}
	#globalheader #h-info li.inquiry a {
		font-size: 14px;
		width: 150px;
		height: 44px;
	}
}

@media screen and (max-width: 700px) {
	#globalheader {
		width: 100%;
		padding: 5px 0;
		box-shadow: none;
	}
	#globalheader .inner {
		display: block;
	}
	#globalheader #siteid {
		width: 300px;
	}
	#globalheader #h-info li.inquiry {
		display: none;
	}
	#globalheader #h-info {
		justify-content: center;
		margin-top: 10px;
	}
	#globalheader #h-info li.time span {
		display: inline-block;
	}
	#globalheader #h-info li.tel {
		font-size: 18px;
	}
	#globalheader #h-info li.tel::before {
		width: 18px;
		height: 18px;
	}
	#globalheader #h-info li.time {
		font-size: 12px;
	}
}

@media screen and (max-width: 360px) {
	#globalheader #siteid {
		width: 240px;
	}
	#globalheader #h-info li.time span {
		display: block;
	}
}

/* ==============================================
    globalnav
============================================== */
#globalnav {
	
}
#globalnav ul {
	display: flex;
	justify-content: space-between;
}
#globalnav li {
	margin-left: 10px;
}
#globalnav li:first-child {
	margin-left: 0;
}
#globalnav li a {
	display: inline-block;
	font-size: 18px;
}
#globalnav li a::after {
	content: "";
	display: inline-block;
	background: url("image/arrow1.svg") no-repeat 0 0 / contain;
	width: 24px;
	height: 24px;
	vertical-align: middle;
	margin-left: 5px;
}

#globalnav .submenu {
	display: none;
}
#globalnav li.briefing a,
#globalnav li.e-book a,
#globalnav li.cluboff a,
#globalnav li.teacher a,
#globalnav li.inquiry a,
#globalnav li.apply a {
	color: #fff;
	display: block;
	padding: 10px 15px;
	margin: 10px 0;
}
#globalnav li.inquiry a {
	background: #f19149;
}
#globalnav li.cluboff a {
	background: #f19149;
}
#globalnav li.teacher a {
	background: #fae20a;
	color: inherit;
}
#globalnav li.apply a {
	background: #4ba836;
}
#globalnav li.apply a span {
	font-size: 0.8em;
}
#globalnav li.briefing a {
	background: #0a9acf;
}
#globalnav li.e-book a {
	background: #63bd52;
}

#globalnav li.apply a::before {
	content: "";
	display: inline-block;
	background-image: url("image/icon_apply.svg");
	width: 54px;
	height: 54px;
	margin-right: 10px;
	vertical-align: middle;
}

#globalnav li.briefing a::after,
#globalnav li.e-book a::after,
#globalnav li.cluboff a::after,
#globalnav li.teacher a::after,
#globalnav li.inquiry a::after,
#globalnav li.apply a::after {
	background-image: url("image/arrow3.svg");
}


@media screen and (max-width: 1000px) {
	#globalnav li {
		margin-left: 5px;
	}
	#globalnav li:first-child {
		margin-left: 0;
	}
	#globalnav li a {
		font-size: 14px;
	}
	#globalnav li a::after {
		width: 18px;
		height: 18px;
	}
}



@media screen and (max-width: 700px) {
	#globalnav {
		position: fixed;
		top: 0;
		left: 0;
		width: 100%;
		height: 100vh;
		background: #fff;
		padding: 60px 10px 10px;
		transform: translateX(100%);
		opacity: 0;
		transition: transform 0.6s cubic-bezier(0.16, 1, 0.3, 1), opacity 0.3s ease;
		z-index: 9;
	}
	#globalnav.active {
		display: block;
		opacity: 1;
		transform: translateX(0);
	}
	#globalnav ul {
		flex-direction: column;
	}
	#globalnav li {
		margin-left: 0px;
	}
	#globalnav li a {
		font-size: 17px;
		display: block;
		padding: 4px 10px;
	}
	#globalnav li a::after {
		width: 18px;
		height: 18px;
		margin-left: 10px;
	}
	#globalnav .submenu {
		display: block;
	}
}

@media screen and (max-width: 340px) {
	#globalnav li a {
		font-size: 15px;
		display: block;
		padding: 3px 10px;
	}
}

/* ==============================================
    sideBtn
============================================== */
#sideBtn {
	position: fixed;
	top: 22vh;
	right: 0;
	z-index: 100;
}
#sideBtn p {
	margin:0 0 40px 0;
}
#sideBtn_member {
	animation: member 5s ease 1s infinite;
	transform-origin: 10% 100%;
}

@keyframes member {
	5% {}
	10% { transform: rotate(-3deg); }
	20% { transform: rotate(0deg); }
	30% { transform: rotate(-3deg); }
	40% {transform: rotate(0deg); }
}


@media screen and (max-width: 700px) {
	#sideBtn {
		display: none;
	}
}

/* ==============================================
    menuBtn span
============================================== */
#menuBtn {
	display: none;
	position: fixed;
	top: 0;
	right: 0;
	width: 60px;
	height: 60px;
	background: #4ba836;
	border-radius: 10px;
	text-indent: -10000px;
	overflow: hidden;
	cursor: pointer;
	z-index: 10;
}
#menuBtn span,
#menuBtn:before,
#menuBtn:after {
	display: block;
	position: absolute;
	width: 20px;
	height: 2px;
	margin-left: -10px;
	background: #fff;
	top: 30px;
	left: 30px;
	transition: all .4s;
	opacity: 1;
}
#menuBtn span {
	margin-top: -1px;
	transition: opacity 150ms 50ms;
}

#menuBtn:before,
#menuBtn:after {
	content: "";
}
#menuBtn:before {
	transform: translate(0, -8px);
}
#menuBtn:after {
	transform: translate(0, 6px);
}

#menuBtn.active span {
	opacity: 0;
}
#menuBtn.active:before  {
	transform: rotate(45deg);
}
#menuBtn.active:after  {
	transform: rotate(-45deg);
}
@media screen and (max-width: 700px) {
	#menuBtn {
		display: block;
		width: 50px;
		height: 50px;
	}
	#menuBtn span,
	#menuBtn:before,
	#menuBtn:after {
		top: 25px;
		left: 25px;
	}
}

/* ==============================================
    breadcrumb
============================================== */

#breadcrumb {
	margin: 20px 0 30px;
}

#breadcrumb ol {
	list-style: none;
}
#breadcrumb li {
	display: inline-block;
	color: #5f4d43;
	font-size: 0.875em;
}

#breadcrumb li a {
	color: #5f4d43;
	text-decoration: none;
}
#breadcrumb li a:hover {
	text-decoration: none;
}

#breadcrumb li a::after {
	content: "";
	display: inline-block;
	background: url("image/arrow2.svg") no-repeat 0 0 / contain;
	width: 12px;
	height: 12px;
	margin: 0 15px;
}

@media screen and (max-width: 700px) {
	#breadcrumb {
		margin: 0;
		padding: 15px 0;
	}
}

/* ==============================================
    contents
============================================== */

#contents {}

.btn a,
a.btn {
	display: inline-block;
}
.btn a::after,
a.btn::after {
	content: "";
	display: inline-block;
	background: url("image/arrow1.svg") no-repeat 0 0 / contain;
	width: 26px;
	height: 26px;
	vertical-align: middle;
	margin-left: 5px;
}


.pdf a,
a.pdf {
	position: relative;
	display: inline-block;
	margin-left: 25px;
}
.pdf a::before,
a.pdf::before {
	position: absolute;
	content: "";
	display: inline-block;
	background: url("image/file_pdf.svg") no-repeat 0 0;
	background-size: contain;
	width: 20px;
	height: 20px;
	margin-left: -25px;
}



/* Youtube レスポンシブ用 */
.movie_wrap {
	position: relative;
	padding-top: 56.25%;
	height: 0;
	overflow: hidden;
}
.movie_wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}


.map_wrap {
	position: relative;
	padding-top: 480px;
	height: 0;
	overflow: hidden;
}
.map_wrap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
@media screen and (max-width: 700px) {
	.map_wrap {
		padding-top: 300px;
	}
}

@media screen and (max-width: 700px) {
	table.scroll {
		overflow: auto;
		white-space: nowrap;
		display: block;
		width: auto;
	}
	table.scroll tbody {
		width: 100%;
	}
	table.scroll::-webkit-scrollbar {
		height: 5px;
	}
	table.scroll::-webkit-scrollbar-track {
		background: #f1f1f1;
	}
	table.scroll::-webkit-scrollbar-thumb {
		background: #bcbcbc;
	}
}

/* ==============================================
    pagetop
============================================== */
#pagetop {
    position: fixed;
    bottom: 10px;
    right: 0;
    display: none;
}
#pagetop img {
	width: 120px;
	height: 120px;
	cursor: pointer;
	transform-origin: bottom left;
	transition: .2s;
	
}
@media screen and (min-width: 701px) {
	#pagetop img:hover {
		opacity: 1;
		transform: rotate(-5deg);
	}
}


@media screen and (max-width: 700px) {
	#pagetop img {
		width: 60px;
		height: 60px;
	}
}

/* ==============================================
    footer
============================================== */
footer {
	margin-top: 100px;
	border-top: 3px solid #d9d9d9;
	padding: 40px 0 50px;
	background: url("image/f_bg2.png") repeat-x bottom center, url("image/f_bg1.png") no-repeat bottom center;
}


#footersitemap > ul {
	display: flex;
	justify-content: flex-start;
	line-height: 1.2;
}

#footersitemap > ul > li {
	width: 20%;
	margin-bottom: 20px;
}

#footersitemap ul ul {
	margin: 5px 5px 0 30px;
	list-style: disc;
	font-size: 0.938em;
}
#footersitemap ul ul li {
	margin-bottom: 5px;
}

#footersitemap li a:hover {
	text-decoration: none;
}
#footersitemap li a::after {
	content: "";
	display: inline-block;
	background: url("image/arrow2.svg") no-repeat 0 0 / contain;
	width: 12px;
	height: 12px;
	vertical-align: middle;
	margin-left: 5px;
}


footer address {
	display: block;
	padding-top: 30px;
	font-style: normal;
}

#f-catch {
	margin-top: 10px;
}
#f-image {
	text-align: center;
	padding-top: 20px;
	margin: 0 auto;
}

#copyright {
	text-align: right;
}


@media screen and (max-width: 1100px) {
	#footersitemap ul {
		font-size: 0.875em;
		flex-wrap: wrap;
	}

}

@media screen and (max-width: 1000px) {
	footer {
		margin-top: 60px;
		padding: 20px 0 3vw;
		background-size: 70%, 120%;
	}
	#footersitemap > ul > li {
		width: 32%;
	}
	#f-image {
		width: 40%;
	}
}

@media screen and (max-width: 700px) {
	footer {
		margin-top: 40px;
		padding: 20px 0 2vw;
		background-size: 110%, 120%;
	}
	#f-catch {
		text-align: center;
		width: 80%;
		margin: 20px auto 10px;
	}
	#f-image {
		width: 40%;
	}
	#footersitemap ul {
		display: none;
	}
	#footersitemap ul.utility {
		display: flex;
	}
	#footersitemap ul.utility li {
		width: auto;
		margin-right: 10px;
		font-size: 12px;
	}
	#footersitemap li a::after {
		width: 8px;
		height: 8px;
	}
}


/* ==============================================
    slick style
============================================== */
.slick-dots li button::before {
	font-size: 12px;
	color: #bbb;
	opacity: 1;
	transition: .4s;
}
.slick-dots li.slick-active button::before {
	color: #000;
}
.slick-dots li button:hover::before {
	opacity: 0.8;
}

.slick-prev,
.slick-next {
	width: 40px;
	height: 40px;
	margin-top: -20px;
	z-index: 10;
}
.slick-prev:before,
.slick-next:before {
	content: "";
	display: inline-block;
	width: 40px;
	height: 40px;
	background-position: 0 0;
	background-repeat: no-repeat;
	background-size: contain;
	transition: .4s;
}

.slick-prev:before {
	background-image: url("image/slick_arrow.svg");
	transform: rotate(180deg);
}
.slick-next:before {
	background-image: url("image/slick_arrow.svg");
}
.slick-prev
{
    left: 10px;
}
[dir='rtl'] .slick-prev
{
    right: 10px;
    left: auto;
}
.slick-next
{
    right: 10px;
}
[dir='rtl'] .slick-next
{
    right: auto;
    left: 10px;
}
@media screen and (max-width: 700px) {
	.slick-prev,
	.slick-next {
		width: 30px;
		height: 30px;
		margin-top: -15px;
	}
	.slick-prev:before,
	.slick-next:before {
		width: 30px;
		height: 30px;
	}
}



/* ==============================================
    スクロールアニメーション
============================================== */
.scrollin {}
.fadein {}
.slidein {}

.scrollin.fadein {
	opacity : 0;
	visibility: hidden;
	transition: 0.5s;
	transform: translateY(100px);
}
.scrollin.fadein.active {
	opacity: 1;
	visibility: visible;
	transform: translateY(0);
}

.scrollin.slidein {
	opacity : 0;
	visibility: hidden;
	transition: 0.5s;
	transform: translateX(300px);
}
.scrollin.slidein.active {
	opacity: 1;
	visibility: visible;
	transform: translateX(0);
}


/* ==============================================
    nav-menubtn
============================================== */
.nav-menubtn ul {
	display: flex;
	justify-content: center;
	align-items: center;
}
.nav-menubtn li {
	margin: 10px;
	width: 24%;
}
.nav-menubtn li a {
	font-size: 1.125em;
	line-height: 1.2;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	text-align: center;
	width: 100%;
	height: 280px;
	background: url("image/btn_bg1.png") no-repeat center center / contain;
}
.nav-menubtn li a:hover {
	background-image: url("image/btn_bg1_on.png");
	opacity: 1;
	text-decoration: none;
}

.nav-menubtn.welfare-menu li a {
	background-image: url("image/btn_bg2.png");
}
.nav-menubtn.welfare-menu li a:hover {
	background-image: url("image/btn_bg2_on.png");
}

.nav-menubtn li a::before {
	content: "";
	display: inline-block;
	background: url("image/icon_research.svg") no-repeat 0 0 / contain;
	width: 58%;
	padding-top: 58%;
	/*height: 160px;*/
	margin: 0 auto;
}

.nav-menubtn li a::after {
	content: "";
	display: inline-block;
	background: url("image/arrow1.svg") no-repeat 0 0 / contain;
	width: 26px;
	height: 26px;
	margin: 5px auto;
}

.nav-menubtn li.research a::before {
	background-image: url("image/icon_research.svg");
}
.nav-menubtn li.scholarship a::before {
	background-image: url("image/icon_scholarship.svg");
}
.nav-menubtn li.culture a::before {
	background-image: url("image/icon_culture.svg");
}
.nav-menubtn li.benefits a::before {
	background-image: url("image/icon_benefits.svg");
}
.nav-menubtn li.health a::before {
	background-image: url("image/icon_health.svg");
}
.nav-menubtn li.hotel a::before {
	background-image: url("image/icon_hotel.svg");
}

.nav-menubtn li.guidance a {
	height: 340px;
	background-size: 100% 360px;
}
.nav-menubtn li.guidance a::before {
	display: none;
}
.nav-menubtn li figure {
	margin-bottom: 5px;
	
}
.nav-menubtn li figure img {
	border: 1px solid #bfbfbf;
	max-width: 110px;
}

@media screen and (max-width: 1000px) {
	.nav-menubtn li a {
		height: 36vw;
	}
	.nav-menubtn li figure {
		width: 50%;
		margin: 0 auto 5px;
	}
	.nav-menubtn li.guidance a {
		height: 40vw;
		background-size: 100% 40vw;
	}
}

@media screen and (max-width: 700px) {
	.nav-menubtn ul {
		flex-wrap: wrap;
	}
	.nav-menubtn li {
		width: 50%;
		margin: 10px auto;
	}
	.nav-menubtn li a {
		height: 42vw;
		font-size: 1.071em;
	}
	.nav-menubtn li.guidance a {
		height: 60vw;
		background-size: 100% 60vw;
	}
	.nav-menubtn li a::after {
		width: 18px;
		height: 18px;
	}
	.nav-menubtn li a::before {
		width: 48%;
		padding-top: 48%;
	}
}

/* ==============================================
    archive-list
============================================== */
dl.archive-list div {
	display: flex;
	justify-content: flex-start;
	border-bottom: 1px solid #dcdcdc;
	padding: 16px 0;
}

dl.archive-list dt {
	width: 130px;
}
dl.archive-list dd {
	flex: 1;
	display: flex;
	flex-direction: column;
}
dl.archive-list dd span {
	display: inline-block;
}
dl.archive-list .entry-date {
	width: 8em;
}
dl.archive-list .entry-tit {
	flex: 1;
}

span.important {
	font-size: 0.875em;
	display: inline-block;
	padding: 2px 5px;
	color: #fff;
	background: #d47677;
	border-radius: 4px;
	margin-right: 14px;
}

a.entry-cat {
	font-size: 15px;
	line-height: 26px;
	width: 100px;
	border: 2px solid #d47577;
	color: #cc6368;
	background: #fff;
	border-radius: 20px;
	display: inline-block;
	text-align: center;
}
a.entry-cat:hover {
	text-decoration: none;
}
a.cat-info {
	border-color: #d47577;
	color: #cc6368;
}
a.cat-magazine {
	border-color: #38a064;
	color: #44925f;
}
a.cat-report {
	border-color: #5c7aac;
	color: #4c6d9b;
}

@media screen and (max-width: 700px) {
	dl.archive-list dt {
		width: 7em;
	}
	dl.archive-list dd {
		flex-direction: column;
	}
	a.entry-cat {
		font-size: 13px;
		line-height: 24px;
		width: 6em;
	}
}

/* ==============================================
    pagination
============================================== */
.pagination {
	text-align: center;
	margin: 30px 0;
}
.pagination span,
.pagination a {
	display: inline-block;
	border: 1px solid #63bd52;
	width: 30px;
	line-height: 30px;
	font-size: 0.875em;
	font-weight: bold;
	color: #63bd52;
	text-align: center;
	background: #fff;
	margin: 5px;
}
.pagination a:hover {
	background: #63bd52;
	color: #fff;
	text-decoration: none;
}
.pagination span {
	background: #63bd52;
	color: #fff;
}

/* ==============================================
    pic
============================================== */
#pic_yotsuba {
	animation: yotsuba 8s ease infinite;
	transform-origin: bottom center;
}
@keyframes yotsuba {
	5% {}
	10% { transform: rotate(6deg); }
	20% { transform: rotate(0deg); }
	30% { transform: rotate(8deg); }
	40% {transform: rotate(0deg); }
}

#pic_leaf {
	animation: leaf 3s ease-in infinite alternate;
	transform-origin: bottom center;
}
@keyframes leaf {
	0% { transform: translateY(0); }
	70% { transform: translateY(0); }
	85% { transform: translateY(-10px) rotate(2deg); }
	100% { transform: translateY(0); }
}

/* ==============================================
    character (toppage)
============================================== */
body.home #contents .inner {
	position: relative;
}
#character {}
#character span {
	display: block;
	position: absolute;
	z-index: 50;
}
#pic_chara1 {
	top: 0;
	right: -300px;
	animation: chara1 10s ease 1s infinite;
	transform-origin: 44% 76%;
}
#pic_chara2 {
	top: 50px;
	left: -200px;
	animation: chara2 4s ease-in infinite alternate;
}

#pic_chara3 {
	top: 1200px;
	right: -150px;
	animation: chara3 7s ease-in infinite;
	transform-origin: 50% 100%;
}
#pic_chara4 {
	top: 1800px;
	left: -210px;
	animation: chara4 10s ease infinite;
	transform-origin: 50% 50%;
}


@keyframes chara1 {
	0% { transform: rotate(0deg); }
	10% { transform: rotate(5deg); }
	20% { transform: rotate(-5deg); }
	30% { transform: rotate(5deg); }
	40% { transform: rotate(-5deg); }
	50% { transform: rotate(0deg); }
}

@keyframes chara2 {
	0% { transform: translateY(0); }
	40% { transform: translateY(0); }
	70% { transform: translateY(-14px); }
	100% { transform: translateY(0); }
}

@keyframes chara3 {
	0% { transform: rotate(0deg); }
	10% { transform: rotate(3deg); }
	30% { transform: rotate(-3deg); }
	50% { transform: rotate(3deg); }
	70% { transform: rotate(-3deg); }
	80% { transform: rotate(0deg); }
}

@keyframes chara4 {
	12% { transform: scale(1); }
	15% { transform: scale(1.02); }
	18% { transform: scale(1); }
	22% { transform: scale(1.02); }
	25% { transform: scale(1); }
	52% { transform: scale(1); }
	55% { transform: scale(1.02); }
	58% { transform: scale(1); }
	62% { transform: scale(1.02); }
	65% { transform: scale(1); }
}

@media screen and (max-width: 1200px) {
	#character {
		display: none;
	}
}


/* ==============================================
    editor font size
============================================== */
.has-x-small-font-size,
.font-ss {
  font-size: 0.750em !important;/*12px  10px*/
}
 
.has-small-font-size,
.font-s {
  font-size: 0.875em !important;/*14px  13px*/
}
 
.has-regular-font-size {
  font-size: 1.000em !important;/*16px*/
}
 
.has-large-font-size,
.font-l {
  font-size: 1.500em !important;/*24px  24px*/
}
 
.has-x-large-font-size,
.font-ll {
  font-size: 1.875em !important;/*30px  36px*/
}
 
.has-huge-font-size,
.font-xl {
  font-size: 2.250em !important;/*36px  50px*/
}

/* ==============================================
    custom color
============================================== */

.has-custom-brown-color {
	color: #5f4d43;
}
.has-custom-orange-color {
	color: #ec8a42;
}
.has-custom-lightorange-color {
	color: #ffe5ce;
}
.has-custom-vividgreen-color {
	color: #63bd52;
}
.has-custom-lightblue-color {
	color: #5088bf;
}
.has-custom-black-color {
	color: #000;
}
.has-custom-mediumgray-color {
	color: #999;
}
.has-custom-lightgray-color {
	color: #d3d3d3;
}
.has-custom-white-color {
	color: #fff;
}
.has-custom-yellow-color {
	color: #fae20a;
}
.has-custom-red-color {
	color: #ff0000;
}
.has-custom-vividred-color {
	color: #cf2e2e;
}


.has-custom-brown-background-color {
	background-color: #5f4d43;
}
.has-custom-orange-background-color {
	background-color: #ec8a42;
}
.has-custom-lightorange-background-color {
	background-color: #ffe5ce;
}
.has-custom-vividgreen-background-color {
	background-color: #63bd52;
}
.has-custom-lightblue-background-color {
	background-color: #5088bf;
}
.has-custom-black-background-color {
	background-color: #000;
}
.has-custom-mediumgray-background-color {
	background-color: #999;
}
.has-custom-lightgray-background-color {
	background-color: #d3d3d3;
}
.has-custom-white-background-color {
	background-color: #fff;
}
.has-custom-yellow-background-color {
	background-color: #fae20a;
}
.has-custom-red-background-color {
	background-color: #ff0000;
}
.has-custom-vividred-background-color {
	background-color: #cf2e2e;
}

/* ==============================================
    entry-content
============================================== */
.entry-content {
	line-height: 1.8;
}

.entry-content h1,.entry-content h2,.entry-content h3,.entry-content h4,.entry-content h5,.entry-content h6 {
	line-height: 1.4;
	font-weight: 400;
}

.entry-content h1 {
	font-size: 2.25em;
	text-align: center;
	margin: 50px 0 50px;
	padding: 0 0 10px 0;
	border-bottom: 2px solid #5f4d43;
}

.subtit,
.entry-content h2 {
	font-size: 2em;
	font-weight: 400;
	padding: 0 0 0 55px;
	margin: 50px 0 40px;
	position: relative;
}
.subtit::before,
.entry-content h2::before {
	content: "";
	display: block;
	background: url("image/circle_g.svg") no-repeat 0 0 / contain;
	width: 44px;
	height: 44px;
	position: absolute;
	top: 0;
	left: 0;
}

#cat-other .subtit::before {
	background-image: url("image/circle_b.svg");
}


.entry-content h3 {
	font-size: 1.500em;
	color: #4ba836;
	padding: 5px;
	margin: 30px 0 20px;
}

.entry-content h4 {
	font-size: 1.375em;
	border-left: 6px solid #4ba836;
	padding: 2px 5px;
	margin: 30px 0 20px;
}

.entry-content h5 {
	font-size: 1.250em;
	margin: 30px 0 20px;
}

.entry-content h6 {
	font-size: 1.125em;
	margin: 30px 0 20px;
}

@media screen and (max-width: 700px) {

}





.entry-content ul,
.entry-content ol {
	margin: 20px 0 30px 30px;
}
.entry-content li {
	line-height: 1.4;
	margin: 5px 0;
}

.entry-content p {
	font-size: 1em;
	line-height: 1.6;
	margin-bottom: 1.5em;
}
.entry-content a {
	color: #63bd52;
}
.entry-content table {
	margin: 10px auto 20px;
	width: 100%;
}
.entry-content th,
.entry-content td {
	border: 1px solid #d2d2d2;
	padding: 10px 15px;
	background: #fff;
}
.entry-content th {
	background: #fafaf5;
	white-space: nowrap;
	text-align: center;
}


.wp-block-buttons {
	margin: 28px 0;
}

.wp-block-button__link {
	background: #f19149;
	color: #fff !important;
}

.wp-block-file a {
	display: inline-block;
	margin: 5px;
	padding: 10px 38px;
	min-height: 50px;
	min-width: 200px;
	background: #f19149;
	border: 1px solid #f19149;
	color: #fff !important;
	border-radius: 50px;
	font-size: 1.125rem;
	position: relative;
}

body.welfare .wp-block-file a {
	background: #44aee4;
	border: 1px solid #44aee4;
}

.wp-block-file a.wp-block-file__button {
	background: #fff;
	color: #f19149 !important;
}
.wp-block-button__link:hover,
.wp-block-file a:hover {
	text-decoration: none;
}

.wp-block-file a::after {
	content: "";
	background: #fff url("image/file_other.svg") no-repeat center center / 20px 20px;
	display: inline-block;
	width: 24px;
	height: 24px;
	border-radius: 4px;
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -12px;
}
.wp-block-file a[href$=".pdf"]::after {
	background-image: url("image/file_pdf.svg");
}
.wp-block-file a[href$=".doc"]::after,
.wp-block-file a[href$=".docx"]::after {
	background-image: url("image/file_word.svg");
}
.wp-block-file a[href$=".xls"]::after,
.wp-block-file a[href$=".xlsx"]::after {
	background-image: url("image/file_excel.svg");
}
.wp-block-file a[href$=".zip"]::after {
	background-image: url("image/file_zip.svg");
}

.wp-block-embed__wrapper {
	position: relative;
	padding-top: 56.25%;
	height: 0;
	overflow: hidden;
}
.wp-block-embed__wrapper iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	border: none;
}


.wp-block-image {
	margin: 0 0 1em;
}

.wp-block-group.has-background {
	padding: 20px;
	margin: 20px 0;
}

.wp-block-file:not(.wp-element-button)  {
	font-size: 1em;
}

.wp-block-buttons {
	margin: 30px auto 30px;
}
.wp-block-button,
.wp-block-file {
	margin-top: 10px;
	margin-bottom: 10px;
}

/* ==============================================
    recaptcha
============================================== */
.grecaptcha-badge {
	margin-bottom: 130px;
}
@media screen and (max-width: 700px) {
	.grecaptcha-badge {
		margin-bottom: 70px;
	}
}
