@charset "UTF-8";

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

  edit

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

.pbPage.c-normal-page .c-header-area,
.pbPage.c-normal-page .c-main-area,
.pbPage.c-normal-page .c-footer-area {
	padding: 0!important;
}
main > .g-nest-block {
	outline: none!important;
	box-shadow: none!important;
}
.g-block-area:hover,
.g-block-area:focus {
	box-shadow: none!important;
}
.g-move-block-area {
	width: auto!important;
	margin: auto!important;
	color: #fff!important;
	letter-spacing: normal!important;
	font-weight: normal!important;
}

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

  base

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

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
	vertical-align: top;
}
.pbPage,
.cp-component-edit {
	position: relative;
	min-height: 100vh;
	-webkit-text-size-adjust: 100%;
	-webkit-print-color-adjust: exact;
	background: #fff;
	font-family: 'Roboto','Noto Sans JP','メイリオ',Meiryo, sans-serif;
	color: #000;
	font-weight: 500;
	font-size: 90%;
	line-height: 1.8;
	word-break: break-all;
}

@media screen and (max-width: 1024px) {
	body.open {
		overflow: hidden;
	}
}

@media screen and (max-width: 1100px) {
	.pbPage {
		overflow: hidden;
	}
}

@media screen and (max-width: 767px) {
	.pbPage,
	.cp-component-edit {
		font-size: 80%;
	}
}

/*  title
------------------------------------------------*/

h1,
h2,
h3,
h4 {
	font-weight: inherit;
	font-size: inherit;
}

/*  link
------------------------------------------------*/

a {
	color: inherit;
	transition: all .3s;
	text-decoration: underline;
	-webkit-tap-highlight-color:rgba(0,0,0,0);
}
a img {
	transition: all .8s;
}

@media (min-width: 768px) {
	a:hover {
		text-decoration: none;
	}
}

/*  list
------------------------------------------------*/

ol,
ul {
	list-style: none;
}

/*  img
------------------------------------------------*/

img {
	max-width: 100%;
	height: auto;
}

/*  table
------------------------------------------------*/

table {
	max-width: 100%;
	border-collapse: collapse;
	border-spacing: 0;
	border: none;
}

/*  form
------------------------------------------------*/

:focus {
	outline: none;
}

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

  utility

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

.u_left {
	text-align: left!important;
}
.u_center {
	text-align: center!important;
}
.u_right {
	text-align: right!important;
}
.u_mt0 {
	margin-top: 0!important;
}
.u_mt10 {
	margin-top: 10px!important;
}
.u_mt20 {
	margin-top: 20px!important;
}
.u_mt30 {
	margin-top: 30px!important;
}
.u_mt40 {
	margin-top: 40px!important;
}
.u_mt50 {
	margin-top: 50px!important;
}

@media print, screen and (min-width: 768px) {
	.u_sp {
		display: none!important;
	}
	.u_pc-center {
		text-align: center!important;
	}
}

@media screen and (max-width: 767px) {
	.u_pc {
		display: none!important;
	}
	.u_pc-center br {
		display: none;
	}
}

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

  area

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

/*  header CONNECT
========================================================================*/

.header {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: space-between;
}
.header:before {
	content: '';
	position: absolute;
	bottom: -8px;
	left: 0;
	width: 100%;
	height: 8px;
	background: linear-gradient(to bottom,  rgba(0,0,0,.08) 0%,rgba(0,0,0,0) 100%);
	transition: all .3s;
}
.header a {
	text-decoration: none;
}

@media screen and (max-width: 1100px) {
	.header {
		padding-left: 15px;
	}
}

/*  logo
------------------------------------------------*/

.header .logo {
	width: 340px;
	margin-left: 20px;
}
.header .logo img {
	display: block;
}

@media screen and (max-width: 1100px) {
	.header .logo {
		width: 250px;
		margin-left: 0;
	}
}
	
/*  nav
------------------------------------------------*/

.header nav {
	display: flex;
}
.header .list {
	display: flex;
}
.header .item {
	position: relative;
}
.header .item-title,
.header .item-link {
	height: 100%;
}
.header .item-title a,
.header .item-link a {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	height: 100%;
	padding: 0 15px;
	font-size: 120%;
	text-align: center;
	letter-spacing: 1px;
	line-height: 1.4;
}
.header .item-title span,
.header .item-link span {
	color: #666;
	font-size: 60%;
	font-weight: normal;
	transition: all .3s;
}
@media (min-width: 1101px) {
	.header .item:hover .item-title a,
	.header .item:hover .item-link a,
	.header .item:hover .item-title span,
	.header .item:hover .item-link span {
		color: #ef6132;
	}
}
.header .item-menu {
	visibility: hidden;
	opacity: 0;
	position: absolute;
	z-index: 1000;
	left: 50%;
	padding: 20px;
	background: rgba(0,63,142,.9);
	background: rgba(0,0,0,.9);
	white-space: nowrap;
	font-size: 90%;
	transition: all .3s;
	transform: translateX(-50%) rotateX(90deg);
	transform-origin: left top;
}
@media (min-width: 1101px) {
	.header .item:hover .item-menu {
		visibility: visible;
		opacity: 1;
		transform: translateX(-50%);
	}
}
.header .item-menu li:not(:first-child) {
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px solid #666;
}
.header .item-menu a {
	display: block;
	padding: 0 10px;
	color: #fff;
}
@media (min-width: 1101px) {
	.header .item-menu a:hover {
		color: #ef6132;
	}
}

@media screen and (max-width: 1100px) {
	.header nav {
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		position: absolute;
		top: 0;
		left: 100%;
		z-index: 3;
		flex-direction: column;
		width: 100%;
		height: 100vh;
		padding: 70px 30px 100px;
		background: rgba(0,0,0,.9);
		transition: all .3s;
	}
	body.open .header nav {
		left: 0;
	}
	.header .list {
		width: 100%;
		flex-direction: column;
	}
	.header .item-title,
	.header .item-link {
		color: #ef6132;
		border-bottom: 1px solid #666;
	}
	.header .item-title,
	.header .item-link {
		height: auto;
	}
	.header .item-title a,
	.header .item-link a {
		padding: 10px 0;
		color: #fff;
	}
	.header .item-title span,
	.header .item-link span {
		color: #999;
	}
	.header .item-menu {
		visibility: visible;
		opacity: 1;
		position: static;
		padding: 15px 0;
		background: none;
		font-size: 100%;
		transform: none;
		border-bottom: 1px solid #666;
	}
	.header .item-menu ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.header .item-menu li,
	.header .item-menu li:not(:first-child) {
		margin: 3px 10px;
	}
	.header .item-menu li:not(:first-child) {
		padding-top: 0;
		border-top: none;
	}
	.header .item-menu li a {
		padding: 0;
	}
}

/*  button
------------------------------------------------*/

.header .button {
	margin-left: 20px;
	padding: 25px 30px;
	background: #003F8E;
	font-size: 85%;
}
.header .button ul {
	display: flex;
}
.header .button li:not(:first-child) {
	margin-left: 10px;
}
.header .button a {
	display: inline-block;
	color: #fff;
}
@media (min-width: 1101px) {
	.header .button a:hover {
		color: #ef6132;
	}
}
.header .button i:only-child {
	width: 2em;
	height: 2em;
	line-height: 2em;
	background: #fff;
	color: #003F8E;
	border-radius: 50%;
	text-align: center;
	transition: all .3s;
}
@media (min-width: 1101px) {
	.header .button i:only-child:hover {
		background: #ef6132;
	}
}
.header .button i:not(:only-child) {
	margin-left: 10px;
	font-size: 140%;
	vertical-align: middle;
}
.header .button span {
	margin-left: 10px;
	padding-left: 10px;
	border-left: 1px dotted;
	line-height: 1;
	vertical-align: middle;
}

@media screen and (max-width: 1100px) {
	.header .button {
		width: 100%;
		margin: 50px 0 0;
		padding: 20px;
		font-size: 100%;
	}
	.header .button ul {
		justify-content: center;
	}
}

/*  sp-menu
------------------------------------------------*/

.header .sp-menu {
	display: none;
	position: relative;
	top: 0;
	right: 0;
	z-index: 4;
	width: 50px;
	height: 50px;
}
.header .sp-menu span {
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	width: 20px;
	height: 2px;
	background: #003F8E;
}
.header .sp-menu span:nth-of-type(1) {
	top: 17px;
}
.header .sp-menu span:nth-of-type(2) {
	top: 24px;
}
.header .sp-menu span:nth-of-type(3) {
	bottom: 17px;
}
body.open .header .sp-menu span:nth-of-type(1) {
	animation: open01 .75s forwards;
}
body.close .header .sp-menu span:nth-of-type(1) {
	animation: close01 .75s;
}
@keyframes open01 {
	0% {transform: translateY(0) rotate(0);}
	50% {transform: translateY(7px) rotate(0);}
	100% {transform: translateY(7px) rotate(45deg); background: #fff;}
}
@keyframes close01 {
	0% {transform: translateY(7px) rotate(45deg);}
	50% {transform: translateY(7px) rotate(0);}
	100% {transform: translateY(0) rotate(0);}
}
body.open .header .sp-menu span:nth-of-type(2) {
	opacity: 0;
}
body.open .header .sp-menu span:nth-of-type(3) {
	animation: open03 .75s forwards;
}
body.close .header .sp-menu span:nth-of-type(3) {
	animation: close03 .75s;
}
@keyframes open03 {
	0% {transform: translateY(0) rotate(0);}
	50% {transform: translateY(-7px) rotate(0);}
	100% {transform: translateY(-7px) rotate(-45deg); background: #fff;}
}
@keyframes close03 {
	0% {transform: translateY(-7px) rotate(-45deg);}
	50% {transform: translateY(-7px) rotate(0);}
	100% {transform: translateY(0) rotate(0);}
}

@media screen and (max-width: 1100px) {
	.header .sp-menu {
		display: block;
	}
}

/*  header SITE PUBLIS
========================================================================*/

.header-publis {
	display: flex;
	align-items: center;
	padding: 0 20px;
	background: #333;
}
.header-publis a {
	text-decoration: none;
}

@media screen and (max-width: 1100px) {
	.header-publis {
		padding: 0 0 0 15px;
	}
}

/*  logo
------------------------------------------------*/

.header-publis .logo {
	margin-right: 30px;
}
.header-publis .logo img {
	display: block;
}

@media screen and (max-width: 1100px) {
	.header-publis .logo {
		width: 160px;
	}
}
	
/*  nav
------------------------------------------------*/

.header-publis nav {
	flex-grow: 1;
	display: flex;
	align-items: center;
}
.header-publis .list {
	display: flex;
}
.header-publis .item {
	position: relative;
}
.header-publis .item-title a,
.header-publis .item-link a {
	position: relative;
	display: inline-block;
	padding: 17px 15px;
	color: #fff;
}
.header-publis .item-title a:before,
.header-publis .item-link a:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	left: 0;
	width: 6px;
	height: 6px;
	border-top: 2px solid #ef6132;
	border-right: 2px solid #ef6132;
	transform: rotate(45deg);
}
@media (min-width: 1101px) {
	.header-publis .item:hover .item-title a,
	.header-publis .item:hover .item-link a {
		color: #ef6132;
	}
}
.header-publis .item-menu {
	visibility: hidden;
	opacity: 0;
	position: absolute;
	z-index: 1000;
	left: 50%;
	padding: 20px;
	background: rgba(0,63,142,.9);
	background: rgba(0,0,0,.9);
	white-space: nowrap;
	font-size: 80%;
	transition: all .3s;
	transform: translateX(-50%) rotateX(90deg);
	transform-origin: left top;
}
@media (min-width: 1101px) {
	.header-publis .item:hover .item-menu {
		visibility: visible;
		opacity: 1;
		transform: translateX(-50%);
	}
}
.header-publis .item-menu li:not(:first-child) {
	margin-top: 8px;
	padding-top: 8px;
	border-top: 1px solid #666;
}
.header-publis .item-menu a {
	display: block;
	padding: 0 10px;
	color: #fff;
}
@media (min-width: 1001px) {
	.header-publis .item-menu a:hover {
		color: #ef6132;
	}
}

@media screen and (max-width: 1100px) {
	.header-publis nav {
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		position: absolute;
		top: 0;
		left: 100%;
		z-index: 3;
		flex-direction: column;
		width: 100%;
		height: 100vh;
		padding: 70px 30px 100px;
		background: rgba(0,0,0,.9);
		transition: all .3s;
	}
	body.open .header-publis nav {
		left: 0;
	}
	.header-publis .list {
		width: 100%;
		flex-direction: column;
	}
	.header-publis .item-title,
	.header-publis .item-link {
		color: #ef6132;
		border-bottom: 1px solid #666;
	}
	.header-publis .item-title a,
	.header-publis .item-link a {
		width: 100%;
		padding: 10px 0;
		color: #ef6132;
		text-align: center;
	}
	.header-publis .item-title a:before,
	.header-publis .item-link a:before {
		display: none;
	}
	.header-publis .item-menu {
		visibility: visible;
		opacity: 1;
		position: static;
		padding: 15px 0;
		background: none;
		font-size: 100%;
		transform: none;
		border-bottom: 1px solid #666;
	}
	.header-publis .item-menu ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: center;
	}
	.header-publis .item-menu li,
	.header-publis .item-menu li:not(:first-child) {
		margin: 3px 10px;
	}
	.header-publis .item-menu li:not(:first-child) {
		padding-top: 0;
		border-top: none;
	}
	.header-publis .item-menu li a {
		padding: 0;
	}
}

