@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&family=Noto Sans JP:wght@400;500;700&display=swap');
@charset "UTF-8";
:root{
--body: #000;
--link: #000;
--accentColor01: #E4007F;
--accentColor02: #7F1084;
--accentColor03: #8fc31f;
}
/*--------------------------------------------
STATE
---------------------------------------------*/
@media screen and (max-width: 1024px){
.is-pc {
	display: none;
}
}
@media print,screen and (min-width: 1025px){
.is-sp {
	display: none;
}
}
/*--------------------------------------------
DATA TEXT
---------------------------------------------*/
[data-before]:before {
content: attr( data-before );
white-space: pre;
}
[data-after]:after {
content: attr( data-after );
white-space: pre;
}
[data-both]:before {
content: attr( data-both );
white-space: pre;
}
[data-both]:after {
content: attr( data-both );
white-space: pre;
}
/*--------------------------------------------
FONTS
---------------------------------------------*/
.noto {
font-family: 'Noto Sans JP', sans-serif;
}
.Noto Sans JP {
font-family: 'Noto Sans JP', sans-serif;
}
.jp {
font-family: 'Noto Sans JP', sans-serif;
}
/*--------------------------------------------
BACKGROUND COLOR
---------------------------------------------*/
.bg_gray {
background-color: rgba(241, 241, 241, .7);
}
/*--------------------------------------------
SECTION
---------------------------------------------*/
@media screen and (max-width: 1024px){
section.box01 {
	padding-bottom: calc( 100 * 100vw / 1024 );
	padding-top: calc( 100 * 100vw / 1024 );
}
section.box02 {
	padding-bottom: calc( 140 * 100vw / 1024 );
	padding-top: calc( 100 * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
section.box01 {
	padding-bottom: 80px;
	padding-top: 80px;
}
section.box02 {
	padding-bottom: 100px;
	padding-top: 100px;
}
}
/*--------------------------------------------
PAGE TITLE
---------------------------------------------*/
#main-title {
align-items: center;
/*color: #fff;*/
color: #8fc31f;
display: flex;
font-family: 'Noto Sans JP', sans-serif;
font-weight: 700;
text-align: center;
padding: 20px 0 20px 0;
}
/*--------------------------------------------
TITLE
---------------------------------------------*/
.title01 {
	/*color: #404040;*/
	color: var(--accentColor02);
}
.title01:not(span) {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: .02em;
	line-height: 1.0;
	padding-bottom: 10px;
}
.title01 span {
	display: block;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	letter-spacing: .15em;
}
.title02 {
	color: #404040;
}
.title02:not(span) {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: .02em;
	line-height: 1.0;
}
.title02 span {
	display: block;
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 500;
	letter-spacing: .15em;
}

@media screen and (max-width: 1024px){
	.title01 {
		padding-bottom: calc( 30 * 100vw / 1024 );
		text-align:center;
	}
	.title01 img{
		height:30px;
	}
	.title01 .dp {
		height:25px;
	}
	.title01:not(span) {
		font-size: 9.7rem;
		white-space: nowrap;
	}
	.title01 span {
		font-size: 2.7rem;
		margin-top: calc( 24 * 100vw / 1024 );
		margin-bottom: calc( 24 * 100vw / 1024 );
	}
	.title02 {
		padding-bottom: 20px;
		border-bottom: 2px solid #4d4d4d;
		margin-bottom: 20px;
	}
	.title02:not(span) {
		font-size: 3.5rem;
		white-space: nowrap;
	}
	.title02 img {
		height:30px;
	}	
}
@media print,screen and (min-width: 1025px){
	.title01 {
		border-bottom: 4px solid #4d4d4d;
		margin-bottom: 20px;
	}
	.en img{
		height:60px;
	}
	.jp img{
		height:50px;
	}
	.title01:not(span) {
		font-size: 5rem;
	}
	.title01 span {
		font-size: 2rem;
		margin-top: 12px;
		padding-left: 5px;
	}
	.title02 {
		padding-bottom: 20px;
		border-bottom: 2px solid #4d4d4d;
		margin-bottom: 20px;
	}
	.title02:not(span) {
		font-size: 3rem;
		white-space: nowrap;
	}
	.title02 img {
		height:40px;
	}	
}
/*--------------------------------------------
LINK
---------------------------------------------*/
a {
backface-visibility: hidden;
position: relative;
transition: opacity .5s ease-in;
will-change: opacity;
}
a:hover {
opacity: .6;
}

a.is-current span {
position: relative;
}
a.is-current span:after  {
background-color: #59267B;
bottom: 0;
content: '';
display: block;
height: 2px;
left: -3%;
position: absolute;
width: 106%;
}

a[target="_blank"].t_blank:after {
background: url("../images/ui/icon/t_blank.svg") 0 0/ contain no-repeat;
content: '';
height: 0.5em;
margin-left: .1em;
width: 0.5em;
}

/*--------------------------------------------
TEXTS
---------------------------------------------*/
.texts01 .en {
	font-family: 'Noto Sans JP', sans-serif;
}
.texts02 .en {
	font-family: 'Noto Sans JP', sans-serif;
}

@media screen and (max-width: 1024px){
	.texts01 {
		margin-bottom: 60px;
	}
	.texts01 .text {
		letter-spacing: .04em;
	}
	.texts01 .jp p {
		/*font-size: 2.7rem;*/
		font-size: 3.2rem;
		line-height: 1.74;
	}
	.texts01 .en p {
		/*font-size: 2.9rem;*/
		font-size: 3.2rem;
		/*font-weight: 600;*/
		line-height: 1.6;
	}
	.texts01 .jp .heading {
		font-size: 3.2rem;
		font-weight: 700;
		line-height: 1.47;
		margin-bottom: calc( 14 * 100vw / 1024 );
	}
	.texts01 .en .heading {
		font-size: 3.2rem;
		font-weight: 700;
		line-height: 1.47;
		margin-bottom: calc( 14 * 100vw / 1024 );
	}
	.texts02 .text {
		letter-spacing: .04em;
	}
	.texts02 .jp p {
		/*font-size: 2.7rem;*/
		font-size: 3.2rem;
		line-height: 1.74;
	}
	.texts02 .en p {
		/*font-size: 2.9rem;*/
		font-size: 3.2rem;
		/*font-weight: 600;*/
		line-height: 1.6;
	}
}
@media print,screen and (min-width: 1025px){
	.texts01 {
		align-items: flex-start;
		display: flex;
		justify-content: space-between;
		margin-bottom: 60px;
	}
	.texts01 .text {
		letter-spacing: .02em;
		/*width: 515px;*/
	}
	.texts01 .jp p {
		font-size: 1.6rem;
		line-height: 2;
	}
	.texts01 .en p {
		font-size: 1.8rem;
		line-height: 1.6;
	}
	.texts01 .jp .heading {
		font-size: 2rem;
		font-weight: 500;
		line-height: 1.6;
		margin-bottom: 10px;
	}
	.texts01 .en .heading {
		font-size: 2rem;
		font-weight: 600;
		line-height: 1.6;
		margin-bottom: 10px;
	}
	.texts02 {
		align-items: flex-start;
		display: flex;
		justify-content: space-between;
		/*margin-bottom: 60px;*/
	}
	.texts02 .text {
		letter-spacing: .02em;
		/*width: 515px;*/
	}
	.texts02 .jp p {
		font-size: 1.6rem;
		line-height: 2;
	}
	.texts02 .en p {
		font-size: 1.8rem;
		line-height: 1.6;
	}
}

/*--------------------------------------------
WORK LIST
---------------------------------------------*/
.work-list ul {
display: flex;
flex-wrap: wrap;
}
.work-list li {
display: flex;
flex-direction: column;
}
.work-list h3 {
align-items: center;
/*display: flex;*/display: inline-block;
flex-direction: column;
font-family: 'Noto Sans JP', sans-serif;
font-weight: 700;
justify-content: center;
letter-spacing: .02em;
/*text-align: center;*/
}
.work-list img {
height: auto;
width: 100%;
border: solid 1px #ddd;
}
.work-list div span {
letter-spacing: .02em;
line-height: 1.8;
}
.work-list div .en {
font-family: 'Noto Sans JP', sans-serif;	
}
.work-list a {
align-items: center;
background-color: var(--accentColor03);
color: #fff;
display: flex;
font-family: 'Noto Sans JP', sans-serif;
font-weight: 700;
justify-content: center;
letter-spacing: .05em;
}
.work-list a span {
align-items: center;
display: flex;
}
.work-list a span:before {
background: url("../images/ui/icon/controller01.svg");
content: '';
}
@media screen and (max-width: 1024px){
	.title01 + .work-list {
		margin-top: calc( 30 * 100vw / 1024 );
	}
	.work-list {
		margin-top: calc( 100 * 100vw / 1024 );
	}
	.work-list li {
		width: 100%;
	}
	.work-list li:not(:nth-child(1)) {
		padding-top: calc( 160 * 100vw / 1024 );
	}
	.work-list h3 {
		margin-bottom: calc( 30 * 100vw / 1024 );
		color:var(--accentColor02);
	}
	.work-list h3:not(.jp) {
		font-size: 5.8rem;		
	}
	.work-list h3 .jp {
		font-size: 5.6rem;
	}
	.work-list img {
		margin-bottom: calc( 30 * 100vw / 1024 );
	}
	.work-list div {
		margin-bottom: calc( 40 * 100vw / 1024 );
	}
	.work-list div p {
		align-items: center;
		display: inline-flex;
		margin-right: calc( 20 * 100% / 1024 );
	}
	.work-list div span:not(.icon01):not(.icon02) {
		font-size: 2.7rem;
	}
	.work-list a {
		border-radius: calc( 8 * 100vw / 1024 );
		font-size: 3rem;
		height: calc( 62 * 100vw / 1024 );
	}
	.work-list a span {
		position: relative;
	}
	.work-list a span:before {
		height: calc( 26 * 100vw / 1024 );
		margin-right: calc( 14 * 100vw / 1024 );
		width: calc( 53 * 100vw / 1024 );
	}
}
@media print,screen and (min-width: 1025px){
	.role + .work-list,
	.note + .work-list,
	.texts01 + .work-list {
		margin-top: 40px;
	}
	.work-list li {
		padding-bottom: 10px;
		padding-top: 10px;
	}
	.work-list li:not(:nth-child(3n+2)) {
		width: 358px;
	}
	.work-list li:nth-child(3n+2) {
		width: 384px;
	}
	.work-list li:not(:nth-child(3n+3)) {
		padding-right: 26px;
	}
	.work-list li:not(:nth-child(3n+1)) {
		padding-left: 26px;
	}
	.work-list li:not(:nth-child(3n+1)) {
		border-left: 1px solid #000;
	}
	.work-list li:nth-child(n+4) {
		margin-top:60px;
	}
	.work-list h3 {
		height: 85px;
		order: 2;
		margin-top: 20px;
		color:var(--accentColor02);
	}
	.work-list h3:not(span) {
		font-size: 2.8rem;		
	}
	.work-list h3 .jp {
		font-size: 2.2rem;
	}
	.work-list h3 .en {
		font-size: 2.3rem;
	}
	.work-list h3 span + span {
		margin-top: 10px;
	}
	.work-list img {
		order: 1;
	}
	.work-list div {
		margin-bottom: 25px;
		order: 3;
	}
	.work-list div span:not(.icon01):not(.icon02) {
		font-size: 1.6rem;
	}
	.work-list div span.jp + span.en:before {
		/*content: '/';*/
		margin: 0 5px;
	}
	.work-list a {
		border-radius: 4px;
		font-size: 1.7rem;
		height: 30px;
		margin-top: auto;
		order: 4;
	}
	.work-list a span {
		position: relative;
	}
	.work-list a span:before {
		height: 15px;
		margin-right: 7px;
		width: 29px;
	}
}

/*--------------------------------------------
ROLE
---------------------------------------------*/
.role {
align-items: flex-start;
border: 1px solid #000;
display: flex;
}
.role dl {
display: flex;
}
.role dd {
letter-spacing: .02em
}
.role dd .en {
font-family: 'Noto Sans JP', sans-serif;	
}
.role dd:before {
content: '・・・';
}
@media screen and (max-width: 1024px){
.role {
	flex-direction: column;
	padding: calc( 20 * 100vw / 1024 );
}
.role dl:not(:nth-child(1)) {
	margin-top: calc( 16 * 100vw / 1024 );
}
.role dt {
	width: calc( 64 * 100vw / 1024 );
}
.role dd {
	font-size: 2.5rem;
	margin-left: 1.6em;
	/*text-indent: -1.6em;*/
}
}
@media print,screen and (min-width: 1025px){
.role {
	flex-wrap: wrap;
	/*justify-content: space-between;*/
	padding: 15px 25px;
}
	.role dl {
		margin-right: 15px;
	}
.role dl:nth-child(n+4) {
	margin-top: 8px;
}
/*.role dl:nth-child(2n) {
	width: 385px;
}*/
.role dt {
	width: 32px;
}
.role dd {
	font-size: 1.4rem;
}
}

/*--------------------------------------------
NOTE
---------------------------------------------*/
.note {
	border: 1px solid #000;
}
.note dl {
	display: flex;
}
.note dd {
	letter-spacing: .02em;	
}
.note dd span:nth-child(1) {
	font-family: 'Noto Sans JP', sans-serif;
}
.note dd span:nth-child(2) {
	font-family: 'Noto Sans JP', sans-serif;
	/*font-weight: 600;*/
}
.note dd:before {
content: '・・・';
}
@media screen and (max-width: 1024px){
.note {
	margin-top: calc( 30 * 100vw / 1024 );
	padding: calc( 16 * 100vw / 1024 ) calc( 22 * 100vw / 1024 );
}
.note dl {
	align-items: baseline;
}
.note dl + dl {
	margin-top: calc( 12 * 100vw / 1024 );
}
.note dd {
	margin-left: 1.6em;
	text-indent: -1.6em;
}
.note dd span:nth-child(1) {
	font-size: 2.5rem;
}
.note dd span:nth-child(2) {
	font-size: 2.7rem;
	line-height: 1.36;
}
.note span + span:before {
	content: '\A';
	white-space: pre;
}
}
@media print,screen and (min-width: 1025px){
.note {
	margin-top: 50px;
	padding: 20px;
	width: 600px;
}
.note dl {
	align-items: center;
}
.note dl + dl {
	margin-top: 5px;
}
.note dd span:nth-child(1) {
	font-size: 1.4rem;
}
.note dd span:nth-child(2) {
	font-size: 1.5rem;
}
}

/*--------------------------------------------
ICON
---------------------------------------------*/
.icon01 {
align-items: center; 
border-radius: 50%;
color: #fff;
display: inline-flex;
font-family: 'Noto Sans JP', sans-serif;
justify-content: center;
}
.icon01.bg-g {
background-color: #646e6e;
}
.icon01.bg-u {
background-color: #900;
}
.icon01.bg_dg {
	background-color: #009933;
}
.icon01.bg_dg1 {
background-color: #26b26f;
}
.icon01.bg_dg2 {
	background-color: #FFCC00;
}
.icon01.bg_dr {
	background-color: #66CC00;
}

.icon01.bg_e {
background-color: #267be3;
}
.icon01.bg_ml {
background-color: #e77c21;
}
.icon01.bg_ms {
background-color: #DC0049;
}
.icon01.bg_p {
background-color: #26b2e0;
}
.icon01.bg_s {
	background-color: #FF3300;
}
.icon01.bg_at {
	background-color: #FF69B4;
}
@media screen and (max-width: 1024px){
.icon01 {
		border-radius: calc( 14 * 100vw / 1024 );
		font-size: 2.5rem;
		height: calc( 38 * 100vw / 1024 );
		line-height: calc( 32 * 100vw / 1024 );
		width: calc( 64 * 100vw / 1024 );
		margin-left:15px;
}
}
@media print,screen and (min-width: 1025px){
.icon01 {
	border-radius: 7px;
	font-size: 1.25rem;
	height: 16px;
	margin-left: 3px;
	width: 30px;
	line-height: 16px;
}
}

.icon02 {
color: #fff;
display: inline-block;
	font-family: 'Noto Sans JP', sans-serif;
font-weight: 700;
letter-spacing: .02em;
text-align: center;
	vertical-align: top;
}

.icon02.bg_vr {
	background-color: var(--accentColor01);
}
@media screen and (max-width: 1024px){
.icon02 {
	border-radius: calc( 14 * 100vw / 1024 );
	font-size: 2.5rem;
	height: calc( 38 * 100vw / 1024 );
	line-height: calc( 32 * 100vw / 1024 );
	width: calc( 124 * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
.icon02 {
	border-radius: 7px;
	font-size: 1.35rem;
	/*height: 16px;
	width: 32px;*/
		height: 20px;
		width: 62px;
	line-height: 16px;
	
}
}

/*--------------------------------------------
LOCAL NAV
---------------------------------------------*/
#localNav {
	background-color: #f2f4f4;
}
#localNav ul {
	display: flex;
}

#localNav a {
	display: flex;
	flex-direction: column;		
}
#localNav a .jp {
	font-weight: 700;
	letter-spacing: .08em;
}
#localNav a .en {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 700;
	letter-spacing: .02em;
}

