@charset "utf-8";

/* visual
----------------------------------------------- */

.visual {
	position: relative;
	z-index: 1;
}
.visual:after {
	display: block;
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 50%;
	background-color: #1a1a1c;
}
.visual__inner {
	position: relative;
	margin: 0 90px;
	z-index: 1;
}
.visual__image {
	position: relative;
	overflow: hidden;
}
.visual__image img {
	width: 100%;
	height: auto;
}
.visual__banner {
	position: absolute;
	right: -50px;
	bottom: -50px;
}

/* ready */

.js-indicate-ready.visual:after,
.js-indicate-ready .visual__image img {
	transition-property: transform;
	transition-timing-function: cubic-bezier(0.86, 0, 0.07, 1);
}
.js-indicate-ready.visual:after {
	transform: scaleX(0);
	transform-origin: left;
}
.js-indicate-ready .visual__image img {
	transform: translateY(100%);
}

/* start */

.js-indicate-start.visual:after {
	transform: scaleX(1);
	transform-origin: right;
	transition-duration: 0.8s;
}
.js-indicate-start .visual__image img {
	transform: translateY(0);
	transition-duration: 0.8s;
}

/* toptitle
----------------------------------------------- */

.toptitle__label {
	display: flex;
	align-items: center;
	font-size: 14px;
	font-weight: 500;
}
.toptitle__label em {
	display: block;
	position: relative;
	height: 16px;
	font-family: "Roboto", sans-serif;
	font-size: 16px;
	font-weight: 500;
	font-style: normal;
}
.toptitle__label em:after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: -65px;
	width: 60px;
	height: 1px;
	background-color: #000;
}
.toptitle__label span {
	margin: 0 0 0 70px;
	height: 14px;
}
.toptitle__title {
	margin: 10px 0 0;
	font-family: "Permanent Marker", cursive;
	font-size: 70px;
	line-height: 70px;
}
.toptitle__title--mini {
	margin: 20px 0 0;
	font-size: 50px;
	line-height: 50px;
}
.toptitle__title small {
	font-size: 35px;
}
.toptitle__text {
	padding: 0 20px 0 0;
	line-height: 1.5;
	font-size: 14px;
}

.toptitle--center {
	text-align: center;
}
.toptitle--center .toptitle__label {
	justify-content: center;
}

.toptitle--nega {
	color: #fff;
}
.toptitle--nega .toptitle__label em:after {
	background-color: #fff;
}

.toptitle__comingsoon {
	margin: 25px 0 0;
	font-size: 30px;
}

/* newstopics
----------------------------------------------- */

.newstopics {
	margin: auto;
	max-width: 1500px;
	overflow: hidden;
}
.newstopics__inner {
	position: relative;
	margin: 0 90px;
	padding: 150px 0;
}
.newstopics__base {
	margin: 0 0 0 300px;
	background-color: #fff;
	/*box-shadow: 0 20px 30px rgba(0,0,0,0.1);*/
}
.newstopics__lists {
	margin: 0 75px;
	padding: 40px 0;
}
.newstopics__list {
	display: flex;
	justify-content: space-between;
	padding: 7px 0;
	border-top: 1px solid #dcdcdc;
}
.newstopics__list:last-child {
	border-bottom: 1px solid #dcdcdc;
}
.newstopics__date {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100px;
	height: 20px;
	font-family: "Roboto", sans-serif;
	color: #ff2d59;
	font-size: 13px;
	background-color: #1a1a1c;
}
.newstopics__text {
	width: calc(100% - 120px);
	font-size: 16px;
	line-height: 24px;
}

/* toptitle */

.newstopics .toptitle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 40px;
	z-index: 1;
}

/* readmore
----------------------------------------------- */

.readmore {
	display: flex;
	justify-content: center;
}
.readmore a {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 171px;
}
.readmore__label {
	height: 14px;
}
.readmore__icon {
	display: block;
	position: relative;
	width: 30px;
	height: 30px;
	border: 2px solid #000;
	border-radius: 30px;
	box-sizing: border-box;
}
.readmore__icon:after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: 13px;
	margin: -1px 0 0;
	width: 50px;
	height: 2px;
	background-color: #ff2d59;
}

.readmore--right {
	justify-content: flex-end;
}

/* message
----------------------------------------------- */

