@charset "UTF-8";
/* reset
----------------------------------------------------------------------------------*/
html, body, #wrapper {
  width: 100%;
  max-height: 100%;
}

body {
  -webkit-text-size-adjust: 100%;
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  line-height: 1;
  word-break: break-all;
  font-display: swap;
  font-weight: 400;
  color: #424243;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.875rem;
  line-height: 1.575rem;
}

h1, h2, h3, h4, h5, h6, p, span, em, b, i, dl, dt, dd, ol, ul, li, tr, th, td, div {
  letter-spacing: 0.05em;
  font-feature-settings: "palt" 1;
}

ul li, ol li {
  display: inline-block;
  vertical-align: top;
  font-size: 0.875rem;
  line-height: 1.575rem;
}

p, p a, div, ul, ol, li, li a, dl, dt, dt a, dd, dd a, section, span, em, i, strong, b {
  box-sizing: border-box;
}

i {
  font-style: normal;
}

h1, h2, h3, h4, h5, h6, strong, b {
  font-size: 100%;
  font-weight: normal;
}

h1, h2, h3, h4, h5, h6, p, span, em, b, i, dl, dt, dd, ol, ul, li, tr, th, td {
  margin: 0;
  padding: 0;
  border: none;
  vertical-align: baseline;
  background: transparent;
}

div, object, iframe, blockquote, pre, abbr, address, cite, code, del, dfn, img, ins, kbd, q, samp, small, sub, sup, var, fieldset, label, legend, table, caption, tbody, tfoot, thead, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: none;
  font-size: 100%;
  font-weight: normal;
  vertical-align: baseline;
  background: transparent;
}

img {
  vertical-align: top;
  line-height: 0;
  -webkit-backface-visibility: hidden;
}

#wrapper img {
  width: 100%;
  height: auto;
}

article, aside, details, figcaption, figure, footer, header, menu, nav, section, div, address, iframe, canvas, hr, textarea {
  display: block; /*  line-height: 1;*/
}

a, label {
  cursor: pointer;
}

blockquote {
  padding: 0;
  margin: 0;
  display: block;
}

address, em {
  font-style: normal;
}

hr {
  border: 0;
  margin: 0;
  padding: 0;
}

ul, ol, li {
  list-style: none;
}

table {
  border-collapse: collapse;
}

/*Android、Xperiaで途中改行されるバグfix*/
/*p { background-image:url(1px-transparent.gif);}*/
.flexImg {
  overflow: hidden;
  position: relative;
}
.flexImg img {
  width: 100% !important;
  height: 100% !important;
  -o-object-fit: cover;
     object-fit: cover;
  font-family: "object-fit: cover;";
}
.flexImg.ab {
  height: 0;
  padding: 100%;
}
.flexImg.ab img {
  position: absolute;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  left: 0;
  right: 0;
  margin: auto;
  z-index: 10;
}

/* IE Flexcolumn時の謎の隙間埋め */
* {
  min-height: 0%;
}

/* hover
----------------------------------------------------------------------------------*/
a, a:link, a:visited {
  color: #f8f8f8;
  text-decoration: none;
  outline: none;
  transition: 0.5s;
  display: inline-block;
}

a:hover { /*color:rgba($mainColor,0.5);*/
  text-decoration: none;
  opacity: 0.6;
}

a img {
  transition: 0.5s;
}

a:hover img {
  opacity: 0.6;
}

*::-moz-selection {
  background: #1d1d1f;
  color: #f8f8f8;
}

*::selection {
  background: #1d1d1f;
  color: #f8f8f8;
}

/* -------------------------------
  PCのみの設定
------------------------------- */
@media print, screen and (min-width:768px) {
  .sp, .spOnly, .tbOnly {
    display: none !important;
  }
  .pc, .pc-tb {
    display: inline-block !important;
    vertical-align: top !important;
  }
  .pc-sp {
    display: inline-block !important;
    vertical-align: top !important;
  }
  /* スマホのみtellink有効（init.jsにも要設定） */
  a[href^="tel:"] {
    cursor: default;
  }
}
/* -------------------------------
タブレットのみの設定
------------------------------- */
@media screen and (min-width:600px) and (max-width:959px) {
  /*.pc,.spOnly{ display:none !important; margin:0; padding:0; width:0; height:0;}
  .sp,.tbOnly,.pc-tb{ display:inline-block !important; vertical-align:top !important;}
  .pc-sp{ display:none !important; margin:0; padding:0; width:0; height:0;}*/
}
/* -------------------------------
スマホのみの設定
------------------------------- */
@media only screen and (max-width: 767px) {
  .pc, .tbOnly, .pc-tb {
    display: none !important;
    margin: 0;
    padding: 0;
    width: 0;
    height: 0;
  }
  .sp, .spOnly {
    display: inline-block !important;
    vertical-align: top !important;
  }
  .pc-sp {
    display: inline-block !important;
    vertical-align: top !important;
  }
}/*# sourceMappingURL=common.css.map */