@charset "UTF-8";
/* clearfix */
.cf { zoom: 1; }
.cf:before, .cf:after { content: ""; display: table; }
.cf:after { clear: both; }

.spOnly{ display: none;}
.colorbox-size{
    margin: 0 auto;
    max-width: 50%;
}

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

.pcOnly{ display: none;}
.spOnly{ display: inline-block;}

}

body {
	color: #FAFAFA;
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 16px;
	line-height: 1.5;
	width: auto;
}
a {
	text-decoration: none;
}
section > p {
	margin: 20px;
}
.grid_mozi {
	margin-top: 50%;
	font-size: 17px;
	font-weight: bold;
	line-height: 1.5;
	text-shadow: 2px 2px 3px #FFFFFF;
}
.grid_title  {
	/*display: none;*/
}
.title_icon  {
	display: none;
}
.icon_a {
	width: 400px;
	margin-top: 0;
	margin-right: auto;
	margin-left: auto;
	height: 250px;
	display: none;
}
.normal_link {
	color: rgba(179,179,179,1.00);
	font-weight: bold;
}
.normal_link:hover {
	color: rgba(255,255,255,1.00);
	font-weight: bold;
}
#back_button {
	width: 200px;
	height: 50px;
	margin-top: 20px;
	margin-right: auto;
	margin-left: auto;
	margin-bottom: 20px;
	background-color: #0B1B80;
	line-height: 50px;
	display: block;
	text-align: center;
	text-decoration: none;
	color: #F6F6F6;
}
header {
	width: 100%;
	height: 100vh;
	position: relative;
}
.top_logo {
	width: 60%;
	max-width: 250px;
	height: auto;
	opacity: 0.8;
}
.center_logo {
	text-align: center;
	margin: 0 auto;
	display: block;
}
/*SNS（Twitter）*/
.sns_area {
	position: absolute;
	border-radius: 5px;
	background-color: rgba(255,255,255,0.70);
	-webkit-box-shadow: 0px 0px 3px 3px rgba(255,255,255,0.65);
	box-shadow: 0px 0px 3px 3px rgba(255,255,255,0.65);
	display: block;
	z-index: 10;
	left: 5%;
	bottom: 30px;
}
.sns_area_over768px {
	display:none;
	position: absolute;
	border-radius: 5px;
	background-color: rgba(255,255,255,0.70);
	-webkit-box-shadow: 0px 0px 3px 3px rgba(255,255,255,0.65);
	box-shadow: 0px 0px 3px 3px rgba(255,255,255,0.65);
	z-index: 10;
	right: 5%;
	bottom: 15%;
}
.sns_area .fa-twitter-square {
	color: rgba(0,255,222,1.00);
	padding: 5px;
	font-size: 30px;
	display: block;
	text-decoration: none;
}
/*ここまで*/
/*グローバルナビゲーションの設定*/
header nav,#photo nav {
	width: 36%;
	position: absolute;
	bottom: 20%;
	right: 60%;
}
header nav ul li,#photo nav ul li {
	text-align: center;
	display: block;
	margin-top: 10px;
	margin-right: 10px;
	margin-left: 10px;
	margin-bottom: 15px;
}
header nav ul li a,#photo nav ul li a {
	font-family: 'Happy Monkey', cursive;
	color: rgba(255,255,255,0.75);
	text-decoration: none;
	line-height: 2;
	display: block;
	font-size: 22px;
	-webkit-box-shadow: 0px 0px 5px 5px rgba(255,255,255,0.50);
	border-radius: 50%;
	box-shadow: 0px 0px 5px 5px rgba(255,255,255,0.50);
	border-bottom: 3px double rgba(255,255,255,1.00);
}
header nav ul li .genzaiti,#photo nav ul li .genzaiti {
	border-bottom: 3px double rgba(246,255,0,1.00);
}
header nav ul li a:hover,#photo nav ul li a:hover {
	color: rgba(255,255,255,1.00);
	border-bottom: 3px double rgba(246,255,0,1.00);
	text-shadow: 2px 2px 5px rgba(255,255,255,1.00);
}
/*ロゴ*/
header h1,#photo h1 {
	margin-top: 5vh;
	margin-right: 0;
	margin-left: 5%;
	margin-bottom: 0;
}
header h1 a:hover img,#photo h1 a:hover img {
	opacity: 0.5;
}
/*サブページ左部のスクロール用矢印*/
#photo p {
	text-align: center;
	position: absolute;
	bottom: 5%;
	width: 100%;
}
#photo p .fa-arrow-circle-o-down  {
	color: rgba(255,255,255,0.65);
	font-size: 80px;
}
#photo p .fa-arrow-circle-o-down:hover {
	color: rgba(255,255,255,0.85);
	text-shadow: 0px 0px 7px rgba(255,255,255,1.00);
}
#photo h2 {
	font-family: 'Happy Monkey', cursive;
	font-size: 50px;
	position: absolute;
	bottom: 30%;
	right: 10%;
	text-shadow: 5px 5px 5px #000000;
}
#wrapper {
	width: 100%;
}
#photo {
	width: 100%;
	position: static;
	display: block;
}
#content {
	margin-top: 0;
	position: static;
	left: 0;
	background-color: #0D0F14;
}
#content h1 {
	font-family: 'Happy Monkey', cursive;
	font-size: 35px;
	line-height: 1;
	padding: 40px;
	font-weight: bold;
	text-shadow: 0px 0px 5px;
}
#content .top_gazou {
	width: 90%;
	margin: 0 5% 5%;
	height: auto;
}

