@charset "UTF-8";
* {
	margin:0;
	padding:0;
}
html{
	height:100%;
}
body {
     font-family: 'Noto Sans JP', sans-serif;
	 height: 100%;
}
p {
	color:#666;
	font-size:13px;
}
h1 {
	font-size:25px;
}
h2 {
	font-size:22px;
}
h3 {
	font-size:15px;
}
h4 {
	font-size:14px;
}
.wrapper-all{
	 min-height: 100vh;
    position: relative;/*←相対位置*/
    padding-bottom: 400px;/*←footerの高さ*/
    box-sizing: border-box;/*←全て含めてmin-height:100vhに*/
}
.wrapper{
width: 100%;
position: relative;
min-height: 100%;
}
.title-1{
text-align: center;
padding: 20px 0 40px 0;
}
.title-2{
padding: 30px 0;
}
a {
	color:#444;
	text-decoration:none;
	transition: all 0.2s linear;
}
a:hover {
	color: #2C9AB7;
}
.hero a {
	color:#fff;
	text-decoration:none;
	transition: all 0.2s linear;
}
.hero a:hover {
	color: #2C9AB7;
}
img {
	max-width: 100%;
	height: auto;
	width : /***/auto;
}
time {
	font-size:10px;
}
.newerposts {
	margin-left:15%;
	padding-bottom: 30px;
}
.olderposts {
	text-align:right;
	margin-right:15%;
	padding-bottom: 30px;
}
.btn{
	text-align: center;
	padding:30px;
}
.button {
    background-color:#111111;
    border: 2px solid #111111;
	color: #FFF;
    padding: 16px 32px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    font-size: 16px;
    margin: 30px 2px;
    -webkit-transition-duration: 0.4s; /* Safari */
    transition-duration: 0.4s;
    cursor: pointer;
	border-radius: 30px;
}
.button:hover {
    background-color: #fff;
	border: 2px solid #111111;
    color: #000;
}
a.button{
	display:inline-block;
	text-decoration:none;
	position:absolute;
	right:30px;
	color:rgba(28, 190, 131, 1);
	background-color:transparent;
	border:1px solid rgba(28, 190, 131, 1);
	border-radius:100px;
	padding: .5em 1.2em;
	margin:5px;
	background-size: 200% 100%;	
	background-image: linear-gradient(to right, transparent 50%, rgba(28, 190, 131, 1) 50%);
	transition: background-position .3s cubic-bezier(0.19, 1, 0.22, 1) .1s, color .5s ease 0s, background-color .5s ease;
}
a.button:hover{
	color:rgba(255, 255, 255, 1);
	background-color:rgba(28, 190, 131, 1);
	background-position: -100% 100%;
}
.button2 {
    background-color:#111111;
    border: 2px solid #111111;
	color: #FFF;
    padding: 16px 32px;
    text-align: center;
    text-decoration: none;
    display: inline-block;
    font-size: 13px;
    margin: 30px 2px;
    transition-duration: 0.4s;
    cursor: pointer;
	border-radius: 30px;
}
.button2:hover {
    background-color: #fff;
	border: 2px solid #111111;
    color: #111111;
}
a.button2{
	display:inline-block;
	text-decoration:none;
	position:absolute;
	right:30px;
	color:rgba(28, 190, 131, 1);
	background-color:transparent;
	border:1px solid rgba(28, 190, 131, 1);
	border-radius:100px;
	padding: .5em 1.2em;
	margin:5px;
	background-size: 200% 100%;	
	background-image: linear-gradient(to right, transparent 50%, rgba(28, 190, 131, 1) 50%);
	transition: background-position .3s cubic-bezier(0.19, 1, 0.22, 1) .1s, color .5s ease 0s, background-color .5s ease;
}
a.button2:hover{
	color:rgba(255, 255, 255, 1);
	background-color:rgba(28, 190, 131, 1);
	background-position: -100% 100%;
}
.not-found{
	text-align: center;
	padding-top: 100px;
}

/* header */
.logo {
	float:left;
	width:10%;
}
.logo img {
	width:150px;
	min-width:150px;
	margin-top:8px;
	margin-left:8px;
}

