@charset "utf-8";
/*=================================*/
/* basic element */
/*=================================*/
html {
  font-size: 62.5%;
}
body {
  width: 100%;
  background: #fff;
  color: #333;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: clamp(14px, 1.33vw, 1.6rem);
  line-height: 1.375;
  position: relative;
  overflow-x: hidden;
  overflow-wrap: anywhere;
  -webkit-text-size-adjust: 100%;
}
@media all and (max-width: 1024px) {
  html.fixed,
  html.fixed body {
    height: 100%;
    overflow: hidden;
  }
}
a {
  transition: all .3s;
  text-decoration: none;
  color: #333;
}
a img {
  border: none;
  transition: all .3s;
}
@media all and (min-width: 640px) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
p {
  line-height: 2.0;
}
sup {
  font-size: 0.6em;
  vertical-align: super;
}
sub {
  font-size: 0.6em;
  vertical-align: text-bottom;
}
b {
  font-weight: 700;
}
select {
  color: #333;
}
button {
  font-family: inherit;
}
img {
  width: 100%;
}
h1,h2,h3,h4,h5,h6,th {
  font-weight: 500;
}
:root {
  --font16: clamp(14px, 1.23vw, 1.6rem);
  --font18: clamp(15px, 1.38vw, 1.8rem);
  --font20: clamp(16px, 1.53vw, 2.0rem);
  --font24: clamp(18px, 1.84vw, 2.4rem);
  --font26: clamp(19px, 2vw, 2.6rem);
  --font28: clamp(20px, 2.15vw, 2.8rem);
  --font32: clamp(20px, 2.46vw, 3.2rem);
  --font40: clamp(28px, 3.07vw, 4.0rem);
  --m10: clamp(5px, 0.76vw, 10px);
  --m15: clamp(10px, 1.15vw, 15px);
  --m20: clamp(10px, 1.53vw, 20px);
  --m24: clamp(15px, 1.84vw, 24px);
  --m25: clamp(15px, 1.92vw, 25px);
  --m30: clamp(15px, 2.3vw, 30px);
  --m35: clamp(20px, 2.69vw, 35px);
  --m40: clamp(20px, 3.07vw, 40px);
  --m45: clamp(23px, 3.46vw, 45px);
  --m50: clamp(25px, 3.84vw, 50px);
  --m55: clamp(28px, 4.23vw, 55px);
  --m60: clamp(30px, 4.61vw, 60px);
  --m65: clamp(30px, 5vw, 65px);
  --m70: clamp(35px, 5.38vw, 70px);
  --m75: clamp(35px, 5.76vw, 75px);
  --m80: clamp(40px, 6.15vw, 80px);
  --m85: clamp(40px, 6.53vw, 85px);
  --m90: clamp(40px, 6.92vw, 90px);
  --m100: clamp(50px, 7.69vw, 100px);
  --m110: clamp(50px, 8.46vw, 110px);
  --m115: clamp(50px, 8.84vw, 115px);
  --m120: clamp(60px, 9.23vw, 120px);
  --m135: clamp(60px, 10.38vw, 135px);
  --m145: clamp(60px, 11.15vw, 145px);
  --m150: clamp(60px, 11.53vw, 150px);
}
/*============================================*/
/* basic style */
/*============================================*/
/* box 
----------------------------------------------*/
.c-content {
  width: 92%;
  max-width: 1200px;
  margin-inline: auto;
  position: relative;
}
/* display:none 
---------------------------------------------*/
@media all and (min-width: 640px) {
  .sp {
    display: none;
  }
}
@media all and (max-width: 639px) and (min-width: 1025px) {
  .tab {
    display: none;
  }
}
@media all and (max-width: 1024px) {
  .pc {
    display: none;
  }
}
/* margin 
---------------------------------------------*/
/* margin-bottom */
.mb0 {margin-bottom: 0 !important;}
.mb5 {margin-bottom: 5px !important;}
.mb10 {margin-bottom: clamp(5px, 0.76vw, 10px) !important;}
.mb15 {margin-bottom: clamp(10px, 1.15vw, 15px) !important;}
.mb20 {margin-bottom: clamp(15px, 1.53vw, 20px) !important;}
.mb25 {margin-bottom: clamp(15px, 1.92vw, 25px) !important;}
.mb30 {margin-bottom: clamp(15px, 2.3vw, 30px) !important;}
.mb35 {margin-bottom: clamp(20px, 2.69vw, 35px) !important;}
.mb40 {margin-bottom: clamp(20px, 3.07vw, 40px) !important;}
.mb45 {margin-bottom: clamp(25px, 3.46vw, 45px) !important;}
.mb50 {margin-bottom: clamp(25px, 3.84vw, 50px) !important;}
.mb55 {margin-bottom: clamp(30px, 4.23vw, 55px) !important;}
.mb60 {margin-bottom: clamp(30px, 4.61vw, 60px) !important;}
.mb65 {margin-bottom: clamp(35px, 5vw, 65px) !important;}
.mb70 {margin-bottom: clamp(35px, 5.38vw, 70px) !important;}
.mb75 {margin-bottom: clamp(40px, 5.76vw, 75px) !important;}
.mb80 {margin-bottom: clamp(40px, 6.15vw, 80px) !important;}
.mb85 {margin-bottom: clamp(40px, 6.53vw, 85px) !important;}
.mb90 {margin-bottom: clamp(40px, 6.92vw, 90px) !important;}
.mb95 {margin-bottom: clamp(40px, 7.3vw, 95px) !important;}
.mb100 {margin-bottom: clamp(50px, 7.69vw, 100px) !important;}
.mb105 {margin-bottom: clamp(50px, 8.07vw, 105px) !important;}
.mb110 {margin-bottom: clamp(50px, 8.46vw, 110px) !important;}
.mb115 {margin-bottom: clamp(50px, 8.84vw, 115px) !important;}
.mb120 {margin-bottom: clamp(60px, 9.23vw, 120px) !important;}
.mb125 {margin-bottom: clamp(60px, 9.61vw, 125px) !important;}
.mb130 {margin-bottom: clamp(60px, 10vw, 130px) !important;}
.mb135 {margin-bottom: clamp(60px, 10.38vw, 135px) !important;}
.mb140 {margin-bottom: clamp(60px, 10.76vw, 140px) !important;}
.mb145 {margin-bottom: clamp(60px, 11.15vw, 145px) !important;}
.mb150 {margin-bottom: clamp(60px, 11.53vw, 150px) !important;}
.mb155 {margin-bottom: clamp(60px, 11.92vw, 155px) !important;}
.mb160 {margin-bottom: clamp(80px, 12.3vw, 160px) !important;}

