@charset "UTF-8";
/*@use "_typography/font-family-noto-sans";*/
/*font-weight　400のみ場合*/
/*@import url('https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New&display=swap');*/
/*全てのウェイトを読み込む*/
@import url("https://fonts.googleapis.com/css2?family=Zen+Kaku+Gothic+New:wght@300;400;500;700;900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Crimson+Text&display=swap");
body {
  font-family: "Zen Kaku Gothic New", sans-serif;
}

/*.eu {
  font-family: "Crimson Text", serif;
  font-weight: 400;
  font-style: normal;
}*/
/*@group mtx-framework*/
/* @group bg */
.bg-ol {
  border: 1px solid #888;
}

.bg-white05 {
  background-color: rgba(255, 255, 255, 0.05) !important;
}

.bg-white1 {
  background-color: rgba(255, 255, 255, 0.1) !important;
}

.bg-white2 {
  background-color: rgba(255, 255, 255, 0.2) !important;
}

.bg-white3 {
  background-color: rgba(255, 255, 255, 0.3) !important;
}

.bg-white4 {
  background-color: rgba(255, 255, 255, 0.4) !important;
}

.bg-white5 {
  background-color: rgba(255, 255, 255, 0.5) !important;
}

.bg-white6 {
  background-color: rgba(255, 255, 255, 0.6) !important;
}

.bg-white7 {
  background-color: rgba(255, 255, 255, 0.7) !important;
}

.bg-white8 {
  background-color: rgba(255, 255, 255, 0.8) !important;
}

.bg-white9 {
  background-color: rgba(255, 255, 255, 0.9) !important;
}

.bg-gray05 {
  background-color: rgba(0, 0, 0, 0.05) !important;
}

.bg-gray1 {
  background-color: rgba(0, 0, 0, 0.1) !important;
}

.bg-gray2 {
  background-color: rgba(0, 0, 0, 0.2) !important;
}

.bg-gray3 {
  background-color: rgba(0, 0, 0, 0.3) !important;
}

.bg-gray4 {
  background-color: rgba(0, 0, 0, 0.4) !important;
}

.bg-gray5 {
  background-color: rgba(0, 0, 0, 0.5) !important;
}

.bg-gray6 {
  background-color: rgba(0, 0, 0, 0.6) !important;
}

.bg-gray7 {
  background-color: rgba(0, 0, 0, 0.7) !important;
}

.bg-gray8 {
  background-color: rgba(0, 0, 0, 0.8) !important;
}

.bg-gray9 {
  background-color: rgba(0, 0, 0, 0.9) !important;
}

.bg-dgray {
  background-color: #8c8c8c !important;
}

.bg-gray {
  background-color: #c5c5c5 !important;
}

.bg-lgray {
  background-color: #e4e4e4 !important;
}

.bg-none {
  background: none !important;
}

.bg-white {
  background: white !important;
}

/*.bg-sea5	{background-color:rgba(0,135,255,0.5)!important;}
.bg-sea4	{background-color:rgba(0,135,255,0.4)!important;}
.bg-sea3	{background-color:rgba(0,135,255,0.3)!important;}
.bg-sea2	{background-color:rgba(0,135,255,0.2)!important;}
.bg-sea1	{background-color:rgba(0,135,255,0.1)!important;}*/
.bg-sea {
  background-color: rgb(64, 91, 128) !important;
}

.bg-sea9 {
  background-color: rgba(64, 91, 128, 0.9) !important;
}

.bg-sea8 {
  background-color: rgba(64, 91, 128, 0.8) !important;
}

.bg-sea7 {
  background-color: rgba(64, 91, 128, 0.7) !important;
}

.bg-sea6 {
  background-color: rgba(64, 91, 128, 0.6) !important;
}

.bg-sea5 {
  background-color: rgba(64, 91, 128, 0.5) !important;
}

.bg-sea4 {
  background-color: rgba(64, 91, 128, 0.4) !important;
}

.bg-sea3 {
  background-color: rgba(64, 91, 128, 0.3) !important;
}

.bg-sea2 {
  background-color: rgba(64, 91, 128, 0.2) !important;
}

.bg-sea1 {
  background-color: rgba(64, 91, 128, 0.1) !important;
}

.bg-sky {
  background-color: rgb(64, 116, 128) !important;
}

.bg-sky9 {
  background-color: rgba(64, 116, 128, 0.9) !important;
}

.bg-sky8 {
  background-color: rgba(64, 116, 128, 0.8) !important;
}

.bg-sky7 {
  background-color: rgba(64, 116, 128, 0.7) !important;
}

.bg-sky6 {
  background-color: rgba(64, 116, 128, 0.6) !important;
}

.bg-sky5 {
  background-color: rgba(64, 116, 128, 0.5) !important;
}

.bg-sky4 {
  background-color: rgba(64, 116, 128, 0.4) !important;
}

.bg-sky3 {
  background-color: rgba(64, 116, 128, 0.3) !important;
}

.bg-sky2 {
  background-color: rgba(64, 116, 128, 0.2) !important;
}

.bg-sky1 {
  background-color: rgba(64, 116, 128, 0.1) !important;
}

.bg-leaf {
  background-color: rgb(51, 128, 67) !important;
}

.bg-leaf9 {
  background-color: rgba(51, 128, 67, 0.9) !important;
}

.bg-leaf8 {
  background-color: rgba(51, 128, 67, 0.8) !important;
}

.bg-leaf7 {
  background-color: rgba(51, 128, 67, 0.7) !important;
}

.bg-leaf6 {
  background-color: rgba(51, 128, 67, 0.6) !important;
}

.bg-leaf5 {
  background-color: rgba(51, 128, 67, 0.5) !important;
}

.bg-leaf4 {
  background-color: rgba(51, 128, 67, 0.4) !important;
}

.bg-leaf3 {
  background-color: rgba(51, 128, 67, 0.3) !important;
}

.bg-leaf2 {
  background-color: rgba(51, 128, 67, 0.2) !important;
}

.bg-leaf1 {
  background-color: rgba(51, 128, 67, 0.1) !important;
}

.bg-grape {
  background-color: rgb(91, 51, 128) !important;
}

.bg-grape9 {
  background-color: rgba(91, 51, 128, 0.9) !important;
}

.bg-grape8 {
  background-color: rgba(91, 51, 128, 0.8) !important;
}

.bg-grape7 {
  background-color: rgba(91, 51, 128, 0.7) !important;
}

.bg-grape6 {
  background-color: rgba(91, 51, 128, 0.6) !important;
}

.bg-grape5 {
  background-color: rgba(91, 51, 128, 0.5) !important;
}

.bg-grape4 {
  background-color: rgba(91, 51, 128, 0.4) !important;
}

.bg-grape3 {
  background-color: rgba(91, 51, 128, 0.3) !important;
}

.bg-grape2 {
  background-color: rgba(91, 51, 128, 0.2) !important;
}

.bg-grape1 {
  background-color: rgba(91, 51, 128, 0.1) !important;
}

.bg-tomato {
  background-color: rgb(255, 33, 0) !important;
}

.bg-tomato9 {
  background-color: rgba(255, 33, 0, 0.9) !important;
}

.bg-tomato8 {
  background-color: rgba(255, 33, 0, 0.8) !important;
}

.bg-tomato7 {
  background-color: rgba(255, 33, 0, 0.7) !important;
}

.bg-tomato6 {
  background-color: rgba(255, 33, 0, 0.6) !important;
}

.bg-tomato5 {
  background-color: rgba(255, 33, 0, 0.5) !important;
}

.bg-tomato4 {
  background-color: rgba(255, 33, 0, 0.4) !important;
}

.bg-tomato3 {
  background-color: rgba(255, 33, 0, 0.3) !important;
}

.bg-tomato2 {
  background-color: rgba(255, 33, 0, 0.2) !important;
}

.bg-tomato1 {
  background-color: rgba(255, 33, 0, 0.1) !important;
}

.bg-orange {
  background-color: rgb(255, 160, 0) !important;
}

.bg-orange9 {
  background-color: rgba(255, 160, 0, 0.9) !important;
}

.bg-orange8 {
  background-color: rgba(255, 160, 0, 0.8) !important;
}

.bg-orange7 {
  background-color: rgba(255, 160, 0, 0.7) !important;
}

.bg-orange6 {
  background-color: rgba(255, 160, 0, 0.6) !important;
}

.bg-orange5 {
  background-color: rgba(255, 160, 0, 0.5) !important;
}

.bg-orange4 {
  background-color: rgba(255, 160, 0, 0.4) !important;
}

.bg-orange3 {
  background-color: rgba(255, 160, 0, 0.3) !important;
}

.bg-orange2 {
  background-color: rgba(255, 160, 0, 0.2) !important;
}

.bg-orange1 {
  background-color: rgba(255, 160, 0, 0.1) !important;
}

.bg-lemon {
  background-color: rgb(255, 230, 0) !important;
}

.bg-lemon9 {
  background-color: rgba(255, 230, 0, 0.9) !important;
}

.bg-lemon8 {
  background-color: rgba(255, 230, 0, 0.8) !important;
}

.bg-lemon7 {
  background-color: rgba(255, 230, 0, 0.7) !important;
}

.bg-lemon6 {
  background-color: rgba(255, 230, 0, 0.6) !important;
}

.bg-lemon5 {
  background-color: rgba(255, 230, 0, 0.5) !important;
}

.bg-lemon4 {
  background-color: rgba(255, 230, 0, 0.4) !important;
}

.bg-lemon3 {
  background-color: rgba(255, 230, 0, 0.3) !important;
}

.bg-lemon2 {
  background-color: rgba(255, 230, 0, 0.2) !important;
}

.bg-lemon1 {
  background-color: rgba(255, 230, 0, 0.1) !important;
}

bg-blue {
  /*background-color:hsl(200deg 30% 70%)!important;*/
  background-color: #8c9ed9 !important;
}

.bg-lblue {
  /*	background-color:hsl(200deg 30% 80%)!important;*/
  background-color: #b3bee6 !important;
}

.bg-llblue {
  /*background-color:hsl(200deg 30% 90%)!important;*/
  background-color: #d9dff2 !important;
}

.bg-blue2 {
  /*background-color:hsl(200deg 30% 70%)!important;*/
  background-color: #8cbfd9 !important;
}

.bg-lblue2 {
  /*	background-color:hsl(200deg 30% 80%)!important;*/
  background-color: #b3d5e6 !important;
}

.bg-llblue2 {
  /*background-color:hsl(200deg 30% 90%)!important;*/
  background-color: #d9eaf2 !important;
}

.bg-green {
  /*background-color:hsl(127deg 30% 70%)!important;*/
  background-color: #8cd995 !important;
}

