@charset "UTF-8";
html {
	font-size: 16px;
	scroll-behavior: smooth
}
@media screen and (max-width:320px) {
	html {
		font-size: 13px
	}
}
@media screen and (min-width:600px) {
	html {
		font-size: 32px
	}
}
body {
	font-family: 'Noto Sans JP', 'Avenir', 'Helvetica Neue', 'Helvetica', 'Arial', 'Hiragino Sans', 'ヒラギノ角ゴシック', YuGothic, 'Yu Gothic', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic', 'sans-serif';
	color: #333;
	background-color: #fff
}
a {
	text-decoration: none
}
img {
	max-width: 100%;
	height: auto
}
p {
	line-height: 1.6
}
h1, h2 {
	text-align: center
}
section {
	margin-bottom: 160px
}
.color-primary {
	color: #155497
}
.bgColor-primary {
	background-color: #155497
}
.color-secondary {
	color: #E61673
}
.bgColor-secondary {
	background-color: #E61673
}
.boldTxt {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 900
}
.anton {
	font-family: 'Anton', sans-serif;
	letter-spacing: 4px
}
.flexbox {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between
}
.mb-1 {
	margin-bottom: 1rem
}
.inner {
	max-width: 1028px;
	margin: auto;
	padding: 0 14px
}
.sp {
	display: block
}
.logo {
	display: inline-block;
	text-align: center;
	color: #FFF
}
.underLine {
	display: inline;
    background-position: left -100% center;
    padding-bottom: 0.9em;
    background-size: 200% 0.3em;
    background-repeat: repeat-x;
    background-image: linear-gradient(to right, rgba(255, 255, 255, 0) 50%, rgb(255, 255, 102) 50%);
    transition: background-position 2s 0.1s;
}
Header {
	background-color: #155497;
	margin-bottom: 64px
}
#firstView .topImage {
	margin-bottom: 24px
}
#issue {
	margin-bottom: 64px
}
#issue .issueImage {
	margin-bottom: 32px
}
#issue .issueList li {
	border: 2px solid #333;
	margin-bottom: 32px;
	padding: 25px;
	border-radius: 55px;
	font-weight: 700
}
#issue .issueList span {
	font-size: 24px;
	color: #155497
}
#issue .issueList em {
	font-size: 48px;
	font-weight: 700;
	vertical-align: -10px
}
#issue .issueList div {
	display: inline-block;
	font-size: 30px;
	margin-left: 12px;
	vertical-align: -4px
}
#issue .issueList strong {
	color: #155497
}
#catch .catchInner h3 {
	text-align: center;
	margin-top: 40px
}
#catch .catchInner h3 img {
	border: 4px solid #155497;
	padding: 16px 64px;
	border-radius: 45px;
	display: inline-block;
	margin: 0 auto;
	background-color: #fff
}
#catch .catchInner ul {
	background-color: #fff;
	padding: 40px 40px 20px 60px;
	border: 4px solid #155497;
	border-radius: 16px;
	margin-top: -45px
}
#catch .catchInner ul li {
	list-style: disc;
	margin-bottom: 24px;
	font-weight: 700;
	line-height: 1.4
}
#catch .catchInner ul li:first-child {
	margin-bottom: 6px
}
#catch .catchInner ul li strong {
	color: #E61673
}
#catch .catchInner ul li strong em {
	font-size: 64px;
	vertical-align: -4px
}
#about h2 {
	background-color: #155497;
	padding: 4px 0;
	margin-bottom: 64px
}
#about .aboutTitle {
	text-align: center
}
#about .aboutTitle img, #about .aboutFlow img {
	margin-bottom: 40px
}
#about .flow {
	position: relative
}
#about .flow img.busy {
	position: absolute;
	bottom: 20px;
	right: -20px
}
#about .flow ul {
	display: flex;
	flex-wrap: wrap
}
#about .flow li {
	list-style: none
}
#about .flow li.wrap {
	background-color: #EDECF6;
	width: 180px;
	margin-right: 20px;
	margin-bottom: 40px;
	list-style: none;
	padding: 10px;
	position: relative
}
#about .flow .wrap>img {
	position: absolute;
	right: -32px;
	z-index: 1
}
#about .flow li em {
	width: 40px;
	height: 40px;
	background-color: #fff;
	border-radius: 40px;
	text-align: center;
	margin: 0 auto;
	border: 2px solid #155497;
	font-size: 18px;
	font-weight: 700;
	color: #155497;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center
}
#about .flow li p {
	text-align: center;
	line-height: 1.4;
	font-weight: 700;
	font-size: 18px;
	margin-top: 8px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 60px
}
#about .flow li ul li {
	background-color: #155497;
	color: #fff;
	font-size: 20px;
	width: 45%;
	text-align: center;
	height: 42px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	margin: 2.5%;
	border-radius: 4px;
	padding: 0 4px
}
#about .flow li ul li span {
	line-height: 1.25
}
#about .flow li ul li span.f16, #about .flow li ul li span.f14, #about .flow li ul li span.f12, #about .flow li ul li span.f10 {
	letter-spacing: -.075em
}
#about .flow li ul li span.f16 {
	font-size: 16px
}
#about .flow li ul li span.f14 {
	font-size: 14px
}
#about .flow li ul li span.f12 {
	font-size: 12px
}
#about .flow li ul li span.f10 {
	font-size: 10px
}
section#cast {
	margin-top: -80px
}
section.category {
	margin-bottom: 40px
}
section#staff {
	margin-bottom: 160px
}
.category .inner {
	background-color: #EDECF6;
	padding: 0
}
.category h2 {
	background-color: #155497;
	color: #fff;
	font-size: 40px;
	font-weight: 700;
	padding: 20px;
	margin-bottom: 40px
}
.category h3 {
	background-color: #155497;
	display: inline-block;
	color: #fff;
	width: 200px;
	text-align: center;
	padding: 8px 0;
	margin-bottom: 16px;
	border-radius: 4px;
	font-size: 24px;
	letter-spacing: -.075em
}
.category ul {
	margin-bottom: 32px;
	line-height: 1.6;
	padding-left: 20px
}
.category ul:last-child {
	margin-bottom: 0
}
.category ul li {
	list-style: disc;
	font-size: 16px;
	font-weight: 700
}
.category ul li div {
	font-weight: 400;
	font-size: 14px
}
.category .castMenu, .category .clientMenu, .category .groupMenu, .category .staffMenu {
	display: flex;
	flex-wrap: wrap;
	padding-bottom: 40px
}
.category .menuLeft, .category .menuRight {
	width: 50%;
	display: flex;
	flex-direction: column;
	padding: 0 2.5%
}
.category .menuLeft {
	border-right: 1px solid #fff
}
.category .menuRight {
	border-left: 1px solid #fff
}
#price .title h2 {
	font-weight: 700;
	display: flex;
	align-items: center
}
#price .title h2::before, #price .title h2::after {
	content: '';
	flex-grow: 1;
	height: 3px;
	background: #333
}
#price .title h2::before {
	margin-right: 30px
}
#price .title h2::after {
	margin-left: 30px
}
#price .title p {
	font-size: 14px;
	text-align: center;
	margin: 4px;
	color: #757575
}
#price .fee {
	font-weight: 700;
	text-align: center;
	margin-top: 16px;
	margin-bottom: 64px
}
#price .fee .status {
	font-size: 48px;
	background-color: #155497;
	color: #fff;
	padding: 8px 24px;
	border-radius: 8px;
	vertical-align: 32px;
	margin-right: 4px
}
#price .fee .payment {
	font-size: 156px;
	color: #155497;
}
#price .fee .payment .small {
	font-size: 48px
}
#price .fee .note {
	font-size: 24px
}
#price .feeList {
	font-weight: 700;
	margin-top: 40px;
	margin-bottom: 80px
}
#price .feeList ul {
	display: flex;
	flex-wrap: wrap;
	row-gap: 40px;
	column-gap: 26px;
	font-size: 16px;
	text-align: center
}
#price .feeList ul li {
	width: 316px
}
#price .feeList li div {
	border: 1px solid #333;
	padding: 12px;
	border-radius: 4px;
	margin-bottom: 16px;
	font-weight: 400
}
#price .feeList .status {
	font-size: 13px;
	background-color: #155497;
	color: #fff;
	padding: 6px;
	border-radius: 4px;
	vertical-align: 8px;
	margin-right: 4px
}
#price .feeList .payment {
	font-size: 42px;
	color: #155497;
}
#price .feeList .payment .small {
    font-size: 18px;
    margin-left: -10px;
}
#price .feeList .note {
	font-size: 12px;
	font-weight: 400
}
#price .feeList li p {
	margin-top: 8px
}
#action {
	margin-top: -40px
}
#action .title {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	margin-bottom: 40px
}
#action .title img {
	margin-right: 8px
}
#action .title h2 {
	font-weight: 700;
	margin-top: 16px
}
#action p {
	font-size: 20px;
	border: 2px solid #333;
	padding: 90px 80px 40px;
	margin-top: -110px
}
#action p strong {
	color: #E61673;
	font-weight: 700
}
#contactUs {
	text-align: center
}
#contactUs a {
	background-color: #CC146D;
	color: #fff;
	padding: 24px 48px;
	border-radius: 4px;
	font-weight: 700
}
Footer {
    height: 50px;
    padding-bottom: 170px;
    text-align: center;
    background-color: #111;
    margin-top: 120px;
}
Footer p {
	line-height: 50px;
	color: #fff;
	font-size: 14px;
	font-weight: 700
}
#main {
	margin-top: 0;
	padding-top: 0
}
.overlayArea {
	display: none;
	position: fixed;
	width: 100%;
	bottom: 0;
	left: 0;
	z-index: 100;
	background: rgba(0, 0, 0, .75);
	text-align: center
}
.overlayArea_btn {
	background-color: #CC146D;
	color: #fff;
	padding: 24px 48px;
	border-radius: 4px;
	font-weight: 700;
	display: inline-block;
	margin: 20px 0
}
.pagetop {
	height: 50px;
	width: 50px;
	position: fixed;
	right: 30px;
	bottom: 30px;
	background: #fff;
	border: solid 2px #333;
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	z-index: 200
}
.pagetop__arrow {
	height: 10px;
	width: 10px;
	border-top: 3px solid #333;
	border-right: 3px solid #333;
	transform: translateY(20%) rotate(-45deg)
}
.scroll {
	display: none;
	padding-top: 70px;
	position: relative;
}
.scroll::before {
	animation: scroll 3.5s infinite;
	border: 2px solid #155497;
	border-width: 0 0 2px 2px;
	content: "";
	display: inline-block;
	margin: auto;
	position: absolute;
	top: 0;
	right: 0;
	left: 0;
	transform: rotate(-45deg);
	width: 20px;
	height: 20px;
}
@keyframes scroll {
	0% {
		transform: rotate(-45deg) translate(0, 0);
	}
	80% {
		transform: rotate(-45deg) translate(-30px, 30px);
	}
	0%, 80%, 100% {
		opacity: 0;
	}
	40% {
		opacity: 1;
	}
}
@media screen and (max-width:768px) {
	#firstView {
		margin: 160px 0 60px;
	}
	section {
		margin-bottom: 64px;
	}
	#issue .issueList span {
		margin-top: -8px;
		display: inline-block
	}
	#issue .issueList em {
		font-size: 32px;
		vertical-align: 0
	}
	#issue .issueList li {
		border-radius: 16px;
		line-height: 1.4;
		margin-bottom: 16px
	}
	#issue .issueList div {
		display: inline-block;
		font-size: 30px;
		margin-left: 0;
		vertical-align: -4px;
		margin-top: 0
	}
	#catch .catchImage {
		margin-bottom: 32px
	}
	#catch .catchInner ul {
		margin-top: -32px
	}
	#catch .catchInner ul li {
		margin-bottom: 16px
	}
	#catch .catchInner ul li:first-child {
		margin-bottom: 16px;
		line-height: 1
	}
	#catch .catchInner h3 {
		width: 80%;
		margin: 0 auto
	}
	#catch .catchInner h3 img {
		padding: 16px 24px;
		border-radius: 8px
	}
	#catch .catchInner ul li strong em {
		font-size: 64px;
		vertical-align: -2px
	}
	#about .aboutTitle img, #about .aboutFlow img {
		margin-bottom: 0
	}
	#about h2 {
		margin-bottom: 24px
	}
	#about .aboutImage img {
		width: 80%
	}
	#about .flow li.wrap {
		width: 47.5%;
		margin: 1.25%
	}
	#about .flow .wrap>img {
		right: -16px
	}
	#about .flow li ul li {
		font-size: 18px
	}
	#about .flow li ul li span.f16 {
		font-size: 14px
	}
	#about .flow img.busy {
		position: inherit;
		bottom: 0;
		right: 0;
		margin: 20px auto;
		display: block;
		width: 50%
	}
	#about .detail>img {
		margin-bottom: 20px
	}
	section#cast {
		margin-top: 0
	}
	.category h2 {
		font-size: 20px;
		padding: 16px
	}
	.category h3 {
		width: auto;
		font-size: 16px;
		letter-spacing: 0;
		margin-bottom: 0
	}
	.category ul {
		margin-bottom: 16px
	}
	.category ul li {
		font-size: 14px;
		font-weight: 400;
		margin-top: 8px
	}
	.category ul li div {
		font-size: 12px
	}
	section#staff {
		margin-bottom: 64px
	}
	#price .fee {
		margin-top: 16px;
	}
	#price .fee .status {
		font-size: 16px;
		padding: 2px 8px;
		vertical-align: 10px;
		border-radius: 4px
	}
	#price .fee .note {
		font-size: 12px
	}
	#price .fee .payment {
		font-size: 48px
	}
	#price .fee .payment .small {
		font-size: 24px
	}
	#price .feeList ul li {
		width: 95%;
		margin: 0 auto
	}
	#price .feeList .note {
		font-size: 12px
	}
	#action .title h2 {
		line-height: 1.6;
		text-align: left
	}
	#action p {
		padding: 90px 20px 40px
	}
	.pagetop {
		right: 8px;
		bottom: 90px
	}
	Footer {
		height: auto;
        padding-bottom: 12vh;
	}
	Footer p {
		line-height: 1.6;
		padding: 10px
	}
	.scroll {
        display: block;
        text-align: center;
        margin-bottom: 80px;
	}
	.pagetop {
		display: none;
	}
}
@media screen and (max-width:414px) {
	#issue .issueList li {
		padding: 5px 10px 10px 10px
	}
	#issue .issueList div {
		font-size: 20px;
		margin-left: 12px;
		margin-top: -4px
	}
	#catch .catchInner ul {
		padding: 60px 20px 20px 40px
	}
	#catch .catchInner ul li strong em {
		font-size: 32px
	}
	#action .title h2 {
		width: 50%
	}
	Footer {
		height: auto;
        padding-bottom: 16vh;
	}
}