.message {
	color: #000;
	text-align: center;
	background-color: #1a1a1c;
}
.message__inner {
	padding: 75px 0;
}
.message__texts {
	padding: 4px 0 0;
}
.message__text {
	padding: 20px 0 0;
	font-size: 16px;
	line-height: 32px;
}
.message__text--title {
	font-size: 24px;
	font-weight: 700;
}
.message__text--title small {
	font-size: 14px;
}

/* readmore */

.message .readmore {
	margin: 40px auto 0;
}

/* job
----------------------------------------------- */

.job {
	margin: auto;
	max-width: 1500px;
}
.job__inner {
	margin: 0 90px;
	padding: 150px 0;
}
.job__title {
	position: relative;
	margin: 70px 0 0;
	padding: 0 0 0 18px;
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 0.05em;
}
.job__title:after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	left: 0;
	margin: -10px 0 0;
	width: 5px;
	height: 20px;
	background-color: #ff2d59;
}
.job__title em {
	font-style: normal;
}
.job__lists {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	padding: 10px 0 0;
}
.job__list {
	position: relative;
	margin: 15px 0 0;
	width: calc(50% - 30px);
}
.job__list a {
	display: flex;
	align-items: center;
	position: relative;
	padding: 0 0 0 45px;
	height: 60px;
	color: #ff2d59;
	font-size: 18px;
	font-weight: 500;
	background-color: #fff;
	box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
	z-index: 1;
}
.job__list a:before {
	display: block;
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #ff2d59;
	transform: scaleX(0);
	z-index: -1;
}
.job__list a:after {
	display: block;
	content: "";
	position: absolute;
	top: 50%;
	right: 25px;
	margin: -7px 0 0;
	width: 9px;
	height: 15px;
	background-image: url(../images/arrow_pink_right.svg);
	background-size: 9px 15px;
	z-index: 1;
}

.job__columns {
	display: flex;
	justify-content: space-between;
}
.job__column {
	width: calc(50% - 30px);
}
.job__column .job__list {
	width: 100%;
}

/* about
----------------------------------------------- */

.about {
	color: #000;
	background-color: #1a1a1c;
	overflow: hidden;
}
.about__inner {
	display: flex;
	justify-content: flex-end;
	align-items: center;
	position: relative;
	margin: auto;
	padding: 75px 0;
	max-width: 1500px;
}
.about__content {
	margin: 0 90px 0 0;
	width: calc(50% - 140px);
	order: 2;
}
.about__image {
	margin: 0 0 0 90px;
	width: calc(50% - 95px);
	overflow: hidden;
	order: 1;
	display: none;
}
.about__image img {
	width: 100%;
	height: auto;
}
.about__text {
	padding: 40px 0 0;
	font-size: 16px;
	text-align: justify;
	line-height: 32px;
}

/* readmore */

.about .readmore {
	margin: 45px 0 0;
}

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

.more__inner {
	margin: auto;
	padding: 150px 0;
	max-width: 1500px;
}
.more__lists {
	display: flex;
	margin: 100px 90px 0 36px;
}
.more__list {
	margin: 0 0 0 54px;
	width: calc(25% - 54px);
}
.more__list:nth-child(odd) {
	margin-top: -40px;
}
.more__list a {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	height: 335px;
	background-color: #fff;
	/*box-shadow: 0 10px 15px rgba(0,0,0,0.2);*/
}
.more__list a:before {
	display: block;
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #ff2d59;
	z-index: 1;
	transform: scaleX(0);
}
.more__list a:after {
	display: block;
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 10px;
	background-color: #ff2d59;
	z-index: 1;
}
.more__no {
	display: flex;
	justify-content: center;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	width: 50px;
	height: 50px;
	color: #fff;
	font-family: "Roboto", sans-serif;
	font-size: 20px;
	background-color: #ff2d59;
	/*box-shadow: 0 10px 15px rgba(0,0,0,0.15);*/
	z-index: 2;
}
.more__text {
	position: relative;
	font-size: 16px;
	font-weight: 500;
	line-height: 27px;
	z-index: 2;
}

/* ready */

.js-indicate-ready .more__list {
	opacity: 0;
	transform: translateY(-25%);
	transition-property: opacity, transform;
}

/* start */

