img {
  border:0;
}

body{
    width:100%;
    background-color: white;
    color: 666666;
    font-size: 13px;
    line-height:2;
    text-align: center;
    margin:0 auto;
    padding:0;
}

#main{
	width: 100% ;
	max-width: 960px ;
    margin:0 auto;
    text-align: left;
    background-color: eee;
}

#topmenu{
	width: 75% ;
	margin:14vmin auto;
}

#headmenu{
	margin:2vmin auto;
}

#topbn {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 50px;
	margin: auto;
	width:600px;
	height:150px;
}

#topbn2 {
	left: 0;
	right: 0;
	margin:40px auto;
	width:600px;
}

#topbn2 img {
	width:600px;
}

#toptw {
	width:800px;
	height:400px;
    display:block;
	left: 0;
	right: 0;
	margin: 100px auto;
	text-align: center;
}

#topbn img {
	width:600px;
}

hr {
	height: 0; 
	margin: 0; 
	padding: 0; 
	border: 0;
	border-top: 1px dotted #999;
	margin:20px 0;
}

#mean {
	border-left: 1px solid;
	text-align: left;
	font-family: "Noto Sans Japanese";
	font-weight: 400;
	font-size:14px;
	padding:0px 15px;
}

#text {
	text-align: left;
	font-family: "Noto Sans Japanese";
	font-weight: 400;
}

#emark {
	float: right;
}

#header {
	width: 100% ;
	max-width: 960px ;
	margin-top: 30px;
	text-align: left;
	font-family: "Noto Sans Japanese";
	font-weight: 400;
	font-size:14px;
}

#cattit {
	width: 100% ;
	max-width: 960px ;
	margin-top: 30px;
	text-align: left;
	font-family: "Noto Sans Japanese";
	font-weight: 400;
	font-size:14px;
}

input[type="text"],
textarea {
	padding: 0.8em;
	outline: none;
	border: 1px solid #DDD;
	-webkit-border-radius: 3px;
	-moz-border-radius: 3px;
	border-radius: 3px;
	font-size: 16px;
}
input[type="text"]:focus,
textarea:focus {
	box-shadow: 0 0 7px #3498db;
	border: 1px solid #3498db;
}

input[type="text"] {
	-webkit-transition: all .3s;
	-moz-transition: all .3s;
	transition: all .3s;
}

.subbut {
    width:200px;
    font-size:16px;
    text-decoration:none;
    display:block;
    text-align:center;
    padding:8px 0 10px;
    color:#333;
    background-color:#eeeeee;
    border-radius:5px;
    cursor : pointer;
}

.category {
	font-family: 'Source Sans Pro', sans-serif;
	font-weight: 900;
	font-size:42px;
}

#column{
	width: 100% ;
	max-width: 960px ;
	margin:0 auto;
	text-align: left;
	border: 1px solid #ccc;
	border-radius: 10px;
	-webkit-border-radius: 10px;
	-moz-border-radius: 10px;
	padding:30px;
	box-sizing: border-box;
}

#column img{
	width: 250px ;
	float: left;
 	margin-right:30px;
}

table#type04 {
	width: 100% ;
	max-width: 960px ;
	border-collapse: separate;
	border-spacing: 1px;
	text-align: left;
	line-height: 1.5;
	border-top: 1px solid #ccc;
}

table#type04 th {
	padding: 20px;
	font-weight: bold;
	vertical-align: top;
	border-bottom: 1px solid #ccc;
white-space: nowrap;
}

table#type04 td {
	padding: 20px;
	vertical-align: top;
	border-bottom: 1px solid #ccc;
}

.comp { font-family: "Noto Sans Japanese"; font-weight: 400; font-size:14px;}

