@charset "utf-8";/* 2025.12.19 */
:root {
  --header-h: 0px;
  --text: #000;
  --main: #ffee7d;
  --sub01: #d7e507;
  --white: #fff;
  --black: #000;
  --red: #EE220C;
  --light01: #d6d6d6;
  --light02: #f3f7b5;
  --grad01: linear-gradient(to right, #ff9f00 0%,#ff7300 50%,#ff5400 100%);
}

*, ::after, ::before {box-sizing: border-box;vertical-align: middle;}
html {font-size: 62.5%;overflow-x: hidden;}
body {
  font-size: 1.5rem;
  line-height: 1.8;
  letter-spacing: 0;
  font-weight: 400;
  font-style: normal;
  margin: 0;
  padding: 0;
  overflow-x: hidden;}

h1, h2, h3, h4, h5, h6 {font-weight: bold;line-height: 1.5;letter-spacing: .05em; text-align: center;margin: 0;padding: 0;}

img { max-width: 100%; height: auto; flex-shrink: 0; -webkit-backface-visibility: hidden;}
a {text-decoration: none; background-color: transparent;}
a:hover {text-decoration:none;}
@media (min-width: 576px) {
  a {transition: 0.2s ease-out;}
  a:hover, a:focus, a:active {opacity: .7!important;}
  a:focus, a:active {opacity: 1;}}
strong {vertical-align: bottom;}
ul {padding-left: 0; margin-top: 0;}
ol {list-style-type: none;}
li {list-style: none;}
dd {margin: 0;}
table {border-collapse: collapse;}
p {margin: 0;}
figure {padding: 0;margin: 0;}
figure img {line-height: 0;}

/* モバイル以外　tel無視 */
@media (min-width: 768px){a[href^="tel:"] { pointer-events: none;}}

.container, .container-s, .container-m, .container-l {
  width: 100%;
  padding-right: 15px;
  padding-left: 15px;
  margin-right: auto;
  margin-left: auto;}

/* pcのみ・spのみ・タブレットtab以上 改行 */
.sp_only, .tab_only, .pc_only {display: none !important;}
@media (max-width: 599px) {
  .sp_only {display: block !important;}}
@media (min-width: 600px) and (max-width: 1024px) {
  .tab_only {display: block !important;}
  .pc_only {display: block !important;}}
@media (min-width: 1025px) {
  .pc_only {display: block !important;}}

/* footer　常に最下部に固定 */
body {
  display: flex;
  flex-direction: column;
  position: relative;
  min-height: 100vh;}
#footer_conts,footer { margin-top: auto;}


.palt {font-feature-settings: "palt";}
.clear {clear: both;}
.underline {text-decoration: underline;}
.nowrap {white-space: nowrap;}
.text-center {text-align: center;}
.text_right {text-align: right;}
.text_left {text-align: left;}
.a_disable {pointer-events: none;}
.counter {position: relative;}
.fw-bold {font-weight: bold;}
.img_tate {max-width: inherit;height: 100%;width: auto;}
.bob-0 { border-bottom: none;}
.hoverFade {opacity: 1;transition: .2s ease-in-out;}
.hoverFade:hover {text-decoration: none;opacity: 0.7;}
.text-indent1 {padding-left: 1em;text-indent: -1em;}
.text-indent2 {padding-left: 2em;text-indent: -2em;}

/* Pagenation */
.pagination {
  display: inline-block;
  padding-left: 0;
  margin: 21px 0;
  border-radius: 4px;}
.pagination > li {display: inline;}
.pagination > li:first-child > a, .pagination > li:first-child > span {
  margin-left: 0;
  border-bottom-left-radius: 4px;
  border-top-left-radius: 4px;}
.pagination > li:last-child > a, .pagination > li:last-child > span {
  border-bottom-right-radius: 4px;
  border-top-right-radius: 4px;}
.pagination > .active > a, .pagination > .active > span, .pagination > .active > a:hover, .pagination > .active > span:hover, .pagination > .active > a:focus, .pagination > .active > span:focus {
  z-index: 3;
  color: #fff;
  background-color: #0d0f50;
  border-color: transparent;
  cursor: default;}
.pagination > li > a, .pagination > li > span {
  position: relative;
  float: left;
  padding: 10px 15px;
  line-height: 1.42857143;
  text-decoration: none;
  color: #373d8c;
  background-color: #fff;
  border: 1px solid #373d8c;
  margin-left: -1px;}

/* == breadcrumb ========= */
.breadcrumb ol {
  font-size: 1.3rem;
  padding-top: 1rem;
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  list-style: none;}
.breadcrumb ol,
.breadcrumb a,
.breadcrumb .active {
  color: #949494;
  text-decoration: none;}
.breadcrumb li {
  display: inline;
}
.breadcrumb li + li::before {
  content: "/";
  padding: 0 1rem;}
.breadcrumb .fas {
  vertical-align: middle;
  line-height: 0;}

/* 調整 */
.mb-1 { margin-bottom: 1rem!important;}
.mb-2 { margin-bottom: 2rem!important;}
.mb-3 { margin-bottom: 3rem!important;}
.mb-4 { margin-bottom: 4rem!important;}
.mb-5 { margin-bottom: 5rem!important;}
.mb-6 { margin-bottom: 6rem!important;}
.mb-7 { margin-bottom: 7rem!important;}
.mb-8 { margin-bottom: 8rem!important;}
.mb-9 { margin-bottom: 9rem!important;}
.mb-10 { margin-bottom: 10rem!important;}
.mb-15 { margin-bottom: 15rem!important;}
.pb-1 { padding-bottom: 1rem!important;}
.pb-2 { padding-bottom: 2rem!important;}
.pb-3 { padding-bottom: 3rem!important;}
.pb-4 { padding-bottom: 4rem!important;}
.pb-5 { padding-bottom: 5rem!important;}
.pb-6 { padding-bottom: 6rem!important;}
.pb-7 { padding-bottom: 7rem!important;}
.pb-8 { padding-bottom: 8rem!important;}
.pb-9 { padding-bottom: 9rem!important;}
.pb-10 { padding-bottom: 10rem!important;}
.m-0 { margin: 0!important;}
.m-0a { margin: 0 auto!important;}
.p-0 { padding: 0!important;}

.mb01 { margin-bottom: 100px!important;}
.mb02 { margin-bottom: 70px!important;}
.mb03 { margin-bottom: 50px!important;}
.mb04 { margin-bottom: 35px!important;}
.mb05 { margin-bottom: 20px!important;}
.mb06 { margin-bottom: 25px!important;}

@media (min-width: 768px) {
  .mb01 { margin-bottom: 150px!important;}
  .mb02 { margin-bottom: 100px!important;}
  .mb03 { margin-bottom: 70px!important;}
  .mb04 { margin-bottom: 50px!important;}
  .mb05 { margin-bottom: 30px!important;}
  .mb06 { margin-bottom: 40px!important;}
}

/* youtube動画埋め込み */
.youtube {
  position: relative;
  height: 0;
  padding-bottom: 56.25%;
  overflow: hidden;}
.youtube iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100% !important;
  height: 100% !important;}

/* Googleマップ */
.g-map {
  width: 100%;
  margin: 0 auto;}

.g-map iframe {
  height: auto;
  width: 100%;}



/*jquery.inview------------------*/
[class*="in_view"] {
  opacity: 0;
  animation-delay: .1s;
  animation-duration: .8s;
}


/* ===========
　　TABLE
============ */
.table-container {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch; /* iOSでのスクロールを滑らかに */
  margin-bottom: 1.5rem;}
table {
  width: 100%;
  border-collapse: collapse; /* 枠線を1本にまとめる */
  border-spacing: 0;
  font-size: 15px;
  text-align: left;
  white-space: nowrap;}
table th {
  background-color: var(--lifht01);
  font-weight: bold;
  padding: 12px 15px;
  border-bottom: 2px solid var(--lifht01);}
table td {
  padding: 12px 15px;
  border-bottom: 1px solid var(--lifht01);
  vertical-align: middle;}
table tbody tr:nth-child(even) {
  background-color: #fafafa;}





