@charset "UTF-8";
/* reset */
/* http://meyerweb.com/eric/tools/css/reset/
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 100%;
	font: inherit;
	vertical-align: baseline;
	box-sizing: border-box;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
/*COMMON --------------------------------------------------*/
body {
	font-size: 16px;
	line-height: 1;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	color: #000;
	position: relative;
	-webkit-text-size-adjust: 100%;
}
p {
	line-height: 2;
}
img {
	max-width: 100%;
	height: auto;
}
a {
	color: #000;
	text-decoration: none;
}
a:hover {
	cursor: pointer;
}
a:visited {
	color: #000;
}
.wrap header {
	padding: 20px 0;
	background-color: #000;
}
.wrap header .inner {
	line-height: 0;
	position: relative;
}
.wrap header .logo {
	max-width: 80px;
	position: absolute;
	top: -4px;
	left: 4%;
}
.wrap header h1 {
	color: #fff;
	text-align: center;
	font-size: 14px;
	line-height: 1;
}
.wrap header h1 a, .wrap header h1 a:visited {
	color: #fff;
}
.wrap main .inner {
	max-width: 1200px;
	margin: 0 auto;
}
.wrap main h2 {
	text-align: center;
	font-size: 40px;
	letter-spacing: .2em;
	font-family: 'Aldrich', sans-serif;
	margin-bottom: 80px;
}
.wrap main .interview, .wrap main .information {
	padding: 100px 0;
}
.wrap main .movie {
	padding: 100px 0 50px;
}
.wrap main .list {
	padding: 100px 0 80px;
}
.link span {
	transition: all .5s;
}
.interview .inner > div section:hover .link span, .article .list li section:hover .link span {
	transform: translate(-10px, 0);
}

@media screen and (max-width: 1200px) {
.wrap header .logo {
	position: absolute;
	left: 4%;
}
.wrap main .inner, footer .inner {
	width: 92%;
	margin: 0 auto;
}
}

@media screen and (max-width: 1024px) {
.wrap header .logo {
	max-width: 70px;
}
}

@media screen and (max-width: 900px) {
.wrap main h2 {
	font-size: 8vw;
	margin-bottom: 10.6vw;
	line-height: 1.2;
}
.wrap main .interview, .wrap main .information, .wrap main .movie, .wrap main .list {
	padding: 16vw 0 10.6vw;
}
.wrap main .lead {
	padding: 21.3vw 0 10.6vw;
}
.wrap main .movie {
	padding: 16vw 0 5.3vw;
}
}

@media screen and (max-width: 480px) {
.wrap header .logo {
	max-width: 60px;
	position: absolute;
	top: -4px;
	left: 4%;
}
.wrap header h1 {
	font-size: 12px;
}
.wrap main .inner, footer .inner {
	width: 92%;
	margin: 0 auto;
}
}
/*COMMON_end ----------------------------------------------*/
/*HEADER --------------------------------------------------*/
/*HEADER_end ----------------------------------------------*/
/*KEY VISUAL --------------------------------------------------*/
.slider .image_01 {
	background: url(../images/slider_bg_01.jpg) no-repeat;
	background-size: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.slider .image_02 {
	background: url(../images/slider_bg_02.jpg) no-repeat;
	background-size: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
}
.slider .title {
	max-width: 55%;
	margin: 11%;
}
.slider .title img.pc {
	display: block;
}
.slider .title img.sp {
	display: none;
}
.slick-dots {
	bottom: -50px;
}
.slick-dotted.slick-slider {
	margin: 0 auto;
}
.slick-dots li {
	width: 10px;
	height: 10px;
	margin: 0 15px;
	padding: 0;
}
.slick-dots li button {
	width: 12px;
	height: 12px;
	margin: 0;
	padding: 0;
	background: #fff;
	border-radius: 6px;
	;
}
.slick-dots li.slick-active button {
	background: #000;
}
.slick-dots li button:before {
	content: none;
}

@media screen and (max-width: 640px) {
.slider .image_01 {
	background: url(../images/slider_bg_01_sp.jpg) no-repeat;
	background-size: 100%;
}
.slider .image_02 {
	background: url(../images/slider_bg_02_sp.jpg) no-repeat;
	background-size: 100%;
}
.slider .title {
	max-width: 80%;
	margin: 19% 10%;
}
.slider .title img.pc {
	display: none;
}
.slider .title img.sp {
	display: block;
}
.slick-dots {
	bottom: -40px;
}
}
/*KEY VISUAL_end ----------------------------------------------*/
/*LEAD --------------------------------------------------*/
.lead {
	padding: 100px 0 80px;
	background: url(../images/net_bg_01.jpg) repeat;
}
.lead .inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	max-width: 1200px;
	margin: 0 auto;
}
.lead .inner div {
	width: 50%;
}
.lead .inner div p {
	margin-bottom: 30px;
}
.lead .inner div p:last-child {
	font-size: 18px;
	line-height: 3;
	margin-bottom: 0;
}

