@charset 'utf-8';


body:not(.expageheader):before {
	height: 60px;
}

@media only screen and (min-width: 769px) and (max-width: 1000px) {

	body:not(.nosticky):not(.expageheader):before {
		height: 60px;
	}
}

@media only screen and (min-width: 1001px) {

	body:before {
		height: 0 !important;
	}

	body:not(.fixed) #upper {
		border: none;
		background: transparent;
		position: relative;
	}

	body.fixed #upper {
		box-shadow: 0 1px 2px rgba(0,0,0,.2);
	}

	#headerelemnavi.elem {
		background: #009844;
	}

	#navitab > li > a {
		color: #fff;
	}

	#navitab > li > a.current,
	#navitab > li > a:hover {
		color: #9ee9c1;
	}

	body.detach:not(.fixed) #headerelemnavi.above #navitab .navilowercontents {
		top: auto;
		bottom: 60px;
	}

	body.detach:not(.fixed) #headerelemnavi.elem {
		margin: 0;
		padding: 0;
	}

	body.detach:not(.fixed) #navitab {
		transform: translateX(0);
	}
}



#mainvisual {
	width: 100%;
	background-image: url(../image/portal/AdobeStock_581748377_Preview.jpeg);
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	overflow: hidden;
	position: relative;
}

#mainvisual > .inner {
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
	text-align: center;
	vertical-align: top;
	position: relative;
}

#promotion {
	width: 100%;
	max-width: 1600px;
	margin: 0 auto;
	text-align: center;
	z-index: 10;
}

#pr_media {
	width: 100%;
	max-width: 800px;
	margin: 0 auto;
	padding-top: 100%;
	overflow: hidden;
	position: relative;
	z-index: 10;
}

#tagline {
	display: flex;
	align-items: flex-start;
	justify-content: center;
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

#tagline .cover {
	width: 100%;
	margin-top: 5%;
	padding: 20px;
}

#tagline h1 {
	margin-bottom: .3em;
	color: #fff;
	font-size: 6.5vw;
	font-weight: 700;
	line-height: 1.4;
	text-shadow: 2px 2px 0 rgba(0,0,0,.6);
	text-align: left;
}

#tagline h1 span {
	display: block;
	letter-spacing: .2em;
}

#tagline p {
	color: #fff;
	font-size: 3.5vw;
	line-height: 1.5;
}

#tagline p:not(:last-child) {
	margin-bottom: 1.5em;
}

#tagline p span {
	display: block;
}

@media only screen and (min-width: 481px) {

	#pr_media {
		padding-top: 90%;
	}

	#tagline h1 {
		font-size: 6.5vw;
	}

	#tagline p {
		font-size: 2.5vw;
	}
}

@media only screen and (min-width: 541px) {

	#pr_media {
		padding-top: 75%;
	}

	#tagline h1 {
		font-size: 32px;
	}

	#tagline h1 span {
		display: inline-block;
		letter-spacing: .5em;
/* 		text-indent: .5em; */
	}

	#tagline p {
		font-size: 14px;
	}

	#tagline p span {
		display: inline-block;
	}

	#tagline p > span {
		display: block;
	}
}

@media only screen and (min-width: 769px) {

	#mainvisual {
		background-position: center 90%;
		background-size: cover;
	}

	#pr_media {
		padding-top: 55%;
	}

	#tagline .cover {
		margin-top: 20%;
	}

	#tagline h1 {
		text-align: center;
		font-size: 42px;
	}
}

@media only screen and (min-width: 1001px) {

	#mainvisual {
		background-position: center 90%;
		background-size: cover;
		transform: translateY(-60px);
		position: absolute;
		top: 0;
		left: 0;
	}

	#tagline .cover {
		align-items: center;
	}

	#tagline .cover {
		display: flex;
		flex-direction: column;
		justify-content: center;
		align-items: center;
		height: 100%;
		margin: 0;
		padding-top: 120px;
	}

	#tagline h1 {
		font-size: 48px;
	}

	#pr_media {
		padding-top: calc(180px + 35%);
	}

	#headerelemnavi {
		top: 35vw;
	}
}

