@charset "UTF-8";

/* reset */
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, 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, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video, button {
	margin: 0;
	padding: 0;
	vertical-align: baseline;
	font-size: 100%;
	font-style: normal;
	font-weight: normal;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	box-sizing: border-box;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
	display: block;
}

/* common */
html {
	min-height: 100%;
	width: 100%;
	font-size: 62.5%;
  font-size: 10px\0; /* IE */
  background: #fff;
}

body{
  line-height: 1;
  word-break: break-all;
  -webkit-text-size-adjust: 100%;
  /* ゴシック体 */
  font-family: "Noto Sans JP", "游ゴシック", "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック体", YuGothic, "Hiragino Kaku Gothic ProN", "Hiragino Sans","Helvetica Neue", Arial,  Meiryo, sans-serif;
  /* 明朝体 */
  /* font-family: "Noto Serif JP", '游明朝','Yu Mincho',YuMincho,"ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif; */
}

/* text */
ul, ol {
  list-style: none;
}
address,i {
  font-style: normal;
}

a,a:link,a:hover,a:visited,a:active,a:focus {
  background-color: transparent;
  text-decoration: none;
  color: inherit;
}
a:hover img{
  opacity: .7;
}

abbr[title] {
  text-decoration: underline dotted;
}

b, strong {
  font-weight: bold;
}

blockquote,
q {
    quotes: none;
}
blockquote:before,blockquote:after,q:before,q:after {
    content: "";
    content: none;
}

.clearfix::after {
  content: "";
  display: block;
  clear: both;
}

/* image */
svg,img,embed,object,iframe {
    border: none;
}

img {
  max-width: 100%;
  height: auto;
  border:none;
  line-height: 1;
}

figure {
    line-height: 1;
    text-align: center;
}

/* form */
input:focus, textarea:focus, button:focus {
	outline: 0;
}

button,input,optgroup,select,textarea {
  -webkit-appearance: none;
  appearance: none;
  vertical-align: middle;
  color: inherit;
  font: inherit;
  background: transparent;
  padding: 0;
  margin: 0;
  border-radius: 0;
  text-align: inherit;
  text-transform: inherit;
}

button,[type="button"],[type="reset"],[type="submit"] {
  cursor: pointer;
}
button:disabled,[type="button"]:disabled,[type="reset"]:disabled,[type="submit"]:disabled {
  cursor: default;
}
:-moz-focusring {
  outline: auto;
}
select:disabled {
  opacity: inherit;
}
option,legend {
  padding: 0;
}
fieldset {
  margin: 0;
  padding: 0;
  min-width: 0;
}
progress {
  vertical-align: baseline;
}
textarea {
  overflow: auto;
}
[type="number"]::-webkit-inner-spin-button,[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
[type="search"] {
  outline-offset: -2px;
}
[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}
[type="number"] {
  -moz-appearance: textfield;
}

label[for] {
  cursor: pointer;
}

/* table */
table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
}

table th {
  vertical-align: top;
  font-weight: normal;
}

caption, th {
  text-align: left;
}

table td {
  vertical-align: top;
  word-break: break-all;
}

/* flex box --*/

.flex_box{
  display:-webkit-box;
  display:flex;
  flex-wrap: wrap;
	-webkit-box-pack: justify;
	justify-content: space-between;
}

.flex_box-reverse{
	-webkit-box-orient: horizontal;
	-webkit-box-direction: reverse;
	flex-direction: row-reverse;
}

.flex_box--start{
	-webkit-box-pack: start;
	justify-content: flex-start;
}

.flex_box--end{
	-webkit-box-pack: end;
	justify-content: flex-end;
}

.flex_box--btm{
	-webkit-box-align: end;
	align-items: flex-end;
}

.flex_box--around{
	justify-content: space-around;
}

.flex_box--center{
	-webkit-box-pack: center;
	justify-content: center;
}

.flex_box--middle{
	-webkit-box-align: center;
	align-items: center;
}

/* min 751px 
----------------------*/
@media screen and (min-width: 751px) {

  /* flex box */
	.flex_box-pc{
		display:-webkit-box;
		display:flex;
		flex-wrap: wrap;
		-webkit-box-pack: justify;
		justify-content: space-between;
	}

  /* sp menu */
  #menu_nav{
    display: none;
  }

  #slide_menu {
      display: none;
  }
}
/* max 750px 
----------------------*/
@media screen and (max-width: 750px) {

  /* flex box */
	.flex_box-sp{
    display:-webkit-box;
    display:flex;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    justify-content: space-between;
  }
	.flex_box-reverse-sp{
		-webkit-box-orient: horizontal;
		-webkit-box-direction: reverse;
		flex-direction: row-reverse;
	}
	.flex_box-column-reverse-sp{
		-webkit-box-orient: vertical;
		-webkit-box-direction: reverse;
		flex-direction: column-reverse;
	}

  /* sp menu */
  body.open {
    overflow: hidden;
  }
  #menu_nav{
    display: block;
  }
  #slide_menu {
    display: none;
    position: fixed;
    top: -100%;
    left: 0;
    width: 100%;
    height: 100%;
    overflow-y:auto;
    z-index: 10001;
    transition: all .4s;
  }
  .open #slide_menu{
    display: block;
  }
}