﻿/*==========================================
File name: base.css
Editors: IT-Force Inc.
Ver3.11 2016/05/08
========================================== */
/********
フォント（span）専用
********/
.f10_px {
  font-size: 10px;
}
.f10_px a {
  font-size: 10px;
}
.f10_px a:hover {
  font-size: 10px;
}
.f12_px {
  font-size: 12px;
}
.f12_px a {
  font-size: 12px;
}
.f12_px a:hover {
  font-size: 12px;
}
.f14_px {
  font-size: 14px;
}
.f14_px a {
  font-size: 14px;
}
.f14_px a:hover {
  font-size: 14px;
}
.f14_Class {
  font-size: 80%;
}
/*行間*/
.line_30px {
  line-height: 30px;
}
.line_20px {
  line-height: 20px;
}
.line_15px {
  line-height: 15px;
}
/*テーブル*/
table.Basic {
  border-top: 1px solid #CCC;
  border-left: 1px solid #CCC;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  font-family: 'BIZ UDPGothic', sans-serif;
}
.Basic th {
  border-right: 1px solid #CCC;
  border-bottom: 1px solid #CCC;
  color: #FFF;
  background: #333;
  padding: 1em;
  text-align: center;
  line-height: 1.4em;
  white-space: nowrap;
}
.Basic td {
  border-right: 1px solid #CCC;
  border-bottom: 1px solid #CCC;
  padding: 1em;
  line-height: 1.4em;
  white-space: nowrap;
}
table.Basic a {
  color: #00F;
}
table.Basic a:hover {
  color: #F00;
  text-decoration: underline;
}
table.basic2 {
  border-top: 1px solid #CCC;
  border-left: 1px solid #CCC;
  border-collapse: collapse;
  border-spacing: 0;
  background-color: #CCC;
  empty-cells: show;
}
.basic2 th {
  border-right: 1px solid #CCC;
  border-bottom: 1px solid #CCC;
  background-position: left top;
  padding: 0.5em 1em;
  text-align: center;
  color: #FFF;
}
.basic2 td {
  border-right: 1px solid #CCC;
  border-bottom: 1px solid #CCC;
  padding: 0.5em 1em;
  text-align: center;
}
table.basic2 a {
  color: #00F;
}
table.basic2 a:hover {
  color: #F00;
  text-decoration: underline;
}
/*ページ内共通テーブル*/
table.common_tb {
  border-top: 1px solid #DEDCDD;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
}
.common_tb th {
  border-bottom: 1px solid #DEDCDD;
  color: #FFF;
  background-image: url();
  background-position: left top;
  padding: 5px 5px;
  font-size: 12px;
  text-align: center;
}
.common_tb td {
  border-bottom: 1px solid #DEDCDD;
  padding: 8px 1em;
  font-size: 12px;
  line-height: 2em;
}
/*CGI用テーブル*/
table#form-tbl {
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
}
#form-tbl th {
  border-bottom: 1px solid #CCC;
  color: #FFF;
  background: #333;
  padding: 1em;
  text-align: center;
  line-height: 1.4em;
  white-space: nowrap;
  font-family: 'Noto Sans JP', sans-serif;
}
#form-tbl td {
  border-bottom: 1px solid #CCC;
  padding: 1em;
  line-height: 1.4em;
  white-space: wrap;
  font-family: 'Noto Sans JP', sans-serif;
  /*background: #F2F2F2;*/
  text-align: left !important;
}
table#form-tbl a {
  color: #00F;
}
table#form-tbl a:hover {
  color: #F00;
  text-decoration: underline;
}
#form {
  margin: auto;
}
.btn td {
  border: none !important;
}
/*ページ内共通テーブル*/
table.common_tb2 {
  border-top: 1px solid #DEDCDD;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
}
.common_tb2 th {
  border-bottom: 1px solid #DEDCDD;
  color: #FFF;
  background-image: url();
  background-position: left top;
  padding: 0.5em;
  font-size: 12px;
  text-align: center;
  line-height: 1.6em;
}
.common_tb2 td {
  border-bottom: 1px solid #DEDCDD;
  padding: 0.5em;
  font-size: 12px;
  line-height: 1.6em;
}
/*ページ内共通テーブル(ラインなし)*/
table.common_tb_noline {
  border-top: 0px solid;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  margin: 10px auto;
  line-height: 2em;
}
.common_tb_noline th {
  border-bottom: 0px solid;
  color: #330000;
  background-position: left top;
  text-align: left;
}
.common_tb_noline td {
  border-bottom: 0px solid;
}
table.common_tbfood {
  border-top: 1px solid #DEDCDD;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
}
.common_tbfood th {
  border-bottom: 1px solid #DEDCDD;
  color: #FFF;
  background-position: left top;
  padding: 4px 1em;
  font-size: 12px;
  text-align: right;
  line-height: 1.8em;
}
.common_tbfood td {
  border-bottom: 1px solid #DEDCDD;
  padding: 4px 1em;
  font-size: 12px;
  line-height: 1.5em;
}
/*ページ内共通テーブル(ラインなし)*/
table.common_tb_noline {
  border-top: 0px solid;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  margin: 10px auto;
  line-height: 2em;
}
.common_tb_noline th {
  border-bottom: 0px solid;
  color: #330000;
  background-position: left top;
  text-align: left;
}
.common_tb_noline td {
  border-bottom: 0px solid;
}
/*ページ内共通テーブル(ラインなし+テキストセンタリング)*/
table.common_tb_noline_txt_c {
  border-top: 0px solid;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  margin: 0px auto;
}
.common_tb_noline_txt_c th {
  border-bottom: 0px solid;
  color: #330000;
  background-position: left top;
  text-align: center;
}
.common_tb_noline_txt_c td {
  border-bottom: 0px solid;
  text-align: center;
}
table.common_tb_noline_txt_c-2 {
  border-top: 0px solid;
  border-collapse: collapse;
  border-spacing: 0;
  empty-cells: show;
  margin: 10px auto;
}
.common_tb_noline_txt_c-2 th {
  border-bottom: 0px solid;
  color: #330000;
  background-position: left top;
  text-align: center;
}
.common_tb_noline_txt_c-2 td {
  border-bottom: 0px solid;
  text-align: center;
}
.common_tb_noline_txt_c-2 a:hover img {
  opacity: 0.5;
  filter: alpha(opacity=50);
  -ms-filter: "alpha( opacity=50 )";
}
/*ページ内共通テーブル(横線のみ)*/
table.line_w {
  border-top: 1px solid #E5E5E5;
  border-left: 0px solid #E5E5E5;
  border-collapse: collapse;
  border-spacing: 0;
  background-color: #CCC;
  empty-cells: show;
  margin: auto;
}
.line_w th {
  border-right: 0px solid #E5E5E5;
  border-bottom: 1px solid #E5E5E5;
  background-image: url();
  background-position: left top;
  padding: 0.5em 1em;
  line-height: 1.5em;
  color: #FFF;
}
.line_w td {
  border-right: 0px solid #E5E5E5;
  border-bottom: 1px solid #E5E5E5;
  padding: 0.5em 1em;
  color: #330000;
}
table.line_w a {
  color: #00F;
}
table.line_w a:hover {
  color: #F00;
  text-decoration: underline;
}
/********
scrollbar
********/
body > * {
  scrollbar-width: 5px;
  scrollbar-base-color: #FFF;
  scrollbar-track-color: #FFF;
  scrollbar-face-color: #EEE;
  scrollbar-shadow-color: #EEE;
  scrollbar-darkshadow-color: #EEE;
  scrollbar-highlight-color: #EEE;
  scrollbar-3dlight-color: #EEE;
  scrollbar-arrow-color: #FFF;
  word-wrap: break-word;
  word-break: break-all;
}
*::-webkit-scrollbar, * .block::-webkit-scrollbar {
  overflow: hidden;
  width: 5px;
  background: #FFF;
  border-radius: 3px;
}
*::-webkit-scrollbar:horizontal, * .block::-webkit-scrollbar:horizontal {
  height: 5px;
}
*::-webkit-scrollbar-button, * .block::-webkit-scrollbar-button {
  display: none;
}
*::-webkit-scrollbar-piece, * .block::-webkit-scrollbar-piece {
  background: #FFF;
}
*::-webkit-scrollbar-piece:start, * .block::-webkit-scrollbar-piece:start {
  background: #FFF;
}
*::-webkit-scrollbar-thumb, * .block::-webkit-scrollbar-thumb {
  overflow: hidden;
  border-radius: 3px;
  background: #CCC;
}
*::-webkit-scrollbar-corner, * .block::-webkit-scrollbar-corner {
  overflow: hidden;
  border-radius: 3px;
  background: #CCC;
}
/* ------------------------------
   #tabAccordion
------------------------------ */
#tabAccordion {
  margin: 0 auto;
  width: 100%;
  height: 400px;
  font-size: 12px;
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
  border: #CCC 1px solid;
  position: relative;
}
#tabAccordion dl {
  top: 0;
  left: 0;
  width: 100%;
  position: absolute;
}
#tabAccordion dl dt {
  top: 0;
  left: 0;
  width: 150px;
  font-weight: bold;
  position: absolute;
  border-right: #FFF 1px solid;
  border-bottom: #FFF 1px solid;
  background: #CCC;
  color: #000;
  box-sizing: border-box;
}
#tabAccordion dl:nth-child(2) dt {
  left: 150px;
}
#tabAccordion dl:nth-child(3) dt {
  left: 300px;
}
#tabAccordion dl:nth-child(4) dt {
  left: 450px;
}
#tabAccordion dl:nth-child(5) dt {
  left: 600px;
  border-right: none;
}
#tabAccordion dl dt a {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
  padding: 8px 0;
  display: block;
  text-align: center;
  -moz-transition: all 0.2s linear;
  -webkit-transition: all 0.2s linear;
  transition: all 0.2s linear;
  color: #000;
  font-weight: normal;
}
#tabAccordion dl dt.btnAcv {
  border-bottom: none;
  background: #0B102D;
}
#tabAccordion dl dt.btnAcv a {
  color: #FFF;
}
#tabAccordion dl dt.btnAcv a:hover {
  color: #333;
}
@media only screen and (min-width: 768px) {
  #tabAccordion dl dt:hover > a {
    background: #fff;
  }
}
#tabAccordion dl dd {
  top: 50px;
  left: 0;
  padding: 12px;
  width: 100%;
  height: 350px;
  text-align: left;
  overflow-y: auto;
  display: none; /*編集の際はこれををコメントアウト*/
  position: absolute;
  box-sizing: border-box;
}
#tabAccordion dl dd a {
  font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "sans-serif";
}
#tabAccordion dl dd p {
  padding-bottom: 2em;
  line-height: 2em;
}
/* ------------------------------
   MEDIAQUERIES LAYOUT
------------------------------ */
@media only screen and (max-width: 1124px) {
  #tabAccordion {
    width: 100%;
    box-sizing: border-box;
  }
  #tabAccordion dl {
    width: 100%;
    box-sizing: border-box;
  }
  #tabAccordion dl dt {
    width: 20%;
  }
  #tabAccordion dl:nth-child(2) dt {
    left: 20%;
  }
  #tabAccordion dl:nth-child(3) dt {
    left: 40%;
  }
  #tabAccordion dl:nth-child(4) dt {
    left: 60%;
  }
  #tabAccordion dl:nth-child(5) dt {
    left: 80%;
  }
}
/* ------------------------------
   MEDIAQUERIES[SP]LAYOUT
------------------------------ */
@media only screen and (max-width: 679px) {
  #tabAccordion {
    width: 100%;
    height: auto;
    border: none;
  }
  #tabAccordion dl {
    top: auto;
    left: auto;
    width: 100%;
    position: relative;
  }
  #tabAccordion dl dt {
    top: auto;
    left: auto;
    width: 100%;
    position: relative;
    border-bottom: #FFF 1px solid;
    border-right: none;
  }
  #tabAccordion dl:first-child dt {
    border-top: #FFF 1px solid;
  }
  #tabAccordion dl:nth-child(2) dt, #tabAccordion dl:nth-child(3) dt, #tabAccordion dl:nth-child(4) dt, #tabAccordion dl:nth-child(5) dt {
    left: auto;
  }
  #tabAccordion dl dt a {
    padding: 10px 20px;
    height: auto;
    line-height: 1em;
    text-align: left;
  }
  #tabAccordion dl dt a:after {
    content: '';
    margin-top: -4px;
    top: 50%;
    right: 15px;
    width: 8px;
    height: 8px;
    font-size: 1em;
    font-weight: bold;
    line-height: 1.2em;
    display: block;
    position: absolute;
    border-top: 1px solid #FFF;
    border-right: 1px solid #FFF;
    -moz-transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
    transform: rotate(135deg);
  }
  #tabAccordion dl dt.btnAcv {
    border-bottom: #FFF 1px solid;
    background: #0B102D;
  }
  #tabAccordion dl dt.btnAcv a:hover {
    color: #FFF;
  }
  #tabAccordion dl dt.btnAcv a:after {
    content: none;
  }
  #tabAccordion dl dd {
    top: auto;
    left: auto;
    padding: 4px 8px 4px 8px;
    width: 100%;
    height: auto;
    position: relative;
    border-bottom: #FFF 1px solid;
  }
}
.msg {
  color: #DB0306;
  font-weight: bold;
}
.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.youtube iframe {
  width: 100%;
  height: 100%;
}
a.anchor {
  display: block;
  padding-top: 100px;
  margin-top: -100px;
  cursor: default;
}
/* ブラウザのスクロールバーを常に表示させることでカクカクッとなるのを防ぐ */
html {
  overflow-y: scroll;
}
/* ローディングの背景部分のCSS */
.loader {
  background: #000;
  height: 100%;
  left: 0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 120;
}
/* ローディングのアニメーション部分のCSS (https://projects.lukehaas.me/css-loaders/) */
.loader-animation, .loader-animation:before, .loader-animation:after {
  background: #ffffff;
  -webkit-animation: load1 1s infinite ease-in-out;
  animation: load1 1s infinite ease-in-out;
  width: 1em;
  height: 4em;
}
.loader-animation {
  height: 10px;
  left: 50%;
  margin: -5px 0 0 -5px;
  position: absolute;
  top: 50%;
  width: 10px;
  color: #ffffff;
  text-indent: -9999em;
  font-size: 10px;
  -webkit-transform: translateZ(0);
  -ms-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}
.loader-animation:before, .loader-animation:after {
  position: absolute;
  top: 0;
  content: '';
}
.loader-animation:before {
  left: -1.5em;
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}
.loader-animation:after {
  left: 1.5em;
}
@-webkit-keyframes load1 {
  0%, 80%, 100% {
    box-shadow: 0 0;
    height: 4em;
  }
  40% {
    box-shadow: 0 -2em;
    height: 5em;
  }
}
@keyframes load1 {
  0%, 80%, 100% {
    box-shadow: 0 0;
    height: 4em;
  }
  40% {
    box-shadow: 0 -2em;
    height: 5em;
  }
}
/*共通枠*/
.Waku_Gray {
  width: 90%;
  border: 1px solid #CCC;
  background: #F2F2F2;
  padding: 8px;
  border-radius: 4px;
  margin: auto;
  font-size: 90%;
  color: #333;
}
.Tbfix {
  position: sticky;
  left: -1px;
}