@media only screen and (min-width: 1201px) {

	#mainvisual {
		background-position: center 60%;
	}

	#pr_media {
		padding-top: 600px;
	}

	#headerelemnavi {
		top: 420px;
	}
}

@media only screen and (min-width: 1601px) {
}



.contentblock .btnarea {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	padding: 0;
}

.contentblock .btnarea > div {
	width: 100%;
	max-width: 420px;
	padding: 5px 0;
}

.contentblock .btnarea a {
	width: 100%;
}



#specialmenu {
	position: relative;
	border-top: 1px solid #ef9522;
	border-bottom: 1px solid #ef9522;
	background: #ffe7da;
	color: #000;
}

#specialmenu > .inner {
	max-width: 800px;
	margin: 0 auto;
	padding: 20px;
	padding-top: 40px;
	position: relative;
}

body.safearea #specialmenu > .inner {
	padding-left: calc(env(safe-area-inset-left) + 20px);
	padding-right: calc(env(safe-area-inset-right) + 20px);
}

/* 
#specialmenu > .inner:after {
	content: "what's new";
	padding: .5em;
	background: #b2918d;
	color: #fff;
	font-size: 14px;
	font-weight: 700;
	position: absolute;
	top: 0;
	left: 0;
}

body.safearea #specialmenu > .inner:after {
	left: env(safe-area-inset-left);
}
 */

#specialmenu .brick {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	font-size: 1.8em;
	line-height: 1.5;
	text-align: center;
}

#specialmenu .brick:before {
	content: "Web Coupon!";
	padding: .5em;
	background: #ef9522;
	color: #fff;
	font-size: 14px;
	font-weight: 700;
	white-space: nowrap;
	position: absolute;
	top: 0;
	left: 0;
}

body.safearea #specialmenu .brick:before {
	left: env(safe-area-inset-left);
}

#specialmenu .brick h2 {
	font-size: 1em;
	font-weight: 700;
	line-height: 1.4;
}

#specialmenu .brick .btnarea a {
	background: #fff;
	color: #ef9522;
	white-space: nowrap
}

#specialmenu .brick .sentence {
	margin-bottom: 1em;
}

@media only screen and (min-width: 481px) {

	#specialmenu > .inner {
		padding-top: 20px;
	}

	#specialmenu .brick {
		flex-direction: row;
	}

	#specialmenu .brick:before {
		position: relative;
		top: auto;
		left: auto;
	}

	body.safearea #specialmenu .brick:before {
		left: auto;
	}

	#specialmenu .brick .btnarea a {
		padding: .7em 1.2em !important;
	}

	#specialmenu .brick .sentence {
		margin-bottom: 0;
		padding: 0 1em;
		flex-grow: 1;
	}
}

@media only screen and (min-width: 481px) {

	#specialmenu .brick h2 {
		font-size: 1.2em;
	}
}


#message {
	width: 100%;
	background: rgba(0,152,68,.1);
	position: relative;
}

#message > .inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 30px 20px;
	position: relative;
}

#message .brick {
	width: 100%;
	margin: 0 auto;
	padding: 30px 20px;
	/*background: rgba(255,255,255,.8);*/
}

#message header {
}

#message header h1 {
}

#message header h1 span {
}

#message .sentence {
	margin-bottom: 2em;
	font-size: 1.6em;
	text-align: center;
	line-height: 1.8;
}

#message .sentence span,
#message .sentence strong {
	display: inline-block;
}

#message .sentence strong {
	color: #000;
	font-size: 1.1em;
	font-weight: 700;
/* 	background:rgba(0, 0, 0, 0) linear-gradient(transparent 90%, #00a6bf 0%) repeat scroll 0 0; */
}

