@charset "utf-8";

/*//////////////////////////////////////////////////////////////////////////////

	HOME

//////////////////////////////////////////////////////////////////////////////*/


/*------------------------------------------------------------------------------

	promotion

------------------------------------------------------------------------------*/

main #promotion {
	position: relative;
	z-index: 10;
}

main #promotion .site_column {
	position: absolute;
	top: 0;
	left: 50%;
	translate: -50% 0;
	height: 100%;
}

main #promotion .site_column::after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	translate: 0 -50%;
	left: 0;
	aspect-ratio: 200/134;
	height: 102%;
	background-image: url(../../common/img/logo_mark.svg);
	background-repeat: no-repeat;
	background-size: contain;
	opacity: 1;
	animation: .8s logo 1;
}

@keyframes logo {
	0% {
		left: -30%;
		opacity: 0;
	}
	100% {
		left: 0;
		opacity: 1;
	}
}


main #promotion .catch {
	position: absolute;
	bottom: -7.5em;
	left: 0;
	z-index: 1;
}

main #promotion .catch h2 {
	font-weight: bold;
	font-size: 3.75em;
}

main #promotion .catch h2 span {
	display: block;
}

main #promotion .catch p {
	letter-spacing: .125em;
	font-family: "Titillium Web", sans-serif;
	font-weight: 600;
	font-style: normal;
	font-size: 1.125em;
	opacity: .5;
}

@media screen and (max-width: 1300px) {

main #promotion .catch {
	bottom: -6.5em;
}

main #promotion .catch h2 {
	font-size: 3em;
}

}

@media screen and (max-width: 1200px) {

main #promotion .catch p {
	font-size: 1em;
}

}

@media screen and (max-width: 900px) {

main #promotion .catch {
	bottom: -5em;
}

main #promotion .catch h2 {
	font-size: 2.5em;
}

main #promotion .catch p {
	font-size: .875em;
}

}

@media screen and (max-width: 767px) {

main #promotion {
	aspect-ratio: 480/716;
}

main #promotion .site_column::after {
	top: auto;
	translate: 0;
	bottom: -.5vw;
	left: -8vw;
	width: 77vw;
	height: auto;
	animation: .8s logo 1;
}

@keyframes logo {
	0% {
		left: -30vw;
		opacity: 0;
	}
	100% {
		left: -8vw;
		opacity: 1;
	}
}

main #promotion .catch {
	position: absolute;
	top: 10vw;
	bottom: auto;
	left: 0;
	writing-mode: vertical-rl;
	font-feature-settings: normal;
}

main #promotion .catch h2 {
	line-height: 1.6;
	font-size: 6.5vw;
}

main #promotion .catch p {
	font-size: 3vw;
}

}


/*------------------------------------------------------------------------------

	message

------------------------------------------------------------------------------*/

main #message {
	position: relative;
	padding-top: 285px;
}

main #message:after {
	content: "";
	display: block;
	position: absolute;
	top: 0;
	right: 0;
	width: 26%;
	aspect-ratio: 1/1;
	background-image: url(../img/message_decoration.svg);
}

main #message .site_column {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
	align-items: flex-start;
}

main #message .site_column::before {
	content: "Message";
	display: block;
	position: absolute;
	top: -1.5em;
	left: 30%;
	padding: .5em .5em;
	background-color: #FFF;
	letter-spacing: .125em;
	line-height: 1;
	font-family: "Titillium Web", sans-serif;
	font-weight: 600;
	font-style: normal;
	font-size: 5em;
	color: rgba(var(--gray-color),1);
}

main #message .text {
	flex: 1;
	padding: 50px 0 0 50px;
}

main #message .text h2,
main #message .text p,
main #message .text li {
	letter-spacing: .06125em;
}

main #message .text .group {
	display: flex;
	flex-direction: column-reverse;
	justify-content: flex-end;
	align-items: stretch;
}

main #message .text h2 {
	margin-bottom: .5em;
	font-weight: bold;
	font-size: 2.25em;
}

main #message .text h2 span {
	display: block;
}

main #message .text .name {
	margin-bottom: 1em;
	font-weight: bold;
	line-height: 1;
	color: rgba(var(--orenge-color),1);
}

main #message .text .intro p {
	margin-bottom: .125em;
}

main #message .text .intro .button {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	margin: 2em 0 0;
}

main #message .text .intro .button li {
	width: 46%;
	margin: 0;
	list-style: none;
}

main #message .text .intro .button a {
	display: block;
	padding: 1.25em .93875em 1.25em 1em;
	background-color: rgba(var(--gray-color),.3);
	background-image: url(../../common/img/icon_arrow_bk.svg);
	background-repeat: no-repeat;
	background-size: .85em;
	background-position: 1.65em center;
	border: 1px solid rgba(var(--text-color),.3);
	text-decoration: none;
	text-align: center;
	font-weight: bold;
	line-height: 1;
	color: inherit;
}

main #message figure {
	width: 47.2%;
	max-width: 586px;
}

@media screen and (max-width: 1200px) {

main #message {
	padding-top: 220px;
}

main #message:after {
	width: 35%;
}

main #message .site_column::before {
	font-size: 4em;
}

}

@media screen and (max-width: 1024px) {

main #message {
	padding-top: 180px;
}

main #message .site_column::before {
	font-size: 3.5em;
}

main #message .text {
	padding-top: 40px;
	padding-left: 40px;
}

main #message figure {
	width: 40%;
}

}

@media screen and (max-width: 900px) {

main #message {
	padding-top: 160px;
}

main #message .site_column::before {
	font-size: 3em;
}

main #message .text h2 {
	font-size: 2em;
}

main #message .text .intro .button li {
	width: 47.5%;
}

main #message .text .intro .button a {
	background-position: 1em center;
	font-size: .875em;
}

}

@media screen and (max-width: 767px) {

main #message {
	padding-top: 10vw;
	height: 110vw;
}

main #message:after {
	display: none;
}

main #message .site_column::before {
	top: -6.5vw;
	left: 32vw;
	padding: 3vw 5vw;
	font-size: 7vw;
}

main #message .text .group {
	writing-mode: vertical-rl;
}

main #message .text {
	padding-top: 17vw;
	padding-left: 3.5vw;
}

main #message .text h2 {
	margin-bottom: .5em;
	font-size: 6vw;
	font-feature-settings: normal;
}

main #message .text .name {
	margin-left: .5em;
	margin-bottom: 0;
	font-size: 3vw;
	font-feature-settings: normal;
}

main #message .text .intro {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	margin-top: 42vw;
}

main #message .text .intro p,
main #message figure {
	width: 64%;
}

}