.bg-lgreen {
  /*	background-color:hsl(127deg 30% 80%)!important;*/
  background-color: #b3e6b8 !important;
}

.bg-llgreen {
  /*background-color:hsl(127deg 30% 90%)!important;*/
  background-color: #d9f2dc !important;
}

/* @end */
/*.bg-lightgray {
	background-color: #e4e4e4;
}*/
/*.bg-darkgray{
	background-color: #8c8c8c;
}*/
/*test 2020-01-28*/
/*.opacity-0 {opacity:0;} .opacity-10 {opacity:0.1;} .opacity-20 {opacity:0.2;}
.opacity-30 {opacity:0.3;}.opacity-40 {opacity:0.4;}.opacity-50 {opacity:0.5;}
.opacity-60 {opacity:0.6;} .opacity-70 {opacity:0.7;}.opacity-80 {opacity:0.8;}
.opacity-90 {opacity:0.9;}.opacity-100 {opacity:1;}*/
/*.box-lightgray, .box-gray, .box-darkgray {
	font-size: 14px;;
	font-weight: 400;
	padding: 4px 14px;
	margin-right: 6px;
	margin-left: 6px;
	/*border-right: 1px solid silver;
	border-left: 1px solid silver;*!/
	border: 1px solid #b4b4b4;
	margin-top: 0px;
}*/
/*ボーダー（枠）共通（薄い色のみ）*/
/*.box-white, .box-lightgray {
	border: 1px solid #b4b4b4;
}

.box-attention {
	padding: 4px 14px;
	margin-right: 10px;
	margin-left: 10px;
	background-color: #d19d80;
	color: white;
	font-weight: 700;
}*/
/*New since 2025*/
.f-black {
  color: black !important;
}

.f-dgray {
  color: #555 !important;
}

.f-gray {
  color: gray !important;
}

.f-lgray {
  color: #afafa !important;
}

.f-silver {
  color: silver !important;
}

.f-white {
  color: white !important;
}

.f-red {
  color: #c62828 !important;
}

.f-white1 {
  color: rgba(255, 255, 255, 0.1) !important;
}

.f-white2 {
  color: rgba(255, 255, 255, 0.2) !important;
}

.f-white3 {
  color: rgba(255, 255, 255, 0.3) !important;
}

.f-white4 {
  color: rgba(255, 255, 255, 0.4) !important;
}

.f-white5 {
  color: rgba(255, 255, 255, 0.5) !important;
}

.f-white6 {
  color: rgba(255, 255, 255, 0.6) !important;
}

.f-white7 {
  color: rgba(255, 255, 255, 0.7) !important;
}

.f-white8 {
  color: rgba(255, 255, 255, 0.8) !important;
}

.f-white9 {
  color: rgba(255, 255, 255, 0.9) !important;
}

.f-white {
  color: rgb(255, 255, 255) !important;
}

.f-gray1 {
  color: rgba(128, 128, 128, 0.1) !important;
}

.f-gray2 {
  color: rgba(128, 128, 128, 0.2) !important;
}

.f-gray3 {
  color: rgba(128, 128, 128, 0.3) !important;
}

.f-gray4 {
  color: rgba(128, 128, 128, 0.4) !important;
}

.f-gray5 {
  color: rgba(128, 128, 128, 0.5) !important;
}

.f-gray6 {
  color: rgba(128, 128, 128, 0.6) !important;
}

.f-gray7 {
  color: rgba(128, 128, 128, 0.7) !important;
}

.f-gray8 {
  color: rgba(128, 128, 128, 0.8) !important;
}

.f-gray9 {
  color: rgba(128, 128, 128, 0.9) !important;
}

.f-black1 {
  color: rgba(0, 0, 0, 0.1) !important;
}

.f-black2 {
  color: rgba(0, 0, 0, 0.2) !important;
}

.f-black3 {
  color: rgba(0, 0, 0, 0.3) !important;
}

.f-black4 {
  color: rgba(0, 0, 0, 0.4) !important;
}

.f-black5 {
  color: rgba(0, 0, 0, 0.5) !important;
}

.f-black6 {
  color: rgba(0, 0, 0, 0.6) !important;
}

.f-black7 {
  color: rgba(0, 0, 0, 0.7) !important;
}

.f-black8 {
  color: rgba(0, 0, 0, 0.8) !important;
}

.f-black9 {
  color: rgba(0, 0, 0, 0.9) !important;
}

.f-black {
  color: rgb(0, 0, 0) !important;
}

/*Font Weight*/
/*.fw1{font-weight: 100;}.fw2{font-weight: 200;}.fw3{font-weight: 300;}.fw4{font-weight: 400;}
.fw5{font-weight: 500;}.fw6{font-weight: 600;}.fw7{font-weight: 700;}.fw8{font-weight: 800;}
.fw9{font-weight: 900;}*/
/*FONT BOLD/NORMAL/LIGHT/THIN*/
/*MTX 2022-02-10*/
/*.fnormal {font-weight: normal!important;} 
.fbold {font-weight: bold!important;}
.flight {font-weight: 300!important;} 
.fthin {font-weight: 100!important;}*/
/*overwrite text.scss*/
/*.fnormal {font-weight: 500;} .fbold {font-weight: 700;}
.flight {font-weight: 300;} .fthin {font-weight: 100;}*/
.f-normal, .fnormal {
  border: none !important;
  text-decoration: none !important;
  font-weight: normal !important;
}

/*.f-heavy{font-weight: 700!important;}*/
/*@group font-weight*/
.fw1 {
  font-weight: 100 !important;
}

.fw2 {
  font-weight: 200 !important;
}

.fw3 {
  font-weight: 300 !important;
}

.fw4 {
  font-weight: 400 !important;
}

.fw5 {
  font-weight: 500 !important;
}

.fw6 {
  font-weight: 600 !important;
}

.fw7 {
  font-weight: 700 !important;
}

.fw8 {
  font-weight: 800 !important;
}

.fw9 {
  font-weight: 900 !important;
}

.f-light {
  font-weight: 200 !important;
}

.f-thin {
  font-weight: 100 !important;
}

strong, .strong {
  font-weight: 700 !important;
}

.thin {
  font-weight: 100 !important;
}

/*@end font-weight*/
/*@group font-size*/
.fxsmall {
  font-size: 0.84rem !important;
}

.fsmall {
  font-size: 0.9rem !important;
}

.fregular {
  font-size: 1rem !important;
}

.flarge {
  font-size: 1.15rem !important;
}

.fxlarge {
  font-size: 1.4rem !important;
}

.f-smaller {
  font-size: smaller !important;
}

.f-larger {
  font-size: larger !important;
}

.f-xsmall {
  font-size: 0.84rem !important;
}

.f-small {
  font-size: 0.9rem !important;
}

.f-regular {
  font-size: 1rem !important;
}

.f-large {
  font-size: 1.15rem !important;
}

.f-xlarge {
  font-size: 1.4rem !important;
}

/*@end font-size*/
/*line height*/
.lh10 {
  line-height: 100%;
}

.lh12 {
  line-height: 120%;
}

.lh14 {
  line-height: 140%;
}

.lh16 {
  line-height: 160%;
}

.lh18 {
  line-height: 180%;
}

.lh20 {
  line-height: 200%;
}

.lh22 {
  line-height: 220%;
}

.lh22 {
  line-height: 240%;
}

.lh26 {
  line-height: 260%;
}

.lh28 {
  line-height: 280%;
}

.lh30 {
  line-height: 300%;
}

/*.btn {font-size: 1.45rem;}*/
.shadow {
  text-shadow: 0px 0px 6px rgba(0, 0, 0, 0.6);
}

/*past>>>bootstrap4 text-light */
/*.tl {text-align: left;} .tc {text-align: center;} .tr {text-align: right;} */
/*FONT SIZE*/
/*MTX added : 1px step  */
.fs6 {
  font-size: 6px !important;
}

.fs7 {
  font-size: 7px !important;
}

.fs8 {
  font-size: 8px !important;
}

.fs9 {
  font-size: 9px !important;
}

.fs10 {
  font-size: 10px !important;
}

.fs11 {
  font-size: 11px !important;
}

.fs12 {
  font-size: 12px !important;
}

.fs13 {
  font-size: 13px !important;
}

.fs14 {
  font-size: 14px !important;
}

.fs15 {
  font-size: 15px !important;
}

.fs16 {
  font-size: 16px !important;
}

.fs17 {
  font-size: 17px !important;
}

.fs18 {
  font-size: 18px !important;
}

.fs19 {
  font-size: 19px !important;
}

.fs20 {
  font-size: 20px !important;
}

.fs21 {
  font-size: 21px !important;
}

.fs22 {
  font-size: 22px !important;
}

.fs23 {
  font-size: 23px !important;
}

.fs24 {
  font-size: 24px !important;
}

.fs25 {
  font-size: 25px !important;
}

.fs26 {
  font-size: 26px !important;
}

.fs27 {
  font-size: 27px !important;
}

.fs28 {
  font-size: 28px !important;
}

.fs29 {
  font-size: 29px !important;
}

.fs30 {
  font-size: 30px !important;
}

.fs31 {
  font-size: 31px !important;
}

.fs32 {
  font-size: 32px !important;
}

.fs33 {
  font-size: 33px !important;
}

.fs34 {
  font-size: 34px !important;
}

.fs35 {
  font-size: 35px !important;
}

.fs36 {
  font-size: 36px !important;
}

.fs37 {
  font-size: 37px !important;
}

.fs38 {
  font-size: 38px !important;
}

.fs39 {
  font-size: 39px !important;
}

.fs40 {
  font-size: 40px !important;
}

/*50~100 [10step]*/
.fs50 {
  font-size: 50px !important;
}

.fs60 {
  font-size: 60px !important;
}

.fs70 {
  font-size: 70px !important;
}

.fs80 {
  font-size: 80px !important;
}

.fs90 {
  font-size: 90px !important;
}

.fs100 {
  font-size: 100px !important;
}