.js-indicate-start .more__list {
	opacity: 1;
	transform: translateY(0);
	transition-duration: 0.8s;
	transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.js-indicate-start .more__list:nth-child(even) {
	transition-delay: 0.25s;
}

/* special
----------------------------------------------- */
.special {
	padding: 0 90px;
	position: relative;
	background-color: #1a1a1c;
	overflow: hidden;
}
.special__inner {
	max-width: 1320px;
	margin: 0 auto;
	padding: 150px 0;
	/* height: 300px; */
}

.special__inner ul {
	margin-top: 70px;
	display: flex;
	flex-wrap: wrap;
}

.special__inner ul li {
	width: calc((100% - 6vw) / 3);
	margin-right: 3vw;
}
.special__inner ul li:last-child {
	margin-right: 0;
}

.special__inner ul li img {
	width: 100%;
	height: auto;
}

.special__inner ul li .year {
	margin-top: 15px;
	text-align: center;
	color: #ceb6ff;
	letter-spacing: 0.1em;
}

/* toptitle */
.special .toptitle {
	display: flex;
	flex-direction: column;
	justify-content: center;
	z-index: 1;
}
.special .movie::before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	background: #ffeb4a;
	opacity: 0.8;
	transition: all 0.3s ease;
}
.special:hover .movie::before {
	opacity: 0.92;
}
.special iframe {
	position: absolute;
	z-index: -1;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-ms-transform: translate(-50%, -50%);
}

/* archive 20191226追加
----------------------------------------------- */

.archive {
	margin: 20px auto 0;
	max-width: 1500px;
	text-align: right;
}
.archive__inner {
	margin: 0 90px;
	padding-bottom: 5px;
	display: inline-block;
	border-bottom: 6px solid #35c89d;
}

.archive__inner .label {
	font-size: 15px;
	font-weight: bold;
	line-height: 25px;
	float: left;
}

.archive__inner ul {
	display: flex;
	flex-direction: row;
}

.archive__inner ul li {
	margin-left: 20px;
}

.archive__inner ul li a {
	color: #c8aa19;
	font-size: 22px;
	font-weight: bold;
}

#modal-content {
	width: 80%;
	margin: 0;
	padding: 0;
	background: #fff;
	position: fixed;
	display: none;
	z-index: 99999;
}

#modal-content .inner {
	position: relative;
}

#modal-content .inner {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
	overflow: hidden;
}

#modal-content .inner #player {
	position: absolute;
	top: 0;
	right: 0;
	width: 100%;
	height: 100%;
}

#modal-overlay {
	z-index: 9999;
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 120%;
	background-color: rgba(0, 0, 0, 0.75);
}

/* entry
----------------------------------------------- */

.entry__inner {
	display: flex;
	justify-content: center;
	padding: 100px 0;
}

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

