@charset "UTF-8";
/* Function style
-----------------------------------*/
/* Variables style
-----------------------------------*/
/* window size
-----------------*/
/* font
-----------------*/
/* color
-----------------*/
/* Mixin style
-----------------------------------*/
/* Reset style
-----------------------------------*/
@import url(./font-awesome.css);
@import url("https://fonts.googleapis.com/css?family=Anton|Bitter:400,700");
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, figure, footer, header,
menu, nav, section, audio, video, canvas {
  border: 0;
  margin: 0;
  padding: 0;
  vertical-align: baseline;
}

article, aside, figure, figcaption, footer,
header, menu, nav, section {
  display: block;
}

body {
  line-height: 1.6;
  font-family: "Bitter", FontAwesome, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "游ゴシック", "Yu Gothic", YuGothic, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 0.75em;
  color: #333;
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  clear: both;
  font-weight: normal;
}

ol, ul {
  list-style: none;
}

blockquote {
  quotes: none;
}

blockquote:before, blockquote:after {
  content: '';
  content: none;
}

del {
  text-decoration: line-through;
}

/* tables still need 'cellspacing="0"' in the markup */
table {
  border-collapse: collapse;
  border-spacing: 0;
}

a img {
  border: none;
}

/* Font style
-----------------------------------*/
body {
  font-family: "Bitter", FontAwesome, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "游ゴシック", "Yu Gothic", YuGothic, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

strong, b {
  font-weight: 700;
}

pre {
  font-family: "Courier 10 Pitch", Courier, monospace;
}

code {
  font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
}

/* Global style
-----------------------------------*/
* {
  position: relative;
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
}

*::selection {
  background: rgba(51, 153, 153, .6);
  color: #fff;
}

*::-moz-selection {
  background: rgba(51, 153, 153, .6);
  color: #fff;
}

a, span, input[type=submit] {
  transition: all 0.2s ease;
}

/* Main global 'theme' and typographic styles */
body {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: subpixel-antialiased;
  font-size: 15px;
  position: relative;
}

body,
input,
textarea {
  color: #464646;
  line-height: 1.6;
}

a:link,
a:visited {
  color: #464646;
  cursor: hand;
  cursor: pointer;
  outline: none;
  text-decoration: none;
  -webkit-text-decoration-skip: objects;
}

a:active,
a:hover {
  text-decoration: none;
  opacity: 0.6;
  outline-width: 0;
}

hr {
  background-color: #ccc;
  border: 0;
  clear: both;
  width: 100%;
  height: 1px;
}

/* Text elements */
h1, h2, h3, h4, h5, h6 {
  font-size: 1em;
}

p {
  margin-bottom: 1.5em;
}

ul {
  list-style: square;
  margin: 0 0 1.5em 2em;
}

ol {
  list-style: decimal;
  margin: 0 0 1.5em 2em;
}

ol ol {
  list-style: upper-alpha;
}

ol ol ol {
  list-style: lower-roman;
}

ol ol ol ol {
  list-style: lower-alpha;
}

ul ul,
ol ol,
ul ol,
ol ul {
  margin-bottom: 0;
}

dl {
  margin: 0 0 1.8em 0;
}

dt {
  font-weight: bold;
}

dt:last-child {
  margin-bottom: 0;
}

dd {
  margin-bottom: 1.5em;
}

dd:last-child {
  margin-bottom: 0;
}

strong, b {
  font-weight: bold;
}

cite,
em,
i {
  font-style: italic;
}

big {
  font-size: 131.25%;
}

ins {
  background: #ffc;
  text-decoration: none;
}

blockquote {
  font-style: italic;
  padding: 0 2em;
}

blockquote cite,
blockquote em,
blockquote i {
  font-style: normal;
}

pre {
  background: #f7f7f7;
  color: #222;
  line-height: 1.5;
  margin-bottom: 1.5em;
  overflow: auto;
  padding: 1.5em;
}

blockquote {
  quotes: "" "";
}

blockquote:before, blockquote:after {
  content: "";
}

q {
  quotes: "“" "”" "‘" "’";
}

:focus {
  outline: none;
}

abbr,
acronym {
  border-bottom: 1px dotted #666;
  cursor: help;
}

sup,
sub {
  height: 0;
  line-height: 1;
  position: relative;
  vertical-align: baseline;
}

sup {
  bottom: 1ex;
}

sub {
  top: .5ex;
}

small {
  font-size: .8em;
}

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
}