/* main */
main {
	width:100%;
	max-width:3840px;
	margin:0 auto;
	padding-bottom: 70px;
}
.category-title {
	text-align: center;
	margin: 20px 0 30px 0;
}
.log{
	max-width: 1220px;
		margin:0 auto;
}
article {
	width:90%;
	margin:0 auto;
	margin-bottom: 30px;
}
.clear {
	clear:both;
}
.center {
	text-align:center;
	margin: 0 auto;
}
.left{
	text-align: left;
	width:90%;
	margin:0 auto;
	padding-bottom: 30px;
}
.right{
	text-align: right;
	width:90%;
	margin:0 auto;
	padding-bottom: 30px;
}
.date{
	text-align: right;
}
.video {
	position:relative;
	width:100%;
	padding-top:56.25%;
}
.video iframe{
	position:absolute;
	top:0;
	right:0;
	width:100%;
	height:100%;
}
.input {
	margin-left:10px;
}
.thanks {
	margin: 0 0 11em 0;
	padding: 11em 0 0 0;
	text-align: center;
	}
.logo-thanks {
	width:20%;
	margin: 0 auto;
	padding-top:1em;
}
.footer-margin {
	margin-top: 30em;
}
/* hero */
.hero {
	clear:both;
	background-color: #FFFFFF;
	padding-top: 220px;
	padding-bottom: 220px;
	background:url(../img/hero.jpg);
	background-position:center;
	background-repeat:no-repeat;
	background-size:cover;
}
.hero-skate {
	clear:both;
	background-color: #FFFFFF;
	padding-top: 220px;
	padding-bottom: 220px;
	background:url("../img_skate/skate-hero.jpg");
	background-position:center;
	background-repeat:no-repeat;
	background-size:cover;
}
.hero_header {
	text-align: center;
	color: #FFF;
	margin-top: 4px;
	text-transform: uppercase;
	letter-spacing: 1px;
}
.tagline {
	text-align: center;
	color: #FFF;
	margin-top: 4px;
	letter-spacing: 1px;
}

/* work categories */
.work-categories {
	display: flex;
}
a img {
	opacity:1;
	transition: all 0.3s linear;
}
a:hover img, a:active img {
	opacity: 0.8;
}
.textbox{
	padding:5px 5px 20px 5px;
}

/* design */
.square-gallery {
	display: flex;
	flex-flow: wrap;
	padding:0 5px;
}
.square-grid {
	width: 25%;
}
.square-inside{
	padding: 0 5px 10px 5px;
	text-align: center;
}
.fadein-bottom {
   opacity: 0;
   animation-name: fadein-bottom;
   animation-duration: 1s;
   animation-timing-function: ease-out;
   animation-fill-mode: forwards;
}
@keyframes fadein-bottom {
   0% {
      opacity: 0;
      transform: translateY(30px);
   }
   100% {
      opacity: 1;
      transform: translateY(0);
   }
}
/*info*/
#info{
	width: 60%;
	margin: 0 auto;
	max-width: 700px;
}
#info dt{
	width: 20%;
	font-size: 15px;
}
#info dd{
width: 80%;
}
.info{
max-width: 800px;
}
.dd{
display: inline;
}
.pp{
max-width: 1110px;
margin: 0 auto;
}
/*contact*/
#form{
	width: 70%;
	margin: 0 auto;
	max-width: 1110px;
}
dl{
	display:flex;
	flex-wrap: wrap;
	font-size: 13px;
}
dt{
	width: 30%;
	font-size: 15px;
	font-weight: bold;
}
dd{
	padding-bottom: 20px;
	width: 70%;
	display: flex;
}
input {
	flex:1;
	font-size: 100%;
}
input[type=checkbox] {
	margin: 0 2px 0 10px;
}
testarea{
font-size: 100%;
}
.txt-unit{
	height:2em;
}
.inputbox{
	margin-right: 1em;
}
.hissu{
	color: red;
	font-size: 0.7em;
}
.contact-form{
	text-align: center;
	margin: 0 auto;
	display:block;
	padding-top: 100px;
}
.checkbox{
display: block;
}
/* footer */
footer {
	clear:both;
	background-color:#222222;
	color:#fff;
	margin:0 auto;
	
	width: 100%;
    text-align: center;
    padding: 30px 0;

 position: absolute;/*←絶対位置*/
    bottom: 0; /*下に固定*/
}
footer ul li a {
	color: #fff;
	text-decoration: none;
}
footer a {
	color:#fff;
	text-decoration:none;
}
.footer-categories {
	display: flex;
	max-width: 1220px;
	margin:0 auto;
}
.column-4 {
	flex-grow:1;
	font-weight: lighter;
	line-height: 20px;
	color: #ccc;
	padding:10px;
	text-align: left;
}
.column-4 ul li {
	list-style:none;
	font-size:12px;
}
.copyright {
	clear:both;
	text-align: center;
	margin-top: 0px;
	padding: 10px 0 15px 0;
	color: #FFFFFF;
	text-transform: uppercase;
	letter-spacing: 1px;
	border-top: solid 1px #555 ;
}
small {
	font-size:10px;
	font-weight:100;
}
.footer2{
	height: 60px;
	position:absolute;
	bottom: 0;
	width: 100%;
}