@media print, screen and (min-width: 1000px) {
	.sp {
		display: none !important;
	}

	/* visual
	----------------------------------------------- */

	.visual__banner a:hover img {
		animation-name: popup;
		animation-duration: 0.5s;
		animation-timing-function: linear;
	}

	/* newstopics
	----------------------------------------------- */

	.newstopics__text a {
		transition-property: color;
		transition-duration: 0.2s;
	}

	/* hover */

	.newstopics__text a:hover {
		color: #00afcc;
	}

	/* readmore
	----------------------------------------------- */

	.readmore a .readmore__icon,
	.readmore a .readmore__icon:after {
		transition-property: border-color, background-color, transform;
		transition-duration: 0.25s;
		transition-timing-function: cubic-bezier(0.77, 0, 0.175, 1);
	}

	/* hover */

	.readmore a:hover .readmore__icon {
		border-color: #ff2d59;
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	}
	.readmore a:hover .readmore__icon:after {
		background-color: #26a99e;
		transform: translateX(13px) scaleX(0.5);
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	}

	/* job
	----------------------------------------------- */

	.job__list a,
	.job__list a:before {
		transform-origin: right;
		transition-property: color, box-shadow, transform;
		transition-duration: 0.25s;
	}
	.job__list a {
		transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
	}

	/* hover */

	.job__list:hover a {
		color: #fff;
		box-shadow: 0 7px 3px rgba(0, 0, 0, 0.5);
		/*
		transform: translate3d(0,-5px,0);
		*/
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	}
	.job__list:hover a:before {
		transform: scaleX(1);
		transform-origin: left;
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	}
	.job__list:hover a:after {
		background-image: url(../images/arrow_white_right.svg);
		animation-name: arrowright;
		animation-duration: 0.5s;
		animation-iteration-count: infinite;
	}

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

	.more__list a,
	.more__list a:before,
	.more__no,
	.more__text {
		transition-property: color, background-color, box-shadow, transform;
		transition-duration: 0.5s;
		transition-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
	}
	.more__list a:before {
		transform-origin: right;
		transition-duration: 0.25s;
		transition-timing-function: cubic-bezier(0.77, 0, 0.175, 1);
	}

	/* hover */

	.more__list:hover a {
		box-shadow: 0 20px 15px rgba(0, 0, 0, 0.1);
		transform: translateY(-10px);
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	}
	.more__list:hover a:before {
		transform: scaleX(1);
		transform-origin: left;
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	}
	.more__list:hover .more__no {
		box-shadow: 0 0 0 rgba(0, 0, 0, 0);
	}
	.more__list:hover .more__text {
		color: #000;
		text-shadow: 0 0 0 rgba(0, 0, 0, 0);
	}

	/* special
	----------------------------------------------- */

	.special {
		display: block;
		position: relative;
	}
	.special:after {
		display: block;
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		background-color: rgba(0, 0, 0, 0);
		z-index: 1;
		transition-property: background-color;
		transition-duration: 0.25s;
	}
	.special__inner {
		position: relative;
		z-index: 2;
	}
	.special__inner ul li {
		transition-property: color, background-color, box-shadow, transform;
		transition-duration: 0.5s;
	}
	.special__inner ul li:hover {
		transform: translateY(-10px);
		transition-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
	}

	.special .making {
		position: absolute;
		bottom: 30px;
		right: 90px;
		background: #fff;
		border: 1px solid #333;
		color: #333;
		padding: 10px 15px;
		font-weight: bold;
		z-index: 10;
		transition: 0.3s;
	}
	.special .making:hover {
		background: #3e3e3e;
		color: #fff;
		cursor: pointer;
	}

	/* hover */

	/* .special:hover:after {
		background-color: rgba(0, 0, 0, 0.4);
	} */

	/* retina
	----------------------------------------------- */

	@media only screen and (-webkit-min-device-pixel-ratio: 2) {
	}
}

/* tablet
----------------------------------------------- */

@media screen and (min-width: 641px) and (max-width: 1000px) {
}

/* mobile
----------------------------------------------- */