/*  button
------------------------------------------------*/

.header-publis .button {
	margin-left: auto;
}
.header-publis .button a {
	position: relative;
	display: inline-block;
	padding: 3px 20px 3px 30px;
	color: #fff;
	border: 1px solid #fff;
	border-radius: 30px;
	font-size: 90%;
}
.header-publis .button a:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	left: 15px;
	width: 6px;
	height: 6px;
	border-top: 2px solid #ef6132;
	border-right: 2px solid #ef6132;
	transform: rotate(45deg);
	transition: all .3s;
}
@media (min-width: 1101px) {
	.header-publis .button a:hover {
		background: #ef6132;
		border-color: #ef6132;
	}
	.header-publis .button a:hover:before {
		border-color: #fff;
	}
}

@media screen and (max-width: 1100px) {
	.header-publis .button {
		margin: 30px auto 0;
	}
}

/*  sp-menu
------------------------------------------------*/

.header-publis .sp-menu {
	display: none;
	position: relative;
	top: 0;
	right: 0;
	z-index: 4;
	width: 50px;
	height: 50px;
}
.header-publis .sp-menu span {
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	width: 20px;
	height: 2px;
	background: #fff;
}
.header-publis .sp-menu span:nth-of-type(1) {
	top: 17px;
}
.header-publis .sp-menu span:nth-of-type(2) {
	top: 24px;
}
.header-publis .sp-menu span:nth-of-type(3) {
	bottom: 17px;
}
body.open .header-publis .sp-menu span:nth-of-type(1) {
	animation: open01 .75s forwards;
}
body.close .header-publis .sp-menu span:nth-of-type(1) {
	animation: close01 .75s;
}
body.open .header-publis .sp-menu span:nth-of-type(2) {
	opacity: 0;
}
body.open .header-publis .sp-menu span:nth-of-type(3) {
	animation: open03 .75s forwards;
}
body.close .header-publis .sp-menu span:nth-of-type(3) {
	animation: close03 .75s;
}

@media screen and (max-width: 1100px) {
	.header-publis .sp-menu {
		display: block;
		margin-left: auto;
	}
}

/*  footer
========================================================================*/

/*  contact
------------------------------------------------*/

.footer-contact {
	padding: 80px 10px 100px;
	background: url(../img/common/bg_contact.jpg) no-repeat center / cover;
	background-attachment: fixed;
	color: #fff;
	text-align: center;
}
.footer-contact .title {
	font-size: 130%;
}
.footer-contact .button {
	margin-top: 20px;
}
.footer-contact .button a {
	display: inline-block;
	width: 100%;
	max-width: 600px;
	padding: 18px;
	color: #fff;
	font-size: 120%;
	border: 1px solid #fff;
	border-radius: 50px;
	text-decoration: none;
}
.footer-contact .button a:before {
	content: '';
	display: inline-block;
	margin: 0 12px 3px 0;
	width: .4em;
	height: .4em;
	border-top: 2px solid #fff;
	border-right: 2px solid #fff;
	transform: rotate(45deg);
}
@media (min-width: 1101px) {
	.footer-contact .button a:hover {
		background: #003F8E;
		border-color: #003F8E;
	}
	.footer-contact .button a:hover:before {
		border-color: #fff;
	}
}

@media screen and (max-width: 1100px) {
	.footer-contact {
		padding: 30px 15px;
		background-attachment: scroll;
	}
	.footer-contact .title {
		font-size: 110%;
	}
	.footer-contact .button a {
		max-width: 400px;
		padding: 10px;
		font-size: 110%;
	}
	.footer-contact .button a:before {
		margin: 0 11px 1px 0;
	}
}

/*  footer
------------------------------------------------*/

.footer {
	display: flex;
	align-items: center;
	margin: 0 auto;
	padding: 25px 20px;
	background: #000;
	color: #fff;
}
.footer a {
	color: #fff;
	text-decoration: none;
}
@media (min-width: 1101px) {
	.footer a:hover {
		text-decoration: underline;
	}
}
.footer .list {
	margin-left: 50px;
}
.footer .list ul {
	display: flex;
	align-items: center;
}
.footer .list li:not(:first-child) {
	margin-left: 20px;
}
.footer .copy {
	margin-left: auto;
}

@media screen and (max-width: 1100px) {
	.footer {
		flex-direction: column;
		padding: 30px 0 20px;
	}
	.footer .list {
		margin: 15px 0 0;
	}
	.footer .copy {
		margin: 30px 0 0;
		font-size: 10px;
	}
}

/*  layout
========================================================================*/

body.l_single #leftArea,
body.l_single #rightArea,
body.l_left #rightArea,
body.l_right #leftArea {
	display: none;
}
body.l_left .pbAreaWrapper1,
body.l_right .pbAreaWrapper1 {
	justify-content: space-between;
	width: calc(100% - 30px);
	max-width: 1200px;
	margin: 0 auto;
	padding: 70px 0 150px;
}
body.l_left .pbAreaWrapper2,
body.l_right .pbAreaWrapper2 {
	width: calc(100% - 300px);
}
.pbLeftArea,
.pbRightArea {
	width: 250px;
}

@media screen and (max-width: 1100px) {
	body.l_left .pbAreaWrapper1,
	body.l_right .pbAreaWrapper1 {
		flex-direction: column;
		padding: 40px 0;
	}
	body.l_left .pbAreaWrapper2,
	body.l_right .pbAreaWrapper2 {
		width:100%;
	}
	.pbLeftArea,
	.pbRightArea {
		order: 1;
		width:100%;
	}
}

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

  component

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

.c_component:not(:first-child) {
	margin-top: 70px;
}
.c_component + div {
	margin-top: 15px;
}
.c_component > div:first-child {
	position: relative;
	overflow: visible;
	padding: 30px 25px 20px;
	background: #f0f7ff;
	color: #5b8bd0;
	font-size: 110%;
	font-weight: bold;
	border: dashed 2px #5b8bd0;
	border-radius: 5px;
}
.c_component > div:first-child:before {
	content: 'ONE POINT';
	position: absolute;
	top: -15px;
	left: 10px;
	padding: 1px 15px;
	background: #5b8bd0;
	color: #fff;
	font-weight: normal;
}
.c_component li {
	position: relative;
	padding-left: 20px;
}
.c_component li:before {
	content: '▼';
	position: absolute;
	top: 0;
	left: 0;
	color: #5b8bd0;
}

.c_component.check:not(:first-child) {
	margin-top: 30px;
}
.c_component.check + div {
	margin-top: 70px;
}
.c_component.check > div:first-child {
	background: #fffbf4;
	color: #ef6132;
	border-color: #ef6132;
}
.c_component.check > div:first-child:before {
	content: 'CHECK';
	background: #ef6132;
}
.c_component.check li:before {
	content: '';
	top: 6px;
	width: 12px;
	height: 6px;
	border-top: 3px solid #ef6132;
	border-right: 3px solid #ef6132;
	transform: rotate(135deg);
}

/*  heading
========================================================================*/

.c_heading {
	display: flex;
	justify-content: center;
	flex-direction: column;
	min-height: 250px;
	padding: 70px 15px;
}
.c_heading > div {
	width: 100%;
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}
.c_h1 {
	position: relative;
	font-size: 200%;
	text-align: center;
	letter-spacing: 3px;
	line-height: 1.4;
}
.c_h1 > div:first-child {
	padding-bottom: 15px;
}
.c_h1 > div:first-child:after {
	content: '';
	position: absolute;
	left: 0;
	right: 0;
	margin: auto;
	bottom: 0;
	width: 50px;
	height: 2px;
	background: #000;
}
.c_subtitle:not(:first-child) {
	margin-top: 15px;
}
.c_subtitle {
	color: #666;
	font-size: 120%;
	text-align: center;
	letter-spacing: 2px;
}

@media screen and (max-width: 767px) {
	.c_heading {
		padding: 30px 15px;
		min-height: 150px;
	}
	.c_h1 {
		font-size: 160%;
	}
	.c_subtitle:not(:first-child) {
		margin-top: 10px;
	}
}

/*  keyvisual
========================================================================*/

.c_keyvisual .image img {
	width: 100%;
	height: 300px;
	object-fit: cover;
}
.c_keyvisual .inner {
	padding: 40px 15px 70px;
}
.c_keyvisual .inner > div {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}

@media screen and (max-width: 767px) {
	.c_keyvisual .image img {
		height: 200px;
	}
	.c_keyvisual .inner {
		padding: 30px 15px 40px;
	}
}

/*  overlap
------------------------------------------------*/

.c_keyvisual.overlap .inner {
	position: relative;
	width: calc(100% - 20px);
	max-width: 1200px;
	margin: -40px auto 0;
	background: #fff;
}

/*  background
========================================================================*/

.c_background {
	position: relative;
	display: flex;
	justify-content: center;
	flex-direction: column;
	min-height: 250px;
}
.c_background > .g-move-block-area {
	z-index: 1;
}
.c_background .image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.c_background .image > div:first-child,
.c_background .image > div:first-child *:not(.mce-resizehandle) {
	height: 100%;
}
.c_background .image.g-block-area > div:first-child {
	padding: 0;
}
.c_background .image.g-block-area > .g-move-block-area {
	display: none;
}
.c_background .image p {
	background: #000;
}
.c_background .image img {
	opacity: .4;
	width: 100%;
	object-fit: cover;
}
.c_background .inner {
	position: relative;
	width: calc(100% - 20px);
	max-width: 1000px;
	margin: 70px auto;
	color: #fff;
	text-shadow: 1px 1px 1px #000;
}
.c_background .c_h1 > div:first-child:after {
	background: #fff;
}
.c_background .c_subtitle {
	color: #fff;
}

