@charset "UTF-8";

html, body, .container {
  height: 100%;
  width: 100%;
}

*,
*:after,
*::before {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
}

body{
  background-image: url(../img/bgw.jpg);
  background-size: cover;
  background-position: center center;
  background-repeat: no-repeat;
  background-attachment: fixed;
}

#load {
	width: 65px;
	height: 65px;
	margin: -68px 0 0 -68px;
	opacity: 1;
  background-color: #fff;
	position: fixed;
	left: 50%;
	top: 50%;
  z-index: 999;
}

#load p{
  font-size: 80%;
  text-align: center;
  color: #000;
}

#wrap{
  width: 1050px;
	margin: 0 auto;
	padding-top: 5px;
	margin-bottom: 10px;
	/* box-shadow */
  box-shadow:rgba(123,212,255, 0.65098) 0px 0px 6px 4px;
	-webkit-box-shadow:rgba(123,212,255, 0.65098) 0px 0px 6px 4px;
	-moz-box-shadow:rgba(123,212,255, 0.65098) 0px 0px 6px 4px;
	background-attachment: scroll;
	background-image: url(../img/bg.png);
	background-repeat: repeat;
  z-index: 1;
}

#wrap_menu{
  width: 1050px;
	margin: 0 auto;
}

.menu{
  z-index: 100;
  text-align: center;
  width: 1050px;
  display: flex;
  display: -ms-flexbox;
  display: -webkit-flex;
  justify-content: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  position: fixed;
  background-color: transparent;
}

.menu hr{
  border: 0;
  margin: 0;
  height: 1px;
  background-image: -webkit-linear-gradient(left, rgba(0,0,0,0), rgba(0,0,0,0.25), rgba(0,0,0,0));
  background-image:    -moz-linear-gradient(left, rgba(0,0,0,0), rgba(0,0,0,0.25), rgba(0,0,0,0));
  background-image:     -ms-linear-gradient(left, rgba(0,0,0,0), rgba(0,0,0,0.25), rgba(0,0,0,0));
  background-image:      -o-linear-gradient(left, rgba(0,0,0,0), rgba(0,0,0,0.25), rgba(0,0,0,0));
}

nav a {
	position: relative;
	display: inline-block;
	margin: 0px 0px 10px 0px;
	outline: none;
}

nav a:hover,
nav a:focus {
	outline: none;
}

.cl-effect-3 a {
	padding: 1px 0;
}

.cl-effect-3 a::after {
	position: absolute;
	top: 100%;
	left: 0;
	width: 100%;
	height: 1.5px;
	background: rgba(255,67,101,0.8);
	content: '';
	opacity: 0;
	-webkit-transition: opacity 0.3s, -webkit-transform 0.3s;
	-moz-transition: opacity 0.3s, -moz-transform 0.3s;
	transition: opacity 0.3s, transform 0.3s;
	-webkit-transform: translateY(10px);
	-moz-transform: translateY(10px);
	transform: translateY(10px);
}

.cl-effect-3 a:hover::after,
.cl-effect-3 a:focus::after {
	opacity: 1;
	-webkit-transform: translateY(0px);
	-moz-transform: translateY(0px);
	transform: translateY(0px);
}

nav a.active {
	position: relative;
	display: inline-block;
	margin: 0px 0px 10px 0px;
	outline: none;
}

nav a.active:hover,
nav a.active:focus {
	outline: none;
}

.cl-effect-3 a.active {
	padding: 1px 0;
}

.cl-effect-3 a.active::after {
	position: absolute;
  display: none;
	top: 100%;
	left: 0;
	width: 100%;
	height: 1.5px;
	background: rgba(255,67,101,0);
}

#activebar_wrap{
  width: 1050px;
  margin: 69px auto 0px auto;
  position: fixed;
  display: flex;
  display: -ms-flexbox;
  display: -webkit-flex;
  justify-content: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  z-index: 101;
}

.activebar{
  width: 145px;
  height: 1.5px;
	background: rgba(255,67,101,0.8);
  z-index: 101;
}

.nonactivebar{
  width: 145px;
  height: 1.5px;
	background: rgba(255,67,101,0);
  z-index: 101;
}


#wrap_world{
  width: 1050px;
  background: url(../img/mahoujin.png) no-repeat center center fixed;
}

.title{
  width: 1050px;
  position: relative;
  text-align: center;
  padding-top: 100px;
}

.world{
	position: relative;
  margin-top: -80px;
  width: 1050px;
  height: 720px;
	z-index: 10;
}

.background{
  position: absolute;
  top: 100px;
  width: 1050px;
  height: 591px;
  z-index: 1;
}

