@charset "UTF-8";
/* CSS Document */

/**
 * Noto Sans CJK JP: https://www.google.com/get/noto/#sans-jpan
 * Noto Sans JP: https://fonts.google.com/earlyaccess#Noto+Sans+JP
 */
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 100;
  src: local("Noto Sans CJK JP Thin"),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Thin.woff2) format('woff2'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Thin.woff) format('woff'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Thin.otf) format('opentype');
}
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 300;
  src: local("Noto Sans CJK JP Light"),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Light.woff2) format('woff2'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Light.woff) format('woff'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Light.otf) format('opentype');
}
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 400;
  src: local("Noto Sans CJK JP Regular"),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff2) format('woff2'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.woff) format('woff'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Regular.otf) format('opentype');
}
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 500;
  src: local("Noto Sans CJK JP Medium"),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Medium.woff2) format('woff2'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Medium.woff) format('woff'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Medium.otf) format('opentype');
}
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 700;
  src: local("Noto Sans CJK JP Bold"),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.woff2) format('woff2'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.woff) format('woff'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Bold.otf) format('opentype');
}
@font-face {
  font-family: 'Noto Sans JP';
  font-style: normal;
  font-weight: 900;
  src: local("Noto Sans CJK JP Black"),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Black.woff2) format('woff2'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Black.woff) format('woff'),
       url(//fonts.gstatic.com/ea/notosansjp/v5/NotoSansJP-Black.otf) format('opentype');
}

*, *:before, *:after {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
}
*:focus {
	outline: none;
}
html, body {
	margin: 0;
	padding: 0;
	color: inherit;
	font-size: 16px;
	font-family: 'Noto Sans JP','メイリオ', Meiryo, sans-serif;
	font-weight: 400;
	-webkit-text-size-adjust: 100%; /*スマホ横の時、文字サイズを変更させない*/
	/* font-feature-settings: "palt"; */
	background: #fff;
}
a {
	color: inherit;
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    tap-highlight-color: rgba(0, 0, 0, 0);
}
a:hover {
	text-decoration: none;
}
a.disabled {
	display: block;
	pointer-events: none;
	opacity: 0.3;
}
img {
	/* display: block; */
	width: 100%;
}
#wrap {
	position: relative;
	min-width: 1000px;
	overflow: hidden;
}
.clearfix:after {
    content:" ";
    display:block;
    clear:both;
}
.only_pc {
	display: block !important;
}
.only_sp {
	display: none !important;
}

@media (max-width: 768px) {
	#wrap {
		min-width: auto;
	}
	.only_pc {
		display: none !important;
	}
	.only_sp {
		display: block !important;
	}
}

/*----------
 mv
----------*/
#mv {
	width: 100%;
	height: 660px;
	background: url(../../img/top/mv_bg.jpg) no-repeat center / cover;
}
#mv .inner {
	position: relative;
	width: 1000px;
	margin: auto;
}
#mv .ttl {
	position: absolute;
	top: 150px;
	left: 25px;
	width: 349px;
}

@media (max-width: 768px) {
	#mv {
		height: 330px;
		background: url(../../img/top/mv_bg.jpg) no-repeat right 20% center / cover;
	}
	#mv .inner {
		width: 100%;
	}
	#mv .ttl {
		top: 125px;
		right: 25px;
		width: 175px;
	}
}

/*----------
 cts
----------*/
#cts {
	width: 1000px;
	padding-bottom: 50px;
	margin: 0 auto;
	color: #353535;
}
.inner {
	padding-top: 50px;
}

/*-- hr --*/
.hr {
	width: 100%;
	height: 1px;
	background-color: #f4f4f4;
	margin-bottom: 20px;
}

/*-- ttl --*/
.ttlA {
	font-size: 24px;
	font-weight: bold;
	line-height: 1.2;
	color: #FF8899;
	text-align: center;
	margin-bottom: 20px;
}
.ttlB {
	position: relative;
	font-size: 24px;
	font-weight: bold;
	line-height: 1.2;
	color: #fb769c;
	padding-left: 30px;
	margin-bottom: 20px;
}
.ttlB:before {
	content: "";
	display: block;
	position: absolute;
	top: 3px;
	left: 0;
	width: 22px;
	height: 24px;
	background: url(../../img/top/icon.png) no-repeat center / cover;
}
.mt {
	margin-top: 40px;
}
.ttlC {
	font-size: 16px;
	font-weight: bold;
	line-height: 1.2;
	margin-bottom: 20px;
}
.ttlC:before {
	content: "●";
	display: inline-block;
	color: #fb769c;
	margin-right: 10px;
}

/*-- txt --*/
.txt {
	font-size: 16px;
	line-height: 1.5;
	margin-bottom: 20px;
}
.txt b {
	font-weight: bold;
}
.txtC {
	text-align: center;
}

/*-- a --*/
a {
	color: #fb769c;
	text-decoration: underline;
}
a:hover {
	text-decoration: none;
}
a.link:after {
	content: "";
	display: inline-block;
	width: 16px;
	height: 16px;
	background: url(../../img/top/icon_link.png) no-repeat center / cover;
	margin-left: 5px;
}
a.pdf:after {
	content: "";
	display: inline-block;
	width: 14px;
	height: 16px;
	background: url(../../img/top/icon_pdf.png) no-repeat center / cover;
	margin-left: 5px;
}

/*-- img --*/
.img {
	width: 100%;
	margin-bottom: 20px;
}
.img a {
	display: block;
	width: 100%;
	transition: opacity 0.3s;
}
.img a:hover {
	opacity: 0.7;
}
.img img {
	display: block;
	width: 100%;
}