/*shulle.jsの設定*/
#sort {
	width: 98%;
	border-bottom: 1px solid #dddddd;
	margin-bottom: 5px;
	overflow: hidden;
}
#sort:after {
  display : table;
  clear : both;
  content : '';
}
#sort ul {
	width: 100%;
	margin-right: -20px;
}
#sort li {
	border-radius: 2px 2px 0 0;
	border: 1px solid #dddddd;
	display: inline-block;
	background-color: #e4e4e4;
	float: left;
	margin-right: 20px;
	width: 10%;
	margin-bottom: -1px;
	text-align: center;
	padding: 6px 0;
	cursor: pointer;
	color: #151819;
	font-size: 12px;
	-webkit-transition: .1s linear;
	-moz-transition: .1s linear;
	-o-transition: .1s linear;
}
#sort li:hover {
	background-color: #f4f4f4;
}
#sort li.active {
	background-color: #f4f4f4;
	border-bottom: 1px solid #f4f4f4;
	cursor: default;
}
/*ソートボタン*/
#btn {
	border-bottom: 1px solid #dddddd;
	margin: 20px;
	overflow: hidden;
}

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

#btn {
	border-bottom: 1px solid #dddddd;
	margin: 15px 0;
	overflow: hidden;
}

}


#btn li {
	font-family: 'Happy Monkey', cursive;
	border-radius: 2px 2px 0 0;
	border: 1px solid #dddddd;
	display: inline-block;
	background-color: #e4e4e4;
	float: left;
	margin-right: 1%;
	width: 17%;
	margin-bottom: -1px;
	text-align: center;
	padding: 6px 0;
	cursor: pointer;
	color: #151819;
	font-size: 16px;
	-webkit-transition: .1s linear;
	-moz-transition: .1s linear;
	-o-transition: .1s linear;
	margin-left: 1%;
}
#btn li:hover {
	background-color: #929292;
}
#btn li.active {
	background-color: #929292;
	border-bottom: 1px solid #f4f4f4;
	cursor: default;
}
#btn li.big{
	width: 26%;
}

/*ソートされる要素*/
#animationList {
	overflow: hidden;
	margin-bottom: 50px;
	min-height: 1000px;
}

#animationList li {
	width: 85%;
	height: auto;
	padding: 15px 10px;
	color: #fff;
}

#animationList li span {
	display: block;
	width: 100%;
	height: auto;
	padding: 20px;
}
#grid {
	height: 1400px !important;
	padding-top: 2%;
}
.about {
	min-height: 1000px;
}
.about p {
	margin-top: 20px;
	margin-right: 20px;
	margin-left: 20px;
	margin-bottom: 10px;
}
/*ソートされる要素の追加設定（アニメーションなど）*/
.hatuhi,.kadan,.yuyake,.hana1,.light,.akasi,.jena,.mosya,.hana2,.dragon,.yakei,.udon,.yuyake2,.left,.right {
	font-family: "Sawarabi Mincho";
	font-size: 0px;
	text-decoration: none;
	color: rgba(250,250,250,1.00);
	display: inline-block;
	transition: .3s;
	text-align: center;
	text-shadow: 2px 2px 4px rgba(0,0,0,1.00);
	-webkit-transition: 0.3s ease-in-out;
       -moz-transition: 0.3s ease-in-out;
         -o-transition: 0.3s ease-in-out;
	filter: saturate(0%);
}
.back {
	font-size: 0px;
	text-decoration: none;
	color: rgba(250,250,250,1.00);
	display: inline-block;
	transition: .2s;
	text-align: center;
	text-shadow: 2px 2px 4px rgba(0,0,0,1.00);
}
.back:hover {
	font-size: 26px;
	text-align: center;
	font-weight: bold;
	text-shadow: 2px 2px 4px rgba(0,0,0,1.00);
	transform:translateY(-18px);
}
.hatuhi:hover,.kadan:hover,.hana1:hover,.akasi:hover,.mosya:hover,.udon:hover {
	font-size: 26px;
	text-align: center;
	font-weight: bold;
	text-shadow: 2px 2px 4px rgba(0,0,0,1.00);
    filter: saturate(100%);
	transform:translateY(-18px);
}
.dragon:hover,.yuyake:hover,.light:hover,.jena:hover,.hana2:hover,.yakei:hover,.yuyake2:hover {
	font-size: 26px;
	font-weight: bold;
	text-align: center;
	filter: saturate(100%);
	transform:translateY(-18px);
}