/*@media  (max-width: 991px) {
.fs10-md {font-size: 10px!important;}.fs11-md {font-size: 11px!important;}.fs12-md {font-size: 12px!important;}
.fs13-md {font-size: 13px!important;}.fs14-md {font-size: 14px!important;}.fs15-md {font-size: 15px!important;}
.fs16-md {font-size: 16px!important;}.fs17-md {font-size: 17px!important;}.fs18-md {font-size: 18px!important;}
.fs19-md {font-size: 19px!important;}.fs20-md {font-size: 20px!important;}.fs21-md {font-size: 21px!important;}
.fs22-md {font-size: 22px!important;}.fs23-md {font-size: 23px!important;}.fs24-md {font-size: 24px!important;}
.fs25-md {font-size: 25px!important;}.fs26-md {font-size: 26px!important;}.fs27-md {font-size: 27px!important;}
.fs28-md {font-size: 28px!important;}.fs29-md {font-size: 29px!important;}.fs30-md {font-size: 30px!important;}
}*/
/*MTX added for bootstrap screen [sm]*/
@media (max-width: 575px) {
  .fs10-sm {
    font-size: 10px !important;
  }
  .fs11-sm {
    font-size: 11px !important;
  }
  .fs12-sm {
    font-size: 12px !important;
  }
  .fs13-sm {
    font-size: 13px !important;
  }
  .fs14-sm {
    font-size: 14px !important;
  }
  .fs15-sm {
    font-size: 15px !important;
  }
  .fs16-sm {
    font-size: 16px !important;
  }
  .fs17-sm {
    font-size: 17px !important;
  }
  .fs18-sm {
    font-size: 18px !important;
  }
  .fs19-sm {
    font-size: 19px !important;
  }
  .fs20-sm {
    font-size: 20px !important;
  }
  .fs21-sm {
    font-size: 21px !important;
  }
  .fs22-sm {
    font-size: 22px !important;
  }
  .fs23-sm {
    font-size: 23px !important;
  }
  .fs24-sm {
    font-size: 24px !important;
  }
  .fs25-sm {
    font-size: 25px !important;
  }
  .fs26-sm {
    font-size: 26px !important;
  }
  .fs27-sm {
    font-size: 27px !important;
  }
  .fs28-sm {
    font-size: 28px !important;
  }
  .fs29-sm {
    font-size: 29px !important;
  }
  .fs30-sm {
    font-size: 30px !important;
  }
}
.fs-xsmall {
  font-size: 0.84rem !important;
}

.fs-small {
  font-size: 0.9rem !important;
}

.fs-regular {
  font-size: 1rem !important;
}

.fs-large {
  font-size: 1.15rem !important;
}

.fs-xlarge {
  font-size: 1.4rem !important;
}

.fs-xsmall-sm {
  font-size: 0.84rem !important;
}

.fs-small-sm {
  font-size: 0.9rem !important;
}

.fs-regular-sm {
  font-size: 1rem !important;
}

.fs-large-sm {
  font-size: 1.15rem !important;
}

.fs-xlarge-sm {
  font-size: 1.4rem !important;
}

/*Class for setting margin*/
.ma0 {
  margin: 0;
}

.mt0 {
  margin-top: 0;
}

.mr0 {
  margin-right: 0;
}

.mb0 {
  margin-bottom: 0;
}

.ml0 {
  margin-left: 0;
}

.ma1 {
  margin: 1px;
}

.mt1 {
  margin-top: 1px;
}

.mr1 {
  margin-right: 1px;
}

.mb1 {
  margin-bottom: 1px;
}

.ml1 {
  margin-left: 1px;
}

.ma2 {
  margin: 2px;
}

.mt2 {
  margin-top: 2px;
}

.mr2 {
  margin-right: 2px;
}

.mb2 {
  margin-bottom: 2px;
}

.ml2 {
  margin-left: 2px;
}

.ma3 {
  margin: 3px;
}

.mt3 {
  margin-top: 3px;
}

.mr3 {
  margin-right: 3px;
}

.mb3 {
  margin-bottom: 3px;
}

.ml3 {
  margin-left: 3px;
}

.ma4 {
  margin: 4px;
}

.mt4 {
  margin-top: 4px;
}

.mr4 {
  margin-right: 4px;
}

.mb4 {
  margin-bottom: 4px;
}

.ml4 {
  margin-left: 4px;
}

.ma5 {
  margin: 5px;
}

.mt5 {
  margin-top: 5px;
}

.mr5 {
  margin-right: 5px;
}

.mb5 {
  margin-bottom: 5px;
}

.ml5 {
  margin-left: 5px;
}

.ma6 {
  margin: 6px;
}

.mt6 {
  margin-top: 6px;
}

.mr6 {
  margin-right: 6px;
}

.mb6 {
  margin-bottom: 6px;
}

.ml6 {
  margin-left: 6px;
}

.ma7 {
  margin: 7px;
}

.mt7 {
  margin-top: 7px;
}

.mr7 {
  margin-right: 7px;
}

.mb7 {
  margin-bottom: 7px;
}

.ml7 {
  margin-left: 7px;
}

.ma8 {
  margin: 8px;
}

.mt8 {
  margin-top: 8px;
}

.mr8 {
  margin-right: 8px;
}

.mb8 {
  margin-bottom: 8px;
}

.ml8 {
  margin-left: 8px;
}

.ma9 {
  margin: 9px;
}

.mt9 {
  margin-top: 9px;
}

.mr9 {
  margin-right: 9px;
}

.mb9 {
  margin-bottom: 9px;
}

.ml9 {
  margin-left: 9px;
}

.ma10 {
  margin: 10px;
}

.mt10 {
  margin-top: 10px;
}

.mr10 {
  margin-right: 10px;
}

.mb10 {
  margin-bottom: 10px;
}

.ml10 {
  margin-left: 10px;
}

.ma15 {
  margin: 15px;
}

.mt15 {
  margin-top: 15px;
}

.mr15 {
  margin-right: 15px;
}

.mb15 {
  margin-bottom: 15px;
}

.ml15 {
  margin-left: 15px;
}

.ma20 {
  margin: 20px;
}

.mt20 {
  margin-top: 20px;
}

.mr20 {
  margin-right: 20px;
}

.mb20 {
  margin-bottom: 20px;
}

.ml20 {
  margin-left: 20px;
}

.ma25 {
  margin: 25px;
}

.mt25 {
  margin-top: 25px;
}

.mr25 {
  margin-right: 25px;
}

.mb25 {
  margin-bottom: 25px;
}

.ml25 {
  margin-left: 25px;
}

.ma30 {
  margin: 30px;
}

.mt30 {
  margin-top: 30px;
}

.mr30 {
  margin-right: 30px;
}

.mb30 {
  margin-bottom: 30px;
}

.ml30 {
  margin-left: 30px;
}

.ma35 {
  margin: 35px;
}

.mt35 {
  margin-top: 35px;
}

.mr35 {
  margin-right: 35px;
}

.mb35 {
  margin-bottom: 35px;
}

.ml35 {
  margin-left: 35px;
}

.ma40 {
  margin: 40px;
}

.mt40 {
  margin-top: 40px;
}

.mr40 {
  margin-right: 40px;
}

.mb40 {
  margin-bottom: 40px;
}

.ml40 {
  margin-left: 40px;
}

.ma45 {
  margin: 45px;
}

.mt45 {
  margin-top: 45px;
}

.mr45 {
  margin-right: 45px;
}

.mb45 {
  margin-bottom: 45px;
}

.ml45 {
  margin-left: 45px;
}

.ma50 {
  margin: 50px;
}

.mt50 {
  margin-top: 50px;
}

.mr50 {
  margin-right: 50px;
}

.mb50 {
  margin-bottom: 50px;
}

.ml50 {
  margin-left: 50px;
}

/*60~100 [10step]*/
.ma60 {
  margin: 60px;
}

.mt60 {
  margin-top: 60px;
}

.mr60 {
  margin-right: 60px;
}

.mb60 {
  margin-bottom: 60px;
}

.ml60 {
  margin-left: 60px;
}

.ma70 {
  margin: 70px;
}

.mt70 {
  margin-top: 70px;
}

.mr70 {
  margin-right: 70px;
}

.mb70 {
  margin-bottom: 70px;
}

.ml70 {
  margin-left: 70px;
}

.ma80 {
  margin: 80px;
}

.mt80 {
  margin-top: 80px;
}

.mr80 {
  margin-right: 80px;
}

.mb80 {
  margin-bottom: 80px;
}

.ml80 {
  margin-left: 80px;
}

.ma90 {
  margin: 90px;
}

.mt90 {
  margin-top: 90px;
}

.mr90 {
  margin-right: 90px;
}

.mb90 {
  margin-bottom: 90px;
}

.ml90 {
  margin-left: 90px;
}

.ma100 {
  margin: 100px;
}

.mt100 {
  margin-top: 100px;
}

.mr100 {
  margin-right: 100px;
}

.mb100 {
  margin-bottom: 100px;
}

.ml100 {
  margin-left: 100px;
}

/*Class for setting padding*/
.pa0 {
  padding: 0;
}

.pt0 {
  padding-top: 0;
}

.pr0 {
  padding-right: 0;
}

.pb0 {
  padding-bottom: 0;
}

.pl0 {
  padding-left: 0;
}

.pa1 {
  padding: 1px;
}

.pt1 {
  padding-top: 1px;
}

.pr1 {
  padding-right: 1px;
}

.pb1 {
  padding-bottom: 1px;
}

.pl1 {
  padding-left: 1px;
}

.pa2 {
  padding: 2px;
}

.pt2 {
  padding-top: 2px;
}

.pr2 {
  padding-right: 2px;
}

.pb2 {
  padding-bottom: 2px;
}

.pl2 {
  padding-left: 2px;
}

.pa3 {
  padding: 3px;
}

.pt3 {
  padding-top: 3px;
}

.pr3 {
  padding-right: 3px;
}

.pb3 {
  padding-bottom: 3px;
}

.pl3 {
  padding-left: 3px;
}

.pa4 {
  padding: 4px;
}

.pt4 {
  padding-top: 4px;
}

.pr4 {
  padding-right: 4px;
}

.pb4 {
  padding-bottom: 4px;
}

.pl4 {
  padding-left: 4px;
}

.pa5 {
  padding: 5px;
}

.pt5 {
  padding-top: 5px;
}

.pr5 {
  padding-right: 5px;
}

.pb5 {
  padding-bottom: 5px;
}

.pl5 {
  padding-left: 5px;
}

.pa6 {
  padding: 6px;
}

.pt6 {
  padding-top: 6px;
}

.pr6 {
  padding-right: 6px;
}

.pb6 {
  padding-bottom: 6px;
}

.pl6 {
  padding-left: 6px;
}

.pa7 {
  padding: 7px;
}

.pt7 {
  padding-top: 7px;
}

.pr7 {
  padding-right: 7px;
}

.pb7 {
  padding-bottom: 7px;
}

.pl7 {
  padding-left: 7px;
}

.pa8 {
  padding: 8px;
}

.pt8 {
  padding-top: 8px;
}

.pr8 {
  padding-right: 8px;
}

.pb8 {
  padding-bottom: 8px;
}

.pl8 {
  padding-left: 8px;
}

.pa9 {
  padding: 9px;
}

.pt9 {
  padding-top: 9px;
}

.pr9 {
  padding-right: 9px;
}