/*-- list --*/
.list {
	list-style: none;
	padding: 0;
	margin: 0;
}
.list li {
	font-size: 16px;
	text-indent: -1em;
	line-height: 1.5;
	padding-left: 1em;
	margin-bottom: 20px;
}

@media (max-width: 768px) {
	#cts {
		width: 96%;
	}
	.inner {
		padding-top: 30px;
	}
	/*-- hr --*/
	.hr {
		margin-bottom: 10px;
	}
	
	/*-- ttl --*/
	.ttlA {
		font-size: 22px;
		margin-bottom: 10px;
	}
	.ttlB {
		font-size: 22px;
		padding-left: 30px;
		margin-bottom: 10px;
	}
	.ttlB:before {
		width: 22px;
		height: 24px;
	}
	.mt {
		margin-top: 20px;
	}
	.ttlC {
		font-size: 14px;
		margin-bottom: 10px;
	}
	.ttlC:before {
		margin-right: 10px;
	}
	
	/*-- txt --*/
	.txt {
		font-size: 14px;
		margin-bottom: 10px;
	}
	
	/*-- img --*/
	.img {
		margin-bottom: 10px;
	}
	
	/*-- list --*/
	.list li {
		font-size: 14px;
		margin-bottom: 10px;
	}
}

/*----------
 about
----------*/
#about .noteA {
	margin: 0 30px;
	padding: 20px 25px;
	background-color: #f4f4f4;
}
#about .noteA p {
	margin: 0;
}
#about .imgBlock {
	display: flex;
}
#about .imgBlock .item {
	width: 50%;
	margin: auto;
}
#about .imgBlock .item img {
	width: 100%;
}
#about .imgBlock .item .img {
	display: block;
	width: 180px;
	margin: auto;
}
#about .imgBlock .item .txt {
	font-size: 14px;
	text-align: center;
	line-height: 1.5;
	margin-top: 10px;
}

@media (max-width: 768px) {
	#about .noteA {
		margin: 0 2%;
		padding: 5px 15px;
	}
	#about .imgBlock {
		flex-direction: column;
	}
	#about .imgBlock .item {
		width: 100%;
		margin: auto;
	}
	#about .imgBlock .item:not(last-child) {
		margin-bottom: 30px;
	}
	#about .imgBlock .item img {
		width: 100%;
	}
	#about .imgBlock .item .img {
		display: block;
		width: 180px;
		margin: auto;
	}
	#about .imgBlock .item .txt {
		font-size: 14px;
		text-align: center;
		margin-top: 10px;
	}
}

/*----------
 past_result
----------*/
.list_past_result {
	display: flex;
	flex-wrap: wrap;
	width: 960px;
	margin: 0 auto;
}
.list_past_result li {
	display: inline-block;
	margin: 0 10px 20px;
}

@media (max-width: 768px) {
	.list_past_result {
		width: 100%;
	}
	.list_past_result li {
		width: 46%;
		margin: 0 2% 4%;
	}
}

/*----------
 schedule-incorp
----------*/
#schedule-incorp .box {
	padding: 20px;
	background-color: #f4f4f4;
}
.list_schedule_incorp {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 20px;
	margin: 0 auto;
}
.list_schedule_incorp li {
	width: calc(50% - 10px);
	height: 100px;
	margin: 0;
}

.list_schedule_incorp li a {
	display: flex;
	align-items: center;
	position: relative;
	width: 100%;
	height: 100%;
	background-color: #fb769c;
	padding: 10px 40px 10px 10px;
	color: #fff;
	line-height: 1.5;
	font-size: 16px;
	font-weight: bold;
	text-decoration: none;
	transition: opacity 0.3s;
	opacity: 1;
}
.list_schedule_incorp li a:after {
	content: "";
	display: block;
	width: 10px;
	height: 5px;
	border-top: 5px solid transparent;
	border-bottom: 5px solid transparent;
	border-left: 5px solid #fff;
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
}
.list_schedule_incorp li a:hover {
	opacity: 0.7;
}
@media (max-width: 768px) {
	#schedule-incorp .box {
		padding: 20px 10px;
	}
	.list_schedule_incorp {
		flex-direction: column;
		gap: 10px;
	}
	.list_schedule_incorp li {
		width: 100%;
		height: 80px;
	}
	.list_schedule_incorp li a {
		font-size: 14px;
		line-height: 1.2;
	}
}

/*----------
 footWrap
----------*/
#footWrap .inFooter {
	background: rgba(114,113,113,0.15) !important;
}
#footWrap .inFooter:before {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 180px;
	background: #ca5577;
}
#footWrap .inFooter > div {
	background: none !important;
}
#footWrap .inFooter .privacy {
	position: relative;
	padding-top: 20px;
	margin-top: 40px !important;
}
#footWrap .inFooter .privacy a {
	color: #fff;
}
#footWrap .inFooter small {
	position: relative;
	color: #fff;
}

@media (max-width: 768px) {
	#footWrap .inFooter:before {
		height: 170px;
	}
	#footWrap .inFooter .privacy {
		position: relative;
		padding-top: 20px;
		margin-top: 20px !important;
	}
}

/*----------
 notice
----------*/
#notice p {
	font-size: 16px;
    font-weight: 700;
	color: #494340;
	text-align: center;
	line-height: 1.2;
}
#notice p a {
	display: block;
	width: 100%;
	padding: 20px 30px;
	background-color: #fcf70a;
	color: #494340;
	text-decoration: none;
	box-sizing: border-box;
}
#notice p a:hover {
	opacity: 0.7;
}

@media (max-width: 768px) {
	#notice p a {
		padding: 20px 25px;
	}
}