a:hover img {
  opacity: 0.8;
}

/*===============================================================================
COMMON
===============================================================================*/
.container .pc {
  display: none;
}

/* Common */
.container .mB0 {
  margin-bottom: 0 !important;
}

.container .mB10 {
  margin-bottom: 10px !important;
}

.container .mB20 {
  margin-bottom: 20px !important;
}

.container .mB40 {
  margin-bottom: 40px !important;
}

.container .mB60 {
  margin-bottom: 60px !important;
}

.container .mT10 {
  margin-top: 10px !important;
}

.container .sp_mB0 {
  margin-bottom: 0 !important;
}

.container .sp_mB10 {
  margin-bottom: 10px !important;
}

.container .sp_mB20 {
  margin-bottom: 20px !important;
}

.container .sp_mB40 {
  margin-bottom: 40px !important;
}

.container .sp_mB60 {
  margin-bottom: 60px !important;
}

.container .sp_mT10 {
  margin-top: 10px !important;
}

ul.list {
  margin: auto;
}

ul.list li {
  text-indent: -1em;
  padding-left: 1em;
}

/* Block */
.container .wrap {
  margin-bottom: 40px;
}

.container .box {
  margin-bottom: 20px;
}

.container .imgbox {
  margin: 0px !important;
}

/* Text align */
.container .align-c {
  text-align: center;
}

.container .align-l {
  text-align: left;
}

.container .align-r {
  text-align: right;
}

/* Title Text */
.container p,
.container h1,
.container h2,
.container h3,
.container h4,
.container li,
.container th,
.container td,
.container dt,
.container dd {
  line-height: 1.8em;
  padding: 0px;
}

.container h1,
.container h2,
.container h3,
.container h4 {
  line-height: 1.4;
}

.container a {
  transition: 0.3s ease-in-out;
}

.container p,
.container li,
.container th,
.container td,
.container dd,
.container ruby {
  font-size: 1rem;
  margin: 0px 0px 20px 0px;
}

.container dt {
  font-size: 1rem;
}

.container h1 {
  font-size: 1.4em;
  border-top: solid 1px #e0e0e0;
  border-bottom: solid 1px #e0e0e0;
  margin-bottom: 20px;
  padding: 10px 0px;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  align-items: center;
}

.container h1 span.subtit {
  font-size: 0.6em;
  background: #32b16c;
  color: #FFF;
  padding: 5px;
  margin-right: 10px;
  border-radius: 5px 5px 5px 5px/5px 5px 5px 5px;
}

.container h2 {
  font-size: 1.6em;
  margin: 0px 0px 10px 0px;
  font-weight: bold;
  color: #742828;
}

.container h3 {
  font-size: 1.4em;
  margin: 0px 0px 10px 0px;
  padding-bottom: 5px;
  font-weight: bold;
  color: #32b16c;
  border-bottom: solid 2px #e0e0e0;
}

.container h3.sub {
  font-size: 1.4em !important;
  border-left: solid 7px #32b16c !important;
  line-height: 1.2em;
  padding-left: 10px !important;
  color: #333 !important;
  border-bottom: none;
}

.container h4 {
  font-size: 1.2em;
  margin: 0px 0px 10px 0px;
  font-weight: bold;
}

.container .container #link01,
.container .container #link02,
.container .container #link03,
.container .container #link04,
.container .container #link05,
.container .container #link06,
.container .container #link07,
.container .container #link08,
.container .container #link09,
.container .container #link10 {
  margin-top: -60px;
  padding-top: 60px;
}

/* SNS Area */
.container .sns ul {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  margin-bottom: 20px;
}

.container .sns ul li {
  margin: 0px 10px 0px 0px;
}

/* Mokuji Area */
.container .mokuji {
  max-width: 500px;
  margin: 0px auto 40px auto;
  background: #f4f4f4;
  border: solid 1px #e0e0e0;
  padding: 20px 30px 30px 30px;
}

.container .mokuji h2 {
  text-align: center;
  font-size: 1.2em;
  color: #333;
}

.container .mokuji ul li {
  margin-bottom: 10px;
  background: url(images/icon03.png) left 8px no-repeat;
  padding-left: 15px;
}

.container .mokuji ul li:last-child {
  margin-bottom: 0px;
}

.container .mokuji ul li a {
  color: #32b16c;
}

.container .mokuji ul li a:hover {
  text-decoration: none;
  color: #333;
}

/* Wrap Orange Bold Area */
.container .wrapbox01 {
  background: #fffeed;
  border: solid 1px #f8b551;
  padding: 20px;
  margin-bottom: 40px;
  box-sizing: border-box;
}

.container .wrapbox01 p:last-child {
  margin-bottom: 0px;
}

