@charset "UTF-8";

/*
----------------------------------------------------*/
html, body {
    height: 100%;
}
body {
	font-size:16px;
	color: #fff;
	background: #c1d2ee;
}

/*
reset
*/
html {overflow-y: scroll;}
body,div,dl,dt,dd,ul,ol,li,
h1,h2,h3,h4,h5,h6,
pre,code,form,fieldset,legend,
p,blockquote,table,th,td {margin: 0; padding: 0;}

img {
}
ul,dl,ol {text-indent: 0;}
li {list-style: none;}
.ie8 img{
  width: auto;
}

a {
    transition: all 0.5s ease;
}
a img:hover{
	opacity: 1;
}

/*layout
----------------------------------------------------*/
#container {
	text-align: center;
	display: flex;
	justify-content: center;
	width: 100vw;
	height: 56.25vw;
	max-width: 1920px;
	max-height: 1080px;
    margin: 0 auto;
   	padding: 0;
	overflow: hidden;
	z-index: 0;
}
img {
	width: 100%;
}

#title {
	width: 35vw;
	height: 56.25vw;
	max-width: 768px;
	max-height: 1080px;
	position: relative;
	background: rgba(216,216,216,.0);
}
#title h1 {
	width: 80%;
	height: 100%;
	max-width: 548px;
	max-height: 1080px;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	margin: auto;
}
#title p {
	width: 12.5vw;
	height: 12.5vw;
	max-width: 240px;
	max-height: 240px;
	position: absolute;
	bottom: 4vw;
	left: 0;
	right: 0;
	margin: auto;
}
#title p a img {
    transition: all 0.5s ease;
}
#title p a img:hover {
	transform: rotate(370deg)
}

#main {
	width: 60vw;
	height: 56.25vw;
	max-width: 1152px;
	max-height: 1080px;
    margin: 0;
	position: relative;
	z-index: 1;
}
#main #fightsong {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1100;
}
#main #utahime {
	position: absolute;
	bottom: 0;
	left: 0;
	z-index: 1100;
}
#main #mask {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1000;
}
#main #photo {
	width: 100%;
	display: flex;
	justify-content: center;
	gap: 0 1vw;
	background: #8a9ab3;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
}
#main .photo {
	width: 28.12%;
}
#main #photo1 {
	top: 0;
	left: 0;
}
#main #photo2 {
	top: 0;
	left: 0;
}
#main #photo3 {
	top: 0;
	left: 0;
}

#column {
}
.page {
	color: #333;
	width:100%;
	height: 100%;
    margin: 0 auto;
   	padding: 0px 0px 0px 0px;
	text-align: center;
}
.page header {
	width: 100%;
	background-size: 50%;
	z-index: 10;
}
#column header {
	height: 180px;
}
#column main {
    padding: 0px 0 0 0;
}
.page h1 {
	width: 30%;
	text-align:center;
	margin: 0px auto 0px auto;
}
.page h1 img {
	width: 100%;
}

.page h2 {
	font-size:16px;
	font-weight: bold;
	line-height:18px;
	margin:10px 0px 20px 0px;
	text-align:left;
}
.page h3 {
	font-size:14px;
	font-weight: bold;
	line-height:18px;
	margin:10px 0px 10px 0px;
	text-align:left;
}
.page h2 span {
	font-size: 80%;
}
.pageBody {
    margin: 0px 40px 10px;
   	padding: 40px 40px;
	background: rgba(255,255,255,0.8);
	border-radius: 20px;
}
.page p {
	font-size:14px;
	line-height:1.8;
	margin:0px 0px 1em 0px;
	text-align:left;
}
.page p .name {
	font-size: 80%;
	font-weight: bold;
}
.page p.auth {
	text-align:right;
}
.pageBody div.flex {
	display: flex;
	justify-content: space-between;
	margin-bottom: 1.5em;
}
.pageBody div.flex.rev {
	flex-direction: row-reverse;
}
.pageBody .flex p {
	width: 50%;
}
.pageBody .flex .mem_photo {
	width: 45%;
	height: auto;
	margin: 0 1em 0 0;
}
.pageBody .rev .mem_photo {
	margin: 0 0 0 1em;
}
.movie {
	width: 100%;
	max-width: 640px;
	margin: 0px auto 1.5em;
	height: auto;
	vertical-align: top;
	padding-bottom: 0px;
}
.movie h2 {
	color: #739891;
	font-size:16px;
	font-weight: bold;
	line-height:18px;
	margin: 2em auto 1em;
	text-align:center;
}
.movie .yt {
	position: relative;
	width: 100%;
	padding-top: 56.25%;
}
.movie .yt iframe {
	position: absolute;
	top: 0;
	right: 0;
	width: 100% !important;
	height: 100% !important;
}
#footer2 {
	color:#333;
	font-family: 'Roboto', sans-serif;
	text-align:center;
	padding:20px 40px 15px 40px;
}
#footer2 a.close {
	color:#fff;
	text-decoration:none;
	border-radius: 16px;
	background:#f29ec8;
	border:3px solid #f29ec8;
	padding:2px 10px;
	margin:5px 40px 0px 40px;
}
#footer2 a.close:hover {
	color: #f29ec8;
	background: #fff;
	border:3px solid #f29ec8;
}
#footer2 p {
	font-size:12px;
	color:#666;
	font-family: 'Roboto', sans-serif;
	text-align:center;
	margin:30px 20px 0px 20px;
}

@media screen and (max-width: 480px) {
.page {
	color: #333;
	width:100%;
	height: 100%;
    margin: 0 auto;
   	padding: 0px 0px 0px 0px;
	text-align: center;
}
#column main {
    padding: 0px 0 0 0;
}
.page h1 {
	width: 50%;
	text-align:center;
	margin: 0px auto 0px auto;
}
.pageBody {
    margin: 0px 20px 10px;
   	padding: 20px 20px;
	background: rgba(255,255,255,0.8);
	border-radius: 20px;
}
.pageBody div.flex {
	display: flex;
	justify-content: space-between;
	flex-direction: column;
	margin-bottom: 1.5em;
}
.pageBody div.flex.rev {
	flex-direction: column;
}
.pageBody .flex p {
	width: 100%;
}
.pageBody .flex .mem_photo {
	width: 100%;
	height: 80vw;
	margin: 0 0em 1em 0;
	object-fit: cover;
	object-position: 0 0;
	overflow: hidden;
}
}