/* align 
---------------------------------------------*/
.alignC {
  text-align: center !important;
}
.alignR {
  text-align: right !important;
}
.alignL {
  text-align: left !important;
}
.valignT {
  vertical-align: top !important;
}
.valignM {
  vertical-align: middle !important;
}
.valignB {
  vertical-align: bottom !important;
}
/* text 
---------------------------------------------*/
.txtB {
  font-weight: 700 !important;
}
.txtM {
  font-weight: 500 !important;
}
.txtN {
  font-weight: 400 !important;
}
.indent {
  margin-left: 1em;
  text-indent: -1em;
}
.txt {
  font-weight: 500;
  letter-spacing: -0.016em;
}
.break {
  word-break: break-word;
}
.txt_link {
  color: #00418F;
  text-decoration: underline;
}
/* list-style 
---------------------------------------------*/
.c-disc {
  padding-left: 1.2em;
  list-style-type: disc;
  line-height: 2.0;
}
.c-dec {
  padding-left: 1.2em;
  list-style-type: decimal;
  line-height: 2.0;
}
.c-dot li {
  padding-left: 1em;
  text-indent: -1em;
  line-height: 2.0;
}
.c-dot li::before {
  content: '・';
}
.c-circle li {
  padding-left: 16px;
  position: relative;
}
.c-circle li::before {
  content: "";
  width: 8px;
  height: 8px;
  background: #33B6EC;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: calc(0.375em + 4px);/* line-height:1.75 */
}
.c-note li {
  padding-left: 1em;
  text-indent: -1em;
  line-height: 2.0;
}
/* 動画
---------------------------------------------*/
.c-movie iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
/*============================================*/
/* tone & manner */
/*============================================*/
/* DL tablelayout
---------------------------------------------*/
.c-dtable {
  display: grid;
  border-top: 1px solid #8CB4E3;
}
.c-dtable > dt,
.c-dtable > dd {
  padding: clamp(18px, 2.3vw, 30px) clamp(24px, 3.07vw, 40px);
  background: #fff;
  border-bottom: 1px solid #8CB4E3;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: -0.016em;
  line-height: 2;
}
.c-dtable > dt {
  background: #FFF1F2;
  font-weight: 700;
}

@media (min-width: 640px) {
  .c-dtable {
    grid-template-columns: 20.816332% 1fr;
  }
  .c-dtable > dt {
    border-right: 1px solid #8CB4E3;
  }
  .c-dtable > dd {
    padding-left: var(--m25);
    padding-right: var(--m25);
  }
}
@media (max-width: 639px) {
  .c-dtable > dt {
    padding: clamp(10px, 2.3vw, 30px) clamp(24px, 3.07vw, 40px);
  }

}