button::-moz-focus-inner,
html [type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
html [type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="number"],
textarea {
  -webkit-appearance: none;
}

input[type="text"],
input[type="password"],
input[type="tel"],
input[type="email"],
input[type="url"],
input[type="search"],
input[type="number"],
textarea {
  background: #fff;
  border: 1px solid #ccc;
  box-shadow: inset 1px 1px 1px rgba(0, 0, 0, .1);
  -moz-box-shadow: inset 1px 1px 1px rgba(0, 0, 0, .1);
  -webkit-box-shadow: inset 1px 1px 1px rgba(0, 0, 0, .1);
  vertical-align: middle;
  font-size: 1em;
  padding: 0.2em 0.5em;
  border-radius: 3px;
  color: #464646;
}

input[disabled][readonly],
select[disabled][readonly],
textarea[disabled][readonly] {
  background-color: #fff;
  border-color: #a6a6a6;
}

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type="search"]::-webkit-search-cancel-button,
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

table {
  border-collapse: separate;
  border-spacing: 1px;
  width: 100%;
  margin-bottom: 1.5em;
  background: #ccc;
}

table th, table td {
  padding: .5em .8em;
  vertical-align: top;
  border-bottom: none;
  text-align: left;
  background: #fff;
}

table th {
  font-weight: bold;
  background: #999;
  color: #fff;
}

.noscript {
  display: none;
}

.fa {
  vertical-align: baseline;
}

/* Structure style
-----------------------------------*/
body {
  color: #000;
  background: center center no-repeat fixed url("../images/bg01.png"), center top url("../images/bg00.png");
  background-size: cover , auto auto;
  text-align: center;
  min-width: 900px;
}

img {
  width: auto;
  height: auto;
  max-width: 100%;
  vertical-align: bottom;
}

/* Header style
-----------------------------------*/
/* footer style
-----------------------------------*/
#footer {
  width: 100%;
  background: #000;
  padding: 50px 0 20px;
  text-align: center;
  color: #fff;
}

#footer a {
  color: #fff;
}

#footer figure {
  margin-bottom: 10px;
}

#footer .copy {
  font-size: 12px;
  line-height: 1.2;
  margin: 0;
}

/* footer style
-----------------------------------*/
/* flex style
-----------------------------------*/
.flexContainer.grid2-1 {
  display: -webkit-flex;
  display: flex;
  -js-display: flex;
  -webkit-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-justify-content: space-between;
          justify-content: space-between;
}

.flexContainer.grid2-1 .itemLeft {
  width: 600px;
  text-align: center;
}

.flexContainer.grid2-1 .itemRight {
  width: 460px;
}

.flexContainer.grid2-1 .textUnit {
  margin-bottom: 0;
}

.flexContainer.grid2-1 .btnGruop {
  margin-bottom: 0;
}

.flexContainer.grid2-1 .btn {
  margin-top: 50px;
}

.flexContainer.grid1-2 {
  display: -webkit-flex;
  display: flex;
  -js-display: flex;
  -webkit-flex-flow: row-reverse wrap;
          flex-flow: row-reverse wrap;
  -webkit-justify-content: space-between;
          justify-content: space-between;
}

.flexContainer.grid1-2 .itemLeft {
  width: 600px;
  text-align: center;
}

.flexContainer.grid1-2 .itemRight {
  width: 460px;
}

.flexContainer.grid1-2 .textUnit {
  margin-bottom: 0;
}

.flexContainer.grid1-2 .btnGruop {
  margin-bottom: 0;
}

.flexContainer.grid1-2 .btn {
  margin-top: 50px;
}

.flexContainer.grid5 {
  display: -webkit-flex;
  display: flex;
  -js-display: flex;
  -webkit-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-justify-content: flex-start;
          justify-content: flex-start;
  padding: 0 10px;
}

.flexContainer.grid5 > div {
  width: 20%;
  padding: 0 5px;
  margin-bottom: 30px;
}

.flexContainer.grid5 > div figure, .flexContainer.grid5 > div img {
  width: 100%;
}

.flexContainer.grid5 .textUnit {
  padding: 0 5px;
}

.flexContainer.grid5 .textUnit p {
  font-size: 13px;
  line-height: 1.6;
}

.flexContainer.grid3 {
  display: -webkit-flex;
  display: flex;
  -js-display: flex;
  -webkit-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-justify-content: space-around;
          justify-content: space-around;
}

.flexContainer.grid3 > figure, .flexContainer.grid3 div {
  width: 32.407%;
  margin-bottom: 1%;
}

.flexContainer.grid3 > figure img, .flexContainer.grid3 div img {
  vertical-align: bottom;
}