.right:hover {
	font-size: 20px;
	text-align: center;
	font-weight: bold;
	text-shadow: 2px 2px 4px rgba(0,0,0,1.00);
    filter: saturate(100%);
	transform:translateY(-18px);
}
.left:hover{
	font-size: 20px;
	font-weight: bold;
	text-align: center;
	filter: saturate(100%);
	transform:translateY(-18px);
}

.other_li {
	background-color: #353535;
}

/*aboutページのグリッド*/
.icon_sumaho {
	display: block;
}
#grid1,#grid2,#grid3,#grid4,#grid5,#grid6 {
	width: 96%;
	height: 200px;
	margin: 2%;
	/*background-color: #B2B2B2;*/
}

/*footer*/
footer {
	padding: 50px;
}
footer .copyright {
	text-align: center;
	color: rgba(226,226,226,1.00);
	font-size: 14px;
}
/*トップページのfooter*/
.top_style {
	position: absolute;
	bottom: 0;
	right: 0%;
}
.top_style .copyright {
	font-size: 14px;
	color: rgba(255,255,255,1.00);
	text-align: right;
}
.grid_inner {
	display: block;
	margin-left: 20px;
	font-size: 30px;
	max-width: 200px;
	text-align: center;
	-webkit-box-shadow: 0px 0px 10px 10px rgba(14,14,14,0.75);
	box-shadow: 0px 0px 10px 10px rgba(14,14,14,0.75);
	border-radius: 100%;
	background-color: rgba(0,0,0,1.00);
}
._3d_roll div:nth-child(1) {
	color:#000000;
}
._3d_roll div:nth-child(2) {
	color: #000000;
	font-size: 25px;
	font-weight: bold;
	text-shadow: 0px 0px 5px #FFFFFF;
	background-color:#B2B2B2;
    display:none;
}
/*ここまで*/
/*Works*/
#content .sakuhin {
	text-align: center;
	width: 90%;
	min-width: 120px;
	margin-bottom: 30px;
	margin-left: auto;
	margin-right: auto;
}
#content .sakuhin img{
	width: 100%;
	height: auto;
	-webkit-box-shadow: 0px 0px 10px 10px rgba(255,255,255,0.35);
	box-shadow: 0px 0px 10px 10px rgba(255,255,255,0.35);
	margin-bottom: 10px;
}
#content .sakuhin h2{
  margin-top:10px;
  font-size:17px;
  font-weight:bold;
}
#content .sakuhin p{
	text-align: left;
	font-size: 14px;
	line-height: 1.5;
	padding: 10px;
	display: none;
}
.sakuhin a {
	color: rgba(255,255,255,1.00);
	text-decoration: none;
}
.sakuhin a:hover {
	color: rgba(235,235,235,0.60);
	text-decoration: none;
}
/*ここまで*/
/*Contact*/
div#contents section#contact h2 {
	margin: 0 0 35px 5px;
	font-size: 26px;
	font-weight: bold;
}
div#contents section#contact p {
  margin:0 0 15px 5px;
}
.contact {
	min-height: 1200px;
}
.tbl-layout {
	width: 95%;
	margin: 0 auto;
	border: 1px solid #FFFFFF;
	background-color: #333333;
}
.tbl-layout dt,
.tbl-layout dd {
  padding: 10px 20px;
}
.tbl-layout dt {
  font-weight: bold;
  font-size:20px;
  color:#ffffff;
  background-color:#1C2559;
  border-top:0px solid #fff;
  border-left: 0px solid #fff;
}
.tbl-layout dd {
	font-size: 16px;
	padding-top: 10px;
	padding-bottom: 20px;
	border-bottom: 0px solid #ccc;
}
.tbl-layout dd textarea {
  width:100%;
}
.tbl-layout .w300{
  font-size:16px;
  width:100%;
  height:24px;
}
.tbl-layout .w70{
  font-size:16px;
  width:55px;	
  height:24px;
}
.tbl-layout .bdchange{
  border-bottom:none;	
}
.zikosyoukai {
	margin-left: 30px;
	margin-bottom: 10px;
	margin-top: 20px;
	font-size: 25px;
	text-shadow: 2px 2px 3px rgba(0,0,0,0.66);
}
.error {
	color: #FF0004;
	font-weight: bold;
}
/*ここまで*/
@media only screen and (min-width: 500px) {
header nav {
	width: 60%;
	left: 10%;
}
#grid {
	height: 1450px !important;
	margin: 0;
	border-width: 0px;
	border-style: none;
}
}
/* PC向けおよび大型タブレット向けのレイアウトの指定：768px～960px */
@media only screen and (min-width: 768px) {
.sns_area {
	display: none;
}
.sns_area_over768px {
	display: block;
}
header h1 {
	margin-top: 15vh;
}
header nav {
	width: 60%;
	left: 55%;
	bottom: 87%;
}
header nav ul li {
	text-align: center;
	width: 20%;
	display: block;
	float: left;
}
header nav ul li a {
	line-height: 50px;
	display: block;
}
#nav-toggle,#nav-bg  {
  display: none;
}
#photo {
	width: 50%;
	position: fixed;
	display: block;
	height: 100vh;
}
#photo p {
	display:none;
}
#photo h2 {
	display:none;
}
#content {
	margin-top: 0;
	width: 50%;
	position: absolute;
	left: 50%;
}
#content .sakuhin p{
	font-size: 13px;
	line-height: 1.5;
	display: block;
}