.wf-ns16 { font-family: "Noto Sans Japanese"; font-weight: 400; font-size:16px;}
.wf-ns18 { font-family: "Noto Sans Japanese"; font-weight: 700; font-size:18px;}
.wf-ns21 { font-family: "Noto Sans Japanese"; font-weight: 700; font-size:21px;}
.wf-ns28 { font-family: "Noto Sans Japanese"; font-weight: 400; font-size:28px;}
.wf-ns36 { font-family: "Noto Sans Japanese"; font-weight: 700; font-size:48px; line-height:1;}
.wf-sm21 { font-family: "Sawarabi Mincho"; font-size:21px; }

a:link,a:visited {
  color:#0066cc;
  text-decoration:none;
}

#footer {
    background-color:#000000;
    color: #fff;
    width:100%;
    text-align: center;
    margin-left:auto;
    margin-right:auto;
    font-size:12px;
    z-index: 10;
    bottom: 0px;
    position: fixed; 
    padding:5px;
    font-family: "Noto Sans Japanese";
    font-weight: 400;
}

sapn.transOFF {opacity:1; filter: alpha(opacity=100); -moz-opacity: 1;}
span.transON  {opacity:.70; filter: alpha(opacity=70); -moz-opacity: 0.7;}

.box{
	width: 100vw;
	height: 100vh;
	margin:0 auto;
	position:relative;
	background:#fff url(../images/top.png) no-repeat;
	background-size:100% auto;
	background-position: center bottom -100px; 
	color:#fff;
	overflow-x: hidden;
}

.box img { 
    width: 300px;
}

#mail{
    width:100%;
    text-align: center;
    margin-left:auto;
    margin-right:auto;
    padding:0px 0 50px 0 ;
}

.br-sp { display:none; }
.br-pc { display:block; }


/* ------------------------------
   #menuList
------------------------------ */

ol, ul {
	list-style: none;
	margin: 0;
	padding: 0;
	border: 0;
}

#menuList {
	margin-top:8px;
	float: right;
	text-align: right;
	font-family: 'Source Sans Pro', sans-serif;
	font-weight: 600;
	font-size:18px;
	z-index: 10;
}

#menuList ul {
	margin: 0 auto;
	width: 100%;
	height: 30px;
}

#menuList ul li {
	padding: 0 0 0 30px;
	height: 30px;
	float: left;
	box-sizing: border-box;
}

#menuList ul li a {
	height: 30px;
	line-height: 30px;
	display: block;
	transition: all 0.2s linear;
	color: #999;
}

#menuList ul li:hover > a {
	color: #000;
}


#menuListtop {
	margin-top:60px;
	float: right;
	text-align: right;
	font-family: 'Source Sans Pro', sans-serif;
	font-weight: 600;
	font-size:20px;
	z-index: 10;
}

#menuTitle {
	float: left;
	z-index: 10;
    color: #666666;
    font-size: 13px;
	text-align: left;

}

#headTitle {
	float: left;
	z-index: 10;
}

#headTitle img{
    width:300px;
    height: auto;
}

#menuListtop ul {
	margin: 0 auto;
	width: 100%;
	height: 30px;
}

#menuListtop ul li {
	padding: 0 0 0 30px;
	height: 30px;
	float: left;
	box-sizing: border-box;
}

#menuListtop ul li a {
	height: 30px;
	line-height: 30px;
	display: block;
	transition: all 0.2s linear;
	color: #999;
}

#menuListtop ul li:hover > a {
	color: #000;
}


#contents {
	margin: 0 auto;
	padding: 40px 0;
	width: 800px;
	text-align: left;
}

#contents p {
	padding-bottom: 2em;
	font-size: 1em;
	line-height: 2em;
}

.rescat {
display: inline-block;
  font-size:16px;
  line-height:11px;
   text-align: center;
  color:#fff;
  background-color:#000;
  padding:6px 10px;
  margin-bottom:10px;
}

#resspec {
	width: 100% ;
	max-width: 340px;
	float:left;
	text-align: left;
	font-family: "Noto Sans Japanese";
	font-weight: 400;
	font-size:14px;
	line-height: 1.5em;
	margin-right:20px;
}

#resph img { 
	width: 100% ;
	max-width: 600px;
}

