@charset "UTF-8";
/* --------------------------------------------------
 Block
-------------------------------------------------- */
/* Common Block --------------- */
.commBlc {
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 4%;
}

@media screen and (max-width: 1000px) {
  /* Common Block --------------- */
  .commBlc {
    width: 100%;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
}

/* --------------------------------------------------
 Title
-------------------------------------------------- */
/* Page Title --------------- */
.pageTtl {
  margin: 0 0 40px;
}

.pageTtl .img img {
  width: 100%;
}

.pageTtl .ttl {
  background-color: #000;
  font-size: 220%;
  color: #fff;
  text-align: center;
  padding: 5px 4%;
}

/* Title Model 01 and Title Model 02 --------------- */
.ttlModel01,
.ttlModel02 {
  font-size: 270%;
  color: #000;
  text-align: center;
  border-bottom: 3px solid #cfcfcf;
  padding: 80px 4% 75px;
  position: relative;
}

.ttlModel01:after,
.ttlModel02:after {
  background: url(../img/common/arrow_down_title.jpg) scroll no-repeat;
  content: "";
  width: 67px;
  height: 22px;
  position: absolute;
  bottom: -22px;
  left: 0;
  right: 0;
  margin: 0 auto;
}

/* Title Model 02 --------------- */
.ttlModel02 {
  padding: 80px 4% 30px;
}

.ttlModel02 .subTtl {
  font-size: 50%;
  margin: 30px 0 0;
  display: block;
}

/* Title Model 03 --------------- */
.ttlModel03 {
  font-size: 140%;
  border-bottom: 1px dashed #666666;
  padding: 10px 0 10px 2%;
  margin: 0 0 20px;
}

/* Title Model 04 --------------- */
.ttlModel04 {
  font-size: 160%;
  border-bottom: 1px dashed #666666;
  text-align: center;
  padding: 40px 0;
  margin: 0 0 30px;
}

@media screen and (max-width: 1000px) {
  /* Title Model 01 and Title Model 02 --------------- */
  .ttlModel01,
  .ttlModel02 {
    padding: 7% 4% 6%;
  }
}

@media screen and (max-width: 768px) {
  /* Page Title --------------- */
  .pageTtl .img {
    overflow: hidden;
    position: relative;
    padding: 0 0 52%;
  }
  .pageTtl .img img {
    width: 200%;
    max-width: none;
    margin: 0 auto;
    position: absolute;
    top: 0;
    left: -45%;
    right: 0;
  }
  .pageTtl .ttl {
    font-size: 180%;
  }
  /* Title Model 01 and Title Model 02 --------------- */
  .ttlModel01,
  .ttlModel02 {
    font-size: 240%;
  }
}

/* --------------------------------------------------
 Table
-------------------------------------------------- */
/* Common Table --------------- */
.tblComm {
  background-color: #fff;
}

.tblComm th {
  background-color: #f7f7f7;
  padding: 2%;
  text-align: left;
}

.tblComm td {
  padding: 2%;
  text-align: left;
}

.tblComm th,
.tblComm td {
  border: 1px solid #d5d5d5;
  font-size: 110%;
  line-height: 2em;
}

/* Form Table --------------- */
.tblForm th {
  background-color: #fff;
  width: 25%;
  padding: 2%;
  text-align: left;
}

.tblForm td {
  padding: 2%;
  text-align: left;
}

.tblForm th,
.tblForm td {
  border-bottom: 1px dotted #ccc;
}

/* Table Model 01 --------------- */
.tblModel01 {
  margin: 10px 0;
}

.tblModel01 th,
.tblModel01 td {
  font-size: 90%;
  color: #444;
  padding: 7px 0;
}

.tblModel01 th {
  font-weight: bold;
  border-bottom: 1px solid #ccc;
}

.tblModel01 .subj {
  font-weight: bold;
}

.tblModel01 td {
  border-bottom: 1px dotted #ccc;
}

.tblModel01 .sp {
  display: none;
}

.tblModel01 .tblSect th {
  padding-top: 40px;
}

/* Table Model 02 --------------- */
.tblModel02 th,
.tblModel02 td {
  font-size: 90%;
  color: #444;
  border: 1px solid #ccc;
  padding: 7px;
}

.tblModel02 th,
.tblModel02 .subj {
  background-color: #eee;
  font-weight: bold;
  text-align: center;
}

.tblModel02 td {
  text-align: right;
}

.tblModel02 .subjSp {
  font-weight: bold;
  display: none;
}

.tblModel02 .sp {
  display: none;
}

/* Border Dashed Table --------------- */
.tblDashBorder th,
.tblDashBorder td {
  border: 1px dashed #3a3a3a;
  padding: 4%;
}

.tblDashBorder tr:first-child th,
.tblDashBorder tr:first-child td {
  border-top: none;
}

.tblDashBorder tr:last-child th,
.tblDashBorder tr:last-child td {
  border-bottom: none;
}

.tblDashBorder th {
  background-color: transparent;
  width: 25%;
  border-left: none;
  text-align: right;
}

.tblDashBorder td {
  border-right: none;
}

@media screen and (max-width: 768px) {
  .tblComm.singleRow th,
  .tblForm.singleRow th {
    display: block;
    font-weight: bold;
    padding-top: 20px;
    padding-bottom: 0;
  }
  .tblComm.singleRow td,
  .tblForm.singleRow td {
    display: block;
    padding-bottom: 20px;
  }
  /* Form Table --------------- */
  .tblForm th {
    width: auto;
  }
  /* Table Model 01 --------------- */
  .tblModel01 .pc {
    display: none;
  }
  .tblModel01 .sp {
    display: table-header-group;
  }
  /* Table Model 02 --------------- */
  .tblModel02 .pc {
    display: none;
  }
  .tblModel02 .subjSp {
    display: block;
  }
}

/* --------------------------------------------------
 List
-------------------------------------------------- */
/* Common List --------------- */
.listComm li {
  width: 48%;
  float: left;
}

.listComm li:nth-child(even) {
  float: right;
}

/* Arrow List --------------- */
.listArrow {
  margin: 10px 0;
}

.listArrow li {
  background: url(../img/common/list_arw.gif) scroll no-repeat left center;
  padding: 0 0 0 22px;
  margin: 0 0 5px;
}

@media screen and (max-width: 768px) {
  /* Common List --------------- */
  .listComm li {
    width: 100%;
    margin: 0 0 20px;
    float: none;
  }
  .listComm li:nth-child(even) {
    float: none;
  }
}

/* --------------------------------------------------
 Button
-------------------------------------------------- */
/* --------------------------------------------------
 Text
-------------------------------------------------- */
.txtCenter {
  text-align: center;
}

.txtBig {
  font-size: 115%;
}

.txtSmall {
  font-size: 85%;
}

.txtWeight {
  font-weight: bold;
}

.txtRed {
  color: #b71212;
}

.txtGreen {
  color: #007e31;
}

.txtGreenBorder {
  color: #fff;
  text-shadow: -1px -1px 0 #007e31, 1px -1px 0 #007e31, -1px 1px 0 #007e31, 1px 1px 0 #007e31;
}

/* --------------------------------------------------
 Other Classes
-------------------------------------------------- */
/* Clear fix --------------- */
.clearFix:after {
  content: "";
  clear: both;
  display: block;
}

/* Clear --------------- */
.clear {
  clear: both;
}

/* Hide --------------- */
.hidden {
  position: absolute;
  text-indent: -9999px;
  overflow: hidden;
}

/* Form Label --------------- */
.required {
  background-color: #9a1f1f;
  font-weight: normal;
  color: #fff;
  display: inline-block;
  margin: 0 10px;
  padding: 0 5px;
  text-align: center;
  line-height: 23px;
  width: 40px;
  border-radius: 5px;
}

.nRequired {
  background-color: #797979;
  font-weight: normal;
  color: #fff;
  display: inline-block;
  margin: 0 10px;
  padding: 0 5px;
  text-align: center;
  line-height: 23px;
  width: 40px;
  border-radius: 5px;
}

/* Popup --------------- */
@media screen and (max-width: 768px) {
  .popup {
    display: block;
    position: relative;
  }
  .popup:after {
    background: rgba(0, 0, 0, 0.1) url(../img/common/popup.png) no-repeat scroll center center/100% auto;
    bottom: 5%;
    content: "";
    height: 40px;
    position: absolute;
    right: 5%;
    width: 40px;
  }
}

/* PDF icon --------------- */
.icnPdf {
  vertical-align: bottom;
  margin: 0px 3%;
}

/* translate --------------- */
.translate-wrap {
  text-align: center;
  border-bottom: 1px solid #e9e9e9;
  padding: 14px 0;
  margin: 0 15px;
}

.translate-wrap p {
  width: 100%;
  display: block;
  text-align: left;
}

.translate-item {
  display: block;
  text-align: left;
  padding: 6% 0 6% 10%;
  margin-left: 5%;
  text-decoration: none !important;
  position: relative;
}

.translate-item::before {
  content: '▷';
  font-size: 10px;
  position: absolute;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-transition: left .2s ease-in-out;
  -o-transition: left .2s ease-in-out;
  transition: left .2s ease-in-out;
}

.translate-item:hover {
  color: inherit;
}

.translate-item:hover::before {
  left: 5px;
}

/* gallery --------------- */
.page-gallery .txt {
  font-size: 160%;
  margin: 8% 0 0;
}

@media screen and (max-width: 768px) {
  .page-gallery .txt {
    font-size: 140%;
  }
}

@media screen and (max-width: 480px) {
  .page-gallery .txt {
    font-size: 120%;
  }
}

.gallery-wrap {
  margin-top: 12%;
}

.gallery-wrap * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

.gallery-wrap img {
  max-width: 100%;
  vertical-align: bottom;
  height: auto;
}

.list-gallery {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: -10px;
}

.list-gallery > li {
  width: calc((100% - 40px) / 2);
  margin: 10px;
  border-bottom: 1px solid #333;
}

.list-gallery > li:nth-child(n+3) {
  margin-top: 40px;
}

.list-gallery-desc {
  padding: 6px 0 12px;
}

@media screen and (max-width: 768px) {
  .list-gallery {
    margin: 0;
    padding-bottom: 33px;
  }
  .list-gallery > li {
    width: 100%;
    margin: 0;
  }
  .list-gallery > li:not(:first-child) {
    margin-top: 40px;
  }
}
