@charset "UTF-8";

/* ==========================================================
 html5 elements
========================================================== */
article,
aside,
figure,
figcaption,
footer,
header,
nav,
section {
  display: block;
}
/* ==========================================================
 reseting
========================================================== */
body {
  line-height: 1.7;
  color: #222;
  font-size: 16px;
  -webkit-text-size-adjust: 100%;
  /* height: 100%; */
  /* position: relative;
  padding-bottom: 114px;
  min-height: 100vh; */
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
*:hover,
*:active,
*:focus,
*:hover *,
*:active *,
*:focus * {
  opacity: 1 !important;
  text-decoration: none !important;
}
a:hover {
  text-decoration: none;
}

@media screen and (max-width: 768px) {
  body {
    font-size: 14px;
  }
  *:hover,
  *:active,
  *:focus,
  *:hover *,
  *:active *,
  *:focus * {
    opacity: 1 !important;
    text-decoration: none !important;
  }
}
body,
input,
textarea,
select,
button {
  font-family: "Noto Sans TC", "PingFang TC", "Hiragino Sans CNS",
    "Microsoft JhengHei", sans-serif;
  /* font-family: "Arial", "メイリオ", "ヒラギノ角ゴ Pro",
    "Hiragino Kaku Gothic Pro", "Meiryo", sans-serif; */
  /* font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ",
    "Meiryo", sans-serif; */
  /* 明朝フォント
  font-family: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", YuMincho, serif;*/
}
.fJP {
  font-family: "Arial", "メイリオ", "ヒラギノ角ゴ Pro",
    "Hiragino Kaku Gothic Pro", "Meiryo", sans-serif;
  /* font-family: "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ",
    "Meiryo", sans-serif; */
  /* 明朝フォント
  font-family: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝体", "Yu Mincho", YuMincho, serif;*/
}

body,
div,
pre,
p,
blockquote,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
form,
fieldset,
th,
td,
button,
figure,
figcaption {
  margin: 0;
  padding: 0;
}
input,
textarea {
  margin: 0;
  font-size: 100%;
}
input,
textarea,
select {
  /*-webkit-appearance: none;*/
}
textarea {
  resize: none;
}
button {
  border: none;
  overflow: visible;
  background: none;
  vertical-align: top;
  font-size: 100%;
  color: inherit;
  cursor: pointer;
  -webkit-appearance: none;
}
label {
  cursor: pointer;
}
table {
  font-size: 16px;
  width: 100%;
  text-align: left;
  border-spacing: 0;
  border: 1px solid #EEEEEE;
}

th,
td {
  padding: 15px 15px;
}

tr th {
  font-weight: bold;
  text-align: left;
  background: #EEEEEE;
  border-bottom: 1px solid #EEEEEE;
}

tr td {
  background: #fff;
  text-align: left;
  border-bottom: 1px solid #EEEEEE;
}

@media screen and (max-width: 480px) {
  tr th {
    width: 100% !important;
    display: block;
    text-align: left;
  }

  tr td {
    width: 100%;
    display: block;
  }

}


fieldset,
img {
  border: 0;
}
img {
  height: auto;
  vertical-align: top;
}
address,
caption,
code,
em,
th {
  font-style: normal;
  font-weight: normal;
}
ol,
ul {
  list-style: none;
}
caption,
th {
  text-align: left;
}
h1,
h2,
h3,
h4,
h5,
h6,
strong,
em {
  font-size: 100%;
  font-weight: normal;
}
a,
input {
  /* outline: none; -webkit-tap-highlight-color:rgba(0,0,0,0);*/
}
sup,
sub {
  font-size: 63%;
}
sup {
  vertical-align: top;
}
sub {
  vertical-align: baseline;
}
* {
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  outline-color: transparent;
}
/* 追加 */
h1 {
  color: #222;
  text-align: center;
  margin-right: 40px;
  /* margin: 0 auto 0.5em; */

  /* sp/h1 */
  font-family: "tt-zhihei-chs-variable", sans-serif;
  font-variation-settings: "wght" 600;
  font-size: 1.625rem;
  font-style: normal;
  /* font-weight: 600; */
  line-height: 120%; /* 1.95rem */
}

@media screen and (max-width: 480px) {
  h1 {
    margin-right: 0px;
    margin-bottom: 10px;
 }
}

h2 {
  /* sp/h2 */
  font-size: 1.5rem;
  font-style: normal;
  font-weight: 700;
  line-height: 130%; /* 1.95rem */
}
h3 {
  text-align: center;
  font-size: 1.125rem;
  font-style: normal;
  font-weight: 600;
  line-height: 150%;
}
h4 {
  /* sp/h4 */
  font-size: 1rem;
  font-style: normal;
  /* font-weight: 700; */
  line-height: 140%; /* 1.4rem */
}
.fWh {
  color: #fff;
}
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
}
#contents {
  width: 100%;
  margin: 0 auto;
}


}