.container .wrapbox01 h3 {
  border: none;
  padding: 0px;
  font-size: 1.2em;
  color: #f19149;
}

.container .wrapbox01 h4 {
  border: none;
  padding: 0px;
  font-size: 1.2em;
  color: #32b16c;
}

/* Wrap Orange Area */
.container .wrapbox02 {
  border: solid 2px #f19149;
  padding: 20px;
  margin-bottom: 40px;
  position: relative;
  box-sizing: border-box;
}

.container .wrapbox02 p:last-child,
.container .wrapbox02 li:last-child {
  margin-bottom: 0px;
}

.container .wrapbox02 h3 {
  border: none;
  padding: 0px;
  font-size: 1.4em;
  text-align: center;
  color: #f19149;
  background: #FFF;
  max-width: 80%;
  margin: -35px auto 10px auto;
}

.container .wrapbox02 h4 {
  border: none;
  padding: 0px;
  font-size: 1.2em;
  color: #f19149;
}

.container .wrapbox02 strong {
  color: #f19149;
  font-weight: bold;
}

.container .wrapbox02 ul li {
  background: url(images/icon01.png) left 7px no-repeat;
  padding: 0px 0px 0px 30px;
  margin-bottom: 10px;
}

/* Wrap Green Bold Area */
.container .wrapbox03 {
  border: solid 2px #32b16c;
  padding: 20px;
  margin-bottom: 40px;
  position: relative;
  box-sizing: border-box;
}

.container .wrapbox03 p:last-child,
.container .wrapbox03 li:last-child {
  margin-bottom: 0px;
}

.container .wrapbox03 h3 {
  border: none;
  padding: 0px;
  font-size: 1.4em;
  text-align: center;
  color: #32b16c;
  background: #FFF;
  max-width: 80%;
  margin: -35px auto 10px auto;
}

.container .wrapbox03 h4 {
  border: none;
  padding: 0px;
  font-size: 1.2em;
  color: #32b16c;
}

.container .wrapbox03 strong {
  color: #32b16c;
  font-weight: bold;
}

.container .wrapbox03 ul li {
  background: url(images/icon02.png) left 7px no-repeat;
  padding: 0px 0px 0px 30px;
  margin-bottom: 10px;
}

/* MainImage Area */
.container .topimg {
  margin-bottom: 30px;
}

.container .topimg img {
  margin-bottom: 20px;
}

/* Profile Area */
.container .publisher {
  border: solid 1px #e0e0e0;
  padding: 20px;
  margin-bottom: 40px;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.container .publisher p:last-child {
  margin-bottom: 0px;
}

.container .publisher .imgbox {
  width: 30%;
}

.container .publisher .imgbox img {
  vertical-align: top;
}

.container .publisher .textbox {
  width: calc(70% - 20px);
}

.container .publisher .tit {
  margin-bottom: 10px;
}

.container .publisher .tit p {
  margin: 0px;
}

.container .publisher .tit ruby {
  font-size: 1.4em;
}

.container .readbox {
  margin-bottom: 40px;
}

.container .readbox .publisher {
  border: none;
  padding: 0px;
  width: 170px;
  display: block;
  float: left;
  margin: 0px 20px 0px 0px;
}

.container .readbox .publisher .textbox {
  width: 100%;
}

.container .readbox .publisher .imgbox {
  width: 100%;
}

.container .readbox .textbox {
  width: 100%;
}

/* Point Area */
.container .pointbox {
  justify-content: flex-start;
  line-height: 1em;
  flex-wrap: wrap;
  align-items: center;
}

.container .pointbox h3 {
  font-size: 1.4em;
  border: none;
  color: #333;
  padding: 0px;
}

.container .pointbox h3 span {
  font-size: 0.8em;
  font-weight: normal;
  color: #FFF;
  background: #f19149;
  padding: 5px;
  margin-right: 10px;
  border-radius: 5px 5px 5px 5px/5px 5px 5px 5px;
}

/* Btn Area */
.container .btnbox {
  margin-top: 40px;
}

.container .btnbox .ichiran {
  display: block;
  text-align: center;
  margin: 20px auto 40px auto;
  width: 80%;
}

.container .btnbox .ichiran a {
  display: block;
  text-align: center;
  font-size: 1.2em;
  text-decoration: none;
  padding: 20px 10px 20px 10px;
  color: #FFF;
  background-color: #32b16c;
  border: 1px solid #32b16c;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.container .btnbox .ichiran a:hover {
  background: #FFF;
  color: #32b16c;
}

.container .btnbox .ichiran a:hover:before {
  content: url(images/arrow01_over.png);
  margin-right: 10px;
}

.container .btnbox .ichiran a:before {
  content: url(images/arrow01.png);
  margin-right: 10px;
}

.container .btnbox .ichiran a span {
  transition: 0.3s ease-in-out;
  border-radius: 100px;
  background: #ffffff;
  color: #32b16c;
  padding: 5px 15px;
  margin-right: 10px;
  margin-top: -5px;
  margin-bottom: 5px;
}

.container .btnbox .ichiran a:hover span {
  background: #32b16c;
  color: #FFF;
}

.container .btnbox .banner {
  text-align: center;
}

.container .btnbox .banner a {
  display: block;
}

/* Column Area */
.container .pain2 > div + div,
.container .pain3 > div + div,
.container .pain4 > div + div {
  margin-top: 20px !important;
}

.container .pain2 + .pain2,
.container .pain2 + .pain3,
.container .pain2 + .pain4,
.container .pain3 + .pain2,
.container .pain3 + .pain3,
.container .pain3 + .pain4,
.container .pain4 + .pain2,
.container .pain4 + .pain3,
.container .pain4 + .pain4 {
  margin-top: 20px !important;
}

.container .sp_pain2,
.container .sp_pain3,
.container .sp_pain4 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}