@media screen and (max-width: 767px) {
	.c_background .inner {
		width: calc(100% - 30px);
		margin: 40px auto;
	}
}

/*  section
========================================================================*/

.c_section.pbNested {
	padding: 80px 15px;
}
.c_section > div {
	max-width: 1000px;
	margin-left: auto;
	margin-right: auto;
}

@media screen and (max-width: 767px) {
	.c_section.pbNested {
		padding: 40px 15px;
	}
}

/*  white
------------------------------------------------*/

.c_section.white {
	background: #FFF;
}

/*  blue
------------------------------------------------*/

.c_section.blue {
	background: #EDF1F7;
}

/*  light
------------------------------------------------*/

.c_section.light {
	background: #f5f5f5;
}

/*  dark
------------------------------------------------*/

.c_section.dark {
	background: #ebebeb;
}

/*  stripe
------------------------------------------------*/

.c_section.stripe {
	background-color: #f2f2f2;
	background-image: linear-gradient(-45deg, #f2f2f2 25%, #e7e7e7 25%, #e7e7e7 50%, #f2f2f2 50%, #f2f2f2 75%, #e7e7e7 75%, #e7e7e7);
	background-size: 5px 5px;
}

/*  small
------------------------------------------------*/

.c_section.small > div {
	max-width: 800px;
}

/*  h2
========================================================================*/

.c_h2:not(:first-child) {
	margin-top: 60px;
}
.c_h2 + div:not(:first-child) {
	margin-top: 15px;
}
.c_h2 {
	font-size: 180%;
	line-height: 1.6;
}

@media screen and (max-width: 767px) {
	.c_h2:not(:first-child) {
		margin-top: 40px;
	}
	.c_h2 + div:not(:first-child) {
		margin-top: 10px;
	}
	.c_h2 {
		font-size: 150%;
	}
}

/*  blue
------------------------------------------------*/

[class*='c_h'].blue {
	color: #003F8E;
}

/*  line
------------------------------------------------*/

[class*='c_h'].line > div:first-child {
	padding-bottom: 10px;
	border-bottom: 2px solid #eee;
}

@media screen and (max-width: 767px) {
	[class*='c_h'].line > div:first-child {
		padding-bottom: 5px;
	}
}

/*  banner
------------------------------------------------*/

.c_h2.banner {
	display: flex;
	justify-content: space-between;
}
.c_h2.banner .h2 {
	display: flex;
	align-items: center;
	width: calc(100% - 170px);
}
.c_h2.banner .image {
	width: 150px;
}

@media screen and (max-width: 767px) {
	.c_h2.banner {
		flex-flow: column;
	}
	.c_h2.banner .h2 {
		width: 100%;
	}
	.c_h2.banner .image {
		margin-top: 10px;
		width: 100%;
		text-align: right;
	}
}

/*  icon
------------------------------------------------*/

.c_h2.icon {
	display: flex;
	justify-content: space-between;
}
.c_h2.icon .image {
	width: 50px;
}
.c_h2.icon .h2 {
	display: flex;
	align-items: center;
	width: calc(100% - 70px);
	margin-top: 2px;
}

@media screen and (max-width: 767px) {
	.c_h2.icon .image {
		width: 30px;
	}
	.c_h2.icon .h2 {
		width: calc(100% - 40px);
	}
}

/*  h3
========================================================================*/

.c_h3:not(:first-child) {
	margin-top: 40px;
}
.c_h3 + div:not(:first-child) {
	margin-top: 10px;
}
.c_h3 {
	font-size: 160%;
	line-height: 1.6;
}

@media screen and (max-width: 767px) {
	.c_h3 {
		font-size: 130%;
	}
}

/*  h4
========================================================================*/

.c_h4:not(:first-child) {
	margin-top: 40px;
}
.c_h4 + div:not(:first-child) {
	margin-top: 10px;
}
.c_h4 {
	font-size: 150%;
	line-height: 1.6;
}

@media screen and (max-width: 767px) {
	.c_h4 {
		font-size: 120%;
	}
}

/*  style
========================================================================*/

.c_style:not(:first-child) {
	margin-top: 30px;
}
.c_style a[target='_blank']:after,
.c_style a[href$='.pdf']:after,
.c_style a[href$='.doc']:after,
.c_style a[href$='.docx']:after,
.c_style a[href$='.xls']:after,
.c_style a[href$='.xlsx']:after,
.c_style a[href$='.ppt']:after,
.c_style a[href$='.pptx']:after,
.c_style a[href$='.zip']:after {
	font-family: 'Font Awesome 5 Free';
	content: '\f35d';
	display: inline-block;
	margin: 0 5px;
	color: #999;
	font-weight: 900;
}
.c_style a[href$='.pdf']:after {
	content: '\f1c1';
	color: #d32e2a;
}
.c_style a[href$='.doc']:after,
.c_style a[href$='.docx']:after {
	content: '\f1c2';
	color: #1d8bf1;
}
.c_style a[href$='.xls']:after,
.c_style a[href$='.xlsx']:after {
	content: '\f1c3';
	color: #47ad53;
}
.c_style a[href$='.ppt']:after,
.c_style a[href$='.pptx']:after {
	content: '\f1c4';
	color: #ee7321;
}
.c_style a[href$='.zip']:after {
	content: '\f1c6';
	color: #ffad00;
}

@media screen and (max-width: 767px) {
	.c_style:not(:first-child) {
		margin-top: 20px;
	}
}

/*  strong
------------------------------------------------*/

.c_style.strong {
	font-weight: bold;
}

/*  large
------------------------------------------------*/

.c_style.large {
	font-size: 120%;
}

/*  small
------------------------------------------------*/

.c_style.small {
	font-size: 90%;
}

/*  caption
------------------------------------------------*/

.c_style.caption:not(:first-child) {
	margin-top: 10px;
}
.c_style.caption {
	font-size: 90%;
}
.c_style.caption {
	color: #999;
}

/*  alert
------------------------------------------------*/

.c_style.alert {
	color: #ac3428;
}

/*  line
========================================================================*/

.c_line,
.c_line + div:not(:first-child) {
	margin-top: 40px;
}
.c_line hr {
	border: none;
	border-top: 1px solid #ccc;
}
.c_line hr + p {
	display: none;
}

/*  dot
------------------------------------------------*/

.c_line.dot hr {
	border-top: 1px dashed #ccc;
}

/*  textbox
========================================================================*/

.c_textbox:not(:first-child) {
	margin-top: 30px;
}
.c_textbox.pbNested {
	padding: 30px;
}

@media screen and (max-width: 767px) {
	.c_textbox:not(:first-child) {
		margin-top: 20px;
	}
	.c_textbox.pbNested {
		padding: 20px;
	}
}

/*  gray
------------------------------------------------*/

.c_textbox.gray {
	background: #f5f5f5;
}
.c_section:not(.white) .c_textbox.gray {
	background: #fff;
}

/*  line
------------------------------------------------*/

.c_textbox.line {
	background: #fff;
	border: 2px solid #ccc;
}

/*  alert
------------------------------------------------*/

.c_textbox.alert {
	background: #faeae8;
	border: 2px solid #ac3428;
}
.c_textbox.alert * {
	color: #ac3428;
}

/*  arrow
========================================================================*/

.c_arrow:not(:first-child),
.c_arrow + div:not(.g-draggable-handle) {
	margin-top: 40px;
}
.c_arrow > div:first-child {
	position: relative;
	padding: 0;
	height: 40px;
}
.c_arrow > div:first-child:before {
	content: '';
	position: absolute;
	left: 50%;
	transform: translateX(-50%);
	border-style: solid;
	border-width: 40px 40px 0;
	border-color: rgba(0,0,0,.2) transparent transparent;
}

@media screen and (max-width: 767px) {
	.c_arrow:not(:first-child),
	.c_arrow + div:not(:first-child) {
		margin-top: 30px;
	}
	.c_arrow > div {
		height: 20px;
	}
	.c_arrow > div:not(.pb-handle):before {
		border-width: 20px 30px 0;
	}
}

/*  light
------------------------------------------------*/

.c_arrow.light > div:not(.pb-handle):before {
	border-top-color: rgba(0,0,0,.6);
}

/*  dark
------------------------------------------------*/

.c_arrow.dark > div:not(.pb-handle):before {
	border-top-color: rgba(0,0,0,1);
}

/*  accordion
========================================================================*/

.c_accordion:not(:first-child) {
	margin-top: 30px;
}
.c_accordion + .c_accordion {
	margin-top: 5px;
}
.c_accordion .trigger {
	position: relative;
	padding: 20px 45px 20px 25px;
	background: #fafafa;
	font-size: 120%;
	font-weight: bold;
	border: 1px solid #ccc;
	cursor: pointer;
}
.c_accordion .trigger:before,
.c_accordion .trigger:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 20px;
	width: 16px;
	height: 2px;
	background: #000;
	transition: all .3s;
}
.c_accordion .trigger:after {
	transform: rotate(90deg);
}
.c_accordion.active .trigger:after {
	transform: rotate(360deg);
}
.c_accordion .content {
	padding: 20px 25px;
	background: #fff;
	border: 1px solid #ccc;
	border-top: none;
}

@media screen and (max-width: 767px) {
	.c_accordion:not(:first-child) {
		margin-top: 20px;
	}
	.c_accordion .trigger {
		padding: 15px 35px 15px 15px;
		font-size: 100%;
	}
	.c_accordion .trigger:before,
    .c_accordion .trigger:after {
		right: 15px;
	}
	.c_accordion .content {
		padding: 15px;
	}
}

/*  qa
------------------------------------------------*/

.c_accordion.qa .trigger > div,
.c_accordion.qa .content > div {
	width: calc(100% - 50px);
	margin-left: auto;
}
.c_accordion.qa .trigger > div:first-child,
.c_accordion.qa .content > div:first-child {
	position: relative;
	overflow: visible;
}
.c_accordion.qa .trigger > div:first-child:before,
.c_accordion.qa .content > div:first-child:before {
	content: 'Q.';
	position: absolute;
	top: 0;
	left: -45px;
	color: #9b0000;
	font-size: 30px;
	font-weight: bold;
	line-height: 1;
}
.c_accordion.qa .content > div:first-child:before {
	content: 'A.';
	top: 2px;
	color: #028893;
}
.c_accordion.qa .trigger.c-block-area > div:first-child:before {
	top: 5px;
}
.c_accordion.qa .content.c-block-area > div:first-child:before {
	top: 12px;
}

@media screen and (max-width: 767px) {
	.c_accordion.qa .trigger > div,
	.c_accordion.qa .content > div {
		width: calc(100% - 30px);
	}
	.c_accordion.qa .trigger > div:first-child:before,
	.c_accordion.qa .content > div:first-child:before {
		left: -25px;
		font-size: 20px;
	}
}

/*  more
========================================================================*/

.c_more:not(:first-child) {
	margin-top: 30px;
}
.c_more .content {
	display: none;
	margin-top: 20px;
}
.c_more.open .more {
	display: none;
}
.c_more:not(.open) .close {
	display: none;
}

@media screen and (max-width: 767px) {
	.c_more:not(:first-child) {
		margin-top: 20px;
	}
}

/*  more-height
------------------------------------------------*/