.mds24 {
	font-family: "Noto Sans Japanese";
	font-weight: 700;
	font-size:24px;
	line-height: 1.3em;
	margin-bottom:10px;
}

#ytfr { 
	float:right;
	width: 100% ;
	max-width: 600px;
}

.youtube {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;

}

/* ------------------------------
   #anime
------------------------------ */
#anime {
  display: block;
  position: relative;
  width: 100%;
  height: 400px;
  text-align: center;
  margin-top: 80px;
}

.name {
width: 100%;
  display: inline-block;
  position: absolute;
  z-index: 2;
top: 50%;
left: 50%;
-ms-transform: translate(-50%,-50%);
-webkit-transform : translate(-50%,-50%);
transform : translate(-50%,-50%);
}

.logob {
  display: inline-block;
  position: absolute;
  z-index: 3;
top: 50%;
left: 50%;
visibility: hidden;
-ms-transform: translate(-50%,-50%);
-webkit-transform : translate(-50%,-50%);
transform : translate(-50%,-50%);
  will-change: transform;
  -webkit-animation-name: lgam2;
  -webkit-animation-duration: 6s;
  -webkit-animation-delay: 24s;
  -webkit-animation-timing-function:ease-in-out;
  -webkit-animation-fill-mode: forwards;
animation-name: lgam2;
animation-duration: 4s;
animation-delay: 14s;
animation-timing-function:ease-in-out;
animation-fill-mode: forwards;
}

.catcha {
width: 100%;
  display: inline-block;
  position: absolute;
  z-index: 1;
top: 50%;
left: 50%;
-ms-transform: translate(-50%,-50%);
-webkit-transform : translate(-50%,-50%);
transform : translate(-50%,-50%);
}

.text {
  font-family: 'EB Garamond', serif;
  font-size: 120px;
  color: white;
  text-indent: 0px;
  letter-spacing: -5px;
  margin: 100px;
}

.text span {
  display: inline-block;
  position: relative;
  will-change: transform;
  -webkit-animation: diffuseShadow 14s ease-in forwards;
          animation: diffuseShadow 14s ease-in forwards;
  margin: 0 10px;
}

.text span:nth-child(1) {
  -webkit-animation-delay: 0s;
          animation-delay: 0s;
}

.text span:nth-child(2) {
  -webkit-animation-delay: 1s;
          animation-delay: 1s;
}

.text span:nth-child(3) {
  -webkit-animation-delay: 2s;
          animation-delay: 2s;
}

.text2 {
  font-family: 'EB Garamond', serif;
  font-size: 120px;
  color: white;
  text-indent: 0px;
  letter-spacing: -5px;
  margin: 100px;
}

.text2 span {
  display: inline-block;
  position: relative;
  will-change: transform;
  -webkit-animation: diffuseShadow2 6s ease-in forwards;
          animation: diffuseShadow2 6s ease-in forwards;
  margin: 0 10px;
}

@-webkit-keyframes lgam {
0% {    opacity:0;  }
40% {  opacity:1;  }
100% {  opacity:0;  }
}

@keyframes lgam {
0% {    opacity:0;  }
40% {  opacity:1;  }
100% {  opacity:0;  }
}

@-webkit-keyframes lgam2 {
0% {  visibility: visible;  opacity:0;   }
100% { visibility: visible; opacity:1;  }
}

@keyframes lgam2 {
0% {  visibility: visible;  opacity:0;   }
100% { visibility: visible; opacity:1;  }
}


@-webkit-keyframes diffuseShadow {
  0%,35% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
  color: white;
  }
  50% {
    text-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
  color: white;
  }
  80%,100% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
    color: white;
    visibility: hidden;
  }
}

@keyframes diffuseShadow {
  0%,35% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
  color: white;
  }
  50% {
    text-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
  color: white;
  }
  80%,100% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
    color: white;
    visibility: hidden;
  }
}

@-webkit-keyframes diffuseShadow2 {
  0% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
  color: white;
  }
  40% {
    text-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
  color: white;
  }
  100% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
    color: white;
    visibility: hidden;
  }
}