.element {
  position: absolute;
  display: none;
  background: transparent;
}

.sunahama{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 240px;
  padding-left: 25px;
  z-index: 100;
}

.joshiryou{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 395px;
  padding-left: 90px;
  z-index: 19;
}

.koya{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 240px;
  padding-left: 230px;
  z-index: 18;
}

.gakuen{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 470px;
  padding-left: 260px;
  z-index: 17;
}

.dungeon{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 250px;
  padding-left: 450px;
  z-index: 16;
}

.lab{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 115px;
  padding-left: 580px;
  z-index: 17;
}

.lab_minato{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 150px;
  padding-left: 820px;
  z-index: 16;
}

.syoutengai{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 460px;
  padding-left: 550px;
  z-index: 13;
}

.danshiryou{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 385px;
  padding-left: 730px;
  z-index: 15;
}

.sunahama2{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 450px;
  padding-left: 850px;
  z-index: 14;
}

.minatosouko{
  position: absolute;
  width: 160px;
  height: 45px;
  padding-top: 590px;
  padding-left: 800px;
  z-index: 10;
}

.world_header{
  width: 1050px;
  margin-top: 25px;
  position: relative;
  text-align: center;
}

.world_header p{
  font-size: 18px;
  color: rgba(20,20,20,1);
  padding-left: 80px;
  background: url("../img/dhead.png") 65px 50% no-repeat;
  margin: 0;
  text-shadow: -1px 1px 0 rgba(255,255,255,1);
}

.world_header hr{
  width: 900px;
  border: 0;
  margin-top: 0;
  height: 0;
  border-top: 1px solid #ffb100;
}



.gallery{
	position: relative;
  width: 1025px;
  height: auto;
  padding-top: 20px;
  padding-bottom: 50px;
  margin: 0 auto;
  display: flex;
  display: -ms-flexbox;
  display: -webkit-flex;
  justify-content: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
	z-index: 1;


//  background-color: rgba(255, 255, 255, 0.75);
  /* border-radius */
/*  border-radius:45px;
  -webkit-border-radius:45px;
  -moz-border-radius:45px;
*/
  /* box-shadow */
/*
  box-shadow:rgba(89, 89, 89, 0.65098) 0px 0px 6px 3px;
  -webkit-box-shadow:rgba(89, 89, 89, 0.65098) 0px 0px 6px 3px;
  -moz-box-shadow:rgba(89, 89, 89, 0.65098) 0px 0px 6px 3px;
*/
}

.imgelm{
  width: 234px;
  height: 133px;
  margin-right: 10px;
  margin-bottom: 15px;
}

.imgelm img{
  border: solid 4px rgba(255, 200, 32, 0.85);
  transition: 0.2s;
}

.imgelm.shadow img:hover{
  transition: 0.2s;
  box-shadow:rgba(89, 89, 89, 0.4) 0px 0px 6px 3px;
  -webkit-box-shadow:rgba(89, 89, 89, 0.4) 0px 0px 6px 3px;
  -moz-box-shadow:rgba(89, 89, 89, 0.4) 0px 0px 6px 3px;
}

#footer{
  width: 100%;
  height: auto;
  padding-top: 10px;
  padding-bottom: 10px;
  background-color: rgba(253, 211, 70, 0.95);
  box-shadow:0 8px 12px -8px rgba(0, 0, 0, 0.75) inset;
  -webkit-box-shadow:0 8px 12px -8px rgba(0, 0, 0, 0.75) inset;
  -moz-box-shadow:0 8px 12px -8px rgba(0, 0, 0, 0.75) inset;
}

.fcontainer{
  width: 1050px;
  display: flex;
  display: -ms-flexbox;
  display: -webkit-flex;
  justify-content: center;
  -ms-flex-pack: center;
  -webkit-justify-content: center;
  -webkit-flex-wrap: wrap;
  flex-wrap:         wrap;
  margin: 0 auto;
  text-shadow: 2px 8px 6px rgba(0,0,0,0.2),
               0px -5px 16px rgba(255,255,255,0.3);
}

.flogo{
  text-align: center;
  width: 500px;
  margin: 0;
  padding: 0;
}
.flogo2{
  text-align: center;
  width: 500px;
  margin-top: 20px;
  padding: 0;
}

.copyright{
  width: auto;
  text-shadow: 2px 8px 6px rgba(0,0,0,0.2),
               0px -5px 16px rgba(255,255,255,0.3);
}
.copyright p{
  text-align: center;
  font-size: 15px;
  font-family: 'Cabin', sans-serif;
  color:#333333;
  padding-left: 14px;
  line-height: 0.8em;
}