.c_more-height:not(:first-child) {
	margin-top: 40px;
}
.c_more-height .content {
	position: relative;
	overflow: hidden!important;
	transition: height .3s;
}
.c_more-height.close .content:after {
	content: '';
	width: 100%;
	height: 200px;
	position: absolute;
	bottom: 0;
	background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(255,255,255,1) 100%);
	pointer-events: none;
}
.c_more-height .c_button {
	display: none;
}
.c_more-height.close .c_button.more,
.c_more-height.open .c_button.close {
	display: block;
}

/*  tab
========================================================================*/

.c_tab:not(:first-child) {
	margin-top: 20px;
}
.c_tab .tab ul {
	display: table;
	table-layout: fixed;
	width: 100%;
	text-align: center;
	margin-bottom: 20px;
}
.c_tab .tab li {
	display: table-cell;
	padding: 7px 20px;
	border: 1px solid #fff;
	background: #eee;
	cursor: pointer;
	transition: all .3s;
}
.c_tab .tab li.active {
	background: #1b2426;
	color: #fff;
}
@media (min-width: 768px) {
	.c_tab .tab li:hover {
		background: #1b2426;
		color: #fff;
	}
}
.c_tab .content:not(.c-block-area) {
	display: none;
}
.c_tab .content.active {
	display: block;
	animation: tab .4s ease-in-out 0s;
}
@keyframes tab {
	0% {opacity: 0; transform: translateY(20px);}
	100% {opacity: 1; transform: translateY(0);}
}
.c_tab .edit:not(.c-block-area) {
	display: none;
}
.c_tab .edit {
	border: 3px solid #000;
	background: #f8f8f8;
	text-align: center;
	font-size: 120%;
}
.c_tab .edit:before {
	content: 'ボタンに表示させるテキストを、入力してください';
	display: block;
	padding: 10px;
	background: #000;
	color: #fff;
}
.c_tab .edit + div {
	margin-top: 0;
}

@media screen and (max-width: 767px) {
	.c_tab .tab ul {
		display: flex;
		flex-wrap: wrap;
	}
}

/*  button
========================================================================*/

.c_button:not(:first-child) {
	margin-top: 30px;
}
.c_button {
	text-align: center;
}
.c_button a {
	position: relative;
	display: inline-block;
	min-width: 280px;
	max-width: 100%;
	padding: 10px 40px;
	background: #333;
	color: #fff;
	text-align: center;
	text-decoration: none;
	border-radius: 9999px;
	line-height: 1.4;
}
.c_button a:after {
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	content: '\f105';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 10px;
	width: 20px;
	height: 20px;
	line-height: 20px;
	color: #999;
	transition: all .3s;
}
.c_button a[target='_blank']:after {
	content: '\f35d';
}
.c_button a[href$='.pdf']:after {
	content: '\f1c1';
	font-weight: normal;
}
.c_button a[href$='.doc']:after,
.c_button a[href$='.docx']:after {
	content: '\f1c2';
	font-weight: normal;
}
.c_button a[href$='.xls']:after,
.c_button a[href$='.xlsx']:after {
	content: '\f1c3';
	font-weight: normal;
}
.c_button a[href$='.ppt']:after,
.c_button a[href$='.pptx']:after {
	content: '\f1c4';
	font-weight: normal;
}
.c_button a[href$='.zip']:after {
	content: '\f1c6';
	font-weight: normal;
}
@media (min-width: 768px) {
	.c_button a:hover {
		background: #003F8E;
	}
	.c_button a:hover:after {
		color: #fff;
	}
}

@media screen and (max-width: 767px) {
	.c_button:not(:first-child) {
		margin-top: 20px;
	}
	.c_button a {
		width: 280px;
		min-width: auto;
	}
}

/*  disabled 
------------------------------------------------*/

.c_button.disabled a {
	background: #999;
}
 .c_button.disabled:not(.c-block-area) a {
	pointer-events: none;
}
.c_button.disabled  a:after {
	color: #fff;
}

/*  red
------------------------------------------------*/

.c_button.red a {
	background: #ac3428;
}
.c_button.red a:after {
	color: #fff;
}
@media (min-width: 768px) {
	.c_button.red a:hover {
		background: #ef6132;
	}
}

/*  prev
------------------------------------------------*/

.c_button.prev a:after {
	content: '\f104';
	right: auto;
	left: 10px;
}

/*  more
------------------------------------------------*/

.c_button.more a:before,
.c_button.more a:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 20px;
	width: 12px;
	height: 2px;
	background: #999;
	transition: all .3s;
}
.c_button.more a:after {
	transform: rotate(90deg);
}

@media (min-width: 768px) {
	.c_button.more a:hover:before,
	.c_button.more a:hover:after {
		background: #fff;
	}
}

/*  close 
------------------------------------------------*/

.c_button.close a {
	background: #999;
}
.c_button.close a:after {
	content: '';
	right: 20px;
	width: 12px;
	height: 2px;
	background: #fff;
}
@media (min-width: 768px) {
	.c_button.close a:hover {
		background: #333;
	}
	.c_button.close a:hover:after {
		background: #999;
	}
}

/*  large
------------------------------------------------*/

.c_button.large:not(:first-child) {
	margin-top: 50px;
}
.c_button.large a {
	width: 600px;
	padding: 18px 50px;
	font-size: 140%;
}
.c_button.large a:after {
	right: 30px;
}

@media screen and (max-width: 767px) {
	.c_button.large:not(:first-child) {
		margin-top: 30px;
	}
	.c_button.large a {
		font-size: 120%;
	}
	.c_button.large a:after {
		right: 20px;
	}
}

/*  buttonset
========================================================================*/

.c_buttonset:not(:first-child) {
	margin-top: 30px;
}
.c_buttonset {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	margin: -10px;
}
.c_buttonset .box {
	margin: 10px;
	width: 280px;
}

@media screen and (max-width: 767px) {
	.c_buttonset > div {
		margin: 0;
	}
	.c_buttonset .box {
		width: 100%;
		margin: 0;
	}
	.c_buttonset .box:not(:first-child) {
		margin-top: 10px;
	}
}

/*  large
------------------------------------------------*/

.c_buttonset.large .box {
	width: calc(50% - 20px);
}

@media screen and (max-width: 767px) {
	.c_buttonset.large .box {
		width: 100%;
	}
}

/*  anchor
========================================================================*/

.c_anchor:not(:first-child) {
	margin-top: 30px;
}
.c_anchor ul {
	display: flex;
	flex-wrap: wrap;
	margin: -5px -20px;
	line-height: 1.6;
	font-weight: bold;
}
.c_anchor li {
	display: flex;
	align-items: center;
	margin: 5px 20px;
}
.c_anchor a {
	position: relative;
	padding-right: 20px;
	text-decoration: none;
}
@media (min-width: 768px) {
	.c_anchor a:hover {
		opacity: .6;
	}
}
.c_anchor a:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 0;
	width: 6px;
	height: 6px;
	border-top: 2px solid #333;
	border-right: 2px solid #333;
	transform: rotate(45deg);
}
.c_anchor a[href^='#']:after {
	top: -5px;
	transform: rotate(135deg);
}


@media screen and (max-width: 767px) {
	.c_anchor:not(:first-child) {
		margin-top: 20px;
	}
	.c_anchor ul {
		margin: -5px -10px;
	}
	.c_anchor li {
		margin: 5px 10px;
	}
	.c_anchor a {
		padding-right: 15px;
	}
}

/*  button
------------------------------------------------*/

.c_anchor.button ul {
	margin: 0;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
}
.c_anchor.button li {
	position: relative;
	width: 25%;
	margin: 0;
	padding: 10px 30px 10px 15px;
	background: #fff;
	border-right: 1px solid #ccc;
	border-bottom: 1px solid #ccc;
}
.c_anchor.button a {
	position: static;
	padding-right: 0;
}
.c_anchor.button:not(.c-block-area) a:before {
	content: '';
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	transition: all .3s;
}
.c_anchor.button a:after {
	right: 15px;
}
@media (min-width: 768px) {
	.c_anchor.button a:hover {
		opacity: 1;
	}
	.c_anchor.button a:hover:before {
		background: rgba(0,0,0,.03);
	}
}

@media screen and (max-width: 767px) {
	.c_anchor.button li {
		width: 50%;
	}
}

/*  list
========================================================================*/

/*  ul
------------------------------------------------*/

.c_style div > ul > li {
	position: relative;
	padding-left: 20px;
}
.c_style div > ul > li:not(:first-child) {
	margin-top: 10px;
}
.c_style div > ul > li:before {
	content: '';
	position: absolute;
	top: .55em;
	left: 0;
	width: .5em;
	height: .5em;
	border-top: 2px solid #003F8E;
	border-right: 2px solid #003F8E;
	transform: rotate(45deg);
}

@media screen and (max-width: 767px) {
	.c_style div > ul > li {
		padding-left: 15px;
	}
}

/*  nested  */

.c_style li ul {
	margin: 20px 0;
	font-size: 95%;
}
.c_style li ul li {
	position: relative;
	padding-left: 15px;
}
.c_style li ul li:not(:first-child) {
	margin-top: 5px;
}
.c_style li ul li:before {
	content: '';
	position: absolute;
	top: .7em;
	left: 0;
	width: 5px;
	height: 5px;
	background: #999;
}

@media screen and (max-width: 767px) {
	.c_style li ul li {
		padding-left: 15px;
	}
}

/*  ol
------------------------------------------------*/

.c_style div > ol {
	counter-reset: cnt;
}
.c_style div > ol > li {
	position: relative;
	padding-left: 30px;
	counter-increment: cnt;
}
.c_style div > ol > li:not(:first-child) {
	margin-top: 10px;
}
.c_style div > ol > li:before {
	content: counter(cnt);
	position: absolute;
	left: 0;
	width: 1.5em;
	height: 1.5em;
	line-height: 1.6em;
	background: #003F8E;
	color: #fff;
	text-align: center;
	border-radius: 50%;
}
.c_style div > ol > li[data-cnt]:before {
	content: attr(data-cnt);
}

@media screen and (max-width: 767px) {
	.c_style div > ol > li {
		padding-left: 15px;
	}
}

/*  nested  */

.c_style li ol {
	counter-reset: cnt;
	margin: 20px 0 30px;
	font-size: 95%;
}
.c_style li ol li {
	position: relative;
	padding-left: 20px;
	counter-increment: cnt;
}
.c_style li ol li:not(:first-child) {
	margin-top: 5px;
}
.c_style li ol li:before {
	content: counter(cnt)" )";
	position: absolute;
	left: 0;
	color: #999;
}
.c_style li ol li[data-cnt]:before {
	content: attr(data-cnt)" )";
}

/*  list-row
------------------------------------------------*/

.c_style.list-row ul {
	display: flex;
	flex-wrap: wrap;
	margin: -5px -10px;
}
.c_style.list-row li,
.c_style.list-row li:not(:first-child) {
	margin: 5px 10px;
}

/*  list-notes
------------------------------------------------*/

.c_style.list-notes * {
	color: #666;
}
.c_style.list-notes li:not(:first-child) {
	margin-top: 5px;
}
.c_style.list-notes ul li:before {
	content: '※';
	top: 0;
	left: 0;
	width: auto;
	height: auto;
	border: none;
	transform: none;
}
.c_style.list-notes ol li {
	padding-left: 30px;
}
.c_style.list-notes ol li:before {
	content: "※"counter(cnt);
	width: auto;
	background: unset;
	color: unset;
}
.c_style.list-notes ol li[data-cnt]:before {
	content: "※"attr(data-cnt);
}

/*  list-notes-en
------------------------------------------------*/