.pb9 {
  padding-bottom: 9px;
}

.pl9 {
  padding-left: 9px;
}

/*60~100 [5step]*/
.pa10 {
  padding: 10px;
}

.pt10 {
  padding-top: 10px;
}

.pr10 {
  padding-right: 10px;
}

.pb10 {
  padding-bottom: 10px;
}

.pl10 {
  padding-left: 10px;
}

.pa15 {
  padding: 15px;
}

.pt15 {
  padding-top: 15px;
}

.pr15 {
  padding-right: 15px;
}

.pb15 {
  padding-bottom: 15px;
}

.pl15 {
  padding-left: 15px;
}

.pa20 {
  padding: 20px;
}

.pt20 {
  padding-top: 20px;
}

.pr20 {
  padding-right: 20px;
}

.pb20 {
  padding-bottom: 20px;
}

.pl20 {
  padding-left: 20px;
}

.pa25 {
  padding: 25px;
}

.pt25 {
  padding-top: 25px;
}

.pr25 {
  padding-right: 25px;
}

.pb25 {
  padding-bottom: 25px;
}

.pl25 {
  padding-left: 25px;
}

.pa30 {
  padding: 30px;
}

.pt30 {
  padding-top: 30px;
}

.pr30 {
  padding-right: 30px;
}

.pb30 {
  padding-bottom: 30px;
}

.pl30 {
  padding-left: 30px;
}

.pa35 {
  padding: 35px;
}

.pt35 {
  padding-top: 35px;
}

.pr35 {
  padding-right: 35px;
}

.pb35 {
  padding-bottom: 35px;
}

.pl35 {
  padding-left: 35px;
}

.pa40 {
  padding: 40px;
}

.pt40 {
  padding-top: 40px;
}

.pr40 {
  padding-right: 40px;
}

.pb40 {
  padding-bottom: 40px;
}

.pl40 {
  padding-left: 40px;
}

.pa45 {
  padding: 45px;
}

.pt45 {
  padding-top: 45px;
}

.pr45 {
  padding-right: 45px;
}

.pb45 {
  padding-bottom: 45px;
}

.pl45 {
  padding-left: 45px;
}

.pa50 {
  padding: 50px;
}

.pt50 {
  padding-top: 50px;
}

.pr50 {
  padding-right: 50px;
}

.pb50 {
  padding-bottom: 50px;
}

.pl50 {
  padding-left: 50px;
}

/*60~100 [10step]*/
.pa60 {
  padding: 60px;
}

.pt60 {
  padding-top: 60px;
}

.pr60 {
  padding-right: 60px;
}

.pb60 {
  padding-bottom: 60px;
}

.pl60 {
  padding-left: 60px;
}

.pa70 {
  padding: 70px;
}

.pt70 {
  padding-top: 70px;
}

.pr70 {
  padding-right: 70px;
}

.pb70 {
  padding-bottom: 70px;
}

.pl70 {
  padding-left: 70px;
}

.pa80 {
  padding: 80px;
}

.pt80 {
  padding-top: 80px;
}

.pr80 {
  padding-right: 80px;
}

.pb80 {
  padding-bottom: 80px;
}

.pl80 {
  padding-left: 80px;
}

.pa90 {
  padding: 90px;
}

.pt90 {
  padding-top: 90px;
}

.pr90 {
  padding-right: 90px;
}

.pb90 {
  padding-bottom: 90px;
}

.pl90 {
  padding-left: 90px;
}

.pa100 {
  padding: 100px;
}

.pt100 {
  padding-top: 100px;
}

.pr100 {
  padding-right: 100px;
}

.pb100 {
  padding-bottom: 100px;
}

.pl100 {
  padding-left: 100px;
}

/*@end*/
/*@group mtx-effect*/
/*2022-12-09*/
a img {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

a:hover img {
  opacity: 0.6;
  filter: alpha(opacity=60);
}

/*when pointing over [a] tag*/
a:hover {
  cursor: pointer;
}

.highlight:hover {
  opacity: 0.5;
  filter: alpha(opacity=50);
  -ms-filter: "alpha( opacity=50 )";
  -moz-opacity: 0.5;
}

.fadein,
.slidein,
.slidein-left,
.slidein-right,
.slidein-up,
.slidein-down {
  opacity: 0;
  transform: none;
  transition: opacity 0.8s ease-out, transform 0.8s ease-out;
}

.fadein.scrollin {
  opacity: 1;
}

.slidein.scrollin,
.slidein-up.scrollin,
.slidein-down.scrollin,
.slidein-left.scrollin,
.slidein-right.scrollin {
  opacity: 1;
  transform: translate(0, 0);
}

/* 方向別初期位置 */
.slidein-up {
  transform: translateY(30px);
}

.slidein-down {
  transform: translateY(-30px);
}

.slidein-left {
  transform: translateX(-30px);
}

.slidein-right {
  transform: translateX(30px);
}

/*@end*/
/*@group parts*/
/*@use "_parts/button-bs4-btn";*/
:root {
  --a-button-bg: #fff;
  --a-button-color: #333;
  --a-button-bg-hover: #ddd;
}

a {
  margin: 0.4em !important;
}

/*@group リンクボタン（アイコン付）*/
a.link {
  /*background-color: #e4edf4;*/
  background-color: var(--a-button-bg);
  border: 1px solid #ccc !important;
}

a.scroll,
a.scroll-down,
a.scroll-up {
  background-color: var(--a-button-bg);
  border: 1px solid #ccc !important;
  box-shadow: 0px 5px 10px 0px rgba(0, 0, 0, 0.2);
}

a.link,
a.scroll,
a.scroll-down,
a.scroll-up {
  position: relative;
  display: inline-block;
  padding: 0.4em 2.4em 0.4em 1.2em;
  background-color: var(--a-button-bg);
  color: var(--a-button-color);
  text-decoration: none;
  border-radius: 99px;
  font-weight: 400;
  transition: background-color 0.3s;
  margin: 0.8em 1em 0.8em 0;
  font-size: 0.95rem;
  box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.14);
}

a.link:hover,
a.scroll:hover,
a.scroll-down:hover,
a.scroll-up:hover {
  background-color: var(--a-button-bg-hover);
  box-shadow: none;
}

a.link:after,
a.scroll:after,
a.scroll-down:after,
a.scroll-up:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0.6em;
  transform: translateY(-50%);
  width: 14px;
  height: 14px;
  background-size: contain;
}

a.link:after {
  background: url("img/icon/peak-right.png") no-repeat center center;
}

a.scroll:after,
a.scroll-down:after {
  background: url("img/icon/arrow-down.png") no-repeat center center;
}

a.scroll-up:after {
  background: url("img/icon/arrow-up.png") no-repeat center center;
}

/*@end*/
/*@group 共通の丸いスクロールボタン*/
/*top-carousel内や各所に使われている*/
a.scroll-circle {
  width: 48px;
  height: 48px;
  background-color: rgba(255, 255, 255, 0.5);
  border: 1px solid rgba(0, 0, 0, 0.1);
  border-radius: 50%;
  display: flex;
  justify-content: center;
  align-items: center;
  box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.14);
}

a.scroll-circle:hover {
  background-color: rgba(128, 128, 128, 0.5);
  transition: background-color 0.8s ease;
}

a.scroll-circle span.peak-down {
  display: inline-block;
  width: 16px;
  height: 16px;
  background: url("img/icon/peak-down.png") no-repeat center center;
  background-size: contain;
}

/*@end*/
/*caption [photo by mtx]*/
.splide {
  position: relative;
  overflow: hidden;
}

.caption-box {
  position: absolute;
  top: 30%;
  left: 50%;
  transform: translateX(-50%);
}

.box {
  position: relative;
  top: 0;
  left: 50%;
  min-height: 180px;
  transform: translateX(-50%);
  background: rgba(0, 0, 0, 0.5);
  color: #fff;
  text-align: center;
  padding: 30px 15px;
}

@media (max-width: 768px) {
  .caption-box {
    top: 40%;
  }
  .box {
    padding: 20px 10px;
  }
}
.photo-by-caption {
  position: absolute;
  right: 10%;
  bottom: 10%;
}

.splide__slide img {
  width: 100%;
  height: auto;
  object-fit: cover;
  max-height: 600px;
}

@media (max-width: 768px) {
  .splide__slide img {
    width: 100vw;
    height: 100vh;
    object-fit: cover;
    max-height: none;
  }
  .caption-box {
    bottom: 20%;
    font-size: 0.9rem;
  }
  .photo-by-caption {
    right: 5%;
    bottom: 5%;
    font-size: 0.8rem;
  }
}
.splide p.eu {
  font-size: 32px;
  color: #fff;
}

/*@use "_parts/accordion-details";*/
/* @group ハンバーガーボタン本体 */
:root {
  --drawer-bg: #ffffff;
  --drawer-text: #111111;
  --toggle-line: #fff;
  --toggle-bg: #bbb;
  --accent-color: #0077cc;
}

#drawer-toggle {
  position: fixed;
  top: 8px;
  right: 8px;
  width: 48px; /* 正方形 */
  height: 48px; /* 正方形 */
  display: flex;
  flex-direction: column;
  justify-content: space-around;
  align-items: center;
  background: var(--toggle-bg);
  border: none;
  border-radius: 4px;
  padding: 4px; /* 余白4px */
  cursor: pointer;
  z-index: 10002;
}

#drawer-toggle span {
  position: relative;
  display: block;
  width: 32px;
  height: 3px;
  background: var(--toggle-line);
  border-radius: 3px;
  transition: transform 0.3s, opacity 0.3s;
}

#drawer-toggle span::before,
#drawer-toggle span::after {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 3px;
  background: var(--toggle-line);
  border-radius: 3px;
  transition: transform 0.3s, opacity 0.3s;
}

#drawer-toggle span::before {
  top: -10px;
}

#drawer-toggle span::after {
  top: 10px;
}

/* ハンバーガー open 時 */
#drawer-toggle.open span {
  background: transparent; /* 中央線を消す */
}

#drawer-toggle.open span::before {
  transform: rotate(45deg) translate(7px, 7px);
}

#drawer-toggle.open span::after {
  transform: rotate(-45deg) translate(7px, -7px);
}

#drawer-toggle:focus {
  outline: none; /* 通常フォーカスは消す */
}

#drawer-toggle:focus-visible {
  outline: 2px solid #0077cc; /* キーボード操作時だけ表示 */
  outline-offset: 4px;
}

/*@end*/
/* @group ドロワー */
#drawer {
  position: fixed;
  top: 0;
  right: -100%;
  width: 100%;
  /*max-width: 360px;*/
  height: 100%;
  background: var(--drawer-bg);
  box-shadow: -4px 0 12px rgba(0, 0, 0, 0.2);
  transition: right 0.3s ease;
  z-index: 10001;
  padding: 20px 20px 20px 20px;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