@media screen and (max-width: 768px) {
  .flexContainer.grid2-1 .itemLeft {
    width: 100%;
    margin-bottom: 20px;
  }
  .flexContainer.grid2-1 .itemRight {
    width: 100%;
  }
  .flexContainer.grid2-1 .btn {
    margin-top: 30px;
  }
  .flexContainer.grid1-2 .itemLeft {
    width: 100%;
    margin-bottom: 20px;
  }
  .flexContainer.grid1-2 .itemRight {
    width: 100%;
  }
  .flexContainer.grid1-2 .btn {
    margin-top: 30px;
  }
  .flexContainer.grid5 {
    padding: 0;
  }
  .flexContainer.grid5 > div {
    width: 33.333%;
    margin-bottom: 20px;
  }
  .flexContainer.grid5 .textUnit {
    padding: 0 5px;
  }
  .flexContainer.grid5 .textUnit p {
    font-size: 13px;
    line-height: 1.6;
  }
}

@media screen and (max-width: 568px) {
  .flexContainer.grid5 > div {
    width: 50%;
    margin-bottom: 20px;
  }
  .flexContainer.grid5 .textUnit {
    padding: 0 2.5%;
  }
  .flexContainer.grid5 .textUnit p {
    font-size: 13px;
    line-height: 1.6;
  }
}

@media screen and (max-width: 414px) {
  .flexContainer.grid5 .textUnit p {
    font-size: 12px;
  }
  .flexContainer.grid3 > figure, .flexContainer.grid3 div {
    width: 47%;
    margin-bottom: 3%;
  }
}

/* content style
-----------------------------------*/
/* index style
-----------------------------------*/
.gNav {
  width: 100%;
  margin: 0 0 30px;
  background: #ff3434;
  border-bottom: 2px solid #fff;
  position: absolute;
  left: 0;
  top: 528px;
  z-index: 100000;
}

.gNav.is-fixed {
  position: fixed;
  top: 0;
}

.gNav ul {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
          flex-flow: row nowrap;
  -webkit-justify-content: space-between;
          justify-content: space-between;
  width: 900px;
  margin: 0 auto;
  list-style: none;
  border-left: 1px solid #fff;
}

.gNav li {
  width: 17%;
}

.gNav li a {
  display: inline-block;
  width: 100%;
  padding: 5px 5px 5px;
  color: #fff;
  line-height: 1;
  text-align: center;
  border-right: 1px solid #fff;
}

.gNav li span {
  display: inline-block;
  width: 100%;
  font-size: 14px;
  padding: 5px 0 0;
}

.gNav li small {
  display: inline-block;
  width: 100%;
  padding: 3px 0 5px;
  font-size: 10px;
  border-bottom: 3px solid #fff;
}

#siteHead {
  width: 900px;
  margin: 0 auto 100px;
}

#details {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
          flex-flow: row nowrap;
  -webkit-justify-content: space-between;
          justify-content: space-between;
  width: 840px;
  margin: 0 auto 120px;
}

#details figure {
  width: 400px;
  -webkit-order: 2;
          order: 2;
}

#details > div {
  width: 400px;
  -webkit-order: 1;
          order: 1;
  padding: 15px 0 0;
}

#details > div p {
  margin-bottom: 25px;
}

#details > div ul {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
          flex-flow: row nowrap;
  width: 100%;
  list-style: none;
  margin: 0;
}

#details > div ul li {
  display: inline-block;
}

#details > div ul li + li {
  margin: 0 0 0 10px;
}

#details > div ul img {
  height: 36px;
}

#details a {
  display: inline-block;
}

#details h1 {
  margin: 0 0 25px;
}

#tour {
  width: 840px;
  margin: 0 auto 150px;
  padding: 0 20px;
}

#tour h1 {
  margin-bottom: 30px;
}

#tour ul {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-justify-content: space-between;
          justify-content: space-between;
  width: 800px;
  margin: 0 auto 20px;
  list-style: none;
}

#tour ul li {
  display: inline-block;
  width: 370px;
  text-align: center;
  padding: 5px 10px;
  margin-bottom: 10px;
  border: 2px solid #000;
  background: rgba(255, 255, 255, .7);
}

#dl {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-justify-content: space-around;
          justify-content: space-around;
  width: 900px;
  margin: 0 auto 150px;
}

#dl h1 {
  width: 100%;
  padding: 0 20px;
  margin-bottom: 30px;
  text-align: center;
}

#dl > div {
  width: 420px;
  text-align: left;
}

#dl > div iframe {
  vertical-align: bottom;
  border: 1px solid #999;
}

#dl > div h3 {
  width: 100%;
  padding: 5px 10px;
  margin-bottom: 10px;
  font-size: 1em;
  line-height: 1.2;
  background: #000;
  text-align: left;
  color: #fff;
}

#media {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row wrap;
          flex-flow: row wrap;
  -webkit-justify-content: center;
          justify-content: center;
  width: 900px;
  margin: 0 auto 150px;
}

#media h1 {
  width: 100%;
  padding: 0 20px;
  margin-bottom: 30px;
  text-align: center;
}

#media > div {
  width: 800px;
}

#media > div iframe {
  vertical-align: bottom;
  border: 1px solid #999;
}