.c_style.list-notes-en * {
	color: #666;
}
.c_style.list-notes-en li:not(:first-child) {
	margin-top: 5px;
}
.c_style.list-notes-en ul li {
	padding-left: 15px;
}
.c_style.list-notes-en ul li:before {
	content: '*';
	top: 1px;
	left: 0;
	width: auto;
	height: auto;
	border: none;
	transform: none;
	font-size: 110%;
}
.c_style.list-notes-en ol li {
	padding-left: 25px;
}
.c_style.list-notes-en ol li:before {
	content: "*"counter(cnt);
	width: auto;
	background: unset;
	color: unset;
}
.c_style.list-notes-en ol li[data-cnt]:before {
	content: "*"attr(data-cnt);
}

/*  image
========================================================================*/

.c_image:not(:first-child) {
	margin-top: 30px;
}
.c_image {
	text-align: center;
}
.c_image a {
	position: relative;
	overflow: hidden;
	display: inline-block;
}
@media (min-width: 768px) {
	.c_image a:hover img {
		transform: scale(1.1);
	}
}
.c_image a:after {
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	content: '\f105';
	position: absolute;
	z-index: 1;
	bottom: 0;
	right: 0;
	width: 25px;
	height: 25px;
	line-height: 25px;
	background: #333;
	color: #999;
	font-size: 12px;
	text-align: center;
}
.c_image a[target='_blank']:after {
	content: '\f35d';
}
.c_image a[href$='.pdf']:after {
	content: '\f1c1';
	font-weight: normal;
}
.c_image a[href$='.doc']:after,
.c_image a[href$='.docx']:after {
	content: '\f1c2';
	font-weight: normal;
}
.c_image a[href$='.xls']:after,
.c_image a[href$='.xlsx']:after {
	content: '\f1c3';
	font-weight: normal;
}
.c_image a[href$='.ppt']:after,
.c_image a[href$='.pptx']:after {
	content: '\f1c4';
}
.c_image a[href$='.zip']:after {
	content: '\f1c6';
	font-weight: normal;
}

@media screen and (max-width: 767px) {
	.c_image:not(:first-child) {
		margin-top: 20px;
	}
}

/*  full
------------------------------------------------*/

.c_image.full a {
	display: block;
}
.c_image.full img {
	width: 100%;
}

/*  list
------------------------------------------------*/

@media screen and (max-width: 767px) {
	.c_image li:not(:first-child) {
		margin-top: 10px;
	}
}

/*  col-2  */

@media print, screen and (min-width: 768px) {
	.c_image.col-2 ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.c_image.col-2 li {
		width: 49%;
	}
	.c_image.col-2 li:nth-child(n+3) {
		margin-top: 20px;
	}
}

/*  col-3  */

@media print, screen and (min-width: 768px) {
	.c_image.col-3 ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.c_image.col-3 ul:after {
		content: '';
		display: block;
		width: 32%;
	}
	.c_image.col-3 li {
		width: 32%;
	}
	.c_image.col-3 li:nth-child(n+4) {
		margin-top: 20px;
	}
}

/*  col-4  */

.c_image.col-4 ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

@media screen and (max-width: 767px) {
	.c_image.col-4 li {
		width: 49%;
		margin-top: 0;
	}
	.c_image.col-4 li:nth-child(n+3) {
		margin-top: 10px;
	}
}

@media print, screen and (min-width: 768px) {
	.c_image.col-4 ul:after,
	.c_image.col-4 ul:before {
		content: '';
		display: block;
		width: 24%;
	}
	.c_image.col-4 ul:before {
		order: 1;
	}
	.c_image.col-4 li {
		width: 24%;
	}
	.c_image.col-4 li:nth-child(n+5) {
		margin-top: 15px;
	}
}

/*  modal
------------------------------------------------*/

.c_image.m-image a:after {
	content: '\f00e';
}
.c_image.m-youtube a:after {
	content: '\f144';
}

/*  iframe
========================================================================*/

div.c_iframe {
	max-width: 800px;
}
.c_iframe > div:not(.g-move-block-area) {
	position: relative;
	padding-top: 0%!important;
	padding-bottom: 56.25%!important;
}
.c_iframe iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

/*  imagebox
========================================================================*/

.c_imagebox:not(:first-child) {
	margin-top: 40px;
}
.c_imagebox {
	display: table;
	width: auto;
	min-width: 100px;
}
.c_imagebox .textbox {
	margin-top: 10px;
	display: table-caption;
	caption-side: bottom;
}

/*  banner
========================================================================*/

