html {
  font-size: 62.5%;
}
body {
  width: 100%;
  background: #fff;
  color: #333;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 1.6rem;
  line-height: 1.375;/*22px*/
  position: relative;
  overflow-x: hidden;
  -webkit-text-size-adjust: 100%;
  overflow-wrap: anywhere;
  word-break: normal;
  line-break: strict;
}

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 {
  --color-main01: #004A8F;
  --font16: clamp(14px, 1.23vw, 1.6rem);
  --font18: clamp(16px, 1.38vw, 1.8rem);
  --font20: clamp(16px, 1.53vw, 2.0rem);
  --font24: clamp(18px, 1.84vw, 2.4rem);
  --font26: clamp(20px, 2vw, 2.6rem);
  --font28: clamp(22px, 2.15vw, 2.8rem);
  --font32: clamp(22px, 2.46vw, 3.2rem);
  --font40: clamp(24px, 3.07vw, 4.0rem);
  --font48: clamp(26px, 3.69vw, 4.8rem);
  --m10: clamp(5px, 0.76vw, 10px);
  --m15: clamp(8px, 1.15vw, 15px);
  --m20: clamp(10px, 1.53vw, 20px);
  --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(25px, 3.46vw, 45px);
  --m50: clamp(30px, 3.84vw, 50px);
  --m55: clamp(30px, 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);
  --m95: clamp(40px, 7.3vw, 95px);
  --m100: clamp(50px, 7.69vw, 100px);
  --m105: clamp(50px, 8.07vw, 105px);
  --m110: clamp(50px, 8.46vw, 110px);
  --m115: clamp(50px, 8.84vw, 115px);
  --m120: clamp(60px, 9.23vw, 120px);
  --m125: clamp(60px, 9.61vw, 125px);
  --m130: clamp(60px, 10vw, 130px);
  --m135: clamp(60px, 10.38vw, 135px);
  --m140: clamp(70px, 10.76vw, 140px);
  --m145: clamp(70px, 11.15vw, 145px);
  --m150: clamp(70px, 11.53vw, 150px);
  --m160: clamp(80px, 12.3vw, 160px);
  --m170: clamp(80px, 13.07vw, 170px);
}
/*============================================*/
/* basic style */
/*============================================*/
/* box 
----------------------------------------------*/
.c-content {
  width: 89.333333%;
  max-width: 1200px;
  margin-inline: auto;
  position: relative;
}
/* clear 
----------------------------------------------*/
.clear {
  clear: both;
}
.clearfix:after {
  content: '';
  display: block;
  clear: both;
}
.fltL {
  float: left;
}
/* 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(30px, 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;
}
.palt {
  font-feature-settings: "palt";
  letter-spacing: 0.5px;
}
.break {
  word-break: break-word;
}
.txt-red {
  color: #E51718;
}
.txt-yellow {
  color: #F7FF00;
}
/* link 
---------------------------------------------*/
.txt_link {
  color: var(--color-main01);
  text-decoration: underline;
}
@media (any-hover: hover) {
  .txt_link:hover {
    text-decoration: none;
  }
}
.blank::after {
  content: "\e904";
  margin-left: 10px;
  font-family: 'icomoon' !important;
  font-size: 11px;
}
/* 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: 20px;
  line-height: 2;
  position: relative;
}
.c-circle li::before {
  content: "";
  width: 10px;
  height: 10px;
  background: #333;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: calc(1em - 4px);
}
.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 */
/*============================================*/
/* TITLE 
----------------------------------------------*/
/* トップページ & L2 & L3 */
.c-ttl {
  font-size: clamp(32px, 3.69vw, 4.8rem);
  font-weight: 500;
  line-height: 1.5;
}
.c-ttl .-en {
  display: flex;
  align-items: center;
  gap: var(--m15);
  font-size: var(--font18);
  margin-bottom: 10px;
}
.c-ttl .-en::before {
  content: "";
  width: 2px;
  height: calc(1em - 2px);
  background: #E51718;
}
.c-ttl .-ja {
  display: block;
}
.c-ttl .-cate {
  display: block;
  font-size: var(--font18);
  margin-bottom: 3px;
  font-weight: 400;
}
/* 左と下にボーダー */
.c-subttl {
  --pb: clamp(13px, 1.76vw, 23px);
  padding-bottom: var(--pb);
  padding-left: clamp(18px, 2.46vw, 32px);
  border-bottom: 1px solid #C1C1C1;
  font-size: var(--font40);
  font-weight: 500;
  line-height: 1.5;
  position: relative;
}
.c-subttl::before {
  content: "";
  width: 4px;
  height: calc((100% - var(--pb)) - .3em);
  background: var(--color-main01);
  position: absolute;
  left: 0;
  top: 0.2em;
}
/* 左に四角アイコン */
.c-subttl-square {
  display: flex;
  gap: 14px;
  padding-bottom: var(--m20);
  border-bottom: 1px solid #C1C1C1;
  font-size: var(--font32);
  font-weight: 500;
  line-height: 1.5;
}
.c-subttl-square::before {
	flex-shrink: 0;
  content: "";
  width: 16px;
  height: 16px;
  background: var(--color-main01);
  position: relative;
  top: 0.75em;
  transform: translateY(-50%);
}
/* ボタン 
----------------------------------------------*/
.c-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  max-width: 356px;
  padding: clamp(13px, 1.61vw, 21px) 26px clamp(13px, 1.61vw, 21px) 37px;
  background: var(--color-main01);
  border: 1px solid var(--color-main01);
  border-radius: 8px;
  color: #fff;
  font-size: clamp(18px, 1.53vw, 20px);
  font-weight: 500;
  cursor: pointer;
  position: relative;
}
.c-btn.wh {
  background: #fff;
  border-color: #fff;
  color: var(--color-main01);
}
.c-btn::after {
  content: "\e901";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: transparent;
  border-radius: 50%;
  color: #fff;
  font-family: 'icomoon' !important;
  font-size: 14px;
  line-height: 1;
  transition: .3s;
}
@media (any-hover: hover) {
  .c-btn:hover {
    background: #fff;
    color: var(--color-main01);
  }
  .c-btn.wh:hover {
    background: var(--color-main01);
    color: #fff;
  }
  .c-btn:hover::after {
  	background: var(--color-main01);
  	font-size: 9px;
  }
  .c-btn.wh:hover::after {
  	background: #fff;
  }
}
/* DL tablelayout
---------------------------------------------*/
.c-dtable {
  display: grid;
  border-top: 1px solid #DFDFDF;
}
.c-dtable > dt,
.c-dtable > dd {
  padding: var(--m25) var(--m40);
  border-bottom: 1px solid #DFDFDF;
  line-height: 1.8125;
}
.c-dtable > dd {
  padding: var(--m25) var(--m60);
}
.c-dtable > dt {
  padding: clamp(8px, 1.92vw, 25px) var(--m40);
  background: #F2F2F6;
  font-weight: 500;
}
@media (min-width: 640px) {
  .c-dtable {
    grid-template-columns: 25% 1fr;
  }
  .c-dtable > dt {
    border-right: 1px solid #DFDFDF;
  }
}
/* table
---------------------------------------------*/
.c-table {
  width: 100%;
  margin-inline: auto;
  border-bottom: 1px solid #DFDFDF;
}
.c-table tr {
  border-top: 1px solid #DFDFDF;
}
.c-table th, .c-table td {
  padding: var(--m25) var(--m40);
  font-weight: 400;
  line-height: 1.75;
  vertical-align: middle;
}
.c-table th {
  padding: var(--m25) var(--m20);
  background: #FFF6F6;
  font-weight: 500;
}
.c-table th + th,
.c-table td + td {
  border-left: 1px solid #DFDFDF;
}
/* scrollTable
---------------------------------------------*/
@media (max-width: 767px) {
  .js-scrollable {
    overflow-x: scroll;
  }
  .js-scrollable::-webkit-scrollbar{
    height: 5px;
  }
  .js-scrollable::-webkit-scrollbar-track{
    background: #F1F1F1;
  }
  .js-scrollable::-webkit-scrollbar-thumb {
    background: #BCBCBC;
  }
  .js-scrollable table {
    width: clamp(590px, 92.3vw, 1200px) !important;
  }
}
/* etc
---------------------------------------------*/
/* hidden */
.hidden {
  display: none;
}
.c-hr {
  margin: var(--m80) 0;
  border-top: 1px solid #DFDFDF;
}
/*=============================================*/
/* SVG ICON */
/*=============================================*/
.ico-external {
  width: 13.318px;
  height: 10.388px;
}
.txt_link .ico-external {
  fill: var(--color-main01);
}
.ico-external-16 {
  width: 16px;
  height: 16px;
}