@charset "UTF-8";
/* CSS Document */
/* ---------------------
  - common
  - header
  - gNavi
  - 
  - footer
  - page_top
  - @media
--------------------- */
/* ==========================================
  common
========================================== */
html {
  font-size: 62.5%;
}
body {
  font-size: 1.5rem;
  font-weight: inherit;
}
body, html {
  color: #3e3e3e;
  font-weight: 300;
  height: 100%;
  margin: 0;
  padding: 0;
  letter-spacing: 0.08em;
  line-height: 1.5;
  font-family: "Noto Sans JP", "Jost", sans-serif;
  overflow-wrap: break-word;
  word-wrap: break-word;
}
.material-symbols-sharp, .material-symbols-rounded {
  vertical-align: middle;
}
* {
  box-sizing: border-box;
}
/* for modern brouser */
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
/* IE7,MacIE5 */
.clearfix {
  display: inline-block;
}
/* WinIE6 below, Exclude MacIE5 \*/
* html .clearfix {
  height: 1%;
}
.clearfix {
  display: block;
}
/**/
h1, h2, h3, h4, h5, dt, dd {
  font-weight: inherit;
  line-height: inherit;
  letter-spacing: 0.1em;
  padding: 0;
  margin: 0;
}
p {
  letter-spacing: 0.15em;
  line-height: inherit;
  padding: 0;
  margin: 0;
}
ul, ol {
  list-style: none;
  margin: 0;
  padding: 0;
}
dl, dt, dd {
  margin: 0;
  padding: 0;
}
a {
  color: inherit;
  text-decoration: none;
}
a:hover {
  opacity: 0.8;
}
img {
  max-width: 100%;
  height: auto;
}
hr {
  height: 1px;
  background-color: #e5e5e5;
  border: none;
  color: #e5e5e5;
  margin-top: 60px;
}
table {
  background: #fff;
  border-collapse: collapse;
  border-spacing: 0;
  width: 100%;
  margin: 0;
}
th, td {
  border-collapse: collapse;
  border: 1px solid #e1e2e2;
  font-weight: 300;
  line-height: 2;
  text-align: left;
  overflow-wrap: break-word;
  word-wrap: break-word;
  padding: 20px;
}
th {
  background: #f1f1f1;
  text-align: center;
  text-align: left;
}
td.middle {
  vertical-align: middle;
}
.table-scroll {
  overflow: auto; /*スクロールさせる*/
  white-space: nowrap; /*文字の折り返しを禁止*/
}
.table-scroll::-webkit-scrollbar {
  height: 5px;
}
.table-scroll::-webkit-scrollbar-track {
  background: #333;
}
.table-scroll::-webkit-scrollbar-thumb {
  background: #999;
}
/*///// ul li /////*/
/*///// margin padding /////*/
.pdt10 {
  padding-top: 10px;
}
.pdt20 {
  padding-top: 20px;
}
.pdt30 {
  padding-top: 30px;
}
.pdt50 {
  padding-top: 50px;
}
.pdt60 {
  padding-top: 60px;
}
.pdt80 {
  padding-top: 80px;
}
.pdt100 {
  padding-top: 100px;
}
.pdt120 {
  padding-top: 120px;
}
.pdb10 {
  padding-bottom: 10px;
}
.pdb20 {
  padding-bottom: 20px;
}
.pdb30 {
  padding-bottom: 30px;
}
.pdb50 {
  padding-bottom: 50px;
}
.pdb60 {
  padding-bottom: 60px;
}
.pd60 {
  padding: 60px;
}
.mg20 {
  margin: 20px;
}
.mg30 {
  margin: 30px;
}
.mgt10 {
  margin-top: 10px;
}
.mgt20 {
  margin-top: 20px;
}
.mgt30 {
  margin-top: 30px;
}
.mgt50 {
  margin-top: 50px;
}
.mgt60 {
  margin-top: 60px;
}
.mgt80 {
  margin-top: 80px;
}
.mgt100 {
  margin-top: 100px;
}
.mgt120 {
  margin-top: 120px;
}
.mgt200 {
  margin-top: 200px;
}
.mgb10 {
  margin-bottom: 10px;
}
.mgb20 {
  margin-bottom: 20px;
}
.mgb30 {
  margin-bottom: 30px;
}
.mgb50 {
  margin-bottom: 50px;
}
.mgb60 {
  margin-bottom: 60px;
}
.mgb120 {
  margin-bottom: 120px;
}
/*///// ul li /////*/
.list_disc {
  list-style: disc outside;
  margin: 0 20px;
}
.list_disc li {
  line-height: 2.6;
}
/*///// background /////*/
/*///// button /////*/
.btn_txt {
  display: inline-block;
  border-bottom: 1px dotted #555352;
  padding-bottom: 2px;
}
/*///// font /////*/
.bold {
  font-weight: 700;
}
.f14 {
  font-size: 14px;
}
/*///// color /////*/
.red {
  color: #FF0004;
}
/*///// col /////*/
.col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.col-start {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: flex-start;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.col-center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.col-end {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: flex-end;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.col-2 {
  width: 46%;
  margin: 0 2%;
}
/*///// align /////*/
.txt_left {
  text-align: left;
}
.txt_center {
  text-align: center;
}
.txt_right {
  text-align: right;
}
.txt_middle {
  vertical-align: middle;
}
/*///// none /////*/
.pc_none {
  display: none;
}
.sp_none {
  display: block;
}
@media screen and (max-width: 780px) {}
@media screen and (max-width: 500px) {
  .pc_none {
    display: block;
  }
  .sp_none {
    display: none;
  }
th, td {
	display: block;
	width: 100%;
}
}
/* ==========================================
  page_top
========================================== */
#page_top {
  width: 60px;
  height: 60px;
  position: fixed;
  right: 5px;
  bottom: 10px;
  border: 1px solid #4c4c4c;
	background: rgba(255,255,255,0.5);
  border-radius: 50%;
}
#page_top a {
  position: relative;
  display: block;
  width: 60px;
  height: 60px;
}
#page_top a::before {
  font-family: "Material Symbols Sharp"; /* CDNで読み込んだものを指定 */
  content: "\e316"; /* Code Point */
  font-size: 40px;
  color: #4c4c4c;
  position: absolute;
  width: 60px;
  height: 60px;
  top: 0;
  bottom: 0;
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
}
#page_top .material-symbols-outlined {
  font-variation-settings:
    'FILL'0, 'wght'400, 'GRAD'0, 'opsz'24
}
@media screen and (max-width: 480px) {
  #page_top {
    bottom: 40px;
  }
}