#review,
#interview {
  width: 900px;
  padding: 0 50px;
  margin: 0 auto 150px;
}

#review img,
#interview img {
  vertical-align: bottom;
}

#review h1,
#interview h1 {
  margin-bottom: 20px;
}

#review h1 img,
#interview h1 img {
  border-radius: 20px;
}

#review h1:after,
#interview h1:after {
  position: absolute;
  right: 5px;
  bottom: 5px;
  display: block;
  content: '';
  width: 127px;
  height: 136px;
  background: center center no-repeat;
}

#review.vol01 h1:after,
#interview.vol01 h1:after {
  background-image: url("../images/int-icon01.png");
}

#review.vol02 h1:after,
#interview.vol02 h1:after {
  background-image: url("../images/int-icon02.png");
}

#review.vol03 h1:after,
#interview.vol03 h1:after {
  background-image: url("../images/int-icon03.png");
}

#review.vol04 h1:after,
#interview.vol04 h1:after {
  background-image: url("../images/int-icon04.png");
}

#review h2,
#interview h2 {
  text-align: center;
  margin-bottom: 20px;
}

#review h3,
#interview h3 {
  font-size: 1.4em;
  padding-top: 30px;
}

#review h3:first-child,
#interview h3:first-child {
  padding-top: 0;
}

#review ul,
#interview ul {
  display: -webkit-flex;
  display: flex;
  -webkit-flex-flow: row nowrap;
          flex-flow: row nowrap;
  -webkit-justify-content: center;
          justify-content: center;
  width: 100%;
  margin: 0 0 20px;
  list-style: none;
}

#review ul li,
#interview ul li {
  width: 31.5%;
  margin: 0 3%;
}

#review ul li a,
#interview ul li a {
  display: inline-block;
  width: 100%;
}

#review ul li img,
#interview ul li img {
  opacity: .3;
  cursor: pointer;
  transition: all 0.2s ease;
}

#review ul li img.is-active, #review ul li img:hover,
#interview ul li img.is-active,
#interview ul li img:hover {
  opacity: 1;
}

#review .inner,
#interview .inner {
  display: none;
  width: 100%;
  text-align: left;
  border: 2px solid #000;
  background: rgba(255, 255, 255, .7);
  padding: 20px;
  margin-bottom: 30px;
  font-size: .9em;
}

#review .inner.is-active,
#interview .inner.is-active {
  display: block;
}

#review .inner p,
#interview .inner p {
  margin-bottom: 1em;
  color: #333;
}

#review .inner p.int00,
#interview .inner p.int00 {
  color: #777;
}

#review .inner p.int01 b,
#interview .inner p.int01 b {
  color: #2174cd;
}

#review .inner p.int02 b,
#interview .inner p.int02 b {
  color: #ff3434;
}

#review .inner p.int03 b,
#interview .inner p.int03 b {
  color: #ff7c38;
}

#review .inner p.is-right,
#interview .inner p.is-right {
  margin: 0;
  color: #999;
}

#review .inner figure img,
#interview .inner figure img {
  border: 1px solid #fff;
  box-shadow: 0 0 10px 2px rgba(0, 0, 0, .4);
}

#review ul li {
  width: 25%;
  margin: 0;
  padding: 0 .5%;
}

/* extension style
-----------------------------------*/
.white {
  color: #fff !important;
}

.black {
  color: #111 !important;
}

.blue {
  color: #3f78c6 !important;
}

.green {
  color: #609c9a !important;
}

.orange {
  color: #fb7818 !important;
}

.red {
  color: #ff3434 !important;
}

.yellow {
  color: #fad00d !important;
}

.purple {
  color: #847bb9 !important;
}

.pink {
  color: #ff82a1 !important;
}

.grey {
  color: #acadad !important;
}

.bg-white {
  background-color: #fff !important;
}

.bg-black {
  background-color: #111 !important;
}

.bg-blue {
  background-color: #3f78c6 !important;
}

.bg-blue-light {
  background-color: #73cbef !important;
}

.bg-green-light {
  background-color: #a0d264 !important;
}

.bg-orange {
  background-color: #fb7818 !important;
}

.bg-red {
  background-color: #ff3434 !important;
}

.bg-yellow {
  background-color: #fad00d !important;
}

.bg-purple {
  background-color: #847bb9 !important;
}

.bg-pink {
  background-color: #ff82a1 !important;
}

.bg-sec-sub {
  background-color: #f4f4f4 !important;
}

.w5p {
  width: 5% !important;
}

.w10p {
  width: 10% !important;
}

.w15p {
  width: 15% !important;
}

.w20p {
  width: 20% !important;
}

.w25p {
  width: 25% !important;
}

.w30p {
  width: 30% !important;
}

.w35p {
  width: 35% !important;
}