@media screen and (max-width: 1024px){
	#localNav ul {
		/*justify-content: space-between;*/
		flex-wrap: wrap;
	}
	/*#localNav li:not(:nth-child(1)) {
		margin-left: calc( 24 * 100% / 1024 );
	}*/
	#localNav li{
		margin-right: calc( 40 * 100% / 1024 );
	}
	#localNav a {
		padding: calc( 12 * 100vw / 1024 ) 0;
		text-align: center;
	}
	#localNav span {
		align-items: center;
		display: flex;
		height: calc( 76 * 100vw / 1024 );
	}
	#localNav a .jp {
		font-size: 2.4rem;
	}
	#localNav a .en {
		font-size: 2.3rem;
	}
	#localNav a .jp img{
		height: 15px;
	}
	#localNav a .en img {
		height: 20px;
	}
}
@media print,screen and (min-width: 1025px){
	#localNav ul {
		justify-content: center;
	}
	#localNav li {
		margin: auto;
		padding:0 20px 0 20px;
	}
	
	#localNav a {
		align-items: center;
		height: 80px;
		justify-content: center;
	}
	#localNav span {
		margin: 5px 0 10px 0;		
	}
	#localNav a .jp {
		font-size: 2.1rem;
	}
	#localNav a .en {
		font-size: 2.0rem;
	}
	#localNav a .jp img{
		height: 20px;
	}
	#localNav a .en img {
		height: 25px;
	}
	#localNav a:after {
	content: '▼';
	color:var(--accentColor02);
	}
}