@keyframes diffuseShadow2 {
  0% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
  color: white;
  }
  40% {
    text-shadow: 0 5px 10px rgba(0, 0, 0, 0.3);
  color: white;
  }
  100% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0);
    color: white;
    visibility: hidden;
  }
}

#anime .logoa img {
    width: 320px;
    margin-top: 60px;
}

#anime .logob img {
    width: 280px;
}



/* ------------------------------
   MEDIAQUERIES LAYOUT
------------------------------ */
@media only screen and (max-width: 768px) {
	#menuList ul {
		width: 100%;
	}

	#menuList ul li {
		width: 20%;
	}
}

/* ------------------------------
   MEDIAQUERIES[SP]LAYOUT
------------------------------ */
@media only screen and (max-width: 768px) {
	#menuListtop {
		display: none;
	}

	#menuList {
		display: none;
	}

	#rwdMenuWrap {
		width: 100%;
		border-bottom: #0099ff 0px solid;
		position: fixed;
		z-index: 10;
	}

	#rwdMenuWrap #switchBtnArea {
		width: 100%;
		height: 50px;
		background-color: #000;
		position: relative;
	}

	#rwdMenuWrap #switchBtnArea #switchBtn {
		top: 5px;
		right: 5px;
		width: 40px;
		height: 40px;
		display: block;
		background: #0099ff;
		position: absolute;
		border-radius: 5px;
	}

	#rwdMenuWrap #switchBtnArea #switchBtn span {
		left: 20%;
		width: 60%;
		height: 4px;
		display: block;
		position: absolute;
		background-color: #fff;
		border-radius: 5px;
		transition: all 0.2s linear;
	}
	#rwdMenuWrap #switchBtnArea #switchBtn span:nth-of-type(1) {
		top: 10px;
		-webkit-transform: rotate(0);
		transform: rotate(0);
	}
	#rwdMenuWrap #switchBtnArea #switchBtn span:nth-of-type(2) {
		top: 18px;
		-webkit-transform: scale(1);
		transform: scale(1);
	}
	#rwdMenuWrap #switchBtnArea #switchBtn span:nth-of-type(3) {
		bottom: 10px;
		-webkit-transform: rotate(0);
		transform: rotate(0);
	}

	#rwdMenuWrap #switchBtnArea #switchBtn.btnClose span:nth-of-type(1) {
		top: 18px;
		-webkit-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
	#rwdMenuWrap #switchBtnArea #switchBtn.btnClose span:nth-of-type(2) {
		-webkit-transform: scale(0);
		transform: scale(0);
	}
	#rwdMenuWrap #switchBtnArea #switchBtn.btnClose span:nth-of-type(3) {
		bottom: 18px;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#rwdMenuWrap ul {
		width: 100%;
		display: none;
	}

	#rwdMenuWrap ul li {
		width: 100%;
		border-bottom: #000 1px solid;
	}

	#rwdMenuWrap ul li a {
		padding: 10px 20px;
		text-align: left;
		display: block;
		background: #0099ff;
		position: relative;
		color: #fff;
		font-family: "Noto Sans Japanese";
		font-weight: 700;
	}

	#rwdMenuWrap ul li a:after {
		content: '';
		margin-top: -4px;
		top: 50%;
		right: 15px;
		width: 8px;
		height: 8px;
		color: #888;
		font-size: 1em;
		font-weight: bold;
		line-height: 1.2em;
		display: block;
		position: absolute;
		border-top: 2px solid #fff;
		border-right: 2px solid #fff;
		-webkit-transform: rotate(45deg);
		transform: rotate(45deg);
	}

	#contents {
		width: 100%;
	}

	#contents p {
		padding: 0 20px 2em 20px;
	}

/* ------------------------------
   #anime
------------------------------ */
#anime {
  display: block;
  position: relative;
  width: 100%;
  height: 260px;
  text-align: center;
  margin-top: 60px;
}