@media only screen and (max-width: 999px) {
	.pc {
		display: none !important;
	}

	/* visual
	----------------------------------------------- */

	.visual:after {
		display: none;
	}
	.visual__inner {
		margin: 0;
		padding: 0 0 10px;
		overflow: hidden;
	}
	.visual__image img {
	}
	.visual__banner {
		right: -10px;
		bottom: 0;
	}
	.visual__banner img {
		width: 90px;
		height: 90px;
	}

	/* toptitle
	----------------------------------------------- */

	.toptitle__label em:after {
		right: -25px;
		width: 20px;
	}
	.toptitle__label span {
		margin: 0 0 0 30px;
	}
	.toptitle__title {
		margin: 5px 0 0;
		font-size: 35px;
		line-height: 35px;
	}
	.toptitle__title small {
		font-size: 30px;
	}
	.toptitle__comingsoon {
		margin: 20px 0 0;
		font-size: 23px;
	}

	/* newstopics
	----------------------------------------------- */

	.newstopics {
		max-width: auto;
	}
	.newstopics__inner {
		margin: 0 20px;
		padding: 80px 0;
	}
	.newstopics__base {
		margin: 30px 0 0;
		/*box-shadow: 0 10px 15px rgba(0,0,0,0.1);*/
	}
	.newstopics__lists {
		margin: 0 20px 0;
		padding: 10px 0 30px;
	}
	.newstopics__list {
		display: block;
		padding: 20px 0 0;
		border: 0;
	}
	.newstopics__list:last-child {
		border: 0;
	}
	.newstopics__date {
		width: 90px;
		height: 20px;
	}
	.newstopics__text {
		display: block;
		margin: 5px 0 0;
		width: auto;
		font-size: 14px;
		line-height: 1.5;
	}

	/* toptitle */

	.newstopics .toptitle {
		display: block;
		position: static;
	}

	/* message
	----------------------------------------------- */

	.message {
		text-align: justify;
	}
	.message__inner {
		margin: 0 20px;
		padding: 50px 0;
	}
	.message__texts {
		padding: 10px 0 0;
	}
	.message__text {
		padding: 20px 0 0;
		font-size: 14px;
		line-height: 1.5;
	}
	.message__text--title {
		text-align: center;
	}

	/* readmore */

	.message .readmore {
		margin: 40px 0 0;
	}

	/* job
	----------------------------------------------- */

	.job {
		max-width: auto;
	}
	.job__inner {
		margin: 0 20px;
		padding: 80px 0;
	}
	.job__title {
		margin: 40px 0 0;
		padding: 0 0 0 16px;
		font-size: 16px;
		line-height: 20px;
	}
	.job__lists {
		display: block;
		padding: 8px 0 0;
	}
	.job__list {
		margin: 10px 0 0;
		width: auto;
	}
	.job__list a {
		padding: 0 30px 0 20px;
		font-size: 16px;
	}

	.job__columns {
		display: block;
	}
	.job__column {
		width: auto;
	}

	/* about
	----------------------------------------------- */

	.about__inner {
		display: block;
		margin: 0 20px;
		padding: 50px 0;
		max-width: auto;
	}
	.about__content {
		margin: 0;
		width: auto;
	}
	.about__image {
		margin: 30px 0 0;
		width: auto;
	}
	.about__image img {
	}
	.about__text {
		font-size: 14px;
		line-height: 1.5;
	}

	/* readmore */

	.about .readmore {
		margin: 35px 0 0;
	}

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

	.more__inner {
		padding: 60px 0;
		max-width: auto;
	}
	.more__lists {
		display: block;
		margin: 40px 20px 0;
		padding: 40px 0 0;
	}
	.more__list {
		margin: 20px 0 0;
		width: auto;
	}
	.more__list + .more__list {
		margin-top: 20px;
	}
	.more__list a {
		height: 125px;
		/*box-shadow: 0 5px 5px rgba(0,0,0,0.1);*/
	}
	.more__list a:before {
		display: none;
	}
	.more__list a:after {
		display: none;
	}
	.more__no {
		width: 40px;
		height: 40px;
		font-size: 15px;
		/*box-shadow: 0 5px 5px rgba(0,0,0,0.1);*/
	}

	/* special
	----------------------------------------------- */

	.special {
		padding: 0 20px;
	}
	.special__inner {
		padding: 60px 0 40px;
	}
	.special .icon {
		width: 33%;
		margin: 40px auto 0;
	}
	.special .icon img {
		width: 100%;
		height: auto;
	}
	.special .special__inner ul {
		margin-top: 40px;
	}
	.special .special__inner ul li {
		width: calc((100% - 3vw) / 2);
		margin-bottom: 20px;
	}
	.special .special__inner ul li:last-child {
		margin-right: 0;
	}
	.special .special__inner ul li:nth-child(even) {
		margin-right: 0;
	}

	/*
	.special {
		position: relative;
	}
	.special__inner {
		overflow: hidden;
	}
	.special__image {
		margin: 0 0 0 -28%;
	}
	.special__image img {
		width: auto;
		height: 500px;
	}
	
*/

	.making {
		width: 70%;
		margin: 30px auto 60px;
		background: #fff;
		border: 1px solid #333;
		color: #333;
		padding: 15px 35px;
		font-weight: bold;
		z-index: 10;
		text-align: center;
		transition: 0.3s;
	}
	.making:hover {
		background: #3e3e3e;
		color: #fff;
		cursor: pointer;
	}

	/* archive 20191226追加
	----------------------------------------------- */

	.archive__inner {
		margin: 0 20px;
		padding-bottom: 12px;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	.archive__inner .label {
		text-align: center;
		margin-bottom: 5px;
	}

	.archive__inner ul {
		display: flex;
		flex-direction: row;
		justify-content: center;
	}

	.archive__inner ul li {
		margin: 0 20px;
	}

	/* entry
	----------------------------------------------- */

	.entry__inner {
		display: block;
		margin: 0 20px;
		padding: 80px 0;
	}
}