/* //追加 */
/* ==========================================================
 base Link
========================================================== */
a {
  color: #222;
  text-decoration: none;
}

a:visited {
  text-decoration: none;
}
a:hover,
a:active,
a:focus {
  text-decoration: none;
}
/* ==========================================================
 clearfix
========================================================== */
.header-in:before,
.header-in:after,
.footer-in:before,
.footer-in:after,
.grid-cmn:before,
.grid-cmn:after,
.grid-hero:before,
.grid-hero:after,
.grid-top:before,
.grid-top:after,
.sec-cmn-in:before,
.sec-cmn-in:after,
.clearfix:before,
.clearfix:after,
.contents:before,
.contents:after {
  content: "";
  display: table;
}
.header-in:after,
.footer-in:after,
.grid-cmn:after,
.grid-hero:after,
.grid-top:after,
.sec-cmn-in:after,
.clearfix:after,
.contents:after {
  clear: both;
}
/* For IE 6/7
---------------------------------------------------------- */
.header-in,
.footer-in,
.grid-cmn,
.grid-hero,
.grid-top,
.clearfix,
.sec-cmn-in,
.contents {
  *zoom: 1;
}
/* ==========================================================
 layout
========================================================== */
html {
  overflow-y: scroll;
}
body {
  min-width: 1210px;
  text-align: center;
}

@media screen and (max-width: 768px) {
  body {
    min-width: 2px;
  }
}
/* ==========================================================
 wrapper
========================================================== */
.wrapper {
  width: 100%;
  /* padding: 152px 0 0; */
}
.fixed .wrapper {
  /* padding: 62px 0 0; */
}
@media screen and (max-width: 768px) {
  .wrapper,
  .fixed .wrapper {
    /* padding: 55px 0 0; */
  }
}
/* ==========================================================
 header
========================================================== */
.header {
  /* position: fixed; */
  top: 0;
  width: 100%;
  z-index: 9999;
  background-color: #fff;
  /* height: 40px; */
  flex-shrink: 0;
  border-bottom: 1px solid #ddd;
  margin-bottom: 30px;
}
.header ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: left;
  -ms-flex-pack: left;
  justify-content: left;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  padding: 0.5em 1em;
}
.header ul li {
  width: 180px;
}
@media screen and (min-width: 1024px) {
  .header ul {
    padding: 8px 0em;
    max-width: 1080px;
    margin: 0 auto;
  }
  .header ul li {
    width: 200px;
  }
}
@media screen and (max-width: 768px) {
  .header {
    margin-bottom: 24px;
    /* height: 55px; */
    /* -webkit-box-shadow: 0 9px 10px rgba(40, 40, 40, 0.12);
    box-shadow: 0 9px 10px rgba(40, 40, 40, 0.12); */
  }
}

/* SP Close Button
---------------------------------------------------------- */

/* SP Background Cover
---------------------------------------------------------- */

/* ==========================================================
 Menu mega
========================================================== */

/* ==========================================================
 Fixed Header
========================================================== */

/* area-bnr
---------------------------------------------------------- */
@media screen and (max-width: 768px) {
}