#drawer.open {
  right: 0;
}

#drawer ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

#drawer li {
  margin: 2px 0;
  padding: 4px;
}

#drawer li:hover {
  background: #eee;
}

#drawer a {
  display: block;
  text-decoration: none;
  font-size: 14px;
  color: var(--drawer-text);
}

#drawer a:hover {
  color: var(--accent-color);
  color: var(--drawer-text);
}

/* オーバーレイ */
#overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s;
  z-index: 10000;
}

#overlay.open {
  opacity: 1;
  visibility: visible;
}

/*  @end*/
/* =========================================================
   共通設定
   ========================================================= */
/* CSS変数の定義 (管理性向上のため) */
:root {
  --header-height: 64px; /* ヘッダーの基準となる高さ */
}

/* 共有（body指定なし） */
* {
  box-sizing: border-box;
}

/* a要素の共通設定 */
a {
  color: inherit;
  text-decoration: none;
}

/* フォーカススタイルをナビゲーション内のリンクに限定 */
.main-navigation a:focus-visible {
  outline: 2px solid #0a66c2;
  outline-offset: 2px;
  border-radius: 10px;
}

/* ul要素のリセット */
ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* HTML/Bodyのリセットと固定ヘッダー対応 */
html,
body {
  margin: 0;
  padding: 0;
}

/* 固定ヘッダーの高さ分、body内容を押し下げる（CSS変数を使用） */
body {
  padding-top: var(--header-height);
}

/* ヘッダー全体 (固定ヘッダー) */
#nav-container {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: var(--header-height); /* CSS変数を使用 */
  background: #eee;
  z-index: 1000;
}

/* PCナビのリンクのフォント太さ */
.main-navigation a {
  font-weight: 400 !important;
}

/* ホバー時の装飾を消す */
.main-navigation a:hover {
  text-decoration: none;
  color: inherit;
}

/* モバイル時、PCナビ要素は完全に無効化（*セレクタを削除し、安全性を向上） */
@media (max-width: 991.98px) {
  .main-navigation {
    display: none !important;
  }
}
/* =========================================================
 PC専用メニュー（lg/992px 以上のみ効かせる）
 ========================================================= */
@media (min-width: 992px) {
  .main-navigation {
    display: block;
    position: relative;
    z-index: 100;
  }
  /* 1階層メニュー */
  .main-navigation .menu {
    display: flex;
    gap: 8px;
  }
  .main-navigation .menu > .menu-item {
    position: relative;
  }
  .main-navigation .menu > .menu-item > a {
    display: block;
    padding: 14px 16px;
    font-weight: 600;
    white-space: nowrap;
    border-radius: 10px;
  }
  .main-navigation .menu > .menu-item > a:hover,
  .main-navigation .menu > .menu-item:focus-within > a {
    background: #f3f4f6;
  }
  .main-navigation .menu > .menu-item.menu-item-has-children > a::after {
    content: "▾";
    margin-left: 0.35em;
    font-size: 0.85em;
    opacity: 0.6;
  }
  /* 2階層 (ドロップダウン) */
  .main-navigation .sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    min-width: 220px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    padding: 8px;
    visibility: hidden;
    opacity: 0;
    transform: none;
    transition: visibility 0.2s step-end, opacity 0.2s, transform 0.2s;
    pointer-events: none;
    z-index: 110;
  }
  .main-navigation .sub-menu > .menu-item {
    position: relative;
  }
  .main-navigation .sub-menu > .menu-item > a {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px 12px;
    border-radius: 8px;
    white-space: nowrap;
  }
  .main-navigation .sub-menu > .menu-item > a:hover,
  .main-navigation .sub-menu > .menu-item:focus-within > a {
    background: #f3f4f6;
  }
  /* 2階層の表示トリガー */
  .main-navigation .menu > .menu-item:hover > .sub-menu,
  .main-navigation .menu > .menu-item:focus-within > .sub-menu {
    visibility: visible;
    opacity: 1;
    transform: none;
    transition: visibility 0s step-start, opacity 0.2s, transform 0.2s;
    pointer-events: auto;
  }
  /* 3階層 (フライアウト) */
  .main-navigation .sub-menu .menu-item-has-children > a::after {
    content: "▸";
    margin-left: 8px;
    opacity: 0.6;
  }
  .main-navigation .sub-menu .sub-menu {
    position: absolute;
    top: -8px;
    left: 100%;
    min-width: 200px;
    background: #fff;
    border: 1px solid #e5e7eb;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.08);
    padding: 8px;
    visibility: hidden;
    opacity: 0;
    transform: none;
    transition: visibility 0.2s step-end, opacity 0.2s, transform 0.2s;
    pointer-events: none;
    z-index: 111;
  }
  /* 3階層の表示トリガー */
  .main-navigation .sub-menu > .menu-item:hover > .sub-menu,
  .main-navigation .sub-menu > .menu-item:focus-within > .sub-menu {
    visibility: visible;
    opacity: 1;
    transform: none;
    transition: visibility 0s step-start, opacity 0.2s, transform 0.2s;
    pointer-events: auto;
  }
  /* 右端メニューのドロップダウン/フライアウトを左開きに切替 */
  .main-navigation .menu > .menu-item:last-child > .sub-menu {
    right: 0;
    left: auto;
  }
  .main-navigation .menu > .menu-item:last-child > .sub-menu .sub-menu {
    left: auto;
    right: 100%;
  }
  /* ホバー切れ防止の“橋渡し”帯 */
  .main-navigation .menu > .menu-item::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 10px;
    pointer-events: auto;
  }
  .main-navigation .sub-menu > .menu-item::after {
    content: "";
    position: absolute;
    top: 0;
    right: -10px;
    width: 10px;
    height: 100%;
    pointer-events: auto;
  }
  .main-navigation .menu > .menu-item:last-child > .sub-menu > .menu-item::after {
    right: auto;
    left: -10px;
  }
  /* 動きを減らす設定 (Sass互換性のため順序を修正) */
}
@media (min-width: 992px) and (min-width: 992px) and (prefers-reduced-motion: reduce) {
  .main-navigation .sub-menu,
  .main-navigation .sub-menu .sub-menu {
    transition: none;
  }
}
/*2025-07-12
AIにサポートされてオリジナルで作成*/
:root {
  --button-acc-bg: #fff;
  --button-acc-bg-hover: #ddd;
  --button-acc-fcolor: #222;
}

/*@group Accordion button*/
button.accordion-header {
  font-size: 1.05rem;
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin: 0.4em 0em;
  padding: 0.24em 1em;
  cursor: pointer;
  background: var(--button-acc-bg);
  color: var(--button-acc-fcolor);
  /*box-shadow: 0px 2px 2px #ccc;*/
  /*box-shadow: 0px 2px 2px 0px rgba(0, 0, 0, 0.1);*/
  box-shadow: 2px 2px 2px 0 rgba(0, 0, 0, 0.14);
  border: 1px solid #bbb;
  border-radius: 2em;
  /*  margin-top: 0.6em;
  margin-bottom: 0.6em;
  margin-left: 1em;*/
  outline: none;
  -webkit-appearance: none;
  appearance: none;
}

/* 状態クラス is-plain を追加したとき */
button.accordion-header.is-plain {
  border: none;
  box-shadow: none;
}

button.accordion-header h2,
button.accordion-header h3 {
  font-weight: 400;
  padding: 0;
  margin: 0;
}

button.accordion-header:hover {
  background: var(--button-acc-bg-hover);
  box-shadow: none;
  transition: background 0.3s ease;
}

button.accordion-header:focus-visible {
  outline: 2px solid #6aa9ff;
  outline-offset: 2px;
}

button.accordion-header::after {
  content: "";
  position: absolute;
  right: 2em;
  width: 1.5em;
  height: 1.5em;
  background-image: url("img/icon/circle-plus.svg");
  background-size: contain;
  background-repeat: no-repeat;
  transition: background-image 0.3s ease;
}

button.accordion-header[aria-expanded=true]::after {
  background-image: url("img/icon/circle-minus.svg");
}

.accordion-content,
.accordion-content * {
  font-size: 1em;
}

.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.4s ease;
  padding: 0 2em;
  border-radius: 0 0 10px 10px;
  background: #fff;
}

.accordion-content.open {
  padding-top: 0em;
  padding-bottom: 3em;
}

@media (prefers-reduced-motion: reduce) {
  .accordion-content,
  button.accordion-header {
    transition: none;
  }
}
/*@end*/
/*:root {
	--a-button-bg: #e2e4eb;
	--a-button-color: #333;
	--a-button-bg-hover: #bbb;
	--button-acc-bg: #efefef;
}*/
.border-b, h2, h3 { /*base*/
  /*デフォルト（色クラス付加なし）はグレー（#aaa)*/
  border-bottom: 1px solid #aaa;
}

.border-b.black {
  border-bottom: 1px solid #111 !important;
}

.border-b.dgray {
  border-bottom: 1px solid #777 !important;
}

.border-b.gray {
  border-bottom: 1px solid #aaa !important;
}

.border-b.lgray {
  border-bottom: 1px solid #ddd !important;
}

.border-b.white {
  border-bottom: 1px solid #fff !important;
}

/*outline color*/
.border-dgray, .ol-dgray {
  border: 1px solid #777 !important;
}

.border-gray, .ol-gray {
  border: 1px solid #aaa !important;
}

.border-dgray, .ol-lgray {
  border: 1px solid #ccc !important;
}

.border-llgray, .ol-llgray {
  border: 1px solid #eee !important;
}

.border-none, .ol-none {
  border: none !important;
}

.border {
  border: 1px solid #ccc !important;
}

/*bootstrap4 has boder-bottom*/
/*.border-bottom {
	border-top: none;
	border-left: none;
	border-right: none;
	border-bottom: 1px solid gray;
}*/
/*.border-bottom {/*base*!/
	border-bottom: 1px solid black;

	.dgray {
	border-bottom: 1px solid #777;
	}
	.gray {
	border-bottom: 1px solid #aaa;
	}
	.lgray {
	border-bottom: 1px solid #ddd;
	}
	.white {
	border-bottom: 1px solid #fff;
	}	

}*/
/* @border */
/*.border-gray {
	display: block;
	border: 1px solid gray;
}*/
/* @end */
.info-box {
  /*background-color: rgba(255, 255, 255, 0.6);	*/
  padding: 0.5rem 1.5rem;
  border: 1px dotted #bbb;
  border-radius: 5px;
  opacity: 1; /*opacity of contents (text etc.)*/
  margin: 16px 0;
  /*-moz-border-radius: 5px;
  -webkit-border-radius: 5px;x
  -o-border-radius: 5px;
  -ms-border-radius: 5px;*/
}

