@charset "UTF-8";
h1, h2, h3, h4, h5, h6 {
  position: relative; }

h1 {
  font-size: 28px;
  line-height: 1.5;
  margin: 1em 0; }
  @media (max-width: 960px) {
    h1 {
      font-size: 21px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    h1 {
      font-size: 21px; } }
  h1.largeText {
    font-size: 48px; }
    @media (max-width: 960px) {
      h1.largeText {
        font-size: 32px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      h1.largeText {
        font-size: 48px; } }
  h1.smallText {
    font-size: 21px; }
    @media (max-width: 960px) {
      h1.smallText {
        font-size: 16px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      h1.smallText {
        font-size: 18px; } }
  h1 span {
    display: block;
    color: #ED1C24; }

h2 {
  font-size: 21px;
  font-weight: bold;
  line-height: 1.5;
  margin: 1em 0; }
  @media (max-width: 960px) {
    h2 {
      font-size: 18px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    h2 {
      font-size: 18px; } }
  h2.largeText {
    font-size: 36px; }
    @media (max-width: 960px) {
      h2.largeText {
        font-size: 21px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      h2.largeText {
        font-size: 28px; } }
  h2.smallText {
    font-size: 21px; }
    @media (max-width: 960px) {
      h2.smallText {
        font-size: 15px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      h2.smallText {
        font-size: 16px; } }

h3 {
  font-size: 19px;
  line-height: 1.5;
  margin: 1em 0;
  border-left: 5px solid #222222;
  padding: 5px 0 5px 10px; }
  @media (max-width: 960px) {
    h3 {
      font-size: 16px;
      border-left: 4px solid #222222;
      padding: 3px 0 3px 10px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    h3 {
      font-size: 18px; } }
  h3.smallText {
    font-size: 16px; }
    @media (max-width: 960px) {
      h3.smallText {
        font-size: 16px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      h3.smallText {
        font-size: 16px; } }
  h3.largeText {
    font-size: 32px; }
    @media (max-width: 960px) {
      h3.largeText {
        font-size: 21px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      h3.largeText {
        font-size: 24px; } }
  h3.catchcopy {
    margin: 0;
    padding: 0;
    border: none;
    font-weight: bold;
    display: inline; }
  h3.black {
    line-height: 20px;
    background-color: #333333;
    padding: 10px 0 10px 30px;
    color: #ffffff;
    position: relative;
    border: none; }
    h3.black:before {
      content: "";
      width: 20px;
      height: 4px;
      position: absolute;
      left: 0;
      top: 50%;
      margin: -2px 0 0 0;
      background-color: #ED1C24; }
  h3.noborder {
    border: none;
    padding: 10px 0; }

h4 {
  font-size: 17px;
  font-weight: bold;
  line-height: 1.5;
  margin: 0.5em 0;
  padding: 0.5em 0;
  border-bottom: 1px solid #222222; }
  @media (max-width: 960px) {
    h4 {
      font-size: 16px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    h4 {
      font-size: 16px; } }
  h4.largeText {
    font-size: 24px; }
    @media (max-width: 960px) {
      h4.largeText {
        font-size: 21px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      h4.largeText {
        font-size: 24px; } }
  h4.smallText {
    font-size: 16px; }
  h4.arrow {
    padding: 0 0 0 20px;
    border: none; }
    h4.arrow:before {
      content: "";
      width: 16px;
      height: 16px;
      position: absolute;
      left: 0;
      top: 50%;
      background-image: url(../images/arrow.svg);
      background-size: 16px 16px;
      background-position: center;
      background-repeat: no-repeat;
      margin: -8px 0 0 0; }
  h4.black {
    line-height: 20px;
    background-color: #333333;
    padding: 10px 0 10px 30px;
    color: #ffffff;
    position: relative;
    border: none; }
    h4.black:before {
      content: "";
      width: 20px;
      height: 4px;
      position: absolute;
      left: 0;
      top: 50%;
      margin: -2px 0 0 0;
      background-color: #ED1C24; }
  h4.noborder {
    border: none; }

h5 {
  font-size: 18px;
  font-weight: bold;
  line-height: 1.5;
  margin: 1em 0; }
  @media (max-width: 960px) {
    h5 {
      font-size: 15px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    h5 {
      font-size: 16px; } }
  h5.largeText {
    font-size: 28px; }
    @media (max-width: 960px) {
      h5.largeText {
        font-size: 18px; } }
    @media (max-width: 960px) {
      h5.largeText {
        font-size: 21px; } }
  h5.smallText {
    font-size: 15px; }
    @media (max-width: 960px) {
      h5.smallText {
        font-size: 14px; } }

p, li, dt, dd {
  margin: 0 0 1em 0;
  font-size: 15px; }
  @media (max-width: 960px) {
    p, li, dt, dd {
      font-size: 14px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    p, li, dt, dd {
      font-size: 14px; } }
  p.xlargeText, li.xlargeText, dt.xlargeText, dd.xlargeText {
    font-size: 40px;
    margin: 0 0 0.25em 0; }
    @media (max-width: 720px) {
      p.xlargeText, li.xlargeText, dt.xlargeText, dd.xlargeText {
        font-size: 24px; } }
    @media (min-width: 721px) and (max-width: 960px) {
      p.xlargeText, li.xlargeText, dt.xlargeText, dd.xlargeText {
        font-size: 28px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      p.xlargeText, li.xlargeText, dt.xlargeText, dd.xlargeText {
        font-size: 26px; } }
  p.largeText, li.largeText, dt.largeText, dd.largeText {
    font-size: 24px;
    margin: 0 0 1em 0; }
    @media (max-width: 720px) {
      p.largeText, li.largeText, dt.largeText, dd.largeText {
        font-size: 18px; } }
    @media (min-width: 721px) and (max-width: 960px) {
      p.largeText, li.largeText, dt.largeText, dd.largeText {
        font-size: 18px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      p.largeText, li.largeText, dt.largeText, dd.largeText {
        font-size: 21px; } }
  p.smallText, li.smallText, dt.smallText, dd.smallText {
    font-size: 12px;
    color: #777777; }
    @media (max-width: 960px) {
      p.smallText, li.smallText, dt.smallText, dd.smallText {
        font-size: 12px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    pdt, pdd, lidt, lidd, dtdt, dtdd, dddt, dddd {
      margin: 0; } }

ul.largeText li,
ol.largeText li {
  font-size: 24px;
  margin: 0 0 1em 0; }
  @media (max-width: 720px) {
    ul.largeText li,
    ol.largeText li {
      font-size: 18px; } }
  @media (min-width: 721px) and (max-width: 1280px) {
    ul.largeText li,
    ol.largeText li {
      font-size: 21px; } }

.mb0 {
  margin-bottom: 0 !important; }

.mt0 {
  margin-top: 0 !important; }

a {
  color: #0066CC; }
  a:hover {
    text-decoration: underline; }

a.btn {
  margin: 1em auto;
  text-align: center;
  line-height: 45px;
  height: 45px;
  display: inline-block;
  width: auto;
  position: relative;
  color: #ffffff;
  padding: 0 2em;
  padding-right: -webkit-calc(2em + 45px);
  padding-right: calc(2em + 45px);
  background-color: #c61017;
  box-shadow: 0 rgba(237, 28, 36, 0);
  transition: all 0.2s ease-in-out;
  border-radius: 3px; }
  @media (max-width: 720px) {
    a.btn {
      line-height: 1.5;
      height: auto;
      padding: 10px;
      padding-right: -webkit-calc(2em + 40px);
      padding-right: calc(2em + 40px); } }
  @media (min-width: 721px) and (max-width: 1280px) {
    a.btn {
      line-height: 40px;
      height: 40px;
      padding: 0 2em;
      padding-right: -webkit-calc(2em + 40px);
      padding-right: calc(2em + 40px); } }
  a.btn i {
    padding: 0 5px 0 0; }
  a.btn:before {
    display: none; }
  a.btn:after {
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    -webkit-font-smoothing: antialiased;
    display: block;
    padding: 0;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-weight: 900;
    width: 45px;
    height: 45px;
    line-height: 45px;
    text-align: center;
    position: absolute;
    right: 5px;
    top: 0;
    transition: all 0.2s ease-in-out; }
    @media (max-width: 720px) {
      a.btn:after {
        width: 40px;
        height: 40px;
        line-height: 40px; } }
  a.btn:hover {
    -webkit-font-smoothing: antialiased;
    background-color: #ED1C24;
    text-decoration: none;
    box-shadow: 0 10px 20px 0 rgba(237, 28, 36, 0.3); }
    a.btn:hover:after {
      right: 0px; }

a.b_btn {
  border-radius: 3px;
  display: inline-block;
  line-height: 30px;
  padding: 0 60px 0 30px;
  color: #ffffff;
  position: relative;
  background: #777777;
  transition: all 0.2s ease-in-out;
  text-decoration: none; }
  @media (max-width: 720px) {
    a.b_btn {
      padding: 0 40px 0 20px;
      transition: all 0s ease-in-out; } }
  @media (min-width: 721px) and (max-width: 1280px) {
    a.b_btn {
      padding: 0 40px 0 20px;
      transition: all 0s ease-in-out; } }
  a.b_btn:after {
    font-family: "Font Awesome 5 Free";
    content: "\f35d";
    -webkit-font-smoothing: antialiased;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-weight: 900;
    font-size: 13px;
    display: block;
    padding: 0;
    position: absolute;
    width: 30px;
    height: 30px;
    text-align: center;
    line-height: 30px;
    right: 0;
    top: 0; }
  a.b_btn:hover {
    background-color: #ED1C24;
    color: #ffffff;
    text-decoration: none; }

a.smallBtn {
  margin: 0.5em auto 0.5em auto;
  text-align: center;
  line-height: 35px;
  height: 35px;
  display: inline-block;
  width: auto;
  position: relative;
  color: #ffffff;
  padding: 0 1.5em;
  padding-right: -webkit-calc(1.5em + 35px);
  padding-right: calc(1.5em + 35px);
  background-color: #c61017;
  box-shadow: 0 rgba(237, 28, 36, 0);
  transition: all 0.2s ease-in-out;
  border-radius: 3px;
  text-decoration: none; }
  @media (max-width: 720px) {
    a.smallBtn {
      line-height: 30px;
      height: auto;
      padding-right: -webkit-calc(1.5em + 20px);
      padding-right: calc(1.5em + 20px); } }
  @media (min-width: 721px) and (max-width: 960px) {
    a.smallBtn {
      transition: all 0s ease-in-out; } }
  a.smallBtn:before {
    display: none; }
  a.smallBtn:after {
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    -webkit-font-smoothing: antialiased;
    display: block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-weight: 900;
    width: 35px;
    height: 35px;
    line-height: 35px;
    text-align: center;
    position: absolute;
    right: 5px;
    top: 0;
    transition: all 0.2s ease-in-out; }
    @media (max-width: 720px) {
      a.smallBtn:after {
        width: 30px;
        height: 30px;
        line-height: 30px;
        transition: all 0s ease-in-out; } }
    @media (min-width: 721px) and (max-width: 960px) {
      a.smallBtn:after {
        transition: all 0s ease-in-out; } }
  a.smallBtn:hover {
    -webkit-font-smoothing: antialiased;
    background-color: #ED1C24;
    box-shadow: 0 10px 20px 0 rgba(237, 28, 36, 0.3);
    text-decoration: none; }
    a.smallBtn:hover:after {
      right: 0px; }

a.largeBtn {
  margin: 0.5em auto;
  text-align: center;
  line-height: 55px;
  height: 55px;
  display: inline-block;
  width: auto;
  position: relative;
  color: #ffffff;
  padding: 0 2em;
  padding-right: -webkit-calc(2em + 55px);
  padding-right: calc(2em + 55px);
  font-size: 1.1em;
  background-color: #c61017;
  box-shadow: 0 rgba(237, 28, 36, 0);
  transition: all 0.2s ease-in-out;
  border-radius: 5px;
  text-decoration: none; }
  @media (max-width: 720px) {
    a.largeBtn {
      line-height: 1.5;
      height: auto;
      padding: 15px;
      padding-right: -webkit-calc(1em + 50px);
      padding-right: calc(1em + 50px);
      font-size: 1em;
      transition: all 0s ease-in-out; } }
  @media (min-width: 721px) and (max-width: 960px) {
    a.largeBtn {
      line-height: 50px;
      height: 50px;
      padding: 0 1em;
      padding-right: -webkit-calc(1em + 50px);
      padding-right: calc(1em + 50px);
      font-size: 110%; } }
  a.largeBtn:before {
    display: none; }
  a.largeBtn:after {
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    -webkit-font-smoothing: antialiased;
    display: block;
    padding: 0 5px 0 0;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    font-weight: 900;
    transition: all 0.2s ease-in-out;
    width: 55px;
    height: 55px;
    line-height: 55px;
    text-align: center;
    position: absolute;
    right: 0;
    top: 0; }
    @media (max-width: 720px) {
      a.largeBtn:after {
        transition: all 0s ease-in-out;
        width: 50px;
        height: 50px;
        line-height: 50px; } }
  a.largeBtn:hover {
    -webkit-font-smoothing: antialiased;
    background-color: #ED1C24;
    color: #ffffff;
    text-decoration: none;
    box-shadow: 0 10px 20px 0 rgba(237, 28, 36, 0.3); }
    a.largeBtn:hover:after {
      padding: 0; }

a.grayBtn {
  text-decoration: none;
  background-color: #444444; }
  a.grayBtn:hover {
    color: #ffffff;
    -webkit-font-smoothing: antialiased;
    background-color: #ED1C24;
    text-decoration: none;
    box-shadow: 0 10px 20px 0 rgba(237, 28, 36, 0.3); }

a.downloadBtn {
  margin: 0.25em auto;
  text-align: center;
  line-height: 40px;
  height: 40px;
  display: inline-block;
  width: auto;
  position: relative;
  color: #ffffff;
  padding: 0 1em;
  padding-right: -webkit-calc(1em + 40px);
  padding-right: calc(1em + 40px);
  background-color: #444444;
  box-shadow: 0 rgba(237, 28, 36, 0);
  transition: all 0.2s ease-in-out;
  border-radius: 3px; }
  a.downloadBtn i {
    padding: 0 5px 0 0; }
  a.downloadBtn:after {
    font-family: "Font Awesome 5 Free";
    content: "\f019";
    -webkit-font-smoothing: antialiased;
    display: block;
    padding: 0;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-weight: 900;
    width: 45px;
    height: 45px;
    line-height: 45px;
    text-align: center;
    position: absolute;
    right: 5px;
    top: 0;
    transition: all 0.2s ease-in-out; }
  a.downloadBtn:hover {
    -webkit-font-smoothing: antialiased;
    background-color: #ED1C24;
    text-decoration: none;
    box-shadow: 0 10px 20px 0 rgba(237, 28, 36, 0.3); }

li, dt, dd {
  margin: 0; }

.bold, .msg,
strong,
b {
  font-weight: bold; }

.red, .msg {
  color: #ED1C24; }

.notice,
.notice li {
  font-size: 13px; }

.serif {
  font-family: "Times New Roman", Times, "serif";
  font-weight: normal; }

article {
  padding: 40px 0 2vw 40px;
  line-height: 1.75; }
  @media (max-width: 720px) {
    article {
      padding: 15px;
      box-shadow: 0px 2px 2px 0px rgba(34, 34, 34, 0); } }
  @media (min-width: 721px) and (max-width: 960px) {
    article {
      padding: 20px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    article {
      padding: 20px 0 20px 40px; } }

section {
  padding: 0 0 2em 0;
  position: relative; }
  section section {
    padding: 0 0 20px 0; }
    @media (max-width: 960px) {
      section section {
        padding: 0 0 10px 0; } }

.flexBox {
  display: flex;
  display: -ms-flex;
  display: -webkit-flex;
  justify-content: flex-start;
  align-content: center;
  align-items: center;
  margin: 0 -10px;
  position: relative;
  padding: 0 0 20px 0; }
  @media (max-width: 720px) {
    .flexBox {
      margin: 0;
      padding: 0;
      flex-direction: column; } }
  @media (min-width: 721px) and (max-width: 960px) {
    .flexBox {
      margin: 0 -5px; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    .flexBox {
      margin: 0 -5px;
      padding: 0 0 10px 0; } }
  .flexBox div, .flexBox figure, .flexBox section, .flexBox li, .flexBox article {
    box-sizing: border-box;
    flex: 1;
    margin: 0 10px;
    word-wrap: break-word;
    min-width: 40px; }
    @media (max-width: 720px) {
      .flexBox div, .flexBox figure, .flexBox section, .flexBox li, .flexBox article {
        margin: 5px 0;
        width: 100%; } }
    @media (min-width: 721px) and (max-width: 1280px) {
      .flexBox div, .flexBox figure, .flexBox section, .flexBox li, .flexBox article {
        margin: 0 5px; } }
    .flexBox div img, .flexBox figure img, .flexBox section img, .flexBox li img, .flexBox article img {
      display: block;
      height: auto;
      max-width: 100%;
      margin: 0 auto; }
    .flexBox div > .flexBox, .flexBox figure > .flexBox, .flexBox section > .flexBox, .flexBox li > .flexBox, .flexBox article > .flexBox {
      padding: 0;
      margin: 0 -10px; }
      .flexBox div > .flexBox div, .flexBox div > .flexBox figure, .flexBox div > .flexBox section, .flexBox div > .flexBox li, .flexBox div > .flexBox article, .flexBox figure > .flexBox div, .flexBox figure > .flexBox figure, .flexBox figure > .flexBox section, .flexBox figure > .flexBox li, .flexBox figure > .flexBox article, .flexBox section > .flexBox div, .flexBox section > .flexBox figure, .flexBox section > .flexBox section, .flexBox section > .flexBox li, .flexBox section > .flexBox article, .flexBox li > .flexBox div, .flexBox li > .flexBox figure, .flexBox li > .flexBox section, .flexBox li > .flexBox li, .flexBox li > .flexBox article, .flexBox article > .flexBox div, .flexBox article > .flexBox figure, .flexBox article > .flexBox section, .flexBox article > .flexBox li, .flexBox article > .flexBox article {
        margin: 0 10px; }
  .flexBox .flex1 {
    flex: 1; }
  .flexBox .flex2 {
    flex: 2; }
  .flexBox .flex3 {
    flex: 3; }
  .flexBox .flex4 {
    flex: 4; }
  .flexBox .flex5 {
    flex: 5; }
  .flexBox .empty {
    margin: 0; }
  .flexBox.center {
    justify-content: center; }
  .flexBox.start {
    align-content: flex-start;
    align-items: flex-start; }
  .flexBox.stretch {
    align-content: stretch;
    align-items: stretch; }
  .flexBox.end {
    align-content: flex-end;
    align-items: flex-end; }
  .flexBox.reverse {
    flex-direction: row-reverse; }
  .flexBox.borderBox {
    padding: 20px; }

.recommend {
  display: flex;
  display: -ms-flex;
  display: -webkit-flex;
  flex-wrap: wrap;
  align-content: stretch;
  align-items: stretch; }
  .recommend div {
    flex: none;
    width: 25%;
    text-align: center;
    margin: 0;
    padding: 0; }
    @media (max-width: 720px) {
      .recommend div {
        width: 50%; } }
    @media (min-width: 721px) and (max-width: 960px) {
      .recommend div {
        flex: 1;
        max-width: 33.33%;
        padding: 1px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      .recommend div {
        width: 33.33%; } }
    .recommend div a {
      display: block;
      position: relative;
      padding: 10px;
      border: 1px solid #eeeeee;
      text-decoration: none;
      margin: -1px 0 0 -1px;
      transition: all 0.2s ease-in-out;
      width: 100%;
      height: 100%;
      box-sizing: border-box;
      color: #222222; }
      @media (min-width: 721px) and (max-width: 960px) {
        .recommend div a {
          transition: all 0s ease-in-out; } }
      .recommend div a div {
        width: 100%; }
      .recommend div a .tag {
        display: inline;
        position: absolute;
        font-size: 12px;
        padding: 0 20px;
        background-color: #ED1C24;
        color: #ffffff;
        left: 0;
        top: 0; }
      .recommend div a img {
        width: 65%;
        padding: 5px 0 10px 0;
        margin: 0 auto; }
        @media (min-width: 721px) and (max-width: 1280px) {
          .recommend div a img {
            padding: 0 0 10px 0; } }
      .recommend div a h4 {
        margin: 0 auto;
        padding: 0 0 10px 0;
        border: none; }
        @media (min-width: 721px) and (max-width: 1280px) {
          .recommend div a h4 {
            font-size: 15px; } }
      .recommend div a .spec {
        padding: 0 0 10px 0; }
        .recommend div a .spec dl {
          width: 100%;
          margin: 0 auto;
          display: flex;
          display: -ms-flex;
          display: -webkit-flex;
          padding: 0 10px;
          box-sizing: border-box; }
          .recommend div a .spec dl dt {
            flex: 1;
            font-size: 13px;
            padding: 0 1em 0 0;
            text-align: right; }
          .recommend div a .spec dl dd {
            flex: 1;
            font-size: 13px;
            text-align: left; }
      .recommend div a .red {
        font-size: 13px; }
        .recommend div a .red p {
          font-size: 12px; }
      .recommend div a p {
        font-size: 12px;
        line-height: 1.2; }
      .recommend div a:hover {
        border: 1px solid #ED1C24;
        z-index: 2; }

dl.flexBox {
  border-bottom: 1px solid #dddddd;
  justify-content: flex-start;
  align-content: stretch;
  align-items: stretch;
  margin: 0;
  padding: 0;
  flex-wrap: wrap; }
  @media (max-width: 720px) {
    dl.flexBox {
      border-top: 1px solid #dddddd;
      border-bottom: none; } }
  dl.flexBox:first-of-type {
    border-top: 1px solid #dddddd; }
  dl.flexBox:last-of-type {
    margin-bottom: 2em; }
    @media (max-width: 720px) {
      dl.flexBox:last-of-type {
        margin-bottom: 1em; } }
    @media (min-width: 721px) and (max-width: 1280px) {
      dl.flexBox:last-of-type {
        margin-bottom: 1em; } }
  dl.flexBox dt {
    padding: 15px;
    background-color: #f7f7f7;
    width: 150px;
    text-align: center;
    margin: 0; }
    @media (max-width: 720px) {
      dl.flexBox dt {
        padding: 10px;
        width: 100%;
        box-sizing: border-box;
        background-color: #eeeeee;
        border-bottom: 1px solid #dddddd; } }
    @media (min-width: 721px) and (max-width: 960px) {
      dl.flexBox dt {
        padding: 10px;
        width: 100px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      dl.flexBox dt {
        padding: 10px;
        width: 130px; } }
  dl.flexBox dd {
    padding: 15px;
    flex: none;
    width: 100%;
    width: -webkit-calc(100% - 180px);
    width: calc(100% - 180px);
    box-sizing: border-box; }
    @media (max-width: 720px) {
      dl.flexBox dd {
        padding: 10px;
        width: 100%; } }
    @media (min-width: 721px) and (max-width: 960px) {
      dl.flexBox dd {
        width: -webkit-calc(100% - 130px);
        width: calc(100% - 130px); } }
    @media (min-width: 961px) and (max-width: 1280px) {
      dl.flexBox dd {
        padding: 10px;
        width: -webkit-calc(100% - 150px);
        width: calc(100% - 150px); } }
    dl.flexBox dd h1, dl.flexBox dd h2, dl.flexBox dd h3, dl.flexBox dd h4, dl.flexBox dd h5, dl.flexBox dd h6 {
      margin-top: 0; }
    dl.flexBox dd div {
      padding: 0 15px 15px 15px;
      margin: 0 -15px; }
      @media (max-width: 960px) {
        dl.flexBox dd div {
          padding: 0 10px 10px 10px;
          margin: 0 -10px;
          box-sizing: border-box; } }
      @media (min-width: 961px) and (max-width: 1280px) {
        dl.flexBox dd div {
          padding: 0 10px 10px 10px;
          margin: 0 -10px;
          box-sizing: border-box; } }
      dl.flexBox dd div + div {
        padding: 15px;
        border-top: 1px solid #dddddd; }
        @media (max-width: 960px) {
          dl.flexBox dd div + div {
            padding: 10px; } }
        @media (min-width: 961px) and (max-width: 1280px) {
          dl.flexBox dd div + div {
            padding: 10px; } }
      dl.flexBox dd div:last-of-type {
        padding-bottom: 0; }

dl.notice dt {
  font-weight: bold;
  margin: 0;
  color: #777777;
  font-size: 13px; }
dl.notice dd {
  font: normal;
  font-size: 13px;
  margin: 0; }

dl.pickup {
  border-bottom: 1px dotted #dddddd;
  padding: 15px 0; }
  dl.pickup dt {
    font-weight: bold;
    position: relative;
    font-size: 18px;
    padding: 5px 0 5px 30px;
    line-height: 1.25; }
    dl.pickup dt:before {
      font-family: "Font Awesome 5 Free";
      content: "\f105";
      position: absolute;
      width: 20px;
      height: 20px;
      line-height: 20px !important;
      display: block;
      left: 0;
      top: 50%;
      text-align: center;
      margin: -10px 0 0 0;
      -webkit-font-smoothing: antialiased;
      padding: 0;
      font-style: normal;
      font-variant: normal;
      text-rendering: auto;
      line-height: 1;
      font-weight: 900; }
  dl.pickup dd {
    font-size: 15px;
    line-height: 1.5;
    padding: 5px 0 0 30px; }
  dl.pickup + p {
    padding-top: 20px; }

dl.virticalTable {
  border: 1px solid #dddddd; }
  dl.virticalTable:not(:last-of-type) {
    border-right: none; }
    @media (max-width: 720px) {
      dl.virticalTable:not(:last-of-type) {
        border-right: 1px solid #dddddd;
        border-bottom: none; } }
  dl.virticalTable dt {
    background: #f7f7f7;
    border-bottom: 1px solid #dddddd;
    padding: 10px;
    font-weight: bold; }
    dl.virticalTable dt p {
      margin: 0; }
    dl.virticalTable dt small {
      font-size: 13px;
      color: #777777; }
  dl.virticalTable dd {
    padding: 10px 0; }
    dl.virticalTable dd ul {
      margin: 0;
      padding: 0; }
      @media (max-width: 720px) {
        dl.virticalTable dd ul.flexBox {
          flex-direction: row; } }
      dl.virticalTable dd ul li {
        margin: 0; }
        dl.virticalTable dd ul li img {
          max-width: 100%;
          width: auto; }
    dl.virticalTable dd p {
      margin: 0;
      padding: 0 10px; }

dl.smalltext dt,
dl.smallText dt {
  font-size: 12px; }
dl.smalltext dd,
dl.smallText dd {
  font-size: 12px;
  color: #777777; }

.new {
  background-color: #c61017;
  color: #ffffff;
  display: inline-block;
  padding: 0 10px;
  margin: 0 5px 0 0; }

.border {
  border: 1px solid #444444;
  display: inline-block;
  padding: 0 10px;
  margin: 0 10px 0 5px; }

.flexBox .before {
  position: relative;
  margin-right: 50px; }
  .flexBox .before:after {
    content: "";
    width: 20px;
    height: 20px;
    display: block;
    border-right: 10px solid #ED1C24;
    border-bottom: 10px solid #ED1C24;
    transform: rotate(-45deg);
    position: absolute;
    right: -40px;
    top: 50%;
    margin: -30px 0 0 0;
    transition: all 0.2s ease-in-out; }
  .flexBox .before + div, .flexBox .before + section {
    margin-left: 50px; }
  @media (max-width: 960px) {
    .flexBox .before {
      margin: 0 0 40px 0; }
      .flexBox .before:after {
        content: "";
        width: 10px;
        height: 10px;
        display: block;
        border-right: none;
        border-left: 5px solid #ED1C24;
        border-bottom: 5px solid #ED1C24;
        transform: rotate(-45deg);
        position: absolute;
        right: 50%;
        top: 100%;
        margin: 5px -7px 0 0;
        transition: all 0.2s ease-in-out; }
      .flexBox .before + div, .flexBox .before + section {
        margin: 0 0 40px 0; } }

.msg {
  margin: 3em 0; }

table {
  width: 100%;
  border: 1px solid #dddddd;
  margin: 0 0 2em 0; }
  @media (max-width: 960px) {
    table {
      margin: 0 0 1em 0; } }
  table th {
    padding: 10px;
    border: 1px solid #dddddd;
    vertical-align: middle;
    background-color: #f7f7f7;
    text-align: center;
    line-height: 1.25; }
    @media (max-width: 720px) {
      table th {
        padding: 2px;
        font-size: 12px;
        word-break: break-all; } }
    @media (min-width: 721px) and (max-width: 960px) {
      table th {
        padding: 7px;
        word-break: break-all; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      table th {
        padding: 5px; } }
    table th.center {
      text-align: center; }
  table td {
    padding: 10px;
    border: 1px solid #dddddd;
    vertical-align: middle;
    line-height: 1.25; }
    @media (max-width: 720px) {
      table td {
        padding: 2px;
        font-size: 12px;
        word-break: break-all; } }
    @media (min-width: 721px) and (max-width: 960px) {
      table td {
        padding: 7px;
        word-break: break-all; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      table td {
        padding: 5px; } }
    table td.center {
      text-align: center; }

table.zebraTable {
  width: 100%;
  border: 1px solid #dddddd; }
  table.zebraTable tr:nth-child(2n+1) {
    background-color: #f7f7f7; }
  table.zebraTable th {
    padding: 10px;
    border: 1px solid #dddddd;
    vertical-align: middle;
    background-color: #eeeeee;
    text-align: center; }
  table.zebraTable td {
    padding: 10px;
    border: 1px solid #dddddd;
    vertical-align: middle; }

table.blueTable {
  width: 100%;
  border: 1px solid #90CAF9; }
  table.blueTable tr:nth-child(2n+1) {
    background-color: #E1F5FE; }
  table.blueTable th {
    padding: 10px;
    border: 1px solid #90CAF9;
    vertical-align: middle;
    background-color: #B3E5FC;
    text-align: center; }
  table.blueTable td {
    padding: 10px;
    border: 1px solid #90CAF9;
    vertical-align: middle;
    text-align: center; }

table.smallTable {
  margin: 0 0 10px 0; }
  table.smallTable th {
    padding: 5px;
    line-height: 1.5; }
    @media (min-width: 961px) and (max-width: 1280px) {
      table.smallTable th {
        padding: 3px; } }
  table.smallTable td {
    padding: 5px;
    line-height: 1.5; }
    @media (min-width: 961px) and (max-width: 1280px) {
      table.smallTable td {
        padding: 3px; } }

table.tbl th {
  padding: 0; }
table.tbl td {
  padding: 0; }

.eventItem {
  margin: 0;
  padding: 20px 0;
  border-top: 1px dotted #dddddd;
  border-bottom: 1px dotted #dddddd;
  display: flex;
  display: -ms-flex;
  display: -webkit-flex; }
  @media (max-width: 720px) {
    .eventItem {
      flex-direction: column; } }
  .eventItem + .eventItem {
    border-top: none; }
  .eventItem div.image {
    width: 210px;
    padding: 0;
    margin: 0; }
    .eventItem div.image img {
      width: 180px;
      height: auto; }
  .eventItem div.text {
    flex: 1;
    padding: 0 40px 0 0; }
    @media (max-width: 720px) {
      .eventItem div.text {
        padding: 10px 0 0 0; } }
    .eventItem div.text h3 + h4 {
      margin-top: 0; }
    .eventItem div.text h4 {
      border: none; }
    .eventItem div.text p {
      margin: 0;
      font-size: 14px; }
      @media (max-width: 720px) {
        .eventItem div.text p {
          font-size: 13px; } }
  .eventItem a {
    display: flex;
    display: -ms-flex;
    display: -webkit-flex;
    padding: 20px 100px 20px 10px;
    transition: all 0.2s ease-in-out;
    align-content: center;
    align-items: center;
    width: 100%;
    position: relative;
    margin: -20px 0;
    color: #222222; }
    @media (max-width: 720px) {
      .eventItem a {
        flex-direction: column;
        padding: 20px 40px 20px 10px;
        box-sizing: border-box; } }
    .eventItem a:before {
      content: "";
      width: 1px;
      height: 40%;
      background-color: #dddddd;
      position: absolute;
      right: 70px;
      top: 30%;
      margin: 0; }
      @media (max-width: 720px) {
        .eventItem a:before {
          content: "";
          height: 80%;
          right: 30px;
          top: 10%; } }
    .eventItem a:after {
      content: "";
      width: 10px;
      height: 10px;
      display: block;
      border-right: 2px solid #cccccc;
      border-bottom: 2px solid #cccccc;
      transform: rotate(-45deg);
      position: absolute;
      right: 25px;
      top: 50%;
      margin: -6px 0 0 0;
      transition: all 0.2s ease-in-out; }
      @media (max-width: 720px) {
        .eventItem a:after {
          right: 10px; } }
    .eventItem a:hover {
      text-decoration: none;
      box-shadow: 0 0.5vw 2vw 0 rgba(0, 0, 0, 0.1); }
      .eventItem a:hover h4 {
        color: #ED1C24; }
      .eventItem a:hover:after {
        right: 20px;
        border-right: 2px solid #0066CC;
        border-bottom: 2px solid #0066CC; }

ul.icon {
  display: flex;
  display: -ms-flex;
  display: -webkit-flex;
  justify-content: flex-start; }
  ul.icon li {
    margin: 0 10px 10px 0;
    background-color: #ED1C24;
    color: #ffffff;
    padding: 0 20px;
    line-height: 24px;
    border-radius: 2px;
    border: 1px solid #ED1C24;
    background: linear-gradient(35deg, #ED1C24, #c61017); }

ul.disc {
  padding: 0 0 0 20px;
  list-style-position: outside; }
  ul.disc li {
    list-style: disc; }

ul.arrow li {
  position: relative;
  padding: 10px 0 10px 20px;
  line-height: 1.25; }
  @media (max-width: 720px) {
    ul.arrow li {
      margin: 0; } }
  ul.arrow li:before {
    font-family: "Font Awesome 5 Free";
    content: "\f105";
    position: absolute;
    width: 20px;
    height: 20px;
    line-height: 20px !important;
    display: block;
    left: 0;
    top: 50%;
    text-align: center;
    margin: -10px 0 0 0;
    -webkit-font-smoothing: antialiased;
    padding: 0;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-weight: 900; }

ul.border {
  border: none;
  display: block; }
  ul.border li {
    padding-top: 10px;
    padding-bottom: 10px;
    position: relative;
    line-height: 1.25;
    border-bottom: 1px dotted #dddddd; }
    @media (max-width: 720px) {
      ul.border li {
        padding-top: 6px;
        padding-bottom: 6px; } }

ul.questionList li {
  border-bottom: 1px dotted #dddddd;
  position: relative; }
  @media (max-width: 720px) {
    ul.questionList li {
      margin: 0; } }
  ul.questionList li a {
    text-decoration: none;
    padding: 20px 40px 20px 40px;
    position: relative;
    display: block;
    color: #222222; }
    @media (max-width: 720px) {
      ul.questionList li a {
        padding: 15px 40px 15px 40px;
        line-height: 1.25; } }
    ul.questionList li a:before {
      content: "Q";
      width: 30px;
      height: 30px;
      line-height: 30px;
      background-color: #de1219;
      color: #ffffff;
      box-shadow: 0px 2px 5px 0px rgba(237, 28, 36, 0.3);
      position: absolute;
      left: 0;
      top: 50%;
      text-align: center;
      margin: -15px 0 0 0;
      border-radius: 2px; }
    ul.questionList li a:after {
      content: "";
      width: 10px;
      height: 10px;
      display: block;
      border-right: 2px solid #cccccc;
      border-bottom: 2px solid #cccccc;
      transform: rotate(-45deg);
      position: absolute;
      right: 20px;
      top: 50%;
      margin: -6px 0 0 0;
      transition: all 0.2s ease-in-out; }
    ul.questionList li a:hover {
      color: #222222; }
      ul.questionList li a:hover:after {
        right: 15px;
        border-right: 1px solid #0066CC;
        border-bottom: 1px solid #0066CC; }

ul.ref li {
  position: relative;
  padding: 5px 0 5px 20px;
  line-height: 1.25; }
  ul.ref li:before {
    content: "*";
    position: absolute;
    width: 20px;
    height: 20px;
    line-height: 20px !important;
    display: block;
    left: 0;
    top: 50%;
    text-align: center;
    margin: -10px 0 0 0;
    -webkit-font-smoothing: antialiased;
    padding: 0;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    font-weight: 900; }

ul.pickup {
  margin: 0 auto 20px auto;
  padding: 0 0 15px 0; }
  ul.pickup li {
    position: relative;
    font-size: 16px;
    border-bottom: 1px dotted #dddddd;
    padding: 15px 0 15px 30px;
    line-height: 1.25; }
    ul.pickup li:before {
      font-family: "Font Awesome 5 Free";
      content: "\f105";
      position: absolute;
      width: 20px;
      height: 20px;
      line-height: 20px !important;
      display: block;
      left: 0;
      top: 50%;
      text-align: center;
      margin: -10px 0 0 0;
      -webkit-font-smoothing: antialiased;
      padding: 0;
      font-style: normal;
      font-variant: normal;
      text-rendering: auto;
      line-height: 1;
      font-weight: 900; }

ul.smallText {
  padding: 10px 0; }
  ul.smallText li {
    font-size: 12px;
    color: #777777; }

.borderBox,
section.borderBox {
  border: 1px solid #dddddd;
  padding: 20px;
  margin: 20px auto; }
  @media (max-width: 720px) {
    .borderBox,
    section.borderBox {
      padding: 10px;
      margin: 10px auto; } }
  @media (min-width: 721px) and (max-width: 960px) {
    .borderBox,
    section.borderBox {
      padding: 15px;
      margin: 10px auto; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    .borderBox,
    section.borderBox {
      padding: 15px;
      margin: 15px auto; } }
  .borderBox > h3,
  section.borderBox > h3 {
    position: relative;
    margin: -20px -20px 20px -20px;
    line-height: 20px;
    background-color: #333333;
    border: none;
    padding: 10px 0 10px 30px;
    color: #ffffff;
    position: relative;
    font-size: 18px; }
    @media (max-width: 720px) {
      .borderBox > h3,
      section.borderBox > h3 {
        margin: -10px -10px 20px -10px; } }
    @media (min-width: 721px) and (max-width: 960px) {
      .borderBox > h3,
      section.borderBox > h3 {
        margin: -15px -15px 15px -15px;
        padding: 15px 0 15px 30px; } }
    @media (min-width: 961px) and (max-width: 1280px) {
      .borderBox > h3,
      section.borderBox > h3 {
        position: relative;
        margin: -15px -15px 15px -15px;
        line-height: 15px;
        padding: 10px 0 10px 30px; } }
    .borderBox > h3:before,
    section.borderBox > h3:before {
      content: "";
      width: 20px;
      height: 4px;
      position: absolute;
      left: 0;
      top: 50%;
      margin: -2px 0 0 0;
      background-color: #ED1C24; }
  .borderBox p + p,
  section.borderBox p + p {
    margin-top: 1em; }
  .borderBox a.btn, .borderBox a.b_btn, .borderBox a.smallBtn, .borderBox a.largeBtn, .borderBox a.grayBtn,
  section.borderBox a.btn,
  section.borderBox a.b_btn,
  section.borderBox a.smallBtn,
  section.borderBox a.largeBtn,
  section.borderBox a.grayBtn {
    color: #ffffff; }
  .borderBox.flexBox,
  section.borderBox.flexBox {
    padding: 20px; }

.grayBox,
section.grayBox {
  padding: 20px;
  background-color: #f7f7f7;
  margin: 20px auto; }
  @media (max-width: 720px) {
    .grayBox,
    section.grayBox {
      padding: 10px;
      margin: 10px auto; } }
  @media (min-width: 721px) and (max-width: 960px) {
    .grayBox,
    section.grayBox {
      padding: 15px;
      margin: 10px auto; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    .grayBox,
    section.grayBox {
      padding: 15px;
      margin: 15px auto; } }
  .grayBox p,
  section.grayBox p {
    margin: 0; }
    .grayBox p + p,
    section.grayBox p + p {
      margin-top: 1em; }

ol {
  padding: 0 0 0 20px;
  list-style-position: outside; }
  ol li {
    list-style: decimal;
    padding: 10px 0 10px 0; }
    @media (max-width: 720px) {
      ol li {
        padding: 5px 0 5px 0; } }
    @media (min-width: 721px) and (max-width: 1280px) {
      ol li {
        padding: 7px 0 7px 0; } }

ol.ref {
  counter-reset: sample;
  padding: 0 0;
  margin: 0; }
  ol.ref li {
    position: relative;
    padding: 5px 0 5px 30px;
    line-height: 1.25;
    list-style: none; }
    ol.ref li:before {
      counter-increment: sample;
      content: "*" counter(sample);
      position: absolute;
      width: 30px;
      height: 20px;
      line-height: 20px !important;
      display: block;
      left: 0;
      top: 3px;
      text-align: left;
      margin: 0;
      -webkit-font-smoothing: antialiased;
      padding: 0;
      font-style: normal;
      font-variant: normal;
      text-rendering: auto;
      line-height: 1;
      font-weight: 900; }

ol.smallText {
  padding: 10px 0; }
  @media (max-width: 720px) {
    ol.smallText {
      padding: 5px 0 5px 0; } }
  @media (min-width: 721px) and (max-width: 1280px) {
    ol.smallText {
      padding: 15px 0; } }
  ol.smallText li {
    font-size: 12px;
    color: #777777; }
    @media (max-width: 720px) {
      ol.smallText li {
        font-size: 12px; } }

ol.nopadding {
  padding: 0; }
  ol.nopadding li {
    padding: 0; }

ol.exp {
  counter-reset: number;
  padding: 0; }
  ol.exp li {
    list-style: none;
    padding: 5px 0 5px 30px;
    margin: 0;
    position: relative;
    line-height: 1.25; }
    ol.exp li:before {
      counter-increment: number;
      content: counter(number);
      width: 22px;
      height: 22px;
      line-height: 22px;
      background-color: #222222;
      color: #ffffff;
      text-align: center;
      font-size: 12px;
      position: absolute;
      left: 0px;
      top: 50%;
      margin: -11px 0 0 0; }
  ol.exp.ratin {
    counter-reset: ratin; }
    ol.exp.ratin li:before {
      counter-increment: ratin;
      content: counter(ratin,lower-alpha);
      width: 22px;
      height: 22px;
      line-height: 22px;
      background-color: #222222;
      color: #ffffff;
      text-align: center;
      font-size: 12px;
      position: absolute;
      left: 0px;
      top: 50%;
      margin: -11px 0 0 0; }

ol.ratin {
  counter-reset: ratin;
  padding: 0; }
  ol.ratin li {
    list-style: none;
    padding: 5px 0 5px 30px;
    margin: 0;
    position: relative;
    line-height: 1.25; }
    ol.ratin li:before {
      counter-increment: ratin;
      content: "(" counter(ratin,lower-alpha) ").";
      width: 22px;
      height: 22px;
      line-height: 22px;
      color: #222222;
      text-align: center;
      position: absolute;
      left: 0px;
      top: 50%;
      margin: -11px 0 0 0; }

sub {
  vertical-align: sub;
  font-size: smaller; }

sup {
  vertical-align: super;
  font-size: smaller; }

.center {
  text-align: center; }

.right {
  text-align: right; }

.sectionHeader {
  margin: 20px 0 20px 0;
  padding: 0;
  border-left: 5px solid #222222;
  display: flex;
  display: -ms-flex;
  display: -webkit-flex;
  justify-content: space-between;
  align-content: center;
  align-items: center;
  flex-wrap: wrap; }
  @media (max-width: 720px) {
    .sectionHeader {
      margin: 15px 0;
      border-left: 4px solid #222222; } }
  @media (min-width: 721px) and (max-width: 960px) {
    .sectionHeader {
      margin: 15px 0 15px 0;
      border-left: 5px solid #222222; } }
  .sectionHeader h1, .sectionHeader h2, .sectionHeader h3, .sectionHeader h4, .sectionHeader h5, .sectionHeader h6 {
    display: inline-block;
    margin: 0;
    line-height: 30px;
    padding: 5px 0 5px 10px;
    line-height: 1.5;
    border: none; }
  .sectionHeader p.detail {
    margin: 0; }
    .sectionHeader p.detail a {
      display: block;
      background-color: #ffffff;
      border: 1px solid #dddddd;
      transition: all 0.2s ease-in-out;
      padding: 5px 30px 5px 15px;
      position: relative;
      color: #222222;
      font-size: 13px; }
      @media (max-width: 960px) {
        .sectionHeader p.detail a {
          transition: all 0s ease-in-out; } }
      @media (min-width: 961px) and (max-width: 1280px) {
        .sectionHeader p.detail a {
          padding: 5px 20px 5px 10px; } }
      .sectionHeader p.detail a:before {
        content: "";
        width: 6px;
        height: 6px;
        display: block;
        border-right: 1px solid #0066CC;
        border-bottom: 1px solid #0066CC;
        transform: rotate(-45deg);
        position: absolute;
        right: 10px;
        top: 50%;
        margin: -4px 0 0 0;
        transition: all 0.2s ease-in-out; }
        @media (min-width: 961px) and (max-width: 1280px) {
          .sectionHeader p.detail a:before {
            right: 5px; } }
      .sectionHeader p.detail a:hover {
        border: 1px solid rgba(0, 102, 204, 0.5);
        color: #0066CC;
        text-decoration: none; }
        .sectionHeader p.detail a:hover:before {
          right: 5px; }

.barHeader {
  margin: 40px 0 10px 0;
  padding: 0;
  border-bottom: 1px solid #dddddd;
  display: flex;
  display: -ms-flex;
  display: -webkit-flex;
  justify-content: space-between;
  align-content: center;
  align-items: center; }
  @media (max-width: 720px) {
    .barHeader {
      margin: 0 0 10px 0;
      padding: 10px 15px 0 15px;
      border-bottom: none; } }
  @media (min-width: 721px) and (max-width: 960px) {
    .barHeader {
      margin: 20px 0 10px 0;
      padding: 0; } }
  .barHeader h1, .barHeader h2, .barHeader h3, .barHeader h4, .barHeader h5, .barHeader h6 {
    display: inline-block;
    margin: 0 0 -2px 0;
    padding: 15px 0;
    line-height: 1.5;
    border: none;
    border-bottom: 3px solid #222222; }
    @media (max-width: 720px) {
      .barHeader h1, .barHeader h2, .barHeader h3, .barHeader h4, .barHeader h5, .barHeader h6 {
        margin: 0;
        padding: 10px 0 10px 0;
        border-bottom: none; } }
    @media (max-width: 720px) {
      .barHeader h1 span, .barHeader h2 span, .barHeader h3 span, .barHeader h4 span, .barHeader h5 span, .barHeader h6 span {
        display: none; } }
  .barHeader p {
    margin: 0;
    line-height: 1.25; }
    .barHeader p a {
      display: block;
      background-color: #ffffff;
      border: 1px solid #dddddd;
      transition: all 0.2s ease-in-out;
      padding: 10px 30px 10px 15px;
      position: relative;
      color: #222222;
      font-size: 13px; }
      @media (max-width: 720px) {
        .barHeader p a {
          background-color: #777777;
          border: 1px solid #777777;
          transition: all 0s ease-in-out;
          padding: 10px 20px 10px 15px;
          margin: 0 5px 0 0;
          color: #ffffff;
          font-size: 12px;
          display: block; } }
      @media (min-width: 721px) and (max-width: 960px) {
        .barHeader p a {
          transition: all 0s ease-in-out; } }
      .barHeader p a:before {
        content: "";
        width: 6px;
        height: 6px;
        display: block;
        border-right: 1px solid #0066CC;
        border-bottom: 1px solid #0066CC;
        transform: rotate(-45deg);
        position: absolute;
        right: 15px;
        top: 50%;
        margin: -4px 0 0 0;
        transition: all 0.2s ease-in-out; }
        @media (max-width: 720px) {
          .barHeader p a:before {
            border-right: 1px solid #ffffff;
            border-bottom: 1px solid #ffffff;
            transition: all 0s ease-in-out; } }
        @media (min-width: 721px) and (max-width: 960px) {
          .barHeader p a:before {
            transition: all 0s ease-in-out; } }
      .barHeader p a:hover {
        border: 1px solid rgba(0, 102, 204, 0.5);
        color: #0066CC;
        text-decoration: none; }
        .barHeader p a:hover:before {
          right: 10px; }
      @media (max-width: 720px) {
        .barHeader p a span {
          display: none; } }

aside#banner {
  margin: 0 30px 0 0;
  position: relative; }
  @media (max-width: 720px) {
    aside#banner {
      margin: 0; } }
  aside#banner ul {
    margin: 0; }
    @media screen and (min-width: 641px) and (max-width: 720px) {
      aside#banner ul {
        display: flex;
        display: -ms-flex;
        display: -webkit-flex;
        flex-wrap: wrap; } }
    @media (min-width: 721px) and (max-width: 960px) {
      aside#banner ul {
        display: flex;
        display: -ms-flex;
        display: -webkit-flex;
        flex-wrap: wrap; } }
    aside#banner ul li {
      display: block;
      position: relative;
      margin: 0 0 20px 0; }
      @media screen and (min-width: 641px) and (max-width: 720px) {
        aside#banner ul li {
          display: block;
          position: relative;
          width: 48%;
          margin: 0 1% 10px 1%; } }
      @media (min-width: 721px) and (max-width: 960px) {
        aside#banner ul li {
          display: block;
          position: relative;
          width: 48%;
          margin: 0 1% 10px 1%; } }
      aside#banner ul li a {
        display: block;
        position: relative;
        color: #222222;
        background-color: #ffffff;
        margin: 0;
        padding: 0 0 20px 0; }
        aside#banner ul li a h4, aside#banner ul li a p {
          padding: 0 10px;
          margin: 0; }
        aside#banner ul li a h4 {
          margin: 1em 0; }
        aside#banner ul li a:hover {
          opacity: 0.7;
          text-decoration: none; }

.scrollBox {
  padding: 20px;
  margin: 0 auto 20px auto;
  border: 1px solid #dddddd;
  height: 300px;
  overflow-y: scroll; }
  @media (max-width: 720px) {
    .scrollBox {
      padding: 15px;
      margin: 0 auto 15px auto;
      height: 50vw; } }
  @media (min-width: 721px) and (max-width: 960px) {
    .scrollBox {
      padding: 15px;
      margin: 0 auto 15px auto; } }
  @media (min-width: 961px) and (max-width: 1280px) {
    .scrollBox {
      padding: 15px;
      margin: 0 auto 15px auto;
      height: 240px; } }

@media (max-width: 720px) {
  li {
    word-break: break-all; } }

small.smallText, strong.smallText, b.smallText, em.smallText {
  font-size: 12px;
  color: #777777; }

/*=========================================================
20210319　穴井関連キーワードCSS追加
=========================================================*/
ul.keyword li {
  display: inline-block; }
  ul.keyword li:not(:last-child)::after {
    content: ","; }

/*# sourceMappingURL=editor.css.map */
