@font-face {
    font-family: 'Brother 1816 Regular';
    src: url("fonts/Brother-1816-Regular.ttf");
}
@font-face {
    font-family: 'Brother 1816 Printed Bold';
    src: url("fonts/Brother1816Printed-Bold.ttf");
}

body {
    margin: 0;
    font-family: "Brother 1816 Regular";
}

/*========= レイアウトのためのCSS ===============*/

h1{
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  color:#fff;
  text-shadow: 0 0 15px #666;
  text-align: center;
}
.common_block02 {
    width: 90%;
    height: auto;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    padding-bottom: 20px;
}
p {
    margin-bottom: 20px;
}


/*========= スクロールをすると下のエリアが上にかぶさるCSS ===============*/

.header{
    /*headerを全画面で見せる*/
  width:100%;
  height: 100vh;
  position: relative;
} 

.header:before{
    /*header の疑似要素に背景画像を指定*/
  content:"";
  position:fixed;
  top:0;
  left:0;
  z-index:-1;
  width:100%;
  height: 100vh;
  /*背景画像設定*/
  background: url('../images/IMG_1697.jpg');
  background-size:cover;
}

/*下の被さるエリアの指定*/
.container{
    position: relative;
    z-index:1;
    text-align: center;
    background-size:cover;
}


.outline {
    display: flex;
    flex-direction: row;
    justify-content: space-between;
    width: 900px;
    margin: 0 auto;
    z-index: 50;
    margin-bottom: 10px;
}
@media screen and (max-width: 1000px) {
    .outline {
        width: 250px;
        flex-direction: column;
        justify-content: center;
    }
}
    .outline-button {
        width: 250px;
        height: 75px;
        box-shadow: 10px 5px 5px black;
        align-items: center;
        justify-content: center;
        display: flex;
        margin-bottom: 10px;
        opacity: .9;
    }
        .outline-button a {
            display: block;
            width: 100%;
            height: 100%;
            display: flex;
            align-items: center;
            justify-content: center;
            text-decoration: none;
        }
            .outline-button:hover {
                opacity: 1;
            }
.expl {
    background-color: #FFFFFF;
    min-height: 100vh;
    padding-top: 50px;
    color: #4D4840;
}
.mv {
    background-color: #F08300;
    min-height: 100vh;
    padding-top: 50px;
    color: black;
}
.contents {
    background-color: #4D4840;
    min-height: 100vh;
    padding-top: 50px;
    color: #FFFFFF;
}