/* @group span.box-ol ,span.box-reverse*/
span.box-ol, span.box-reverse {
  font-size: 0.96rem;
  font-weight: 400;
}

span.box-ol, span.box-reverse {
  /*line-height: 2.5;*/
  display: inline-flex;
  white-space: nowrap; /*2025-07-18*/
  border-radius: 4px;
  line-height: 1.4;
  padding: 2px 10px;
  margin: 2px 2px 2px 0;
}

span.box-ol, .box-ol {
  border: 1px solid #ccc;
  color: #444;
}

span.box-reverse, .box-reverse {
  background-color: #666;
  color: #fff;
}

/* @end */
/* @group dv.box-ol*/
div.container > div.row > div:has(div.box-ol) {
  padding-top: 30px;
}

div.box-ol {
  padding: 10px 30px;
  border: 1px solid #ddd;
  border-radius: 20px;
  height: 100%;
}

div.box-ol, div.box-reverse {
  border-radius: 12px;
}

/* @end */
:root {
  /* ---------------------------------- */
  /* 1. Grid/レイアウト設定 */
  /* ---------------------------------- */
  --grid-gap: 1em;
  --grid-max-width: 1240px;
  /* 2. 列数設定 */
  --grid-cols-mobile: 1;
  --grid-cols-tablet: 2;
  --grid-cols-pc: 3;
  /* 3. Gridアイテム (li) スタイル設定 */
  --li-bg-color: #fafafa;
  --li-line-height: 1.8;
  --li-font-size: 1em;
}

/* ---------------------------------- */
/* 2. Gridコンテナとアイテムのスタイル */
/* ---------------------------------- */
.grid-list {
  /* 親要素（ul）にGridを適用 */
  display: grid;
  /* 変数の適用 */
  max-width: var(--grid-max-width);
  gap: var(--grid-gap);
  margin: 1em auto;
  width: 100%;
  /* モバイル (最小画面) = 1列 (変数適用) */
  grid-template-columns: repeat(var(--grid-cols-mobile), 1fr);
}

.grid-list li {
  /* liのスタイル (変数適用) */
  padding: 1em;
  border: 1px solid #ddd;
  border-radius: 0.5em;
  background: var(--li-bg-color);
  line-height: var(--li-line-height);
  font-size: var(--li-font-size);
  /* Gridではアイテムへの margin は原則不要 */
}

/* ---------------------------------- */
/* 3. レスポンシブ設定 (ブレークポイントは固定値) */
/* ---------------------------------- */
/* タブレット縦 (sm: 576px以上) = 2列 */
@media (min-width: 576px) {
  .grid-list {
    grid-template-columns: repeat(var(--grid-cols-tablet), 1fr);
  }
}
/* PC/デスクトップ (lg: 992px以上) = 3列 */
@media (min-width: 992px) {
  .grid-list {
    grid-template-columns: repeat(var(--grid-cols-pc), 1fr);
  }
}
/* tree-matrix.layout.scss — 分離版・修正（レガシー安全）
   目的：レイアウトと見た目の骨格のみ。色は変数参照に限定（テーマ側で上書き）。
   読み込み順：layout → theme-hue
*/
/* ========================= 基本スコープ ========================= */
.container-tree-matrix {
  /* カスタムプロパティ（初期値。themeで上書き可） */
  --canvas-h: 320px;
  --col1-w: 120px;
  --col2-w: 120px;
  --col3-min: 180px;
  --row-gap: 8px;
  --col-gap: 14px;
  /* 色用（既定値）: theme-hueで上書き */
  --label-h: 40;
  --label-s: 38%;
  --label-L1: 70%;
  --label-step: 8%;
  --card-L: 86%;
  /* タイポ/装飾 */
  --h2-size: 1.2rem;
  --h2-weight: 700;
  --h2-color: #222;
  --h3-size: 1.1rem;
  --h3-weight: 500;
  --h3-color: #222;
  --p-size: 1rem;
  --p-weight: 400;
  --p-color: #222;
  --radius: 18px;
  --bg: #eee;
  --container-pad: 16px;
  /* ベース（min() 不使用） */
  width: 90%;
  max-width: 1140px;
  margin: 12px auto;
  padding: 20px var(--container-pad);
  background: var(--bg);
  font-size: 14px;
  line-height: 1.6;
  color: #233018;
  /* 表示の詰め具合プリセット */
}
.container-tree-matrix.is-dense {
  --row-gap: 6px;
  --col-gap: 10px;
  --container-pad: 12px;
  --radius: 14px;
}
.container-tree-matrix.is-relaxed {
  --row-gap: 12px;
  --col-gap: 20px;
  --container-pad: 22px;
  --radius: 22px;
}

/* リセット（必要最小限） */
.container-tree-matrix div {
  margin: 0;
  padding: 0;
  border: none;
  background: none;
}

/* 見出し・段落 */
.container-tree-matrix h1,
.container-tree-matrix h2,
.container-tree-matrix h3,
.container-tree-matrix h4,
.container-tree-matrix p {
  margin: 0;
}

.container-tree-matrix h2 {
  font-size: var(--h2-size);
  font-weight: var(--h2-weight);
  color: var(--h2-color);
}

.container-tree-matrix h3,
.container-tree-matrix h4 {
  font-size: var(--h3-size);
  font-weight: var(--h3-weight);
  color: var(--h3-color);
}

.container-tree-matrix p {
  font-size: var(--p-size);
  font-weight: var(--p-weight);
  color: var(--p-color);
}

/* タイトル */
.container-tree-matrix > header.title-panel {
  background: hsl(var(--label-h), var(--label-s), calc(var(--label-L1) + var(--label-step) - 6%));
  border-radius: var(--radius);
  text-align: center;
  padding: 10px 16px;
  margin: 0 0 calc(var(--row-gap) + 4px);
  font-weight: 700;
  font-size: 1.4rem;
  border: 1px solid #bbb;
}

/* 骨格 */
.container-tree-matrix .tree-viewport {
  display: flex;
  flex-direction: column;
  gap: var(--row-gap);
}

.container-tree-matrix .tree-viewport > .branch + .branch {
  margin-top: 16px;
}

.container-tree-matrix .branch,
.container-tree-matrix .card-stack {
  display: flex;
  flex-direction: column;
  gap: var(--row-gap);
}

/* ===== デスクトップ固定幅 ===== */
@media (min-width: 768px) {
  .container-tree-matrix .branch {
    flex-direction: row;
    align-items: stretch;
    column-gap: var(--col-gap);
    flex-wrap: nowrap; /* 折り返し防止 */
  }
  /* 1列目（固定） */
  .container-tree-matrix .branch-label {
    flex: 0 0 var(--col1-w);
    width: var(--col1-w);
    min-width: var(--col1-w);
    box-sizing: border-box;
  }
  /* 2列目（固定） */
  .container-tree-matrix .sub-branch-label {
    flex: 0 0 var(--col2-w);
    width: var(--col2-w);
    min-width: var(--col2-w);
    box-sizing: border-box;
  }
  /* 3列目（可変） */
  .container-tree-matrix .card-stack {
    flex: 1 1 auto;
    min-width: 0; /* 長文で左列を押し広げない */
  }
}
/* ラベル */
.container-tree-matrix .label-box {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  border-radius: 14px;
  flex: 0 0 auto;
}

.container-tree-matrix .branch-label,
.container-tree-matrix .sub-branch-label {
  padding: 6px 8px 6px 20px;
  overflow-wrap: anywhere;
}

.container-tree-matrix .branch-label {
  background: hsl(var(--label-h), var(--label-s), var(--label-L1));
  font-size: var(--h2-size);
  font-weight: var(--h2-weight);
  color: var(--h2-color);
}

.container-tree-matrix .sub-branch-label {
  background: hsl(var(--label-h), var(--label-s), calc(var(--label-L1) + var(--label-step)));
  font-size: var(--h3-size);
  font-weight: var(--h3-weight);
  color: var(--h3-color);
}

/* カード */
.container-tree-matrix {
  --card-pad-x:16px;
  --card-pad-y:10px;
}

.container-tree-matrix p.card-panel {
  display: block;
  background: hsl(var(--label-h), var(--label-s), var(--card-L));
  border-radius: var(--radius);
  padding: var(--card-pad-y) var(--card-pad-x) !important;
  min-width: var(--col3-min);
  box-sizing: border-box;
}

/* ===== モバイル ===== */
@media (max-width: 767px) {
  .container-tree-matrix {
    --indent-label: 20px;
    --indent-cards: 40px;
    --subgroup-gap: 18px;
  }
  .container-tree-matrix .sub-branch-label {
    margin-left: var(--indent-label) !important;
    width: calc(100% - var(--indent-label)) !important;
    min-width: 0;
    box-sizing: border-box;
    padding-left: 20px !important;
  }
  .container-tree-matrix .sub-branch-label + .card-stack {
    padding-left: var(--indent-cards) !important;
    width: calc(100% - var(--indent-cards)) !important;
    min-width: 0;
    box-sizing: border-box;
  }
  .container-tree-matrix .card-stack > .branch + .branch {
    margin-top: var(--subgroup-gap);
  }
}
/* ===== 印刷最適化（任意） ===== */
@media print {
  .container-tree-matrix {
    background: none;
    color: #111;
    outline: 1px solid #999;
  }
  .container-tree-matrix > header.title-panel,
  .container-tree-matrix .branch-label,
  .container-tree-matrix .sub-branch-label,
  .container-tree-matrix p.card-panel {
    background: none !important;
    border: 1px solid #bbb !important;
  }
}
/* tree-matrix.theme-hue.scss — 分離版・修正（レガシー安全）
   目的：色相（Hue）をクラス指定で切替。レイアウト系の指定は一切しない。
   読み込み順：layout（先） → theme-hue（後）
*/
/* 既定テーマ（必要に応じて変更） */
.container-tree-matrix {
  --label-h: 40; /* 色相 */
  --label-s: 38%; /* 彩度 */
  --label-L1: 70%; /* ラベル明度 */
  --label-step: 8%;
  --card-L: 86%; /* カード明度 */
}

/* ===================== 数値（10度刻み） ===================== */
.hue-0 {
  --label-h: 0;
}

.hue-10 {
  --label-h: 10;
}

.hue-20 {
  --label-h: 20;
}

.hue-30 {
  --label-h: 30;
}

.hue-40 {
  --label-h: 40;
}

.hue-50 {
  --label-h: 50;
}

.hue-60 {
  --label-h: 60;
}

.hue-70 {
  --label-h: 70;
}