.text {
  font-family: 'EB Garamond', serif;
  font-size: 80px;
  line-height: 0.7em;
  color: white;
  text-indent: 0px;
  letter-spacing: -2px;
  margin: 40px;
}

.text2 {
  font-family: 'EB Garamond', serif;
  font-size: 80px;
  line-height: 0.7em;
  color: white;
  text-indent: 0px;
  letter-spacing: -2px;
  margin: 0px;
}

#anime .logob img {
    width: 220px;
}

}

/* ------------------------------
   CLEARFIX ELEMENTS
------------------------------ */
#menuList > ul:before,
#menuList > ul:after {
	content: " ";
	display: table;
}
#menuList > ul:after {clear: both;}
#menuList > ul {*zoom: 1;}


/* スマホだけに適用するCSS--------------------------------------------------------------------- */
@media screen and (max-width:768px)
{

body{
-webkit-text-size-adjust: 100%;
    width:100%;
    background-color: white;
    color: 666666;
    font-size: 13px;
    line-height:1.7;
    text-align: center;
    margin:0 auto;
    padding:0;

}

.box{
	width: 100vw;
	height: 100vh;
	margin:0 auto;
	position:relative;
	background:#fff url(../images/top.png) no-repeat;
	background-size: auto 60%;
	background-position: center bottom; 
	color:#fff;
	font-family: "Noto Sans Japanese";
	font-weight: 700;
	font-size:16px;
	overflow-x: hidden;
}

.box img { 
	margin-top: 20px;
    width: 100%;
}

#main{
	width: 90% ;
	max-width: 960px ;
	margin:0 auto;
	text-align: center;
	overflow:hidden;
}

#headTitle {
	float: left;
	z-index: 10;
	position:fixed;
	margin-left:-10px;
}

#headTitle img {
	width: 240px;
}

#cattit {
	width: 100% ;
	margin-top: 20px;
    margin-bottom: 30px;
	text-align: left;
	font-family: "Noto Sans Japanese";
	font-weight: 400;
	font-size:14px;
}

.cat {
	font-family: 'Oswald', sans-serif;
	font-weight: 700;
	font-size:42px;
	line-height:1;
}

.wf-sm21 { font-family: "Sawarabi Mincho"; font-size:18px; }


#column img{
	width: 100% ;
    margin-bottom: 15px;
}

table#type04 {
	width: 100% ;
	border-collapse: separate;
	border-spacing: 1px;
	text-align: left;
	line-height: 1.5;
	border-top: 1px solid #ccc;
}

table#type04 th {
	padding: 20px;
	font-weight: bold;
	vertical-align: top;
	border-bottom: 1px solid #ccc;
white-space: nowrap;
}

table#type04 td {
	padding: 20px;
	vertical-align: top;
	border-bottom: 1px solid #ccc;
}

.comp { font-family: "Noto Sans Japanese"; font-weight: 400; font-size:12px;}

#footer {
    background-color:#000000;
    color: #fff;
    width:100%;
    text-align: center;
    margin-left:auto;
    margin-right:auto;
    font-size:9px;
    z-index: 10;
    bottom: 0px;
    position: fixed; 
    padding:5px;
    font-family: "Noto Sans Japanese";
    font-weight: 400;
}

.br-sp { display:block; }
.br-pc { display:none; }

#topbn {
	position: absolute;
	left: 0;
	right: 0;
	bottom: 50px;
	margin: auto;
	width:100%;
}

#topbn2 {
	left: 0;
	right: 0;
	margin:20px auto;
	width:100%;
}

#topbn2 img {
	width:80%;
}

#topbn img {
	width:80%;
}

#toptw {
	width:80%;
	display:block;
	left: 0;
	right: 0;
	margin: 100px auto;
	text-align: center;
}

#resspec {
	width: 100% ;
	max-width: 100% ;
	float:left;
	text-align: left;
	font-family: "Noto Sans Japanese";
	font-weight: 400;
	font-size:14px;
	margin-bottom:20px;
}

}