@charset "UTF-8";

@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: 'YuGothic M';
  src: local('Yu Gothic Medium');
  font-weight: 400;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}

/* =================================================== *

   基本設定

 * =================================================== */
* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -o-box-sizing: border-box;
  box-sizing: border-box;
  font: inherit;
  font-family: inherit;
  font-size: 100%;
  font-style: inherit;
  font-weight: inherit;
  text-decoration: none;
  vertical-align: baseline;
  outline: none;
  word-break: break-all;
}
html {
  width: 100%;
  height: 100%;
  font-size: 10px;
}
body {
  margin: 0;
  position: relative;
  line-height: 1.8;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -o-text-size-adjust: 100%;
  text-size-adjust: 100%;

  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;

}
article, aside, dialog, figure, footer, header, main, menu, nav, section {
  display: block;
}
ol, ul {
  list-style: none;
}
ol, ul, li, dt, dd {
  margin: 0;
  padding: 0;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  table-layout: fixed;
}
.clearfix:after {
  content: " ";
  display: block;
  clear: both;
}
.inblock-wrap {
  width: 100%;
  position: relative;
  font-size: 0;
}
.inblock-wrap > * {
  font-size: 1.4rem;
  position: relative;
  vertical-align: top;
  display: inline-block;
}
.flex-wrap {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  width:100%;
  position:relative;
}
.flex-wrap > * {
  position:relative;
}

a.bl {
  display: block;
}
/* =================================================== *

   フォント

 * =================================================== */
body {
  font-family: "Noto Sans Japanese", "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "HiraKakuProN-W3",  'メイリオ','Meiryo', "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  color: #4a4a4a;
  font-weight: normal;
  font-size: 14px;
  font-size: 1.4rem;
}
.min {
  font-family: "游明朝", "Yu Mincho", "游明朝体", "YuMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", "HiraMinProN-W3", "Sawarabi Mincho", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.exo {
  font-family: 'Exo', sans-serif;
  letter-spacing: 1px;
}
p {
  margin-bottom: 0.5em;
}
a {
  text-decoration: none;
}
strong, .strong, .bold {
  font-weight: 700 !important;
}
.slim {
  font-weight: 200 !important;
}
.ul {
  text-decoration: underline !important;
}
.big {
  font-size: 110%;
}
.small {
  font-size: 90%;
}
h1, h2, h3, h4, h5, h6 {
  line-height: 1.5;
}


/* =================================================== *

   アイコン

 * =================================================== */
i.icon {
  margin-right:0.5em;
}


/* =================================================== *

   画像

 * =================================================== */
 img{
  vertical-align:top; 
 }
.pic {
  position: relative;
}
.text-pic {
  position: relative;
  text-align: center;
}
.pic a {
  display:block;
  outline:none;
}
.pic img, .text-pic img {
  width: 100%;
  height: auto;
}
/* =================================================== *

   位置

 * =================================================== */
 
.float-right {
  float: right !important;
}
.float-left {
  float: left !important;
}
.left {
  text-align: left !important;
}
.center {
  text-align: center !important;
}
.right {
  text-align: right !important;
}

.abs {
  position: absolute;
}

.fixed {
  position: fixed;
}

@media screen and (max-width: 767px) {
  
  .sp-left {
    text-align: left !important;
  }
  
  .sp-center {
    text-align: center !important; 
  }
  
  .sp-right {
    text-align: right !important;
  }
}

/* =================================================== *

   アニメーション

 * =================================================== */

.delay200 {
  animation-delay:0.2s !important;
}

.delay400 {
  animation-delay:0.4s !important;
}

.delay600 {
  animation-delay:0.6s !important;
}

.delay800 {
  animation-delay:0.8s !important;
}

.delay1000 {
  animation-delay:1s !important;
}

.delay1200 {
  animation-delay:1.2s !important;
}
.delay1400 {
  animation-delay:1.4s !important;
}
.delay1600 {
  animation-delay:1.6s !important;
}
.delay1800 {
  animation-delay:1.8s !important;
}
.delay2000 {
  animation-delay:2s !important;
}


.animated {
 animation-duration:1.5s; 
}
.animated.slow {
  animation-duration:2.5s;  
}
.animated.fast {
  animation-duration:1s; 
}

/* =================================================== *

   表示切り替え

 * =================================================== */
.sp-only {
  display:none !important;
}

@media screen and (max-width: 767px) {
  .pc-only {
     display: none !important;
  }
  .sp-only {  
    display:block !important;
  }
}