@media screen and (max-width: 768px) {
article {
	width:100%;
	margin-bottom: 10px;
}
/* work categories */
.work-categories {
	display:block;
}
.square-grid {
	width: 50%;
}
.square-inside{
	padding: 0 5px 10px 5px;
}
/*INFO*/
#info dt{
	text-align: left;
}
#form, #info{
width: 80%;
}
/*CONTACT*/
dl{
    flex-flow: column nowrap;
}
dt, dd{
    width: 100%;
}
dd{
    border-left: none;
}
}


@media screen and (max-width: 500px) {
.hero h2 {
	font-size:16px;
}
.hero p {
	font-size:12px;
}
.footer-categories{
	display: block;
}
#form, #info{
width: 90%;
}
.checkbox{
flex-direction:column;
}
}


/* global-nav */
.inner {
	width: 100%;
	max-width:1220px;
	margin: 0 auto;
}
.inner:after {
	content: "";
	clear: both;
	display: block;
}
header {
	font-size: 14px;
	position: static;
	margin: auto 0;
	padding: 0;
	line-height: 1;
	z-index: 999;
}
header a,
header {
	color: #444444;
	text-decoration: none;
}
header .inner {
	position: relative;
}
#global-nav ul {
	list-style: none;
	position: absolute;
	right: 0;
	top: 38%;
	font-size: 14px;
}
#global-nav ul li {
	float: left;
	position: relative;
	font-weight:500;
}
#global-nav ul li a {
	padding: 0 10px;
}
/* Btn Hover */
#global-nav ul li a {
	color:#333333;
	text-decoration:none;
	transition: all 0.2s linear;
}
#global-nav ul li a:hover {
	color: #2C9AB7;
}
/* Toggle Button */
#nav-toggle {
	display: none;
	position: absolute;
	right: 12px;
	top: 14px;
	width: 34px;
	height: 36px;
	cursor: pointer;
	z-index: 101;
}
#nav-toggle div {
	position: relative;
}
#nav-toggle span {
	display: block;
	position: absolute;
	height: 4px;
	width: 100%;
	background: #111111;
	left: 0;
	transition: .35s ease-in-out;
}
#nav-toggle span:nth-child(1) {
	top: 0;
}
#nav-toggle span:nth-child(2) {
	top: 11px;
}
#nav-toggle span:nth-child(3) {
	top: 22px;
}


@media screen and (max-width: 768px) {
header a {
	color: #111111;
}
	header,
	.inner {
		width: 100%;
		padding: 0;
	}
	header {
		top: 0;
		position: fixed;
		margin-top: 0;
	}
	/* Fixed reset */
	header.fixed {
		padding-top: 0;
		background: transparent;
	}
	#mobile-head {
		background: #fff;
		width: 100%;
		height: 56px;
		z-index: 999;
		position: relative;
	}
	#global-nav {
		position: absolute;
		/* 開いてないときは画面外に配置 */
		top: -500px;
		background: #222222;
		width: 100%;
		text-align: center;
		padding: 10px 0;
		transition: .5s ease-in-out;
	}
	#global-nav ul {
		list-style: none;
		position: static;
		right: 0;
		bottom: 0;
		font-size: 11px;
	}
	#global-nav ul li {
		float: none;
		position: static;
	}
	#global-nav ul li:after  {
		display: none;
	}
	header #global-nav ul li a,
	header.fixed #global-nav ul li a {
		width: 100%;
		display: block;
		color: #fff;
		padding: 18px 0;
	}
	#nav-toggle {
		display: block;
	}
	/* #nav-toggle 切り替えアニメーション */
	.open #nav-toggle span:nth-child(1) {
		top: 11px;
		transform: rotate(135deg);
	}
	.open #nav-toggle span:nth-child(2) {
		width: 0;
		left: 50%;
	}
	.open #nav-toggle span:nth-child(3) {
		top: 11px;
		transform: rotate(-135deg);
	}
	/* #global-nav スライドアニメーション */
	.open #global-nav {
		/* #global-nav top + #mobile-head height */
		transform: translateY(556px);
	}
	main {
		margin-top:56px;
	}
}