#message .sentence h2 {
	margin-bottom: 1.5em;
	font-size: 1.4em;
	font-weight: 400;
	line-height: 1.4;
}

#message .sentence h2 span {
	display: block;
}

#message .sentence h2 small {
	display: block;
	font-size: .65em;
}

#message .sentence p:not(:last-child) {
	margin-bottom: 1em;
}

@media only screen and (min-width: 641px) {

	#message > .inner {
		padding: 80px 20px;
		padding-top: 40px;
	}

	body.safearea #message > .inner {
		padding-left: calc(env(safe-area-inset-left) + 20px);
		padding-right: calc(env(safe-area-inset-right) + 20px);
	}

	#message .brick {
	}
}

@media only screen and (min-width: 1001px) {

	#message {
		margin-top: 35%;
	}

	body.fixed #message {
		margin-top: calc(180px + 35% - 60px);
	}

	#message:before {
		content: '';
		width: 100%;
		height: 60px;
		background: #009844;
		position: absolute;
		left: 0;
		top: -60px;
	}
}

@media only screen and (min-width: 1201px) {

	#message {
		margin-top: 420px;
	}

	body.fixed #message {
		margin-top: calc(180px + 420px - 60px);
	}
}


#lead {
	width: 100%;
	margin: 30px auto;
	position: relative;
}

#lead .sentence {
	font-size: 2em;
	text-align: center;
	line-height: 1.8;
}

#lead .sentence p:not(:last-child) {
	margin-bottom: 1em;
}

#lead .sentence p span {
	display: inline-block;
}

#lead .sentence ul {
	list-style: none;
	margin-bottom: 1em;
}

#lead .sentence li {
	list-style: none;
	padding: .7em 1.2em;
	border-radius: 99px;
	background: #00662d;
	color: #fff;
	line-height: 1.6;
}

#lead .sentence li:not(:last-child) {
	margin-bottom: .2em;
}

#lead .sentence li span {
	display: inline-block;
}

#lead .sentence figure {
	margin-bottom: 1em;
}

#lead .sentence figure img {
	width: 100%;
	height: auto;
}



#bureau {
	background: #fff;
	position: relative;
}

#bureau #information {
	width: 100%;
	height: auto;
	position: relative;
}

#bureau #information > .inner {
	max-width: none !important;
	margin: 0 auto;
	position: relative;
}

/* 
#bureau #information .articlelistblock {
	max-width: none;
}

#information .articlelist .item {
	width: 100%;
	background: #fff;
}

#information .articlelist .item .desc {
	display: block;
	color: #000;
	font-size: .9em;
}

@media only screen and (min-width: 541px) {

	#information .articlelist .item {
		width: calc(100% / 2);
		padding: 1.5% !important;
		background: none;
	}

	#information .articlelist.card .item article {
	}

	#information .articlelist.card .item.hover article {
		background: #f2f2f2;
	}
}

@media only screen and (min-width: 769px) {

	#bureau #information {
	}

	#information .articlelist .item .enclosed {
		font-size: 1.4em;
	}
}

@media only screen and (min-width: 1001px) {

	#bureau #information {
	}

	#information .articlelist .item {
		width: calc(100% / 4);
	}
}
 */





#discount {
	background: #eee0e3;
	position: relative;
}

#discount > .inner {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

body.safearea #course > .inner {
	padding-left: calc(env(safe-area-inset-left) + 20px);
	padding-right: calc(env(safe-area-inset-right) + 20px);
}


#discountitems {
	width: 100%;
	display: flex;
	flex-direction: row;
	justify-content: flex-start;
	flex-wrap: wrap;
	margin-bottom: -20%;
	text-align: center;
	position: relative;
}

#discountitems .item {
	display: flex;
	width: 50%;
	max-width: 260px;
	margin: 0 auto;
	padding: 5px;
	transform: translateY(-50%);
}

#discountitems .item a {
	display: block;
	width: 100%;
	color: #000;
}