.c_banner:not(:first-child) {
	margin-top: 40px;
}
.c_banner {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.c_banner .box {
	position: relative;
	display: flex;
	align-items: center;
	min-height: 250px;
	padding: 30px 40px 30px 30px;
}
.c_banner .box > .g-move-block-area {
	z-index: 1;
}
.c_banner .c_image {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.c_banner .c_image > div:first-child,
.c_banner .c_image > div:first-child *:not(.mce-resizehandle) {
	height: 100%;
}
.c_banner .c_image.g-block-area > div:first-child {
	padding: 0;
}
.c_banner .c_image > .g-move-block-area {
	display: none;
}
.c_banner .c_image p {
	background: #000;
}
.c_banner .c_image a {
	display: block;
}
.c_banner .c_image img {
	opacity: .4;
	width: 100%;
	object-fit: cover;
}
.c_banner .textbox {
	position: relative;
	color: #fff;
	text-shadow: 1px 1px 1px #000;
	line-height: 1.6;
}
.c_banner .textbox:not(.g-block-area) {
	pointer-events: none;
}
.c_banner .title {
	font-size: 150%;
}
.c_banner .text:not(:first-child) {
	margin-top: 5px;
}

@media screen and (max-width: 767px) {
	.c_banner:not(:first-child) {
		margin-top: 20px;
	}
	.c_banner .box {
		width: 100%;
		min-height: 180px;
		padding: 30px 30px 30px 20px;
	}
	.c_banner .box:not(:first-child) {
		margin-top: 10px;
	}
}

/*  col-2
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_banner.col-2 .box {
		width: 49%;
	}
	.c_banner.col-2 .box:nth-child(n+3) {
		margin-top: 20px;
	}
}

/*  col-3
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_banner.col-3:after {
		content: '';
		display: block;
		width: 32%;
	}
	.c_banner.col-3 .box {
		width: 32%;
		min-height: 150px;
	}
	.c_banner.col-3 .box:nth-child(n+4) {
		margin-top: 20px;
	}
}

/*  half
------------------------------------------------*/

.c_banner.half .box {
	padding: 0;
}
.c_banner.half .c_image img {
	opacity: 1;
}
.c_banner.half .textbox {
	display: flex;
	flex-direction: column;
	justify-content: center;
	width: 50%;
	height: 100%;
	padding: 20px;
	background: rgba(0,0,0,.6);
}
.c_banner.half .title {
	font-size: 130%;
}

@media screen and (max-width: 767px) {
	.c_banner.half .textbox {
		padding: 15px;
	}
}

/*  image-text
========================================================================*/

.c_image-text:not(:first-child) {
	margin-top: 30px;
}
.c_image-text {
	display: flex;
	justify-content: space-between;
}
.c_image-text .imagebox,
.c_image-text .textbox {
	width: 48%;
}
.c_image-text .c_image:not(.transparent) p {
	background: #ddd;
}
.c_image-text .c_image a {
	display: block;
}
.c_image-text .textbox {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

@media screen and (max-width: 767px) {
	.c_image-text {
		flex-direction: column;
	}
	.c_image-text .imagebox,
	.c_image-text .textbox {
		width: 100%;
	}
	.c_image-text .imagebox {
		display: table;
		width: auto;
		margin: 0 auto;
	}
	.c_image-text .imagebox .c_style {
		display: table-caption;
		caption-side: bottom;
	}
	.c_image-text .textbox {
		margin-top: 15px;
	}
}

/*  sp-reverse
------------------------------------------------*/

@media screen and (max-width: 767px) {
	.c_image-text.sp-reverse {
		flex-direction: column-reverse;
	}
	.c_image-text.sp-reverse .imagebox {
		margin-top: 20px;
	}
	.c_image-text.sp-reverse .textbox {
		margin-top: 0;
	}
}

/*  gray
------------------------------------------------*/

.c_image-text.gray {
	padding: 40px;
	background: #f5f5f5;
}
.c_section:not(.white) .c_image-text.gray {
	background: #fff;
}

@media screen and (max-width: 767px) {
	.c_image-text.gray {
		padding: 20px 20px 30px;
	}
}

/*  line
------------------------------------------------*/

.c_image-text.line {
	padding: 40px;
	background: #fff;
    border: 2px solid #ccc;
}

@media screen and (max-width: 767px) {
	.c_image-text.line {
		padding: 20px 20px 30px;
	}
}

/*  simple
------------------------------------------------*/

.c_image-text.simple {
	background: #f5f5f5;
}
.c_section:not(.white) .c_image-text.simple {
	background: #fff;
}
.c_image-text.simple .imagebox,
.c_image-text.simple .textbox {
	width: 50%;
}
.c_image-text.simple .imagebox {
	background: #ddd;
}
.c_image-text.simple .textbox {
	padding: 40px;
}

@media screen and (max-width: 767px) {
	.c_image-text.simple .imagebox,
	.c_image-text.simple .textbox {
		width: 100%;
	}
	.c_image-text.simple .textbox {
		margin-top: 0;
		padding: 20px 20px 30px;
	}
}

/*  small
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_image-text .imagebox.small {
		width: 33%;
	}
	.c_image-text .imagebox.small + .textbox {
		width: 63%;
	}
	.c_image-text.simple .imagebox.small + .textbox {
		width: 67%;
	}
}

/*  mini
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_image-text .imagebox.mini {
		width: 25%;
	}
	.c_image-text .imagebox.mini + .textbox {
		width: 71%;
	}
	.c_image-text.simple .imagebox.mini + .textbox {
		width: 75%;
	}
}

/*  flow
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_image-text.flow {
		display: block;
		overflow: hidden;
	}
	.c_image-text.flow .imagebox {
		float: left;
		margin-right: 4%;
		margin-bottom: 10px;
		position: relative;
		z-index: 1;
	}
	.c_image-text.flow .textbox {
		display: block;
		width: 100%!important;
	}
	.c_image-text.flow .textbox .c-block {
		overflow: visible;
	}
}

/*  auto
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_image-text.auto {
		display: block;
		overflow: hidden;
	}
	.c_image-text.auto .imagebox,
	.c_image-text.auto .textbox {
		width: auto;
	}
	.c_image-text.auto .imagebox {
		display: table;
		float: left;
		min-width: 100px;
		max-width: 80%;
		margin-right: 4%;
	}
	.c_image-text.auto .caption {
		display: table-caption;
		caption-side: bottom;
	}
	.c_image-text.auto .caption.c-block-area {
		padding-bottom: 10px;
	}
}

/*  pc-reverse
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_image-text.pc-reverse {
		flex-direction: row-reverse;
	}
	.c_image-text.pc-reverse.flow .imagebox,
	.c_image-text.pc-reverse.auto .imagebox {
		float: right;
		margin-right: 0;
		margin-left: 4%;
	}
}

/*  table
========================================================================*/

.c_style table th,
.c_style table td {
	height: calc(1em + 20px);
	padding: 9px 15px;
	background: #fff;
	text-align: left;
	vertical-align: middle;
	font-weight: normal;
}
.c_style table:not([border]) th,
.c_style table:not([border]) td {
	border: 1px solid #ccc;
}
.c_style table th {
	background: #333;
	color: #fff;
}
.c_style thead th:not(:first-child) {
	background: #666;
}
.c_style thead td {
	background: #999;
	color: #fff;
}

@media screen and (max-width: 767px) {
	.c_style table {
		font-size: 90%;
	}
	.c_style table th,
	.c_style table td {
		padding: 10px;
	}
	.c_style table td {
		padding: 10px;
	}
}

/*  table-col
------------------------------------------------*/

.c_style.table-col table {
	width: 100%;
	table-layout: fixed;
}

@media screen and (max-width: 767px) {
	.c_style.table-col table,
	.c_style.table-col thead,
	.c_style.table-col tbody,
	.c_style.table-col tr,
	.c_style.table-col th,
	.c_style.table-col td {
		display: block;
		width: 100%!important;
		height: auto!important;
	}
	.c_style.table-col table:not([border]) th {
		border: none;
	}
	.c_style.table-col table:not([border]) td {
		border-top: none;
	}
	.c_style.table-col table:not([border]) tr:not(:last-child) td:last-child {
		border-bottom: none;
	}
}

/*  table-swipe
------------------------------------------------*/

.c_style.table-swipe table {
	width: 100%;
	table-layout: fixed;
}
@keyframes swipe {
  40%, 60%, 80% {transform: scale(1);}
  50%, 70% {transform: scale(.9);}
}

@media screen and (max-width: 767px) {
	.c_style.table-swipe {
		overflow: auto;
		position: relative;
	}
	.c_style.table-swipe:before,
	.c_style.table-swipe:after {
		content: '';
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
		transition: all .3s;
		pointer-events: none;
	}
	.c_style.table-swipe:before {
		width: 80px;
		height: 70px;
		background: rgba(0,0,0,.7);
		border-radius: 5px;
	}
	.c_style.table-swipe:after {
		width: 60px;
		height: 60px;
		background: url(../img/common/icon_swipe.png) no-repeat center top / contain;
		animation: swipe 2s ease-out infinite;
	}
	.c_style.table-swipe.active:before,
	.c_style.table-swipe.active:after {
		opacity: 0;
	}
	.c_style.table-swipe::-webkit-scrollbar {
		height: 10px;
	}
	.c_style.table-swipe::-webkit-scrollbar-thumb {
		background: #d9dcdf;
		border-radius: 10px;
	}
	.c_style.table-swipe::-webkit-scrollbar-track {
		background: #f5f5f5;
		border-radius: 10px;
	}
	.c_style.table-swipe table {
		width: 800px;
		max-width: none;
		margin-bottom: 3px;
	}
}

/*  table-swipe-fix
------------------------------------------------*/

.c_style.table-swipe-fix table {
	width: 100%;
	table-layout: fixed;
}

@media screen and (max-width: 767px) {
	.c_style.table-swipe-fix {
		overflow: auto;
		position: relative;
	}
	.c_style.table-swipe-fix:before,
	.c_style.table-swipe-fix:after {
		content: '';
		position: absolute;
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		margin: auto;
		transition: all .3s;
		pointer-events: none;
		z-index: 1;
	}
	.c_style.table-swipe-fix:before {
		width: 80px;
		height: 70px;
		background: rgba(0,0,0,.7);
		border-radius: 5px;
	}
	.c_style.table-swipe-fix:after {
		width: 60px;
		height: 60px;
		background: url(../img/common/icon_swipe.png) no-repeat center top / contain;
		animation: swipe 2s ease-out infinite;
	}
	.c_style.table-swipe-fix.active:before,
	.c_style.table-swipe-fix.active:after {
		opacity: 0;
	}
	.c_style.table-swipe-fix::-webkit-scrollbar {
		height: 10px;
	}
	.c_style.table-swipe-fix::-webkit-scrollbar-thumb {
		background: #d9dcdf;
		border-radius: 10px;
	}
	.c_style.table-swipe-fix::-webkit-scrollbar-track {
		background: #f5f5f5;
		border-radius: 10px;
	}
	.c_style.table-swipe-fix table {
		width: 800px;
		max-width: none;
		margin-bottom: 3px;
	}
	.c_style.table-swipe-fix table th:first-child {
		position: sticky;
		left: 0;
	}
}

/*  panel
========================================================================*/

.c_panel:not(:first-child) {
	margin-top: 40px;
}
.c_panel .box {
	display: flex;
	flex-flow: column;
}
.c_panel .c_image:not(.transparent) p {
	background: #ddd;
}
.c_panel .c_image a {
	display: block;
}
.c_panel .title:not(:first-child) {
	margin-top: 20px;
}
.c_panel [class*='c_h']:not(:first-child) {
	margin-top: 20px;
}
.c_panel .c_button {
	margin-top: auto;
}
.c_panel .c_button a {
	margin-top: 30px;
}

@media screen and (max-width: 767px) {
	.c_panel .box:not(:first-child) {
		margin-top: 40px;
	}
	.c_panel .c_button a {
		margin-top: 20px;
	}
}

/*  col-2
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_panel.col-2 {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.c_panel.col-2 .box {
		width: 49%;
	}
	.c_panel.col-2 .box:nth-child(n+3) {
		margin-top: 40px;
	}
}

/*  col-3
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_panel.col-3 {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.c_panel.col-3:after {
		content: '';
		display: block;
		width: 32%;
	}
	.c_panel.col-3 .box {
		width: 32%;
	}
	.c_panel.col-3 .box:nth-child(n+4) {
		margin-top: 40px;
	}
}

/*  col-4
------------------------------------------------*/

.c_panel.col-4 {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	font-size: 90%;
}
.c_panel.col-4 [class*='c_h']:not(:first-child) {
	margin-top: 10px;
}
.c_panel.col-4 [class*='c_h'] + div {
	margin-top: 5px;
}
.c_panel.col-4 .c_button a {
	min-width: auto;
	width: 90%;
	margin-top: 15px;
	padding: 8px 25px 7px 10px;
}

@media print, screen and (min-width: 768px) {
	.c_panel.col-4:after,
	.c_panel.col-4:before {
		content: '';
		display: block;
		width: 24%;
	}
	.c_panel.col-4:before {
		order: 1;
	}
	.c_panel.col-4 .box {
		width: 24%;
	}
	.c_panel.col-4 .box:nth-child(n+5) {
		margin-top: 40px;
	}
}

@media screen and (max-width: 767px) {
	.c_panel.col-4 .box {
		width: 49%;
		margin-top: 0;
	}
	.c_panel.col-4 .box:nth-child(n+3) {
		margin-top: 30px;
	}
}

/*  card
========================================================================*/

.c_card:not(:first-child) {
	margin-top: 40px;
}
.c_card .box {
	position: relative;
	background: #f1f1f1;
}
.c_section:not(.white) .c_card .box {
	background: #fff;
}
.c_card .box.link:after {
	font-family: 'Font Awesome 5 Free';
	font-weight: 900;
	content: '\f105';
	position: absolute;
	z-index: 1;
	bottom: 0;
	right: 0;
	width: 25px;
	height: 25px;
	line-height: 25px;
	background: #333;
	color: #999;
	font-size: 12px;
	text-align: center;
	pointer-events: none;
}
.c_card .box.blank:after {
	content: '\f35d';
}
.c_card .box.pdf:after {
	content: '\f1c1';
	font-weight: normal;
}
.c_card .c_image a {
	display: block;
	position: static;
}
.c_card .c_image:not(.c-block-area) a:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 0;
	right: 0;
}
.c_card .c_image a:after {
	display: none;
}
.c_card .c_image img {
	width: 100%;
}
.c_card .textbox {
	padding: 30px 30px 40px;
}
.c_card [class*='c_h'] + div {
	margin-top: 5px;
}

@media screen and (max-width: 767px) {
	.c_card .box:not(:first-child) {
		margin-top: 20px;
	}
	.c_card .textbox {
		padding: 20px 20px 30px;
	}
}

/*  col-2
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_card.col-2 {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.c_card.col-2 .box {
		width: 49%;
	}
	.c_card.col-2 .box:nth-child(n+3) {
		margin-top: 40px;
	}
}

/*  col-3
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
    .c_card.col-3 {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.c_card.col-3:after {
		content: '';
		display: block;
		width: 32%;
	}
	.c_card.col-3 .box {
		width: 32%;
	}
	.c_card.col-3 .box:nth-child(n+4) {
		margin-top: 40px;
	}
	.c_card.col-3 .textbox {
		padding: 20px 20px 30px;
	}
}

/*  col-4
------------------------------------------------*/

.c_card.col-4 {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	font-size: 90%;
}

@media print, screen and (min-width: 768px) {
	.c_card.col-4:after,
	.c_card.col-4:before {
		content: '';
		display: block;
		width: 24%;
	}
	.c_card.col-4:before {
		order: 1;
	}
	.c_card.col-4 .box {
		width: 24%;
	}
	.c_card.col-4 .box:nth-child(n+5) {
		margin-top: 40px;
	}
	.c_card.col-4 .textbox {
		padding: 20px 20px 30px;
	}
}

@media screen and (max-width: 767px) {
	.c_card.col-4 .box {
		width: 49%;
		margin-top: 0;
	}
	.c_card.col-4 .box:nth-child(n+3) {
		margin-top: 10px;
	}
	.c_card.col-4 .textbox {
		padding: 10px 10px 25px;
	}
}

/*  banner
------------------------------------------------*/

.c_card.banner .box {
	display: flex;
}
.c_card.banner .c_image {
	background: #ddd;
}
.c_card.banner .textbox {
	display: flex;
	flex-direction: column;
	justify-content: center;
}

/*  col-1  */

@media print, screen and (min-width: 768px) {
	.c_card.banner.col-1 .textbox {
		width: 50%;
	}
}

@media screen and (max-width: 767px) {
	.c_card.banner.col-1 .box {
		flex-flow: column;
	}
}

/*  col-2  */

.c_card.banner.col-2 .c_image {
	width: 40%;
}
.c_card.banner.col-2 .textbox {
	width: 60%;
	padding: 25px;
}

/*  col-3  */

.c_card.banner.col-3 .c_image {
	width: 33%;
}
.c_card.banner.col-3 .textbox {
	width: 67%;
	padding: 15px;
}

/*  col-4  */

.c_card.banner.col-4 .c_image {
	width: 33%;
}
.c_card.banner.col-4 .textbox {
	width: 67%;
	padding: 15px;
}

/*  slider
========================================================================*/

.c_slider:not(:first-child) {
	margin-top: 30px;
}
div.c_slider {
	overflow: hidden;
	padding: 0;
	background: #d3d5d8;
}
.c_slider > ul {
	opacity: 0;
	max-width: 1200px;
	margin: 0 auto;
	box-shadow: 0 0 8px rgba(0,0,0,.1);
}
.c_slider > ul > li:not(:first-child) {
	display: none;
}
.c_slider ul.slick-initialized {
	opacity: 1;
}
.c_slider ul.slick-dotted {
	margin-bottom: 0;
}
.c_slider .slick-arrow {
	left: 0;
	z-index: 1;
	width: 60px;
	height: 60px;
	background: #333;
	transition: all .3s;
}
.c_slider .slick-next {
	left: auto;
	right: 0;
}
.c_slider .slick-arrow:focus {
	background: #333;
}
.c_slider .slick-arrow:hover {
	background: #ef6132;
}
.c_slider .slick-arrow:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	left: 25px;
	width: 10px;
	height: 10px;
	border-left: 3px solid #fff;
	border-bottom: 3px solid #fff;
	opacity: 1;
	transform: rotate(45deg);
}
.c_slider .slick-next:before {
	left: auto;
	right: 25px;
	transform: rotate(-135deg);
}
.c_slider .slick-dots {
	bottom: 15px;
	height: 5px;
	padding: 0 20px;
	text-align: right;
}
.c_slider .slick-dots li {
	height: 100%;
}
.c_slider .slick-dots li button {
	width: 100%;
	height: 100%;
	padding: 0;
	background: #999;
}
.c_slider .slick-dots li.slick-active button {
	background: #333;
}
.c_slider .slick-dots li button:before {
	display: none;
}
.c_slider .slick-slide {
	position: relative;
}
.c_slider .slick-slide a {
	overflow: hidden;
	display: block;
	text-decoration: none;
}
@media (min-width: 768px) {
	.c_slider .slick-slide a:hover img {
		transform: scale(1.1);
	}
}
.c_slider .slick-slide img {
	width: 100%;
}
.c_slider .textbox {
	display: block;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	padding: 30px;
	background: rgba(0,0,0,.8);
	color: #fff;
	text-align: center;
}
.c_slider .title {
	display: block;
	font-weight: bold;
	font-family: 'Roboto Condensed', sans-serif;
	letter-spacing: 3px;
	font-size: 200%;
}
.c_slider .text {
	display: block;
	color: #ccc;
}

@media screen and (max-width: 767px) {
	.c_slider:not(:first-child) {
		margin-top: 20px;
	}
	div.c_slider {
		background: none;
	}
	.c_slider .slick-arrow {
		display: none!important;
	}
	.c_slider ul.slick-dotted {
		padding-bottom: 30px;
	}
	.c_slider .slick-dots {
		bottom: 13px;
		text-align: center;
	}
	.c_slider .textbox {
		width: 300px;
		max-width: 70%;
		padding: 20px;
	}
	.c_slider .title {
		font-size: 150%;
	}
}

/*  carousel
========================================================================*/

.c_carousel:not(:first-child) {
	margin-top: 30px;
}
.c_carousel > ul {
	opacity: 0;
	transition: all .3s;
}
.c_carousel ul.slick-initialized {
	opacity: 1;
	margin: 0 -5px;
}
.c_carousel .slick-dotted.slick-slider {
	margin-bottom: 0;
	padding-bottom: 30px;
}
.c_carousel .slick-arrow {
	left: -70px;
	width: 60px;
	height: 60px;
	background: #333;
	transition: all .3s;
}
.c_carousel .slick-next {
	left: auto;
	right: -70px;
}
.c_carousel .slick-arrow:focus {
	background: #333;
}
.c_carousel .slick-arrow:hover {
	background: #ef6132;
}
.c_carousel .slick-arrow:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	left: 25px;
	width: 10px;
	height: 10px;
	border-left: 3px solid #fff;
	border-bottom: 3px solid #fff;
	opacity: 1;
	transform: rotate(45deg);
}
.c_carousel .slick-next:before {
	left: auto;
	right: 25px;
	transform: rotate(-135deg);
}
.c_carousel .slick-dots {
	bottom: 0;
	height: 5px;
	padding: 0 20px;
}
.c_carousel .slick-dots li {
	width: 40px;
	height: 100%;
}
.c_carousel .slick-dots li button {
	width: 100%;
	height: 100%;
	padding: 0;
	background: #999;
}
.c_carousel .slick-dots li.slick-active button {
	background: #333;
}
.c_carousel .slick-dots li button:before {
	display: none;
}
.c_carousel .slick-track {
	display: flex;
}
.c_carousel .slick-slide {
	height: auto!important;
	margin: 0 5px;
	background: #f5f5f5;
}
.c_carousel .slick-slide li,
.c_carousel .slick-slide div {
	height: 100%;
}
.c_carousel .slick-slide a {
	display: block;
	height: 100%;
	text-decoration: none;
}
@media (min-width: 768px) {
	.c_carousel .slick-slide a:hover {
		background: rgba(0,0,0,.1);
	}
}
.c_carousel .slick-list img {
	width: 100%;
}
.c_carousel .textbox {
	display: block;
	padding: 25px 20px;
	text-align: center;
}
.c_carousel .title {
	display: block;
	font-weight: bold;
	font-family: 'Roboto Condensed', sans-serif;
	letter-spacing: 3px;
	font-size: 150%;
}
.c_carousel .text:not(:first-child) {
	margin-top: 10px;
}
.c_carousel .text {
	display: block;
	color: #999;
}