/*Mobile Safariで動作しなかったため断念*/
/*#grid {
	height: 625px !important;
	margin: 2%;
	padding-top: 2%;
	border: 1px solid #FFFFFF;
}
#grid1 {
	width:65%;
	float:left;
	margin:0 0 2% 3.25%;
}
#grid2 {
	width:26%;
	height:407px;
	margin:0 3.5% 0 0;
	float:right;
}
#grid3 {
	width:31.5%;
	margin:0 0 2% 3.25%;
	float:left;
}
#grid4 {
	width:31.4%;
	margin:0 0 2% 2%;
	float:left;
}
#grid5 {
	width:45.7%;
	margin:0 2% 0 3%;
	float:left;
}
#grid6 {
	width:45%;
	float:right;
	margin:0 3.5% 0 0%;
}
.tategaki {
-webkit-writing-mode: vertical-rl;
  	-ms-writing-mode: tb-rl;
 	 writing-mode: vertical-rl;
	 -webkit-text-orientation: right;
}*/
}

@media only screen and (min-width: 933px) {
/*shaffle.js*/
#global-nav ul li {
	text-align: center;
	width: 20%;
	display: block;
	float: none;
}
#animationList li {
	width: 180px;
	height: 180px;
	float: left;
	padding: 20px;
}
#animationList li span {
	width: 170px;
	height: 170px;
}
#content h1 {
	font-size: 45px;
	padding: 45px;
}
.hatuhi:hover,.kadan:hover,.hana1:hover,.akasi:hover,.mosya:hover,.udon:hover {
	transform: rotate(7deg);
}
.dragon:hover,.yuyake:hover,.light:hover,.jena:hover,.hana2:hover,.yakei:hover,.yuyake2:hover {
	transform: rotate(-7deg);
}
	
.right:hover{
	transform: rotate(7deg);
}
.left:hover{
	transform: rotate(-7deg);
}
	
.back:hover {
	transform: rotate(0deg);
}
/*#grid {
	height: 630px !important;
}
#grid2 {
	width:26%;
	height:400px;
}*/
}
/* PC向けレイアウトの指定：961px以上では固定レイアウト */
@media only screen and (min-width: 961px) {
#photo {
	width: 50%;
	position: fixed;
	display: block;
	height: 100vh;
}
#content {
	margin-top:0;
	width: 50%;
	position: absolute;
	left: 50%;
	min-height: 100vh;
}
#content h1 {
	font-size: 50px;
}
/*#grid {
	height: 635px !important;
}
#grid2 {
	width:26%;
	height:413px;
}*/
#content .sakuhin {
 width:100%;
 float: left;
}
#content .sakuhin img{
	float: left;
	width:55%;
	max-width: 305px;
	margin-right: 20px;
	margin-left: 20px;
}
#content .sakuhin p{
  width:40%;
}
}