.w40p {
  width: 40% !important;
}

.w45p {
  width: 45% !important;
}

.w50p {
  width: 50% !important;
}

.w55p {
  width: 55% !important;
}

.w60p {
  width: 60% !important;
}

.w65p {
  width: 65% !important;
}

.w70p {
  width: 70% !important;
}

.w75p {
  width: 75% !important;
}

.w80p {
  width: 80% !important;
}

.w85p {
  width: 85% !important;
}

.w90p {
  width: 90% !important;
}

.w95p {
  width: 95% !important;
}

.w100p {
  width: 100% !important;
}

.w5em {
  width: 5em !important;
}

.w6em {
  width: 6em !important;
}

.w7em {
  width: 7em !important;
}

.w8em {
  width: 8em !important;
}

.w9em {
  width: 9em !important;
}

.w10em {
  width: 10em !important;
}

.flr {
  float: right !important;
}

.fll {
  float: left !important;
}

.fln {
  float: none !important;
}

.clb {
  clear: both !important;
}

.cln {
  clear: none !important;
}

.is-left {
  text-align: left !important;
}

.is-center {
  text-align: center !important;
}

.is-right {
  text-align: right !important;
}

.is-bold {
  font-weight: bold !important;
}

.nowrap {
  white-space: nowrap !important;
}

/* 文字サイズ */
.fs08 {
  font-size: .8em !important;
}

.fs09 {
  font-size: .9em !important;
}

.fs11 {
  font-size: 1.1em !important;
}

.fs12 {
  font-size: 1.2em !important;
}

.fs12_5 {
  font-size: 1.25em !important;
}

.fs13 {
  font-size: 1.3em !important;
}

.fs14 {
  font-size: 1.4em !important;
}

.fs15 {
  font-size: 1.5em !important;
}

.fs16 {
  font-size: 1.6em !important;
}

.fs17 {
  font-size: 1.7em !important;
}

.fs18 {
  font-size: 1.8em !important;
}

.fs19 {
  font-size: 1.9em !important;
}

.fs20 {
  font-size: 2.0em !important;
}

.fs24b {
  font-size: 2.4em;
  font-weight: bold;
  line-height: 1em;
}

.fs40b {
  font-size: 4.0em;
  font-weight: bold;
  line-height: 1em;
}

.lh1 {
  line-height: 1 !important;
}

.lh12 {
  line-height: 1.2 !important;
}

.lh14 {
  line-height: 1.4 !important;
}

.lh16 {
  line-height: 1.6 !important;
}

.lh18 {
  line-height: 1.8 !important;
}

.lh20 {
  line-height: 2 !important;
}

/* margin */
.m0 {
  margin: 0 !important;
}

.m5 {
  margin: 5px !important;
}

.m10 {
  margin: 10px !important;
}

.m15 {
  margin: 15px !important;
}

.m20 {
  margin: 20px !important;
}

.m30 {
  margin: 30px !important;
}

.m40 {
  margin: 40px !important;
}

.m50 {
  margin: 50px !important;
}

.mt0 {
  margin-top: 0 !important;
}

.mt5 {
  margin-top: 5px !important;
}

.mt10 {
  margin-top: 10px !important;
}

.mt15 {
  margin-top: 15px !important;
}