#discountitems .item a:hover,
#discountitems .item a.hover {
	text-decoration: none;
}

#discountitems .item .inner {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: 100%;
	padding: 5px;
}

#discountitems figure {
	width: 100%;
	position: relative;
}

#discountitems figure img {
	width: 100%;
	height: auto;
}

#discountitems figure .foto {
	display: block;
	width: 100%;
	border-radius: 50%;
	background: #df7e93;
	overflow: hidden;
	transition: .4s;
}

#discountitems a:hover figure .foto,
#discountitems a.hover figure .foto {
	/*transform: rotate(20deg) scale(1.1);*/
	transform: scale(1.1);
}

#discountitems figure .badge {
	display: inline-block;
	padding: .8em 1.2em;
	border-radius: 99px;
	background: #00662d;
	color: #fff;
	font-size: 16px;
	line-height: 1;
	position: absolute;
	top: 7%;
	left: 0;
}


#discountitems h2 {
	padding-bottom: .5em;
	font-size: 2em;
	line-height: 1.4;
	font-weight: 700;
	text-decoration: none;
}

#discountitems p {
	font-size: 1.6em;
	line-height: 1.6;
}

#discountitems h2 span,
#discountitems p span {
	display: inline-block;
}

@media only screen and (min-width: 541px) {

	#discountitems {
		margin-bottom: -15%;
	}

	#discountitems .item {
		width: 33.33%;
		max-width: 320px;
	}

	#discountitems .item .inner {
		padding: 15px;
	}
}


@media only screen and (min-width: 1001px) {

	#discountitems {
		margin-bottom: -12%;
	}

	#discountitems .item {
		width: 25%;
	}
}


#customersblock {
	width: 100%;
	padding: 50px 20px;
	background-color: #fff;
	background-image: url(../image/portal/back-customersblock.jpg);
	background-repeat: no-repeat;
	background-position: center center;
	background-size: cover;
	position: relative;
}

#customersblock:before {
	content: '';
	width: 100%;
	background: #fff;
	opacity: .7;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
}

#customersblock .blockheader {
	margin-bottom: 30px;
}

@media only screen and (min-width: 769px) {

	#customersblock {
		padding: 80px 20px;
	}
}

#customersblock .flickity-prev-next-button.previous { left: -10px; }
#customersblock .flickity-prev-next-button.next { right: -10px; }

@media only screen and (min-width: 1001px) {

	#customersblock .flickity-prev-next-button.previous { left: -44px; }
	#customersblock .flickity-prev-next-button.next { right: -44px; }
}


#newslists {
	width: 100%;
	background: #fff;
	position: relative;
}

#newslists > .inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 30px 0;
	position: relative;
}

body.safearea #newslists .blockheader {
	padding-left: env(safe-area-inset-left);
	padding-right: env(safe-area-inset-right);
}

#newslistsection {
	width: 100%;
	height: auto;
	position: relative;
}

#newslistsection .newslists {
	width: 100%;
	opacity: 0;
	position: absolute;
	top: 0;
	left: 0;
}

#newslistsection .newslists.open {
	opacity: 1;
	position: relative;
	z-index: 10;
}

#newslists .newslists .articlelistblock {
	max-width: 900px;
	margin: 0 auto;
}

#newslists .btnarea {
	padding: 0 20px;
}

@media only screen and (min-width: 541px) {

	#newslists > .inner {
		padding: 30px 20px;
	}

	body.safearea #newslists > .inner {
		padding-left: calc(env(safe-area-inset-left) + 20px);
		padding-right: calc(env(safe-area-inset-right) + 20px);
	}
}

@media only screen and (min-width: 769px) {

	#newslists > .inner {
		padding: 50px 20px;
	}
}



.newslists .articlelist {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
/* 	margin-bottom: 30px; */
	padding: 0;
	position: relative;
}

.newslists .articlelist .item {
	display: flex;
	width: 100%;
	vertical-align: top;
	position: relative;
	cursor: pointer;
}