/* PC向けレイアウトの指定：961px以上では固定レイアウト */
@media only screen and (min-width: 1333px) {
#content .sakuhin h2{
  font-size:18px;
  font-weight:bold;
  border-left:5px solid #ffffff;
  margin-bottom:10px;
  padding-left:10px;
  text-align:left;
  float:left;
  max-width: 340px;
}
#content .sakuhin p{
  line-height:2em;
  border:1px solid #CCC;
  float:left;
	margin-top: 5px;
}
}
@media only screen and (min-width: 1400px) {
	.icon_sumaho {
	display: none;
}
.grid_title  {
	position: absolute;
	top: 45%;
	left: 50%;
    transform: translateX(-50%);
}
.grid_title .title_icon {
	display: block;
}
._3d_roll {
    perspective: 500px;
    -webkit-perspective: 500px;
    -moz-perspective: 500px;
}
.grid_inner {
	display:none;
}
._3d_roll div {
	position: absolute;
	width:100%;
	height:100%;
	padding: 10px;
    border: #ffffff solid 1px;
    text-align: center;
    pointer-events: none;
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
	-webkit-perspective: 500px;
	perspective: 500px;
}
._3d_roll div:nth-child(1) {
	color:#000000;
    transform: rotateX(90deg);
    -webkit-transform: rotateX(90deg);
    -moz-transform: rotateX(90deg);
    transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    transform-origin: 50% 50% -25px;
    -webkit-transform-origin: 50% 50% -25px;
    -moz-transform-origin: 50% 50% -25px;
}
._3d_roll div:nth-child(2) {
	color: #000000;
	font-size: 25px;
	font-weight: bold;
	text-shadow: 0px 0px 5px #FFFFFF;
	background-color:#B2B2B2;
    transform: rotateX(0deg);
    -webkit-transform: rotateX(0deg);
    -moz-transform: rotateX(0deg);
    transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    transform-origin: 50% 50% -25px;
    -webkit-transform-origin: 50% 50% -25px;
    -moz-transform-origin: 50% 50% -25px;
	display:block;
}
._3d_roll:hover div:nth-child(1) {
    transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    transform: rotateX(0deg);
    -webkit-transform: rotateX(0deg);
    -moz-transform: rotateX(0deg);
}
._3d_roll:hover div:nth-child(2) {
    transition: all 0.2s ease;
    -webkit-transition: all 0.2s ease;
    -moz-transition: all 0.2s ease;
    transform: rotateX(-90deg);
    -webkit-transform: rotateX(-180deg);
    -moz-transform: rotateX(-180deg);
	background-color:rgba(0,0,0,0.00);
	color:rgba(0,0,0,0.00);
	border:rgba(0,0,0,0.00);
}
.title_icon {
	display: block;
}
.icon_a {
	width: 100%;
	height: 100%;
	display: block;
}
/*ここまで*/
#grid {
	width: 670px;
	height: 700px !important;
	margin: 0 auto;
	padding-top: 2%;
	border: 1px solid #FFFFFF;
}
#grid1 {
	width: 386px;
	float: left;
	margin-top: 15px;
	margin-right: 0;
	margin-left: 30px;
}
#grid2 {
	width: 193px;
	height: 430px;
	margin: 15px 30px 0 15px;
	float: right;
}
#grid3 {
	width: 178px;
	margin-top: 15px;
	margin-right: 15px;
	margin-left: 30px;
	float: left;
}
#grid4 {
	width: 178px;
	margin-top: 15px;
	margin-right: 15px;
	margin-left: 15px;
	float: left;
}
#grid5 {
	width: 290px;
	float: left;
	margin: 15px 15px 15px 30px;
}
#grid6 {
	width: 290px;
	float: right;
	margin: 15px 30px 15px 15px;
}
.tategaki {
	-webkit-writing-mode: vertical-rl;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	-webkit-text-orientation: right;
	padding-left: 25px;
	font-size: 30px;
	padding-top: 90px;
}

}
@media only screen and (min-width: 1510px) {
#content .sakuhin p{
  width:50%;
}
}