@media screen and (max-width: 767px) {
	.c_carousel:not(:first-child) {
		margin-top: 20px;
	}
	.c_carousel .slick-dotted.slick-slider {
		padding-bottom: 15px;
	}
	.c_carousel .slick-arrow {
		z-index: 1;
		left: 0;
		width: 50px;
		height: 50px;
	}
	.c_carousel .slick-arrow + .slick-list {
		margin: 0 20px;
	}
	.c_carousel .slick-next {
		left: auto;
		right: 0;
	}
	.c_carousel .slick-arrow:focus {
		background: #333;
	}
	.c_carousel .slick-arrow:hover {
		background: #ef6132;
	}
	.c_carousel .slick-arrow:before {
		left: 20px;
		border-width: 2px;
	}
	.c_carousel .slick-next:before {
		left: auto;
		right: 20px;
	}
	.c_carousel .slick-dots li {
		width: 20px;
	}
	.c_carousel .slick-slide {
		height: 100%!important;
		margin: 0;
	}
	.c_carousel .slick-slide li,
	.c_carousel .slick-slide div {
		height: auto;
	}
	.c_carousel .textbox {
		padding: 20px;
	}
	.c_carousel .text:not(:first-child) {
		margin-top: 5px;
	}
}

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

  page

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

/*  detail
========================================================================*/

/*  h1
------------------------------------------------*/

.c_h1-simple + div:not(.c_day) {
	margin-top: 20px;
}
.c_h1-simple {
	padding-bottom: 10px;
	font-size: 200%;
	border-bottom: 2px solid #eee;
}
.c_date {
	margin-top: 10px;
	text-align: right;
	color: #666;
}
.c_date + div:not(.c_date) {
	margin-top: 10px;
}

@media screen and (max-width: 767px) {
	.c_h1-simple + div:not(.c_date) {
		margin-top: 15px;
	}
	.c_h1-simple {
		font-size: 160%;
	}
}

/*  side
------------------------------------------------*/

.c_side .title a {
	display: block;
	padding: 10px 20px;
	background: #333;
	color: #fff;
	text-decoration: none;
}
@media (min-width: 768px) {
	.c_side .title a:hover {
		color: #ef6132;
	}
}
.c_side .menu li {
	margin-top: 1px;
}
.c_side .menu a {
	position: relative;
	display: block;
	padding: 8px 25px 8px 15px;
	background: rgba(0,0,0,.03);
	text-decoration: none;
	border-left: 2px solid rgba(0,0,0,.1);
}
@media (min-width: 768px) {
	.c_side .menu a:hover {
		background: rgba(0,0,0,.07);
	}
}
.c_side .menu a:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 15px;
	width: 6px;
	height: 6px;
	border-top: 2px solid #ccc;
	border-right: 2px solid #ccc;
	transform: rotate(45deg);
}

@media screen and (max-width: 1100px) {
	.c_side {
		margin-top: 40px;
	}
}

/*  top
========================================================================*/

/*  section-mainVisual
------------------------------------------------*/

.c_section-mainVisual.pbNested {
	position: relative;
	display: flex;
	justify-content: center;
	flex-direction: column;
	min-height: 300px;
	padding: 100px 15px;
}
.c_section-mainVisual .back {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
.c_section-mainVisual .back > div:first-child,
.c_section-mainVisual .back > div:first-child * {
	/* padding: 0; */
	height: 100%;
}
.c_section-mainVisual .back img {
	width: 100%;
	object-fit: cover;
}
.c_section-mainVisual .inner {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	color: #fff;
	text-align: center;
}
.c_section-mainVisual .title {
	font-size: 250%;
	text-shadow: 0 0 12px #000;
}
.c_section-mainVisual .text {
	margin-top: 20px;
	text-shadow: 0 0 12px #000;
	font-size: 110%;
}
.c_section-mainVisual .button {
	margin-top: 50px;
}
.c_section-mainVisual .button a {
	position: relative;
	display: inline-block;
	width: 100%;
	max-width: 400px;
	padding: 12px 30px;
	background: rgba(255,255,255,.9);
	color: #003F8E;
	border: 1px solid #003F8E;
	text-decoration: none;
}
.c_section-mainVisual .button a:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 25px;
	width: .4em;
	height: .4em;
	border-top: 2px solid #003F8E;
	border-right: 2px solid #003F8E;
	transform: rotate(45deg);
	transition: all .3s;
}
@media (min-width: 768px) {
	.c_section-mainVisual .button a:hover {
		background: #003F8E;
		color: #fff;
	}
	.c_section-mainVisual .button a:hover:after {
		border-color: #fff;
	}
}

@media screen and (max-width: 767px) {
	.c_section-mainVisual.pbNested {
		padding: 50px 15px;
	}
	.c_section-mainVisual .title {
		font-size: 160%;
	}
	.c_section-mainVisual .text {
		max-width: 400px;
		padding: 15px;
		background: rgba(0,0,0,.8);
		font-size: 100%;
		text-align: left;
	}
	.c_section-mainVisual .text p {
		background: none;
	}
	.c_section-mainVisual .text br {
		display: none;
	}
	.c_section-mainVisual .button {
		margin-top: 30px;
	}
}

/*  logo
------------------------------------------------*/

.c_image.logo {
	text-align: left;
}
.c_image.logo + div {
	margin-top: 30px;
}

@media screen and (max-width: 767px) {
	.c_image.logo + div {
		margin-top: 15px;
	}
	.c_image.logo img {
		width: 80%;	
	}
}

/*  form
========================================================================*/

.c_form .step {
	text-align: center;
	line-height: 1.4;
}
.c_form .step ul {
	display: flex;
	justify-content: space-between;
}
.c_form .step li {
	width: 33%;
	padding: 10px 5px;
	background: rgba(0,0,0,.1);
}
.c_form .step li.active {
	background: #333;
	color: #fff;
}
.c_form .step p:not(:first-child) {
	margin-top: 30px;
}
.c_form .form:not(:first-child) {
	margin-top: 40px;
}
.c_form table {
	width: 100%;
}
.c_form table:not(:first-child) {
	margin-top: 30px;
}
.c_form th,
.c_form td {
	padding: 20px;
	border: 1px solid #ccc;
	text-align: left;
	vertical-align: middle;
	font-weight: normal;
}
.c_form th {
	width: 30%;
	background: #333;
	color: #fff;
}
.c_form td {
	width: 70%;
}
.c_form .description {
	padding: 10px 15px;
	background: #eee;
	color: #999;
	font-size: 90%;
	border-left: 3px solid #999;
}
.c_form .description:not(:last-child) {
	margin-bottom: 20px;
}
.c_form .error {
	margin-bottom: 20px;
	padding: 10px 15px;
	background: rgba(204,51,0,0.1);
	color: #cc3300;
	font-size: 90%;
	border: 1px solid #cc3300;
}
.c_form input[type="text"],
.c_form select,
.c_form textarea,
.c_form input[type="submit"],
.c_form button {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-family: 'Roboto Condensed','Noto Sans JP','メイリオ',Meiryo, sans-serif;
	border-radius: 0;
	border: none;
}
.c_form input[type="text"],
.c_form textarea {
	width: 100%;
	padding: 10px 15px;
	border: 1px solid #ccc;
}