.hue-80 {
  --label-h: 80;
}

.hue-90 {
  --label-h: 90;
}

.hue-100 {
  --label-h: 100;
}

.hue-110 {
  --label-h: 110;
}

.hue-120 {
  --label-h: 120;
}

.hue-130 {
  --label-h: 130;
}

.hue-140 {
  --label-h: 140;
}

.hue-150 {
  --label-h: 150;
}

.hue-160 {
  --label-h: 160;
}

.hue-170 {
  --label-h: 170;
}

.hue-180 {
  --label-h: 180;
}

.hue-190 {
  --label-h: 190;
}

.hue-200 {
  --label-h: 200;
}

.hue-210 {
  --label-h: 210;
}

.hue-220 {
  --label-h: 220;
}

.hue-230 {
  --label-h: 230;
}

.hue-240 {
  --label-h: 240;
}

.hue-250 {
  --label-h: 250;
}

.hue-260 {
  --label-h: 260;
}

.hue-270 {
  --label-h: 270;
}

.hue-280 {
  --label-h: 280;
}

.hue-290 {
  --label-h: 290;
}

.hue-300 {
  --label-h: 300;
}

.hue-310 {
  --label-h: 310;
}

.hue-320 {
  --label-h: 320;
}

.hue-330 {
  --label-h: 330;
}

.hue-340 {
  --label-h: 340;
}

.hue-350 {
  --label-h: 350;
}

/* ===================== 名称（約12色） ===================== */
.hue-red {
  --label-h: 0;
}

.hue-orange {
  --label-h: 30;
}

.hue-yellow {
  --label-h: 60;
}

.hue-green {
  --label-h: 120;
}

.hue-teal {
  --label-h: 150;
}

.hue-cyan {
  --label-h: 180;
}

.hue-sky {
  --label-h: 200;
}

.hue-blue {
  --label-h: 220;
}

.hue-indigo {
  --label-h: 240;
}

.hue-violet {
  --label-h: 270;
}

.hue-pink {
  --label-h: 300;
}

.hue-rose {
  --label-h: 330;
}

/* 注意：このファイルでは display / align-items / width 等は書かない（色だけを上書き） */
/*@use "_parts/tree-matrix";*/
:root {
  --pj-z: 1000;
  --pj-bg: rgba(255,255,255,.98);
  --pj-shadow: 0 6px 16px rgba(0,0,0,.16);
  --pj-radius-pill: 9999px;
  --pj-offset: 60px;
}

@media (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }
  .pj-trigger, .pj-item button {
    transition: none !important;
  }
}
html {
  scroll-padding-top: var(--pj-offset);
}

h2, [data-mokuji], [data-toc] {
  scroll-margin-top: var(--pj-offset);
}

body.pj-lock {
  overflow: hidden;
}

.pj-trigger {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: 12px;
  z-index: var(--pj-z);
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 8px;
  padding: 10px 20px;
  border-radius: var(--pj-radius-pill);
  border: 1px solid #ccc;
  cursor: pointer;
  background: #ddd;
  color: #111;
  box-shadow: var(--pj-shadow);
  font-size: 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  transition: transform 0.15s ease, background 0.2s, box-shadow 0.2s;
}
.pj-trigger:hover {
  background: #e6e6e6;
}
.pj-trigger:active {
  transform: translate(-50%, 1px) scale(0.98);
}

.pj-popup {
  position: fixed;
  z-index: var(--pj-z);
  left: 50%;
  transform: translateX(-50%);
  bottom: 84px;
  min-width: min(86vw, 680px);
  max-height: min(72vh, 720px);
  background: var(--pj-bg);
  border: 1px solid #ccc;
  border-radius: 20px;
  box-shadow: var(--pj-shadow);
  font-size: 14px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.18s ease, transform 0.18s ease;
}
.pj-popup.is-open {
  opacity: 1;
  visibility: visible;
}

.pj-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.15);
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.18s ease;
  z-index: calc(var(--pj-z) - 1);
}

.pj-popup.is-open + .pj-backdrop {
  opacity: 1;
  visibility: visible;
}

.pj-head {
  display: flex;
  align-items: center;
  padding: 6px 14px;
  background: #eee;
  border-bottom: 1px solid rgba(0, 0, 0, 0.06);
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
}

.pj-title {
  font-size: 13px;
  font-weight: 600;
  color: #111;
}

.pj-close {
  margin-left: auto;
  border: 0;
  background: transparent;
  cursor: pointer;
  width: 28px;
  height: 28px;
  border-radius: 50%;
}

.pj-body {
  max-height: min(72vh, 720px);
  overflow-y: auto;
  overflow-x: hidden;
  padding: 12px;
}