.newslists .articlelist .item > .inner {
	display: flex;
	width: 100%;
	position: relative;
	transition: .2s;
}

.newslists .articlelist .item article {
	display: flex;
	width: 100%;
	overflow: hidden;
	position: relative;
	z-index: 1;
}

.newslists .articlelist .item .enclosed {
	font-size: 1.2em;
}

.newslists .articlelist .item .title {
	width: 100%;
	margin: .3em 0;
	font-size: 1.4em;
	font-weight: 700;
	line-height: 1.5;
	word-wrap: break-word;
	overflow: hidden;
}

.newslists .articlelist .item .title a {
	color: #000;
	text-decoration: none;
}

.newslists .articlelist .meta {
	margin: .3em 0;
	margin-right: 1em;
	line-height: 1.4;
}

.newslists .articlelist .category span {
	display: inline-block;
}

.newslists .articlelist .category span {
	display: inline-block;
	margin-right: .3em;
	margin-bottom: .3em;
}

.newslists .articlelist .category span a {
	display: inline-block;
	padding: .5em 1em;
	background: #666;
	color: #fff;
	text-decoration: none;
}

.newslists .articlelist .category span a:hover,
.newslists .articlelist .category span a.hover {
	background: #999;
}

.newslists .articlelist time {
	color: #808080;
}

.newslists .articlelist .item .desc {
	display: none;
	color: #666;
	font-size: 1.1em;
	line-height: 1.6;
	word-wrap: break-word;
}

.newslists .articlelist .item .arrow {
	display: block;
	height: 100%;
	font-size: 0;
	position: absolute;
	top: 0;
	right: 10px;
}

.newslists .articlelist .item .arrow:before {
	display: inline-block;
	content: '';
	height: 100%;
	vertical-align: middle;
}

.newslists .articlelist .item .icon {
	display: inline-block;
	width: 32px;
	height: 32px;
	color: #808080;
	vertical-align: middle;
	transform: rotate(-90deg);
}

.newslists .articlelist .item .icon span {
	display: inline-block;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: .2s;
}

.newslists .articlelist .item.hover .icon span {
	opacity: 1;
	transform: translateY(10px);
}

.newslists .articlelist .item .icon svg {
	fill: currentColor;
}

.newslists .articlelist .item .btn {
	width: 100%;
	padding: 5%;
	font-size: 1.2em;
	line-height: 1;
	text-align: right;
}

.newslists .articlelist .item .btn a {
	display: inline-block;
	padding: .5em 1em;
	border: 1px solid;
	text-decoration: none;
}

.newslists .articlelist .item .btn a:hover,
.newslists .articlelist .item .btn a.hover {
	background: #f2f2f2;
}

.newslists .articlelist .item .thumb {
	width: 100%;
	overflow: hidden;
	position: relative;
}

.newslists .articlelist .item figure {
	width: 100%;
	margin-top: 0;
	padding-top: 60%;
	overflow: hidden;
	position: relative;
	z-index: 1;
}

.newslists .articlelist .item .enclosed figure {
	margin: .5em 0;
}

.newslists .articlelist .item figure span {
	display: block;
	width: 100%;
	transform: translateY(-50%);
	overflow: hidden;
	position: absolute;
	top: 50%;
	left: 0;
}

.newslists .articlelist .item figure img {
	width: 100%;
	height: auto;
	position: relative;
	transition: .2s;
}

/* override */
.newslists .articlelist .item {
	border-bottom: 1px solid #ccc;
}

.newslists .articlelist .item:first-child {
	border-top: 1px solid #ccc;
}

.newslists .articlelist .item article {
	padding: 15px 20px;
}

.newslists .articlelist.thumb .item .enclosed {
	width: 80%;
	padding-left: 7%;
}

.newslists .articlelist.arrowicon .item .enclosed {
	width: 100%;
	padding-right: 15px;
}

