@charset "UTF-8";

/************************************************
* 全般スタイル
************************************************/
html {
  font-size: 16px;
  font-size: 16px\9;
  box-sizing: border-box;
}

html, body {
  scroll-padding-top: 60px;
}
@media (min-width: 40em) {
  html, body {
    scroll-padding-top: 150px;
  }
}

body {
  color: var(--color-text);
  font-family: 'Lato', 'Noto Sans', 'Noto Sans JP', 'Hiragino Sans', 'ヒラギノ角ゴシック', 'Hiragino Kaku Gothic Pro', 'ヒラギノ角ゴ Pro W3', 'メイリオ', 'Meiryo', sans-serif;
  font-size: 15px;
  line-height: 2.0;
  overflow-x: auto;
}

a,
a:link,
a:active,
a:visited {
  color: var(--color-link);
  transition: 0.2s;
  text-decoration: none;
}
a:hover {
  text-decoration: none;
}
@media (min-width: 40em) {
  a[href^="tel:"] {
    pointer-events: none;
    text-decoration: none;
    color: inherit;
  }
}

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
}
_:-ms-input-placeholder, :root img {
  flex-shrink: 0;
}

iframe {
  vertical-align: bottom;
}

strong, b {
  font-weight: bold;
}

sup {
  vertical-align: super;
  font-size: smaller;
}

sub {
  vertical-align: baseline;
  bottom: -0.25em;
  position: relative;
  font-size: smaller;
  line-height: 0;
}

@media (min-width: 40em) {
  html,
  .c-container {
    min-width: 71.75rem;
  }
  .c-container {
    max-width: 71.75rem;
  }
  .c-container--limit {
    padding-right: 0;
    padding-left: 0;
    max-width: 85rem;
  }
}

#page {
  position: relative;
  overflow-x: hidden;
  overflow-y: hidden;
}
.home #page {
  margin-bottom: 0;
}

/* swiper */
.swiper-pagination-bullet {
  width: 10px;
  height: 10px;
}
.swiper-pagination-bullet-active {
  background-color: var(--color-main);
}
.swiper-container-horizontal > .swiper-pagination-bullets,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  bottom: 10px;
}

/*resTables*/
table.restables-clone {
  display: none;
}

@media (max-width: 40em) {
  table.restables-origin {
      display: none;
  }
  table.restables-clone {
      display: table;
  }
}

/* Lity */
.lity-container {
  max-width: 95%;
}

/* Elementor */
.elementor-background-slideshow.swiper-container {
  padding-bottom: 0;
}