.pj-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 820px) {
  .pj-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

.pj-item button {
  all: unset;
  box-sizing: border-box;
  display: block;
  width: 100%;
  padding: 10px 18px;
  border-radius: var(--pj-radius-pill);
  border: 2px solid transparent;
  background: #fff;
  font-size: 14px;
  line-height: 1.4;
  font-weight: 500;
  cursor: pointer;
  text-align: left;
  min-height: 40px;
  transition: background 0.2s, border-color 0.2s, box-shadow 0.2s;
  box-shadow: inset 0 0 0 1px #ccc;
}
.pj-item button:hover {
  background: #f7f7f7;
  border-color: #999;
}
.pj-item button:focus {
  outline: none;
  border-color: #aaa;
  box-shadow: 0 0 0 2px rgba(170, 170, 170, 0.4);
}

.pj-item[aria-current=true] button {
  border: 2px solid #aaa;
  background: #f2f2f2;
}

/* 主語: 目次ブロック（.pj-toc）
   目的語: レイアウト（スマホ=縦1列、タブレット=横3列、PC=横4列、中央寄せ） */
.pj-toc {
  margin: 1rem 0;
  padding: 0.4rem 0.4rem;
  /*border: 1px solid #ddd;*/
  border-radius: 6px;
  background: #fff;
}
.pj-toc ul {
  list-style: none;
  margin: 0 auto;
  padding: 0;
  max-width: 1024px;
  display: grid;
  grid-template-columns: 1fr;
  gap: 0.5rem 1rem;
  justify-items: center;
}
@media (min-width: 768px) {
  .pj-toc ul {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media (min-width: 1024px) {
  .pj-toc ul {
    grid-template-columns: repeat(4, 1fr);
  }
}
.pj-toc li a {
  display: block;
  padding: 0.1rem 0.2rem;
  text-decoration: none;
  font-weight: 400;
  line-height: 1.4;
}
.pj-toc li a:hover {
  color: #222;
  text-decoration: underline;
}
.pj-toc li[aria-current=true] a {
  text-decoration: underline;
}

/*@end*/
/*@group typography*/
/* @group base font-family etc */
/*standard font-size for using "rem"*/
/*@group font-size Control with @media */
html {
  /*font-size: 100%; */
  /*font-size: 82%;*/
  font-size: 92%;
}

@media (min-width: 768px) {
  html {
    /*font-size: 93.75%;*/ /* タブレットでは15px */
    font-size: 90%;
  }
}
@media (min-width: 1024px) {
  html {
    /*font-size: 87.5%; */ /* PCでは14px */
    font-size: 87.5%;
  }
}
/*@end html*/
/*@group body , p */
body,
p,
.p {
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.05em;
  line-height: 1.6;
}

body, p, .p {
  line-height: 1.6;
  padding-top: 0.4rem;
  padding-bottom: 2rem;
  margin: 0;
  border: none;
  /*word-break: break-all;*/
  word-wrap: break-word;
  /*http://tamasally.hatenablog.com/entry/2014/03/13/005428*/
}

/*@end*/
/*@group h(x) */
h1,
h2,
h3,
h4,
h5,
.h1,
.h2,
.h3,
.h4,
.h5 {
  margin-top: 0.6rem;
  margin-bottom: 0.6rem;
  line-height: 1.6;
}

/*h1,.h1 {font-weight: 700;}
h2,.h2 {font-weight: 700;}
h3,.h3 {font-weight: 600;}*/
h1,
.h1 {
  font-size: 1.6rem;
}

h2,
.h2 {
  font-size: 1.45rem;
}

h3,
.h3 {
  font-size: 1.25rem;
}

h4,
.h4 {
  font-size: 1.15rem;
}

h5,
.h5 {
  font-size: 1.05rem;
}

/*@end*/
/*@group li*/
li {
  list-style-type: none;
}

/* @end */
h1 span, h2 span, h3 span, h4 span, p span {
  font-size: 0.8em;
  padding: 0.6em;
}

/*@group eu*/
.eu {
  font-family: "Crimson Text", serif;
  letter-spacing: 0.07em;
  line-height: 1.1;
}

h1.eu, h2.eu, h3.eu, h4.eu, p.eu, span.eu div.eu {
  font-size: 32px;
  margin-top: 0.5rem;
  margin-bottom: 1rem;
  padding: 5px;
  font-weight: 200;
}

/*@end*/
/*@group 装飾的なもの　*/
h2 span.number, span.number {
  display: inline-flex;
  justify-content: center; /* 横方向中央 */
  align-items: center; /* 縦方向中央 */
  width: 1.5em;
  height: 1.5em;
  border-radius: 50%;
  background-color: #888;
  color: #fff;
  font-weight: bold;
  font-size: 1.2em;
  margin: 0 10px 0 0;
  font-family: "Crimson Text", serif;
  font-weight: 600;
  font-style: normal;
  padding: 0 0 0 3px; /* ごく微妙に右寄せ */
}

span.hl,
span.highlighter {
  font-size: inherit;
  background: linear-gradient(#ffeabb 0 0) no-repeat;
  background-size: 100% 0.4em; /* 下線の太さ */
  background-position: 0 80%; /* テキスト下端 */
}

.lead {
  /*h1などのタグ内にspan.leadを設定し、リードテキスト*/
  color: #333;
  line-height: 1.6 !important;
  font-size: 1.1rem;
  font-weight: 400;
  border: none;
  border-radius: 0;
  background: none;
}

/*@end*/
.mark {
  padding: 5px 20px 0px 10px;
  width: 100%;
  background-color: transparent;
  border-bottom: 1px solid silver;
}

/*@end*/
/*@group css for this site only*/
/*@use "_site_mtx/foot";*/
/*@group .pill*/
.h2.pill,
h2.pill,
div.pill h2,
section.pill h2,
section.pill-dark h2 {
  text-align: center;
  padding: 6px 2px;
  margin: 1.4em 0 0.4em 0;
  /*border: 1px solid #ddd;*/
  border-radius: 99px;
}

span.pill,
p.pill,
h4.pill,
.h3.pill,
h3.pill,
div.pill h3,
section.pill h3,
section.pill-dark h3 {
  padding: 2px 24px;
  margin: 0.6em 0 0.4em 0;
  /*border: 1px solid #ddd;*/
  border-radius: 99px;
}

div.pill h4,
section.pill h4 {
  padding: 2px 0 2px 2px;
  margin: 1.6em 0 0.4em 0;
  /*border: 1px solid #ddd;*/
  /*border-radius: 99px;*/
  border-bottom: 1px solid #ccc;
  line-height: 1.8;
}

section.pill-dark h2 {
  background-color: #666;
  color: white;
}

section.pill-dark h3 {
  background-color: #888;
  color: white;
}

section.pill h2 {
  background-color: #eee;
  color: #222;
  /*border: 1px solid #666;*/
}

section.pill h3 {
  background-color: #fff;
  color: #444;
  /*border: 1px solid #aaa;*/
}

div.pill h2,
div.pill h3,
section.pill h2,
section.pill h3,
h2.pill,
h3.pill {
  border: 1px solid #bbb;
}

/*@end*/
/*@group .basic*/
.basic h2,
.basic h3 {
  text-align: left;
  border: none;
  border-radius: 0;
  color: #222;
  background: none;
  padding-left: 0;
  margin-left: 0;
}

/*@end .basic */
/* @group SECTION common */
/*section for scroll button 
between sections*/
section.scroll-section {
  text-align: center;
  padding-top: 10px;
  padding-bottom: 10px;
}

section,
section.standard {
  padding-top: 40px;
  padding-bottom: 40px;
  border-bottom: 1px dotted hsl(0, 0%, 50%);
  /*padding: 40px 20px;*/
}

/*section#intro {
	padding-top: 20px;
	padding-bottom: 20px;
	border-bottom: 1px dotted hsl(0, 0%, 50%);
}*/
section#head {
  /*head-page.html*/
}

/*I guess this "content-section" is overwrite BS4 or based on grayscale.css
 Im not sure.*/
.content-section {
  padding-top: 20px;
  padding-bottom: 20px;
}

/*mtx*/
.border-section {
  background: #fff;
  padding-top: 10px;
  padding-bottom: 5px;
  border-bottom-style: none;
}

/*"section#intro-section" is used for head part of each page with background image.*/
/*indivisual image is set by <style>tag before page head on each page.*/
/*examle:
background-image: url(https://xxxxx.com/img/xxxxx.jpg);
css setting of bg image is needed before intro-section*/
.intro-section,
section#intro-section {
  background-size: cover;
  position: relative;
  /*height: 100%;*/
  border: none;
  opacity: 0.8;
  background-repeat: no-repeat;
  background-position: center center;
}

.intro-section .white-area,
section#intro-section .white-area {
  /*text area in the class "row"*/
  /*this css setting is to avoid influence of opacity value of bg image. */
  /*rgb 256 256 256" means white. The end number is the value of bg color opacity */
  background-color: rgba(255, 255, 255, 0.6);
}

/*CSS for buttons that will show when scrolling*/
/*1)buttons that show after scrolling
for bottom navigation menu

/* .scroll_show -------------------------------------*/
ul.scroll_show {
  position: fixed;
  right: 10px;
  bottom: 40px;
  padding: 0px;
  width: 360px;
  list-style: none;
  z-index: 1;
}

/*bottom navigation menu*/
ul.scroll_show li a {
  display: float;
  width: 40px;
  height: 40px;
  font-size: 14px;
  font-weight: 500;
  padding-top: 10px;
  padding-bottom: 14px;
  color: black;
  text-align: center;
  border-radius: 2px;
  display: block;
  float: right;
  margin: 0.5px;
  list-style: none;
}

/*ul.scroll_show li a.wide{
	width: 60px;
}  */
ul.scroll_show li.page-top a {
  background: gray;
  color: white;
  border-radius: 50%;
}

ul.scroll_show li.page-top .fa {
  color: white;
}

ul.scroll_show li.page-top a:hover {
  background: #ddd;
  transition: 0.5s;
  -webkit-transition: 0.5s;
}

ul.scroll_show li a:hover {
  text-decoration: none;
}

ul.scroll_show li a {
  background: rgba(224, 223, 223, 0.6);
  border: 1px solid #c9c9c9;
}

ul.scroll_show li a:hover,
ul.scroll_show li.fa a:hover,
ul.scroll_show li.far a:hover {
  background: rgba(255, 255, 255, 0.8);
  transition: 0.5s;
  -webkit-transition: 0.5s;
  border: 1px solid #dedede;
}

ul.scroll_show li .fa,
ul.scroll_show li .far {
  font-size: 20px;
  color: gray;
} /* .scroll_show -------------------------------------*/
/*@end*/
/*@group for mtx pages*/
/*@use "_site_mtx/text";*/
/* @group .in-ol */
/*bootstrapでレイアウトが崩れないようにグリッド要素に枠線*/
.in-ol {
  position: relative;
  background-color: none;
  border-radius: 12px;
  overflow: hidden;
  z-index: 0;
}

.in-ol::before {
  content: "";
  position: absolute;
  top: 6px;
  left: 6px;
  right: 6px;
  bottom: 6px;
  /*background-color: #eee;*/
  border: 1px solid #ddd;
  border-radius: 8px;
  box-sizing: border-box;
  pointer-events: none;
  z-index: -1;
}

.in-ol {
  padding: 2em;
}

@media (min-width: 768px) {
  .in-ol {
    padding: 1em;
  }
}
@media (min-width: 1024px) {
  .in-ol {
    padding: 1.4em;
  }
}
/*@end in-ol */
/*@group in-bg-(color)*/
/* 色別クラス：擬似要素に適用する */
.in-bg-white::before {
  background-color: white !important;
}

.in-bg-white5::before {
  background-color: rgba(255, 255, 255, 0.5) !important;
}

.in-ol.bg-gray::before {
  background-color: #e8e8e8 !important;
}

.in-ol.bg-blue::before {
  background-color: #e0f0ff !important;
}

.in-ol.bg-red::before {
  background-color: #ffe0e0 !important;
}

.in-ol.bg-green::before {
  background-color: #e0ffe0 !important;
}

.in-bg-sky::before {
  background-color: rgba(64, 116, 128, 0.2) !important;
}

.in-bg-sea::before {
  background-color: rgba(64, 91, 128, 0.2) !important;
}

.in-bg-grape::before {
  background-color: rgba(183, 160, 213, 0.2) !important;
}

.in-bg-orange::before {
  background-color: rgba(254, 200, 200, 0.2) !important;
}

/*@end*/
.title-section {
  background: #ccd4de;
  padding: 40px 0;
}

.title-section h2, .title-section p.h2 {
  color: #222;
  text-align: left;
  font-size: 24px;
  background: rgba(255, 255, 255, 0.35);
  border: none;
  border-radius: 0;
  font-weight: 500;
  padding-left: 20px;
}

.title-section h3 {
  color: #222;
  text-align: left;
  font-size: 16px;
  background: rgba(255, 255, 255, 0.2);
  padding: 4px 20px;
  font-weight: 300;
  border: none;
  border-radius: 0;
}

.title-section p {
  font-size: 15px;
  font-weight: 400;
  border: none;
  display: block;
  padding: 10px 20px !important;
  background: rgba(255, 255, 255, 0.1);
}

/* @group SECTION sitemap */
/*SECTION sitemap*/
section#footer-sitemap, section#footer {
  background-color: hsl(0, 7%, 94%);
}

section#footer a, #sitemap a {
  color: #333;
}

#foot hr {
  margin: 6px 0;
  padding: 0;
  border: 1px solid #eee;
}

div#sitemap div div {
  margin: 0.2em 0em;
}

div#sitemap div div a {
  font-size: 0.9rem;
  border-left: 0.5px solid #ddd;
  border-right: 0.5px solid #ddd;
}

div#sitemap div div a {
  padding: 0.3em 0.6em;
  display: inline-flex;
  width: 100%;
}

div#sitemap div div a:hover {
  background-color: #ddd;
  text-decoration: none;
  cursor: pointer;
}

section#footer div, section#footer .fa {
  color: #222;
  opacity: 1;
}

/*section#footer {
	/*background-image: url(img_bg/paper_00108.jpg);*!/
	background-size: cover;
	position: relative;
	/*	height: 100%;*!/
	opacity: 1;
}*/
/*section#footer::before, bg-dark::before {
	background-color: rgba(20, 20, 20, .1);
	/* specify its area *!/
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	content: ' ';
}*/
/*@end*/
/*@group for top page*/
/*TOP page*/
section#welcome,
section#support,
section#marketing,
section#branding {
  border: none !important;
}

section#about-mtx-top-page,
section#intro-mtx-top-page {
  background: #faf9f8;
  border: none;
}

section#support {
  background: #faf9f8;
  border: none;
}

section#marketing {
  background: #f8faf9;
}

section#branding {
  background: #faf9f8;
}

.box-ol {
  background: white;
}

section#intro-mtx-top-page {
  padding: 1em 0;
  color: #222;
}
section#intro-mtx-top-page h2,
section#intro-mtx-top-page h3 {
  margin: 0;
  padding: 0;
  border: none;
}

section#intro-mtx-top-page > div > div > div {
  margin: 0;
  padding: 0.4em 0.8em;
}
section#intro-mtx-top-page > div > div > div > div {
  height: 100%;
  width: 100%;
  padding: 0.4em 1.6em;
  border: 1px solid #ccc;
  border-radius: 1em;
}
section#intro-mtx-top-page > div > div > div .no-border {
  border: none !important;
}
section#intro-mtx-top-page > div > div > div div img {
  width: 100%;
  height: auto;
  object-fit: contain;
  /* またはcover/noneなど目的に応じて */
}

#one-stop > div {
  background-color: #999;
  color: #fff;
}
#one-stop h2 {
  color: white;
}
#one-stop h2 span {
  border-radius: 1em;
  border: 1px solid white;
}
#one-stop * {
  color: white;
}

#intro-grid-inner > div > div {
  background-color: white;
}

#intro-grid-inner h3 {
  font-size: 1.1em;
}
#intro-grid-inner span {
  font-size: 0.85em;
}

@media (max-width: 576px) {
  #intro-grid-inner h3 {
    font-size: 0.95em;
  }
  #intro-grid-inner span {
    font-size: 0.8em;
  }
}
/*@end*/
/*----------COLOR----------*/
body {
  color: #000;
}

a {
  color: gray;
}

.eu {
  color: #ababab;
}

body {
  padding-top: 60px;
}

/*BootStrap5のCSSスムーススクロールを切り、JS-scrollを優先*/
@media (prefers-reduced-motion: no-preference) {
  html {
    scroll-behavior: auto !important;
  }
}