.mt20 {
  margin-top: 20px !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb5 {
  margin-bottom: 5px !important;
}

.mb10 {
  margin-bottom: 10px !important;
}

.mb15 {
  margin-bottom: 15px !important;
}

.mb20 {
  margin-bottom: 20px !important;
}

.mb25 {
  margin-bottom: 25px !important;
}

.mb30 {
  margin-bottom: 30px !important;
}

.mb35 {
  margin-bottom: 35px !important;
}

.mb40 {
  margin-bottom: 40px !important;
}

.mb45 {
  margin-bottom: 45px !important;
}

.mb50 {
  margin-bottom: 50px !important;
}

.mb55 {
  margin-bottom: 55px !important;
}

.mb60 {
  margin-bottom: 60px !important;
}

.mb65 {
  margin-bottom: 65px !important;
}

.mb70 {
  margin-bottom: 70px !important;
}

.mb75 {
  margin-bottom: 75px !important;
}

.mb80 {
  margin-bottom: 80px !important;
}

.mb85 {
  margin-bottom: 85px !important;
}

.mb90 {
  margin-bottom: 90px !important;
}

.mb95 {
  margin-bottom: 95px !important;
}

.mb100 {
  margin-bottom: 100px !important;
}

.mb200 {
  margin-bottom: 200px !important;
}

.ml0 {
  margin-left: 0 !important;
}

.ml5 {
  margin-left: 5px !important;
}

.ml10 {
  margin-left: 10px !important;
}

.ml20 {
  margin-left: 20px !important;
}

.ml30 {
  margin-left: 30px !important;
}

.ml40 {
  margin-left: 40px !important;
}

.ml50 {
  margin-left: 50px !important;
}

.mr0 {
  margin-right: 0 !important;
}

.mr5 {
  margin-right: 5px !important;
}

.mr10 {
  margin-right: 10px !important;
}

.mr20 {
  margin-right: 20px !important;
}

.mr30 {
  margin-right: 30px !important;
}

.mr40 {
  margin-right: 40px !important;
}

.mr50 {
  margin-right: 50px !important;
}

.mlr5 {
  margin-right: 5px !important;
  margin-left: 5px !important;
}

.mlr10 {
  margin-right: 10px !important;
  margin-left: 10px !important;
}

/* padding */
.p0 {
  padding: 0 !important;
}

.p5 {
  padding: 5px !important;
}

.p10 {
  padding: 10px !important;
}

.p15 {
  padding: 15px !important;
}

.p20 {
  padding: 20px !important;
}

.p25 {
  padding: 25px !important;
}

.p30 {
  padding: 30px !important;
}

.p35 {
  padding: 35px !important;
}

.p40 {
  padding: 40px !important;
}

.p45 {
  padding: 45px !important;
}

.p50 {
  padding: 50px !important;
}

.pb0 {
  padding-bottom: 0 !important;
}

.pb5 {
  padding-bottom: 5px !important;
}

.pb10 {
  padding-bottom: 10px !important;
}

.pb15 {
  padding-bottom: 15px !important;
}

.pb20 {
  padding-bottom: 20px !important;
}

.pb25 {
  padding-bottom: 25px !important;
}

.pb30 {
  padding-bottom: 30px !important;
}

.pb35 {
  padding-bottom: 35px !important;
}

.pb40 {
  padding-bottom: 40px !important;
}

.pb45 {
  padding-bottom: 45px !important;
}

.pb50 {
  padding-bottom: 50px !important;
}

.pb80 {
  padding-bottom: 50px !important;
}

.pt0 {
  padding-top: 0 !important;
}

.pt5 {
  padding-top: 5px !important;
}

.pt10 {
  padding-top: 10px !important;
}

.pt15 {
  padding-top: 15px !important;
}

.pt20 {
  padding-top: 20px !important;
}

.pt25 {
  padding-top: 25px !important;
}

.pt30 {
  padding-top: 30px !important;
}

.pt35 {
  padding-top: 35px !important;
}

.pt40 {
  padding-top: 40px !important;
}

.pt45 {
  padding-top: 45px !important;
}

.pt50 {
  padding-top: 50px !important;
}

.pl0 {
  padding-left: 0 !important;
}

.pl10 {
  padding-left: 10px !important;
}

.pl20 {
  padding-left: 20px !important;
}

.pl30 {
  padding-left: 30px !important;
}

.pl40 {
  padding-left: 40px !important;
}

.pl50 {
  padding-left: 50px !important;
}

.pr0 {
  padding-right: 0 !important;
}

.pr10 {
  padding-right: 10px !important;
}

.pr20 {
  padding-right: 20px !important;
}

.pr30 {
  padding-right: 30px !important;
}

.pr40 {
  padding-right: 40px !important;
}

.pr50 {
  padding-right: 50px !important;
}

.plr5 {
  padding-left: 5px !important;
  padding-right: 5px !important;
}

.plr10 {
  padding-left: 10px !important;
  padding-right: 10px !important;
}

.plr15 {
  padding-left: 15px !important;
  padding-right: 15px !important;
}

.plr20 {
  padding-left: 20px !important;
  padding-right: 20px !important;
}

.plr25 {
  padding-left: 25px !important;
  padding-right: 25px !important;
}

.ofx {
  width: 100% !important;
  overflow-x: auto;
}

.video-container {
  display: block;
  width: 100%;
  position: relative;
  padding-bottom: 53%;
  padding-top: 30px;
  height: 0;
  overflow: hidden;
}

.video-container + p {
  clear: both !important;
}

.video-container iframe {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 50;
}

.button {
  display: inline-block;
  text-align: center;
  background: #fff;
  color: #111;
  padding: .3em .8em;
  font-size: 1em;
  line-height: 1;
  border-radius: 3px;
  border: 1px solid #555;
  font-family: "Bitter", FontAwesome, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, "游ゴシック", "Yu Gothic", YuGothic, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}

.button + .button {
  margin: 0 0 .7em .5em;
}

.button[disabled] {
  opacity: .5;
}

.button img {
  vertical-align: middle;
}

.button:hover {
  text-decoration: none;
}

.button.is-round {
  border-radius: 1.5em;
}

.button.is-white {
  background-color: #fff;
  border-color: transparent;
  color: #111;
}

.button.is-white:hover, .button.is-white:focus, .button.is-white.is-active {
  background-color: #e6e6e6;
  border-color: transparent;
  color: #111;
}

.button.is-white:active {
  border-color: transparent;
}

.button.is-white.is-inverted {
  background-color: #111;
  color: #fff;
}

.button.is-white.is-inverted:hover {
  background-color: #040404;
}

.button.is-white.is-loading:after {
  border-color: transparent transparent #111 #111 !important;
}

.button.is-white.is-outlined {
  background-color: transparent;
  border-color: #fff;
  color: #fff;
}

.button.is-white.is-outlined:hover, .button.is-white.is-outlined:focus {
  background-color: #fff;
  border-color: #fff;
  color: #111;
}

.button.is-black {
  background-color: #111;
  border-color: transparent;
  color: #fff;
}

.button.is-black:hover, .button.is-black:focus, .button.is-black.is-active {
  background-color: black;
  border-color: transparent;
  color: #fff;
}

.button.is-black:active {
  border-color: transparent;
}

.button.is-black.is-inverted {
  background-color: #fff;
  color: #111;
}

.button.is-black.is-inverted:hover {
  background-color: #f2f2f2;
}

.button.is-black.is-loading:after {
  border-color: transparent transparent #fff #fff !important;
}

.button.is-black.is-outlined {
  background-color: transparent;
  border-color: #111;
  color: #111;
}

.button.is-black.is-outlined:hover, .button.is-black.is-outlined:focus {
  background-color: #111;
  border-color: #111;
  color: #fff;
}

.button.is-light {
  background-color: #b2b6b9;
  border-color: transparent;
  color: #69707a;
}

.button.is-light:hover, .button.is-light:focus, .button.is-light.is-active {
  background-color: #979da1;
  border-color: transparent;
  color: #69707a;
}

.button.is-light:active {
  border-color: transparent;
}

.button.is-light.is-inverted {
  background-color: #69707a;
  color: #b2b6b9;
}

.button.is-light.is-inverted:hover {
  background-color: #5d636c;
}

.button.is-light.is-loading:after {
  border-color: transparent transparent #69707a #69707a !important;
}

.button.is-light.is-outlined {
  background-color: transparent;
  border-color: #b2b6b9;
  color: #b2b6b9;
}

.button.is-light.is-outlined:hover, .button.is-light.is-outlined:focus {
  background-color: #b2b6b9;
  border-color: #b2b6b9;
  color: #69707a;
}

.button.is-dark {
  background-color: #69707a;
  border-color: transparent;
  color: #b2b6b9;
}

.button.is-dark:hover, .button.is-dark:focus, .button.is-dark.is-active {
  background-color: #51575f;
  border-color: transparent;
  color: #b2b6b9;
}

.button.is-dark:active {
  border-color: transparent;
}

.button.is-dark.is-inverted {
  background-color: #b2b6b9;
  color: #69707a;
}

.button.is-dark.is-inverted:hover {
  background-color: #a5a9ad;
}

.button.is-dark.is-loading:after {
  border-color: transparent transparent #b2b6b9 #b2b6b9 !important;
}

.button.is-dark.is-outlined {
  background-color: transparent;
  border-color: #69707a;
  color: #69707a;
}

.button.is-dark.is-outlined:hover, .button.is-dark.is-outlined:focus {
  background-color: #69707a;
  border-color: #69707a;
  color: #b2b6b9;
}

.button.is-primary {
  background-color: #1fc8db;
  border-color: transparent;
  color: white;
}

.button.is-primary:hover, .button.is-primary:focus, .button.is-primary.is-active {
  background-color: #199fae;
  border-color: transparent;
  color: white;
}

.button.is-primary:active {
  border-color: transparent;
}

.button.is-primary.is-inverted {
  background-color: white;
  color: #1fc8db;
}

.button.is-primary.is-inverted:hover {
  background-color: #f2f2f2;
}

.button.is-primary.is-loading:after {
  border-color: transparent transparent white white !important;
}

.button.is-primary.is-outlined {
  background-color: transparent;
  border-color: #1fc8db;
  color: #1fc8db;
}

.button.is-primary.is-outlined:hover, .button.is-primary.is-outlined:focus {
  background-color: #1fc8db;
  border-color: #1fc8db;
  color: white;
}

.button.is-info {
  background-color: #3f78c6;
  border-color: transparent;
  color: white;
}

.button.is-info:hover, .button.is-info:focus, .button.is-info.is-active {
  background-color: #3060a2;
  border-color: transparent;
  color: white;
}

.button.is-info:active {
  border-color: transparent;
}

.button.is-info.is-inverted {
  background-color: white;
  color: #3f78c6;
}

.button.is-info.is-inverted:hover {
  background-color: #f2f2f2;
}

.button.is-info.is-loading:after {
  border-color: transparent transparent white white !important;
}

.button.is-info.is-outlined {
  background-color: transparent;
  border-color: #3f78c6;
  color: #3f78c6;
}

.button.is-info.is-outlined:hover, .button.is-info.is-outlined:focus {
  background-color: #3f78c6;
  border-color: #3f78c6;
  color: white;
}

.button.is-success {
  background-color: #609c9a;
  border-color: transparent;
  color: white;
}

.button.is-success:hover, .button.is-success:focus, .button.is-success.is-active {
  background-color: #4d7c7b;
  border-color: transparent;
  color: white;
}

.button.is-success:active {
  border-color: transparent;
}

.button.is-success.is-inverted {
  background-color: white;
  color: #609c9a;
}

.button.is-success.is-inverted:hover {
  background-color: #f2f2f2;
}

.button.is-success.is-loading:after {
  border-color: transparent transparent white white !important;
}

.button.is-success.is-outlined {
  background-color: transparent;
  border-color: #609c9a;
  color: #609c9a;
}

.button.is-success.is-outlined:hover, .button.is-success.is-outlined:focus {
  background-color: #609c9a;
  border-color: #609c9a;
  color: white;
}

.button.is-warning {
  background-color: #fad00d;
  border-color: transparent;
  color: white;
}

.button.is-warning:hover, .button.is-warning:focus, .button.is-warning.is-active {
  background-color: #d0ac04;
  border-color: transparent;
  color: white;
}

.button.is-warning:active {
  border-color: transparent;
}

.button.is-warning.is-inverted {
  background-color: white;
  color: #fad00d;
}

.button.is-warning.is-inverted:hover {
  background-color: #f2f2f2;
}

.button.is-warning.is-loading:after {
  border-color: transparent transparent white white !important;
}

.button.is-warning.is-outlined {
  background-color: transparent;
  border-color: #fad00d;
  color: #fad00d;
}

.button.is-warning.is-outlined:hover, .button.is-warning.is-outlined:focus {
  background-color: #fad00d;
  border-color: #fad00d;
  color: white;
}

.button.is-danger {
  background-color: #ff3434;
  border-color: transparent;
  color: white;
}

.button.is-danger:hover, .button.is-danger:focus, .button.is-danger.is-active {
  background-color: #ff0101;
  border-color: transparent;
  color: white;
}

.button.is-danger:active {
  border-color: transparent;
}

.button.is-danger.is-inverted {
  background-color: white;
  color: #ff3434;
}

.button.is-danger.is-inverted:hover {
  background-color: #f2f2f2;
}

.button.is-danger.is-loading:after {
  border-color: transparent transparent white white !important;
}

.button.is-danger.is-outlined {
  background-color: transparent;
  border-color: #ff3434;
  color: #ff3434;
}

.button.is-danger.is-outlined:hover, .button.is-danger.is-outlined:focus {
  background-color: #ff3434;
  border-color: #ff3434;
  color: white;
}

.button.is-white {
  color: #555 !important;
  border-color: #fff !important;
  background: #fff !important;
}

.button.is-light {
  color: #777 !important;
  border-color: #ccc !important;
  background: #efefef !important;
}

.button.is-gray {
  color: #fff !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .5);
  border-color: #5f5f5f !important;
  background: linear-gradient(#b5b5b5, #a9a9a9) !important;
}

.button.is-dark {
  color: #fff !important;
  border-color: #111 !important;
  background: #444 !important;
}

.button.is-black {
  color: #fff !important;
  border-color: #111 !important;
  background: #000 !important;
}

.button.is-primary {
  color: #fff !important;
  background: #1fc8db !important;
  border-color: #0c85a3 !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .5);
}

.button.is-success, .button.is-green {
  color: #fff !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .5);
  border-color: #00c36a !important;
  background: #00c36a !important;
}

.button.is-info {
  color: #fff !important;
  background: #3f78c6 !important;
  border-color: #11448a !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .5);
}

.button.is-warning {
  color: rgba(17, 17, 17, .7) !important;
  background: #fbda41 !important;
  border-color: #ebad06 !important;
}

.button.is-danger {
  color: #fff !important;
  background: #ff3434 !important;
  border-color: #ff3434 !important;
  text-shadow: 0 1px 0 rgba(0, 0, 0, .5);
}

.is-iBlock {
  display: inline-block;
  transition: all 0s ease;
}

.is-block {
  display: block;
}

.is-none {
  display: none !important;
}

/* @ hover
// ------------------------------------------------------------ */
.no-hover:hover {
  opacity: 1;
  text-decoration: none;
  cursor: default;
}

@media screen and (max-width: 414px) {
  .is-hidden-sp {
    display: none !important;
  }
  .is-visible-sp {
    display: block !important;
  }
}