/*--------------------------------------------
TO TOP
---------------------------------------------*/
#toTop {
align-items: center;
background-color: rgba(0, 0, 0, 0.5); 
border-radius: 50%;
display: flex;
justify-content: center;
position: fixed; 
}
#toTop:before {
background: url("../images/ui/icon/arrow_top01.svg") 0 0/ contain no-repeat;
content: '';
}
@media screen and (max-width: 1024px){
#toTop {
	bottom: calc( 10 * 100vw / 1024 ); 
	height: calc( 90 * 100vw / 1024 );
	right: calc( 20 * 100% / 1024 );
	width: calc( 90 * 100% / 1024 );
}
#toTop:before {
	height: calc( 45 * 100vw / 1024 );
	width: calc( 45 * 100vw / 1024 );
}
}
@media print,screen and (min-width: 1025px){
#toTop {
	bottom: 20px; 
	height: 60px;
	right: 20px; 
	width: 60px;
}
#toTop:before {
	background-size: 30px 30px;
	height: 30px;
	width: 30px;
}
}

/*--------------------------------------------
SURVEY BANNER
---------------------------------------------*/

@media screen and (max-width: 1024px){
	#surveay .survey_banner{
		width: 80%;
		margin: 30px auto;
		
	}
	#survey .survey_banner a{
		align-items: center;
		background-color: #B24996;
		background-color: var(--accentColor01);
		color: #fff;
		display: flex;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		justify-content: center;
		letter-spacing: .05em;
		line-height:1.5;
		border:5px solid #aaa;
		border-radius: 4px;
		font-size: 3.2rem;
		height: 150px;
		margin-top: auto;
		order: 4;
		text-align: center;
		background: url("../images/common/bg_banner.png") center 0/ cover no-repeat;
		
	}
	#survey .survey_banner span{
		
	}

}
@media print,screen and (min-width: 1025px){
	#survey .survey_banner{
		width: 80%;
		margin: 60px auto;
		
	}
	#survey .survey_banner a{
		align-items: center;
		background-color: #B24996;
		background-color: var(--accentColor01);
		color: #fff;
		display: flex;
		font-family: 'Noto Sans JP', sans-serif;
		font-weight: 700;
		justify-content: center;
		letter-spacing: .05em;
		line-height:1.5;
		border:5px solid #aaa;
		border-radius: 4px;
		font-size: 3.3rem;
		height: 150px;
		margin-top: auto;
		order: 4;
		text-align: center;
		background: url("../images/common/bg_banner.png") center 0/ cover no-repeat;

	}
	#survey .survey_banner span{
		
	}
	
	

}
/*--------------------------------------------
IFRAME-CONTAINER
---------------------------------------------*/
.iframe-container{
position: relative;
}
.iframe-container > iframe {
bottom: 0;
height: 100%;
left: 0;
margin: auto;
position: absolute;
right: 0;
top: 0;
width: 100%;
}