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%;
}

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(15px, 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(20px, 2.15vw, 2.8rem);
  --font32: clamp(22px, 2.46vw, 3.2rem);
  --font40: clamp(24px, 3.07vw, 4.0rem);
  --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: 85.333333%;/*320px*/
  width: 90.666666%;/*340px*/
  max-width: 1200px;
  margin-inline: auto;
  position: relative;
}
.c-content.w320 {
	width: 85.333333%;
}
/* clear 
----------------------------------------------*/
.clear {
  clear: both;
}
.clearfix:after {
  content: '';
  display: block;
  clear: both;
}
.fltL {
  float: left;
}
/* display:none 
---------------------------------------------*/
@media (min-width: 640px) {
  .sp {
    display: none;
  }
}
@media (max-width: 639px) and (min-width: 1025px) {
  .tab {
    display: none;
  }
}
@media (max-width: 1024px) {
  .pc {
    display: none;
  }
}
@media (min-width: 1025px) {
	.-tab {
		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_link {
  color: var(--color-main01);
  text-decoration: underline;
}
@media (any-hover: hover) {
  .txt_link:hover {
    text-decoration: none;
  }
}
.txt-red {
  color: #E51718;
}
/* 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 
----------------------------------------------*/
.c-ttl {
	margin-bottom: var(--m20);
	color: #B98C08;
	font-size: clamp(28px, 3.69vw, 4.8rem);
	font-weight: 700;
}
/* 左にボーダー */
.c-subttl {
	display: flex;
	gap: var(--m20);
	margin-bottom: var(--m40);
  font-size: var(--font32);
  font-weight: 700;
  line-height: 1.25;
  position: relative;
}
.c-subttl::before {
  content: "";
  width: 6px;
  background: #B98C08;
  position: relative;
  top: 2px;
}
/* ボタン 
----------------------------------------------*/
.c-btn {
  display: block;
  width: 100%;
  max-width: 300px;
  margin-inline: auto;
  padding: clamp(18px, 1.92vw, 25px) 0;
  background: var(--color-main01);
  border: 1px solid var(--color-main01);
  border-radius: 50px;
  color: #fff;
  font-size: clamp(16px, 2.34vw, 20px);
  font-weight: 500;
	text-align: center;
  cursor: pointer;
  position: relative;
}
.c-btn.wh {
  background: #fff;
  border-color: #fff;
  color: var(--color-main01);
}
@media (max-width: 639px) {
	.c-btn.w200 {
		max-width: 200px;
	}
}
.c-btn__txt {
	display: block;
	width: 86%;
	margin-left: auto;
}
@media (min-width: 640px) {
	.c-btn__txt {
		width: 93.333333%;
	}
}
.c-btn__icon {
	width: 80%;
	height: clamp(32px, 3.07vw, 40px);
	position: absolute;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
}
.c-btn__icon::before {
	content: "";
  width: clamp(32px, 3.07vw, 40px);
  height: clamp(32px, 3.07vw, 40px);
  background: #fff;
  border-radius: 50%;
  position: absolute;
  left: 0;
  top: 0;
  transition: left 210ms 0ms cubic-bezier(0.23, 1, 0.32, 1);
}
.c-btn__icon::after {
  content: "\e901";
  display: flex;
  align-items: center;
  justify-content: center;
  width: clamp(32px, 3.07vw, 40px);
  height: clamp(32px, 3.07vw, 40px);
  color: var(--color-main01);
  font-family: 'icomoon' !important;
  font-size: clamp(7px, 0.69vw, 9px);
  line-height: 0;
  transition: all 210ms 20ms cubic-bezier(0.23, 1, 0.32, 1);
  position: absolute;
  left: 0;
  top: 0;
}
.c-btn.wh .c-btn__icon::before {
  background: var(--color-main01);
}
.c-btn.wh .c-btn__icon::after {
  color: #fff;
}
@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 .c-btn__txt {
  	margin-left: 0;
  }
  .c-btn:hover .c-btn__icon::before,
  .c-btn:hover .c-btn__icon::after {
  	color: #fff;
    left: calc(100% - clamp(35px, 3.07vw, 40px));
  }
  .c-btn:hover .c-btn__icon::before {
  	background: var(--color-main01);
  }
  .c-btn.wh:hover .c-btn__icon::before {
    background: #fff;
  }
  .c-btn.wh:hover .c-btn__icon::after {
    color: var(--color-main01);
  }
}
/* 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 {
}
/* TEXT BOX
-----------------------------------------------*/
.c-box__yellow {
	padding: var(--m50) 20px;
	background: #FFF5B4;
	border-radius: clamp(30px, 5.23vw, 68px);
	text-align: center;
}
.c-box__yellow p {
	font-size: var(--font32);
	font-weight: 700;
	line-height: 1.4375;
}
/* アコーディオン
-----------------------------------------------*/
.js-accodion dt {
	padding-right: 40px;
	cursor: pointer;
	position: relative;
}
.js-accodion dt::before,
.js-accodion dt::after {
  content: "";
  width: clamp(20px, 1.92vw, 25px);
  height: 3px;
  background: var(--color-main01);
  position: absolute;
  right: clamp(15px, 2vw, 24px);
  top: 50%;
  transform: translateY(-50%);
}
.js-accodion dt::after {
  transform: rotate(90deg) translate(0, 0);
}
.js-accodion dt.open::after {
  display: none;
}