@media screen and (max-width: 1200px) {
.lead .inner div:first-child img {
	width: 80%;
}
.lead .inner div p:last-child {
	font-size: 16px;
}
}

@media screen and (max-width: 1024px) {
.lead .inner div p:last-child {
	line-height: 2.5;
}
}

@media screen and (max-width: 480px) {
.lead {
	padding: 21.3vw 0 10.6vw;
}
.lead .inner div {
	width: 100%;
}
.lead .inner div:first-child {
	width: 80%;
	margin: 0 auto 40px;
}
.lead .inner div:first-child img {
	width: 100%;
}
.lead .inner div p:last-child {
	line-height: 2;
}
}
/*LEAD_end ----------------------------------------------*/
/*INTERVIEW --------------------------------------------------*/
.interview .inner > div {
	display: flex;
	flex-wrap: wrap;
	line-height: 0;
}
.interview .inner > .two, .interview .inner > .four, .interview .inner > .six {
	flex-flow: row-reverse;
}
.interview .inner > div div {
	width: 50%;
}
.interview .inner > div section .link {
	display: flex;
	justify-content: space-between;
}
.interview .inner > div section .link .arrow {
	display: inline-block;
	width: 80px;
	height: 1px;
	background-color: #000;
	position: relative;
	top: 25px;
	left: 0;
}
.interview .inner > div section .link .arrow::before {
	display: inline-block;
	content: "";
	width: 32px;
	height: 1px;
	background-color: #000;
	transform: rotate(45deg);
	position: absolute;
	top: -12px;
	right: -4px;
}
.interview .inner > div section .link .arrow::after {
	display: inline-block;
	content: "";
	width: 32px;
	height: 1px;
	background-color: #000;
	transform: rotate(-45deg);
	position: absolute;
	top: 12px;
	right: -4px;
}
.interview .inner > .one div:first-child {
	background: url(../images/img_01.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.interview .inner > .two div:first-child {
	background: url(../images/img_02.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.interview .inner > .three div:first-child {
	background: url(../images/img_03.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.interview .inner > .four div:first-child {
	background: url(../images/img_04.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.interview .inner > .five div:first-child {
	background: url(../images/img_05.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.interview .inner > .six div:first-child {
	background: url(../images/img_06.jpg) no-repeat;
	background-size: cover;
	background-position: center;
}
.interview .inner > div div img.sp {
	display: none;
}
.interview .inner > div section div {
	width: 100%;
}
.interview .inner > .one section div, .interview .inner > .two section div, .interview .inner > .three section div, .interview .inner > .four section div, .interview .inner > .five section div, .interview .inner > .six section div {
	background: none;
}
.interview .inner > div section {
	padding: 5vw 0 5vw 5vw;
	font-weight: bold;
	position: relative;
}
.interview .inner > div:nth-child(odd) section {
	padding: 5vw 5vw 5vw 0;
	font-weight: bold;
}
/*.interview .inner > .four section, .interview .inner > .five section, .interview .inner > .six section {
	color: #e5e5e5;
}*/
.interview .inner > div section .number {
	font-size: 140px;
	color: #e5e5e5;
	font-family: 'Aldrich', sans-serif;
	line-height: 1;
	margin-bottom: 40px;
}
.interview .inner > div section h3 {
	font-size: 28px;
	line-height: 1.8;
	margin-bottom: 40px;
}
/*.interview .inner > .four section h3, .interview .inner > .five section h3, .interview .inner > .six section h3 {
	letter-spacing: .2em;
}*/
.interview .inner > div section div .category {
	font-size: 24px;
	margin-bottom: 20px;
}
.interview .inner > div section div .name {
	font-size: 30px;
	line-height: 1.2;
}
.interview .inner > div section div .name span {
	font-size: 16px;
	font-weight: normal;
	letter-spacing: .2em;
}

@media screen and (max-width: 1024px) {
.interview .inner > div section .number {
	font-size: 120px;
}
}

@media screen and (max-width: 768px) {
.interview .inner > div section .number {
	font-size: 100px;
}
.interview .inner > div section h3 {
	font-size: 24px;
}
}

@media screen and (max-width: 640px) {
.interview .inner > div div, .interview .inner > div section {
	width: 100%;
}
.interview .inner > div div img.sp {
	display: block;
}
.interview .inner > .two, .interview .inner > .four, .interview .inner > .six {
	flex-direction: initial;
	flex-flow: wrap;
}
.interview .inner > div section, .interview .inner > div:nth-child(odd) section {
	padding: 10.6vw 0 16vw;
}
.interview .inner > div section .number {
	font-size: 80px;
	margin-bottom: 4vw;
}
.interview .inner > div section h3 {
	font-size: 5.3vw;
	margin-bottom: 5.3vw;
}
.interview .inner > div section div .category {
	font-size: 4.8vw;
	margin-bottom: 2.6vw;
}
.interview .inner > div section div .name {
	font-size: 6.4vw;
}
.wrap .interview .inner > .six section {
	padding-bottom: 0;
}
}
/*INTERVIEW_end ----------------------------------------------*/
/*INFORMATION --------------------------------------------------*/
.information {
	background: url(../images/net_bg_01.jpg) repeat;
}
.information .inner {
	max-width: 1200px;
	margin: 0 auto;
}
.information .inner h3 {
	font-size: 24px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 50px;
}
.information .inner h3 + div {
	margin-bottom: 50px;
}
.information .inner .btn {
	width: 350px;
	margin: 0 auto 15px;
	text-align: center;
}
.information .inner .btn a {
	display: block;
	padding: 20px 0;
	border: 1px solid #000;
	position: relative;
	transition: 1s;
}
.information .inner .btn + p {
	text-align: center;
	font-size: 12px;
}
.information .inner .btn a span {
	display: inline-block;
	width: 25px;
	height: 1px;
	background-color: #000;
	position: relative;
	top: -5px;
	left: 15px;
	transition: 1s;
}
.information .inner .btn a span::before {
	display: inline-block;
	content: "";
	width: 10px;
	height: 1px;
	background-color: #000;
	transform: rotate(45deg);
	position: absolute;
	top: -4px;
	right: -1px;
	transition: 1s;
}
.information .inner .btn a span::after {
	display: inline-block;
	content: "";
	width: 10px;
	height: 1px;
	background-color: #000;
	transform: rotate(-45deg);
	position: absolute;
	top: 4px;
	right: -1px;
	transition: 1s;
}
.information .inner .btn a:hover {
	color: #fff;
	background-color: #000;
}
.information .inner .btn a:hover span, .information .inner .btn a:hover span::before, .information .inner .btn a:hover span::after {
	background-color: #fff;
}

@media screen and (max-width: 640px) {
.information .inner h3 + div {
	margin-bottom: 8vw;
}
}

@media screen and (max-width: 480px) {
.information .inner h3 {
	font-size: 5.3vw;
	margin-bottom: 8vw;
}
.information .inner h3 + p {
	margin-bottom: 10.6vw;
}
.information .inner .btn {
	width: 80%;
}
}
/*INFORMATION_end ----------------------------------------------*/
/*ARTICLE --------------------------------------------------*/
.article .wrap .interview {
	padding: 40px 0 100px;
}
.article .interview h2 {
	margin-bottom: 40px;
	line-height: 1.2;
}
.article .interview h2 span {
	font-size: 18px;
	font-weight: bold;
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", sans-serif;
	display: inline-block;
	margin-top: 10px;
	line-height: 1.8;
}
.article .interview .inner > .two, .article .interview .inner > .four, .article .interview .inner > .six {
	flex-flow: initial;
}
.article .wrap main .inner {
	max-width: none;
}
.article .interview .inner > div section {
	width: 50%;
	padding: 5vw;
}
.article .interview .inner > .four section, .article .interview .inner > .five section, .article .interview .inner > .six section {
	color: #000;
}
.article .interview .inner .contents {
	max-width : 1200px;
	margin: 0 auto;
	padding: 80px 0 0;
}
.article .interview .inner .contents p {
	margin-bottom: 40px;
}
.article .interview .inner .contents p:last-child {
	margin-bottom: 0;
}
.article .interview .inner .contents figure {
	margin: 0 auto 40px;
}
.article .interview .inner > div section .link {
	display: block;
	margin-bottom: 20px;
}
.article .interview .inner > div section .profile {
	font-size: 14px;
	font-weight: normal;
}
.article .list {
	background: url(../images/net_bg_01.jpg) repeat;
}
.article .wrap main .list .inner {
	max-width: 1200px;
	margin: 0 auto;
}
.article .list ul {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.article .list li {
	width: 32%;
	font-weight: bold;
	background-color: #fff;
	margin-bottom: 30px;
}
.article .list li:nth-child(4), .article .list li:nth-child(5), .article .list li:nth-child(6) {
	margin-bottom: 0;
}
.article .list li .number {
	font-size: 80px;
	color: #e5e5e5;
	font-family: 'Aldrich', sans-serif;
	line-height: 1;
	padding: 30px 20px 20px;
}
.article .list li section {
	padding: 0 20px 30px;
}
.article .list li section.cs {
	color: #e5e5e5;
}
.article .list li .title {
	font-size: 16px;
	line-height: 1.8;
	min-height: 4em;
	margin-bottom: 20px;
}
.article .list li section.cs .title {
	letter-spacing: .2em;
}
.article .list li .category {
	font-size: 14px;
	margin-bottom: 10px;
}
.article .list li .name {
	font-size: 20px;
	line-height: 1;
}
.article .list li .name span {
	font-size: 12px;
	font-weight: normal;
	letter-spacing: .2em;
}
.article .list li .link {
	display: flex;
	justify-content: space-between;
	margin: 0;
}
.article .list li .link .arrow {
	display: inline-block;
	width: 50px;
	height: 1px;
	background-color: #000;
	position: relative;
	top: 20px;
	left: 0;
}
.article .list li .link .arrow::before {
	display: inline-block;
	content: "";
	width: 20px;
	height: 1px;
	background-color: #000;
	transform: rotate(45deg);
	position: absolute;
	top: -7px;
	right: -4px;
}
.article .list li .link .arrow::after {
	display: inline-block;
	content: "";
	width: 20px;
	height: 1px;
	background-color: #000;
	transform: rotate(-45deg);
	position: absolute;
	top: 7px;
	right: -4px;
}

@media screen and (max-width: 1200px) {
.article .wrap main .inner {
	width: 100%;
}
.article .interview .inner .contents, .article .wrap main .list .inner {
	width: 92%;
	margin: 0 auto;
}
}

@media screen and (max-width: 900px) {
.article .interview .inner .contents {
	padding: 10.6vw 0 0;
}
.article .list li {
	width: 48%;
}
.article .list li:nth-child(4) {
	margin-bottom: 30px;
}
}

@media screen and (max-width: 768px) {
.article .interview .inner .contents p {
	margin-bottom: 30px;
}
.article .interview .inner .contents figure {
	margin: 0 auto 30px;
}
}

@media screen and (max-width: 640px) {
.article .wrap .interview {
	padding: 5.3vw 0 0;
}
.article .interview h2 {
	width: 92%;
	margin: 0 auto 4vw;
}
.article .interview h2 span {
	font-size: 14px;
}
.article .interview .inner .contents {
	padding: 10.6vw 0;
}
.article .interview .inner > .two, .article .interview .inner > .four, .article .interview .inner > .six {
	flex-flow: wrap;
}
.article .interview .inner > div section {
	width: 92%;
	margin: 0 auto;
}
.article .interview .inner > div section, .article .interview .inner > .six section {
	padding: 10.6vw 0;
	border-bottom: 1px solid #000;
}
.article .list li {
	width: 100%;
	margin-bottom: 30px;
}
.article .list li:nth-child(4), .article .list li:nth-child(5) {
	margin-bottom: 30px;
}
.article .list li:last-child {
	margin-bottom: 0;
}
.article .list li > div {
	display: flex;
	align-items: center;
}
.article .list li > div figure {
	width: 40%;
}
.article .list li > div .number {
	width: 60%;
	text-align: center;
}
.article .list li section {
	padding: 20px;
}
.article .list li .title {
	min-height: inherit;
}
}

@media screen and (max-width: 480px) {
}
/*ARTICLE_end ----------------------------------------------*/
/*MOVIE --------------------------------------------------*/
.youtube {
	position: relative;
	padding-bottom: 56.25%;
	height: 0;
	overflow: hidden;
}
.youtube iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
/*MOVIE_end ----------------------------------------------*/

/*PAGETOP --------------------------------------------------*/

.pagetop {
	font-size: 14px;
	text-align: center;
	padding: 8px 0 5px;
	letter-spacing: .2em;
	font-family: 'Aldrich', sans-serif;
}
.pagetop::before {
	display: block;
	font-size: 30px;
	font-family: "Font Awesome 5 Free";
	line-height: .6;
	content: "\f0d8";
	font-weight: 900;
	color: #000;
}
/*PAGETOP_end ----------------------------------------------*/

/*BNR --------------------------------------------------*/
.bnr img.pc {
	display: block;
}
.bnr img.sp {
	display: none;
}
.bnr #menuBtn {
	text-align: right;
	line-height: 0;
}
.bnr p img:hover {
	opacity: 1;
	cursor: pointer;
}
.bnr {
	width: 240px;
	position: fixed;
	right: 0;
	bottom: 10px;
	z-index: 100;
	line-height: 0;
}

@media screen and (max-width: 640px) {
.bnr {
	width: 100%;
	bottom: 0;
}
.bnr img.pc {
	display: none;
}
.bnr img.sp {
	display: block;
}
}
/*BNR_end ----------------------------------------------*/
/*FOOTER --------------------------------------------------*/
footer p {
	text-align: center;
	font-size: 12px;
}
.credit {
	padding: 20px 0;
	background-color: #e5e5e5;
}
.copy {
	color: #b2b2b2;
	padding: 30px 0;
	background-color: #000;
}

@media screen and (max-width: 480px) {
footer .inner {
	font-size: 11px;
}
.credit {
	padding: 12px 0;
}
}
/*FOOTER_end ----------------------------------------------*/