.container .sp_pain2 > div {
  width: calc(50% - 10px);
}

.container .sp_pain3 > div {
  width: calc(33.33% - 10px);
}

.container .sp_pain4 > div {
  width: calc(25% - 10px);
}

.container .sp_pain2 > div + div,
.container .sp_pain3 > div + div,
.container .sp_pain4 > div + div {
  margin-top: 0 !important;
}

/* Table Area */
.container table.table-data {
  font-size: 87.5%;
  line-height: 1.6;
  width: 100%;
  border-collapse: collapse;
  border-top: 1px solid #ccc;
  border-right: 1px solid #ccc;
}

.container table.table-data th,
.container table.table-data td {
  vertical-align: top;
  padding: 7px 12px;
  border-left: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
}

.container table.table-data.valign-m th,
.container table.table-data.valign-m td {
  vertical-align: middle;
}

.container table.table-data.talign-c th,
.container table.table-data.talign-c td {
  text-align: center;
}

.container table.table-data th {
  background-color: #f5f7f8;
  font-weight: normal;
  text-align: left;
}

.container table.table-data thead th {
  background-color: #eceff1;
  text-align: center;
}

.container table.table-data .bg {
  background-color: #f5f7f8;
}

/* Scroll Area */
.container .scroll {
  white-space: nowrap;
  overflow: scroll;
  width: 100%;
}

.container .scroll img,
.container .scroll table {
  min-width: 600px !important;
}

/* ------------------ Page Only ------------------ */
.container h1 {
  margin: 0;
  border: none;
  padding: 0;
}
.container ul, .container li, .container a, .container p, .container section {
  margin: 0;
  padding: 0;
}
.container a {
  text-decoration: none;
}
.container .flowWrap {
  background-color: #3D0511;
  padding-bottom: 40px;
}
.container .flowWrap .pageNav {
  background-color: #84172E;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.container .flowWrap .pageNav li {
  width: calc((100% - 12px) / 4);
  text-align: center;
  margin: 4px 0;
  background-color: #3D0511;
  padding: 16px 0 64px;
  position: relative;
}
.container .flowWrap .pageNav li::after {
  position: absolute;
  display: block;
  content: url("images/arrow01.png");
  transform: translateX(-50%) rotate(90deg);
  bottom: 0;
  left: 50%;
}
.container .flowWrap .pageNav li a {
  width: 100%;
  color: #fffbfb;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.4;
  display: block;
}
.container .flowWrap section {
  margin: 0 10px;
  margin-top: 64px;
  text-align: center;
}
.container .flowWrap section > img {
  height: 100px;
  width: auto;
}
.container .flowWrap section ul {
  margin-top: 40px;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: space-between;
}
.container .flowWrap #pare01, .container .flowWrap #pare02 {
  background: url("images/backarrow01_sp.png") no-repeat center 100px;
}
.container .flowWrap #pare03 {
  background: url("images/backarrow02_sp.png") no-repeat center 100px;
}
.container .linkList {
  background-color: #FFF2E4;
  padding: 10px 0;
}
.container .linkList ul {
  margin: 0 10px;
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: center;
  row-gap: 16px;
}
.container .linkList ul li {
  width: calc((100% - 16px) / 2);
  height: 100%;
  line-height: 0;
}
.container .linkList ul li a {
  display: inline-block;
  width: 100%;
}

/* ------------------ print ------------------ */
@media print {
  .header_head {
    position: static;
  }
  body {
    width: 375px;
  }
  #popfind {
    overflow: inherit;
  }
  .popfindFull {
    max-width: 360px;
  }
}