/* btn-sub
---------------------------------------------------------- */
@media screen and (max-width: 768px) {
}

@media screen and (max-width: 768px) {
}
/* .sp-lnav-ttl
---------------------------------------------------------- */
@media screen and (max-width: 768px) {
}
/* ==========================================================
 nav-breadcrumb
========================================================== */

/* ==========================================================
 contents
========================================================== */
.contents {
  width: 1200px;
  margin: 0 auto;
  padding: 50px 10px 70px;
  text-align: left;
}

@media screen and (max-width: 768px) {
  .contents {
    width: 100%;
    padding: 0;
  }
}

/* ==========================================================
 grid
========================================================== */

/* ==========================================================
 area
========================================================== */
/* area-cmn
---------------------------------------------------------- */

/* ==========================================================
 section
========================================================== */

/* ==========================================================
 box
========================================================== */

/* ==========================================================
 title
========================================================== */

/* ==========================================================
 text
========================================================== */

/* txt-size
---------------------------------------------------------- */
.txt-b {
  font-size: 18px;
}
.txt-l {
  font-size: 16px;
}
.txt-m {
  font-size: 14px;
}
.txt-s {
  font-size: 12px;
}
.txt-xs {
  font-size: 10px;
}
/* txt-color
---------------------------------------------------------- */

/* ==========================================================
 list
========================================================== */

/* list-number
---------------------------------------------------------- */

/* ==========================================================
 table
========================================================== */

/* ==========================================================
 Tabs
========================================================== */

@media screen and (max-width: 768px) {
}
/* ==========================================================
 button
========================================================== */

/* ==========================================================
 rwd switch
========================================================== */
/* pc
---------------------------------------------------------- */
.only-pc {
}
.only-sp,
.no-pc {
  display: none !important;
}
.no-sp {
}
table.only-pc {
  display: table !important;
}
table.only-sp {
  display: none !important;
}
/* sp
---------------------------------------------------------- */
@media screen and (max-width: 768px) {
  .only-pc,
  .no-sp {
    display: none !important;
  }
  .only-sp,
  .no-pc {
    display: block !important;
  }
  img.only-sp,
  img.no-pc {
    display: inline-block !important;
  }
  table.only-sp {
    display: table !important;
  }
  table.only-pc {
    display: none !important;
  }
  tr.only-sp,
  tr.no-pc {
    display: table-row !important;
  }
}
/* ==========================================================
 tool
========================================================== */

/* pagination
---------------------------------------------------------- */

/* googleカスタム検索
---------------------------------------------------------- */
/* .search-box-pc {
}

/* ==========================================================
 footer
========================================================== */

footer {
  /* position: sticky; */
  padding: 2.7em 0;
  background-color: #fff;
  /* background-color: rgba(255, 255, 255, 0.7); */
  color: #222;
  /* top: 100vh; */
  /* width: 100%;
  position: absolute;
  left: 0;
  bottom: 0; */
  margin-top: auto;
}
footer img {
  width: 4em;
  margin: 0 auto 1.4em;
}
footer ul {
  width: 80%;
  margin: 0 auto 1em;
  -ms-flex-pack: distribute;
  justify-content: space-around !important;
  max-width: 450px;
  line-height: 2.5;
}
footer ul li {
  margin: 0 0.8rem 0.2rem;
}
footer .copylight {
  font-size: 70%;
  color: #bbbbbb;
}
footer a {
  color: #222;
}

.backBtn {
  margin: 0 auto 5em;
}
.backBtn a {
  padding: 0.5rem 1.5rem;
  border-radius: 6px;
  background: #E74A4A;
  /* background: linear-gradient(90deg, #d1c082 0%, #b7920e 100%); */
  color: #fff;
  font-weight: 600;
  font-size: 0.8rem;
  outline: 1px solid rgb(255, 255, 255);
  outline-offset: -2px;
  letter-spacing: 0.02rem;
}
@media screen and (min-width: 1024px) {
  footer {
    padding: 4.7em 0;
  }
  .backBtn {
    margin: 0 auto 8em;
  }
}