.newslists .articlelist.card.thumb:not(.arrowicon) .item {
	padding: 3% 7%;
	border: none;
}

.newslists .articlelist.card.thumb:not(.arrowicon) .item article {
	padding: 2%;
	border-radius: 0;
	background: #fff;
	box-shadow: 0 1px 3px rgba(0,0,0,.2);
	transition: .2s;
}

.newslists .articlelist.card.thumb:not(.arrowicon) .item .enclosed {
	width: 100%;
	padding: 5%;
}

.newslists .articlelist .category span a {
	border-radius: 0;
}

.newslists .articlelist .item .btn a {
	border-radius: 0;
}

.newslists .articlelist .item .thumb {
	width: 20%;
}

.newslists .articlelist .item .enclosed .thumb {
	width: 100%;
}

.newslists .articlelist .item figure {
	border-radius: 0;
	padding-top: 100%;
}

.newslists .articlelist .item .enclosed figure {
	padding-top: 60%;
}

.newslists .articlelist.card .item.hover figure img {
	transform: scale(1.3);
}

.newslists .articlelist .item .title {
	font-size: 1.2em;
	overflow: hidden;
}

.newslists .articlelist .item .title a {
	display: block;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

@media only screen and (min-width: 541px) {

	.newslists .articlelist.card {
		padding: 1%;
	}

	.newslists .articlelist.card .item {
		padding: 1.5% !important;
		border: none;
	}

	.newslists .articlelist.card .item article {
		display: block;
		padding: 0 !important;
		border-radius: 0;
		background: #fff;
		box-shadow: 0 1px 3px rgba(0,0,0,.2);
		transition: .2s;
	}

	.newslists .articlelist.card .item.hover article {
		background: #f2f2f2;
	}

	.newslists .articlelist.card .item .enclosed {
		width: 100%;
		padding: 7% !important;
	}

	.newslists .articlelist .item .desc {
		display: block;
	}

	.newslists .articlelist .item .title {
		font-size: 1.4em;
	}

	.newslists .articlelist.card .item.hover .icon span {
		opacity: 0;
		transform: translateY(0);
	}

	.newslists .articlelist.card .item .btn {
		text-align: center;
	}

	.newslists .articlelist.card .item figure {
		padding-top: 60%;
	}

	.newslists .articlelist.card .item figure {
		border-radius: 0 !important;
	}

	.newslists .articlelist.card .item .thumb {
		width: 100%;
	}
}


.newslists .articlelist .viewport {
	width: 100%;
	overflow: hidden;
	position: relative;
}


.newslists .articlelist .item {
	border-bottom-color:  #91ebb9;
}

.newslists .articlelist .item:first-child {
	border-top: none;
}

.newslists .articlelist .item article {
	font-size: .85em;
}

.newslists .articlelist .item .enclosed {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: flex-start;
	font-size: 1.4em;
}

.newslists .articlelist .item .custommeta {
	margin: .3em 0;
	font-size: .85em;
}

.newslists .articlelist .item .articletag span {
	display: inline-block;
	padding: .3em 1.2em;
	background: #df7e93;
	color: #fff;
	font-size: 1.2em;
	text-align: center;
	line-height: 1;
	white-space: nowrap;
}

.newslists .articlelist .item .articletag span.news {
	background: #7faecc;
}

.newslists .articlelist .item .articletag span.event {
	background: #3dcb7c;
}

.newslists .articlelist .item .articletag span.medical {
	background: #ac8ff2;
}

.newslists .articlelist .item .articletag span.nursing {
	background: #58a6e0;
}

.newslists .articlelist .item .articletag span.pharmacy {
	background: #51cced;
}

.newslists .articlelist .item .articletag span.high-school {
	background: #36c18f;
}

.newslists .articlelist .item .articletag span.peace {
	background: #9ace49;
}

.newslists .articlelist .item .articletag span.other {
	background: #9a9a9a;
}

@media only screen and (min-width: 541px) {

}

@media only screen and (min-width: 769px) {

	.newslists .articlelist .item article {
		padding: 20px;
		font-size: 1.1em;
	}

	.newslists .articlelist .item .enclosed {
		flex-direction: row;
		font-size: 1.2em;
	}

	.newslists .articlelist .item .meta {
		width: 9em;
		margin: 0;
		white-space: nowrap;
	}

	.newslists .articlelist .item .custommeta {
		width: 15em;
		margin: 0;
		padding-right: 2em;
	}

	.newslists .articlelist .item  .articletag span {
		width: 100%;
	}

	.newslists .articlelist .item .title {
		flex-grow: 1;
		width: calc(100% - 19em);
		margin: 0;
	}

/* 
	#news-general .newslists .articlelist .item .title {
		width: calc(100% - (15em));
	}
 */
}

.categorynavi {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: 2em;
}

.categorynavi > div {
	width: 160px;
	padding: 3px;
	font-size: 1.4em;
}

.categorynavi > div > a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
	padding: .5em;
	background: #ccc;
	color: #fff;
	font-weight: 700;
	text-decoration: none;
}