/* 目次 */
.snip1543 {
    background-color: #fff;
    color: #ffffff;
    font-family: 'Source Sans Pro', sans-serif;
    font-size: 16px;
    margin: 10px;
    max-width: 315px;
    min-width: 230px;
    overflow: hidden;
    position: relative;
    text-align: left;
    width: 100%;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
  
  .snip1543 *,
  .snip1543 *:before,
  .snip1543 *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: all 0.45s ease;
    transition: all 0.45s ease;
  }
  
  .snip1543 img {
    backface-visibility: hidden;
    max-width: 100%;
    vertical-align: top;
  }
  
  .snip1543:before,
  .snip1543:after {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    content: '';
    background-color: #F08300;
    opacity: 0.5;
    -webkit-transition: all 0.45s ease;
    transition: all 0.45s ease;
  }
  
  .snip1543:before {
    -webkit-transform: skew(30deg) translateX(-80%);
    transform: skew(30deg) translateX(-80%);
  }
  
  .snip1543:after {
    -webkit-transform: skew(-30deg) translateX(-70%);
    transform: skew(-30deg) translateX(-70%);
  }
  
  .snip1543 figcaption {
    position: absolute;
    top: 0px;
    bottom: 0px;
    left: 0px;
    right: 0px;
    z-index: 1;
    bottom: 0;
    padding: 25px 40% 25px 20px;
  }
  
  .snip1543 figcaption:before,
  .snip1543 figcaption:after {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    background-color: #F08300;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.7);
    content: '';
    opacity: 0.5;
    z-index: -1;
  }
  
  .snip1543 figcaption:before {
    -webkit-transform: skew(30deg) translateX(-100%);
    transform: skew(30deg) translateX(-100%);
  }
  
  .snip1543 figcaption:after {
    -webkit-transform: skew(-30deg) translateX(-90%);
    transform: skew(-30deg) translateX(-90%);
  }
  
  .snip1543 h3,
  .snip1543 p {
    margin: 0;
    opacity: 0;
    letter-spacing: 1px;
  }
  
  .snip1543 h3 {
    font-family: 'Teko', sans-serif;
    font-size: 36px;
    font-weight: 700;
    line-height: 1em;
    text-transform: uppercase;
  }
  
  .snip1543 p {
    font-size: 0.9em;
  }
  
  .snip1543 a {
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 1;
  }
  
  .snip1543:hover h3,
  .snip1543.hover h3,
  .snip1543:hover p,
  .snip1543.hover p {
    -webkit-transform: translateY(0);
    transform: translateY(0);
    opacity: 0.9;
    -webkit-transition-delay: 0.2s;
    transition-delay: 0.2s;
  }
  
  .snip1543:hover:before,
  .snip1543.hover:before {
    -webkit-transform: skew(30deg) translateX(-20%);
    transform: skew(30deg) translateX(-20%);
    -webkit-transition-delay: 0.05s;
    transition-delay: 0.05s;
  }
  
  .snip1543:hover:after,
  .snip1543.hover:after {
    -webkit-transform: skew(-30deg) translateX(-10%);
    transform: skew(-30deg) translateX(-10%);
  }
  
  .snip1543:hover figcaption:before,
  .snip1543.hover figcaption:before {
    -webkit-transform: skew(30deg) translateX(-40%);
    transform: skew(30deg) translateX(-40%);
    -webkit-transition-delay: 0.15s;
    transition-delay: 0.15s;
  }
  
  .snip1543:hover figcaption:after,
  .snip1543.hover figcaption:after {
    -webkit-transform: skew(-30deg) translateX(-30%);
    transform: skew(-30deg) translateX(-30%);
    -webkit-transition-delay: 0.1s;
    transition-delay: 0.1s;
  }


/* 見出し */
.heading05 {
	position: relative;
	padding-bottom: 50px;
	font-size: 26px;
	text-align: center;
    margin-bottom: 50px;
    font-family: 'Brother 1816 Printed Bold';
}
.heading05::before {
	content: attr(data-en);
	display: block;
	font-size: 20px;
	font-style: italic;
	text-transform: uppercase;
}
.heading05::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translate(-50%) rotate(30deg);
	width: 1px;
	height: 40px;
}
#orangecat .heading05::before {
    color: #F08300;
}
#orangecat .heading05::after {
    background-color: #F08300;
}
#manager .heading05::before {
    color: #4D4840;
}
#manager .heading05::after {
    background-color: #4D4840;
}
#part-timer .heading05::before {
    color: #FFFFFF;
}
#part-timer .heading05::after {
    background-color: #FFFFFF;
}


/* ボタン */
  .bn632-hover {
    width: 160px;
    font-size: 16px;
    font-weight: 600;
    color: #FFFFFF;
    cursor: pointer;
    margin: 20px;
    height: 55px;
    text-align:center;
    border: none;
    background-size: 300% 100%;
    border-radius: 50px;
    moz-transition: all .4s ease-in-out;
    -o-transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
    transition: all .4s ease-in-out;
  }
  
  .bn632-hover:hover {
    background-position: 100% 0;
    moz-transition: all .4s ease-in-out;
    -o-transition: all .4s ease-in-out;
    -webkit-transition: all .4s ease-in-out;
    transition: all .4s ease-in-out;
  }
  
  .bn632-hover:focus {
    outline: none;
  }
  
  .bn632-hover.bn27 {
      background-image: linear-gradient(
        to right,
        #2e2e2e,
        #4D4840,
        #915000,
        #b66400
      );
      box-shadow: #4D4840;
    }
  .bn632-hover.bn28 {
        background-image: linear-gradient(
          to right,
          #F08300,
          #c46c00,
          #353535,
          #212121
        );
        box-shadow: #4D4840;
      }
