@charset "UTF-8";

a:hover img {
  opacity: 0.80;
}

/*===============================================================================
コンテンツ
===============================================================================*/
.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: 1.0rem;
  margin: 0px 0px 20px 0px;
}
.container dt {
  font-size: 1.0rem;
}

.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;
}


.mR0 {
  margin-right: 0px !important;
}
.mT10 {  margin-top: 10px;}
.mT20 {  margin-top: 20px;}
.mT30 {  margin-top: 30px;}
.mT40 {  margin-top: 40px;}
.mB20 {  margin-bottom: 20px;}
.mB30 {  margin-bottom: 30px;}
.mB50 {  margin-bottom: 50px;}


/* ------------------ Page Only ------------------ */

.container .block03 .step_box .tit h3 {
    color: #333;
    margin-bottom: 20px;
}
.container .block03 .step_box .tit h3 span {
    font-size: 0.8em;
    font-weight: normal;
    color: #FFF;
    background: #32b16c;
    padding: 3px 13px;
    margin-right: 10px;
    border-radius: 5px 5px 5px 5px/ 5px 5px 5px 5px;
}


.container .block03 .step_list {
    margin-bottom: 40px;
}
.container .block03 .step_list li {
    width: 100%;
    margin-bottom: 10px;
}
.container .block03 .step_list li p {
    margin: 0;
}

.container .block03 .step_list li a {
    background: #32b16c;
    border-radius: 10px;
    display: block;
    padding: 10px;
    color: #ffffff;
    text-decoration: none;
}
.container .block03 .step_list li a:hover {
    opacity: 0.7;
}
.container .block03 .step_list li p.ttl span {
    background: #ffffff;
    border-radius: 8px;
    width: 5em;
    display: inline-block;
    text-align: center;
    color: #f19149;
    margin-right: 1em;
}
.container .block03 .step_list li p.ttl em {
    font-weight: bold;
}
.container .block03 .step_list li p.img {
    margin-top: 10px;
}
.container .block03 .step_list li p.img img {
    vertical-align: middle;
}

.container .block03 .step_box + .step_box {
    margin-top: 60px;
}
.container .block03 .step_box .tit h3 {
    color: #333;
}
.container .block03 .step_box .tit h3 span {
    font-size: 0.8em;
    font-weight: normal;
    color: #FFF;
    background: #32b16c;
    padding: 3px 13px;
    margin-right: 10px;
    border-radius: 5px 5px 5px 5px/ 5px 5px 5px 5px;
}

.container .block03 .step_box.step01 .wrapbox02 {
    margin-top: 20px;
}
.container .block03 .step_box.step01 .wrapbox02 ul li {
    display: block;
    margin-bottom: 0;
}
.container .block03 .step_box.step01 .wrapbox02 ul li a {
    color: #ffffff;
    background: url("images/arrow01.png") no-repeat 10px center, #582a13;
    border-radius: 3px;
    text-decoration: none;
    padding: 5px 15px 5px 35px;
    font-size: 14px;
    margin-left: -2em;
    margin-bottom: 10px;
    display: block;
}


.container .block03 .step_box.step02 .wrapbox02 {
    margin-top: 10px;
}


/* item */

.container .item.check {
  background: #f2ffb6;
}
.container .item + .item {
    margin-top: 40px;
}

.container .item .pointbox h3 {
  color: #333;
}

.container .item figure {
  text-align: center;
}

.container .item figure img {
  margin-bottom: 10px;
}

.container .item .sche {
  margin-bottom: 10px;
}

.container .item h3 {
  font-size: 16px;
  border: none;
  margin: 0px;
  color: #32b16c;
}
.container .item h3 > span.icon {
  background: #32b16c;
  border-radius: 100px;
  font-weight: normal;
  font-size: 16px;
  padding: 3px 10px;
  margin-right: 10px;
  color: #ffffff;
}

.container .item p {
  margin-bottom: 10px;
}
.container .item p em {
    font-weight: bold;
    color: #f19149;
}

.container .item p span.data {
  color: #f19149;
  font-weight: bold;
  display: block;
}
.container .item p strong.read {
  color: #571519;
  font-weight: bold;
  display: block;
}

.container .item .itembtn {
  margin: 0px 0px 10px 0px;
  padding: 0px;
}

.container .item .itembtn a {
  text-align: center;
  font-size: 1.2em;
  text-decoration: none;
  padding: 15px;
  color: #FFF;
  background-color: #582a13;
  border: 1px solid #582a13;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
}

.container .item .itembtn a:hover {
  background: #FFF;
  color: #32b16c;
  border: 1px solid #32b16c;
}

.container .item .itembtn a:hover:before {
  content: url(images/arrow01_over.png);
  margin-right: 10px;
}

.container .item .itembtn a:before {
  content: url(images/arrow01.png);
  margin-right: 10px;
}

.container .pointwrap img {
  margin-bottom: 50px;
}

.container .challenge .itembtn {
  margin-bottom: 0px;
}

/* table */
.container table.table {
    width: 100%;
}
.container table.table th {
    background:#e6ede3; 
}
.container table.table th,
.container table.table td {
    width: 25%;
    text-align: center;
    padding: 5px;
}
.container table.table,
.container table.table th,
.container table.table td {
    border-collapse: collapse;
    border:1px solid #333;
}

@media print {
    .header_head {
        position: static;
    }
    body{
        width: 375px;
    }
    #popfind {
        overflow: inherit;
    }
    .popfindFull {
        max-width: 360px;
    }
}