.categorynavi > div.medical > a {
	background: #ac8ff2;
}

.categorynavi > div.medical > a:hover,
.categorynavi > div.medical > a.hover {
	background: #d8b7ff;
}

.categorynavi > div.nursing > a {
	background: #58a6e0;
}

.categorynavi > div.nursing > a:hover,
.categorynavi > div.nursing > a.hover {
	background: #92c2e6;
}

.categorynavi > div.pharmacy > a {
	background: #51cced;
}

.categorynavi > div.pharmacy > a:hover,
.categorynavi > div.pharmacy > a.hover {
	background: #81dcf4;
}

.categorynavi > div.high-school > a {
	background: #36c18f;
}

.categorynavi > div.high-school > a:hover,
.categorynavi > div.high-school > a.hover {
	background: #68d1ab;
}

.categorynavi > div.peace > a {
	background: #9ace49;
}

.categorynavi > div.peace > a:hover,
.categorynavi > div.peace > a.hover {
	background: #b5db7a;
}



#jobfairlist {
	width: 100%;
	background: rgba(236,228,121,.1);
	position: relative;
}

#jobfairlist > .inner {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 30px 20px;
	position: relative;
}

body.safearea #jobfairlist > .inner {
	padding-left: calc(env(safe-area-inset-left) + 20px);
	padding-right: calc(env(safe-area-inset-right) + 20px);
}

#jobfairlist .btnarea a {
	color: #c5bc4c;
}

@media only screen and (min-width: 769px) {

	#jobfairlist > .inner {
		padding-top: 50px;
		padding-bottom: 50px;
	}
}


.jobfairlistblock {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	margin-bottom: 30px;
	position: relative;
}

.jobfairlistblock .item {
	display: flex;
	width: 100%;
	max-width: 400px;
	padding: 15px;
	font-size: 1.4em;
	line-height: 1.6;
	position: relative;
}

.jobfairlistblock .item > .inner {
	display: flex;
	flex-direction: column;
	width: 100%;
	position: relative;
}

.jobfairlistblock .item .cover {
	height: 100%;
	padding: 1.5em;
	background: rgba(236,228,121,.3);
}

.jobfairlistblock .item .line {
	display: flex;
	border-bottom: 1px solid;
}

.jobfairlistblock .item .line .head {
	width: 4em;
	padding: .7em 0 .5em 0;
	font-weight: 700;
}

.jobfairlistblock .item .line .spec {
	width: calc(100% - 4em);
	padding: .7em 1em .5em 0;
}

.jobfairlistblock .item .itemtab {
	width: 55%;
	padding: .3em 1em;
	background: #ece479;
	font-weight: 700;
}


@media only screen and (min-width: 1001px) {

	.jobfairlistblock .item {
		width: 33.333%;
	}
}


