@charset "utf-8";
* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}
html {
  font-size: 62.5%;
  height: 100%;
}
body {
  width: 100%;
  min-height: 100%;
  font-size: 16px;
  font-size: 1.6rem;
  font-weight: 400;
  font-style: normal;
  font-family: "Open Sans", "Noto Sans JP", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", "Meiryo", sans-serif;
  line-height: 1.8;
  font-feature-settings: "palt";
  letter-spacing: 1px;
  color: var(--text);
  background-color: #fff;
  margin: 0;
  padding: 0;
  position: relative;
}
body.is-open {
  height: 100%;
  overflow: hidden;
}
@media all and (-ms-high-contrast: none) {
  body {
    font-style: normal;
  }
}
h1, h2, h3, h4, h5, h6, p, ul, ol, dl {
  font-size: 100%;
  margin: 0;
  padding: 0;
  list-style-type: none;
}
p, ul, ol, dl {
  text-align: justify;
  word-break: break-all;
  text-justify: inter-ideograph;
  text-justify: inter-character;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, nav, section, summary {
  display: block;
}
section p, section ul, section ol, section dl, section table, article p, article ul, article ol, article dl, article table, div p, div ul, div ol, div dl, div table {
  margin-bottom: 15px;
}
section p:last-child, section ul:last-child, section ol:last-child, section dl:last-child, section table:last-child, article p:last-child, article ul:last-child, article ol:last-child, article dl:last-child, article table:last-child, div p:last-child, div ul:last-child, div ol:last-child, div dl:last-child, div table:last-child, dd:last-of-type, li:last-of-type {
  margin-bottom: 0;
}
a {
  font-weight: 500;
  color: var(--textlink);
  text-decoration: none;
  transition: all 0.5s ease 0s;
  cursor: pointer;
}
a:hover {
  color: var(--primary);
}
a img {
  border: medium none;
  margin: 0;
  padding: 0;
  transition: all 0.3s;
}
a img:hover {
  opacity: .7;
}
img {
  width: 100%;
  max-width: 100%;
  height: auto;
}
table {
  border-spacing: 0;
  margin: 0;
  padding: 0;
}
figure {
  margin: 0;
}
figure img {
  width: 100%;
}
input, textarea, select, button {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}
input:focus {
  outline: none;
}
input:focus::after {
  outline: none;
}
/*  color  */
.red {
  color: #f03a3a !important;
  font-weight: 500;
}
.blue {
  color: #2ea7e0 !important;
}
.purple {
  color: #006699 !important;
}
.gry01 {
  color: #666666 !important;
}
.bk {
  color: #000 !important;
}
.pink {
  color: #F6C !important;
}
.orange {
  color: #ff5151 !important;
}
.yellow {
  color: #FF0 !important;
}
:root{
  --primary: #EAA332;
  --colorBg1: #EFF4F9;
  --colorBg2: #DFE2E5;
  --colorBg3: #EFE7D8;
  --text: #3D4451;
  --textlink: #347DA5;
  --link1: #4A3A25;
  --border1: #6E7D96;
  --border2: #8C9BAD;
  --sub1: #ED6B1F;
  --sub2: #F9EEB3;
  --sub3: #FFFCE4;
}
.opa {
  transition: 0.3s;
}
.opa:hover {
  opacity: 0.6;
}
.f12 {
  font-size: 1.2rem;
}
.f13 {
  font-size: 1.3rem;
}
.f14 {
  font-size: 1.4rem;
}
.f15 {
  font-size: 1.5rem;
}
.f16 {
  font-size: 1.6rem;
}
.f18 {
  font-size: 1.8rem;
}
.f20 {
  font-size: 2.0rem;
}
.f22 {
  font-size: 2.2rem;
}
.f24 {
  font-size: 2.4rem;
}
.f25 {
  font-size: 2.5rem;
}
.t_l {
  text-align: left !important;
}
.t_r {
  text-align: right !important;
}
.t_c {
  text-align: center !important;
}
.fw4 {
  font-weight: 400;
}
.fw5 {
  font-weight: 500;
}
.fw6 {
  font-weight: 600;
}
.fw7 {
  font-weight: 700;
}
.mb_0 {
  margin-bottom: 0 !important;
}
.mb_10 {
  margin-bottom: 10px !important;
}
.mb_20 {
  margin-bottom: 20px !important;
}
.mb_30 {
  margin-bottom: 30px !important;
}
.mb_40 {
  margin-bottom: 40px !important;
}
.mb_50 {
  margin-bottom: 50px !important;
}
.mt_0 {
  margin-top: 0 !important;
}
.mr_0 {
  margin-right: 0 !important;
}
.ml_0 {
  margin-left: 0 !important;
}
.pb_0 {
  padding-bottom: 0 !important;
}
@media (min-width: 980px) {
  /* display */
  .dn_pc {
    display: none !important;
  }
  .in-block_sp {
    display: inline;
  }
}
@media (min-width: 769px) {
  .dn_pc2 {
    display: none !important;
  }
}
@media (max-width:979px) {
  body {
    line-height: 1.75;
    font-size: 1.5rem;
  }
  p, ul, ol, dl {
    text-align: left;
  }
  /* display */
  .dn_mob {
    display: none !important;
  }
  .db_mob {
    display: block !important;
  }
  .in-block_sp {
    display: inline-block;
  }
  @media (max-width: 768px) {
    .dn_mob2 {
      display: none !important;
    }
  }
}