@media screen and (max-width: 767px) {
	.c_form .description:not(:last-child) {
		margin-bottom: 10px;
	}
	.c_form .error {
		margin-bottom: 10px;
	}
	.c_form th,
    .c_form td {
		display: block;
		width: 100%!important;
		padding: 15px;
	}
	.c_form th {
		padding: 10px 15px;
		border: none;
	}
	.c_form td {
		border-top: none;
	}
	.c_form input[type="text"],
	.c_form textarea {
		padding: 8px 10px;
	}
}

/*  input
------------------------------------------------*/

.c_form input:-webkit-autofill {
	box-shadow: 0 0 0 1000px white inset;
}

/*  mail  */
.c_form .pb-form-input-email-email {
	margin: 5px 0 10px;
}
.c_form .pb-form-input-email-confirm {
	margin-top: 5px;
}

/*  address  */
.c_form .pb-form-label-post-address-post {
	display: block;
	margin-bottom: 5px;
	vertical-align: middle;
}
.c_form input.pb-form-input-post-address-post {
	width: 130px;
	vertical-align: middle;
}
.c_form .pb-form-button-post-address-search {
	margin-left: 5px;
	padding: 11px 20px;
	background: #333;
	color: #fff;
	border: none;
	border-radius: 2px;
	cursor: pointer;
	transition: all .3s;
}
@media (min-width: 768px) {
	.c_form .pb-form-button-post-address-search:hover {
		background: #003F8E;
	}
}
.c_form .pb-form-label-post-address-address {
	display: block;
	width: 100%;
	margin: 10px 0 5px;
}

@media screen and (max-width: 767px) {
	.c_form .pb-form-button-post-address-search {
		padding: 9px 14px;
	}
	.c_form .pb-form-label-post-address-address {
		margin: 5px 0 3px;
	}
}

/*  select
------------------------------------------------*/

.c_form select {
	margin: 3px 0;
	padding: 10px 35px 10px 15px;
	border: 1px solid #ccc;
	background: url(../img/common/arrow_select.png) no-repeat calc(100% - 15px) center;
}
.c_form select + label {
	margin-left: 5px;
	vertical-align: bottom;
}
.c_form select + label:not(:last-child) {
	margin-right: 20px;
}

@media screen and (max-width: 767px) {
	.c_form select {
		padding: 8px 35px 8px 10px;
		background-position: calc(100% - 10px) center;
	}
	.c_form select + label {
		margin-left: 3px;
	}
	.c_form select + label:not(:last-child) {
		margin-right: 8px;
	}
}

/*  radio , checkbox
------------------------------------------------*/

.c_form input[type="radio"],
.c_form input[type="checkbox"] {
	margin-right: 5px;
	transform: translateY(6px);
}

/*  textarea
------------------------------------------------*/

.c_form textarea {
	resize: none;
	height: 150px;
}
.c_form textarea::-webkit-scrollbar {
    width: 3px;
}
.c_form textarea::-webkit-scrollbar-thumb {
	background: #999;
}
.c_form textarea::-webkit-scrollbar-track {
	background: #d9dcdf;
}

/*  privacy
------------------------------------------------*/

.c_form .privacy {
	margin-top: 30px;
	padding: 30px;
	background: #f5f5f5;
}
.c_form .privacy .inner {
	overflow: auto;
	height: 200px;
	padding-right: 15px;
}
.c_form .privacy .inner::-webkit-scrollbar {
    width: 3px;
}
.c_form .privacy .inner::-webkit-scrollbar-thumb {
	background: #999;
}
.c_form .privacy .inner::-webkit-scrollbar-track {
	background: #d9dcdf;
}
.c_form .privacy .title {
	font-weight: bold;
	font-size: 120%;
}
.c_form .privacy .title:not(:first-child) {
	margin-top: 30px;
}

@media screen and (max-width: 767px) {
	.c_form .privacy {
		padding: 15px;
	}
}

/*  button
------------------------------------------------*/

.c_form .button {
	margin-top: 40px;
	text-align: center;
}
.c_form .button ul {
	display: flex;
	align-items: center;
	justify-content: center;
}
.c_form .button li {
	width: 200px;
	margin: 0 5px;
}
.c_form .button input[type="submit"],
.c_form .button button {
	display: block;
	width: 100%;
	padding: 10px 20px;
	background: #333;
	color: #fff;
	border-radius: 2px;
	cursor: pointer;
	transition: all .3s;
}
.c_form .button button {
	background: #ccc;
	color: #000;
}
@media (min-width: 768px) {
	.c_form .button input[type="submit"]:hover {
		background: #003F8E;
	}
	.c_form .button button:hover {
		background: #eee;
	}
}

@media screen and (max-width: 767px) {
	.c_form .button {
		margin-top: 20px;
	}
	.c_form .button li {
		width: 50%;
	}
}

/*  search
========================================================================*/

.c_search:not(:first-child) {
	margin-top: 40px;
}
.c_search > div {
	max-width: 800px;
    margin: 0 auto;
}
.c_search .form {
	display: flex;
	justify-content: space-between;
}
.c_search .input {
	width: calc(100% - 80px);
}
.c_search .button {
	width: 70px;
}
.c_search input[type="text"],
.c_search input[type="submit"] {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	display: block;
	width: 100%;
	height: 100%;
	padding: 8px 15px 9px;
	font-family: 'Noto Sans JP', sans-serif;
	font-size: inherit;
	border-radius: 2px;
	line-height: 1;
}
.c_search input[type="text"] {
	border: 1px solid #ccc;
}
.c_search input[type="text"]:-webkit-autofill {
	box-shadow: 0 0 0 1000px white inset;
}
.c_search input[type="submit"] {
	background: #333;
	color: #fff;
	border: none;
	cursor: pointer;
	transition: all .3s;
}
@media (min-width: 768px) {
	.c_search input[type="submit"]:hover {
		background: #003F8E;
	}
}

/*  result
------------------------------------------------*/

.c_result > div {
	max-width: 800px;
    margin: 0 auto;
}
.c_result a {
	text-decoration: none;
}
.c_result .pager {
	margin: 40px 0;
}
.c_result .pager ul {
	display: flex;
	justify-content: space-between;
}
.c_result .pager .connect-link-disable {
	opacity: .3;
	pointer-events: none;
}
.c_result .pager .prev a,
.c_result .pager .next a {
	position: relative;
	display: block;
	padding: 5px 20px;
	background: #eee;
}
.c_result .pager .prev a:before,
.c_result .pager .next a:after {
	content: '';
	position: relative;
	top: -2px;
	display: inline-block;
	width: .4em;
	height: .4em;
	border-top: 1px solid #333;
	border-right: 1px solid #333;
	transition: all .3s;
}
.c_result .pager .prev a:before {
	margin-right: 10px;
	transform: rotate(-135deg);
}
.c_result .pager .next a:after {
	margin-left: 10px;
	transform: rotate(45deg);
}
@media (min-width: 768px) {
	.c_result .pager a:hover {
		background: #003F8E;
		color: #fff;
	}
	.c_result .pager a:hover:before,
	.c_result .pager a:hover:after {
		border-color: #fff!important;
	}
}
.c_result .pager .count {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.c_result .list {
	border-top: 1px solid #ccc;
}
.c_result .list li {
	border-bottom: 1px solid #ccc;
}
.c_result .list a {
	position: relative;
	display: block;
	padding: 15px 35px 15px 0;
}
.c_result .list a:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 15px;
	width: 5px;
	height: 5px;
	border-top: 2px solid #ccc;
	border-right: 2px solid #ccc;
	transform: rotate(45deg);
	transition: all .3s;
}
@media (min-width: 768px) {
	.c_result .list a:hover:after {
		border-color: #666;
		right: 5px;
	}
}
.c_result .list .text {
	color: #999;
	font-size: 85%;
}

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

  category

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

/*  link  */

[class*='c_p-'] a {
	text-decoration: none;
}

/*  label  */

[class*='c_p-'] .label {
	width: 90px;
	color: #fff;
	font-size: 10px;
	text-align: center;
}
[class*='c_p-'] .label + .label {
	margin-left: 2px;
}
[class*='c_p-'] .label.news {
	background: #970d08;
}
[class*='c_p-'] .label.press {
	background: #0e7635;
}
[class*='c_p-'] .label.event {
	background: #028893;
}
[class*='c_p-'] .label.seminar {
	background: #c7b104;
}

/*  hot  */

[class*='c_p-'] .item.hot:after {
	content: 'HOT';
	position: absolute;
	top: -5px;
	right: -5px;
	background: #970d08;
	color: #fff;
	width: 25px;
	height: 25px;
	border-radius: 50%;
	line-height: 25px;
	text-align: center;
	font-size: 10px;
	pointer-events: none;
	animation: bound-anim 1.5s infinite;
}
@keyframes bound-anim {
	0% {
		transform: rotate(-10deg);
	}
	50% {
		transform: rotate(10deg);
	}
	100% {
		transform: rotate(-10deg);
	}
}

/*  p-category
========================================================================*/

.c_p-category:not(:first-child) {
	margin-top: 30px;
}
.c_p-category {
	border-bottom: 1px solid #ccc;
}
.c_p-category .item {
	position: relative;
}
.c_p-category a {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	padding: 15px 35px 15px 0;
	border-top: 1px solid #ccc;
}
.c_p-category a:after {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	margin: auto;
	right: 15px;
	width: 5px;
	height: 5px;
	border-top: 2px solid #ccc;
	border-right: 2px solid #ccc;
	transform: rotate(45deg);
	transition: all .3s;
}
@media (min-width: 768px) {
	.c_p-category a:hover:after {
		border-color: #666;
		right: 5px;
	}
}
.c_p-category .date {
	width: 80px;
}
.c_p-category .title {
	width: 100%;
	margin-top: 7px;
}
.c_p-category .new {
	position: relative;
	top: 4px;
	display: inline-block;
	margin-left: 5px;
	padding: 3px 5px 2px;
	background: #da162f;
	color: #fff;
	font-size: 10px;
	line-height: 1;
}

/*  p-card
========================================================================*/

.c_p-card:not(:first-child) {
	margin-top: 30px;
}
.c_p-card a {
	text-decoration: none;
}
.c_p-card .item:not(:first-child) {
	margin-top: 15px;
}
.c_p-card .item {
	position: relative;
	background: #f1f1f1;
}
.c_section:not(.white) .c_p-card .item {
	background: #fff;
}
.c_p-card .image {
	overflow: hidden;
	display: block;
	background: #ddd;
	text-align: center;
}
@media (min-width: 768px) {
	.c_p-card a:hover .image img {
		transform: scale(1.1);
	}
}
.c_p-card .textbox {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	padding: 15px;
}
.c_p-card .new {
	position: absolute;
	top: 0;
	left: 0;
	padding: 0 5px;
	background: #da162f;
	color: #fff;
	pointer-events: none;
}
.c_p-card .date {
	margin-right: 15px;
}
.c_p-card .title {
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	width: 100%;
	margin-top: 5px;
}

/*  col-1
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
	.c_p-card.col-1 a {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: 30px;
	}
	.c_p-card.col-1 .image {
		width: 31%;
	}
	.c_p-card.col-1 .textbox {
		width: 66%;
		padding: 0;
	}
	.c_p-card.col-1 .title {
		font-size: 150%;
	}
}

/*  col-3
------------------------------------------------*/

@media print, screen and (min-width: 768px) {
    .c_p-card.col-3 > div {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	.c_p-card.col-3 > div:after {
		content: '';
		display: block;
		width: 32%;
	}
	.c_p-card.col-3 .item {
		width: 32%;
		margin-top: 0;
	}
	.c_p-card.col-3 .item:nth-child(n+4) {
		margin-top: 40px;
	}
}