@charset "utf-8";
/*--------------------------------------------------------

  home

  01. forPC Layout

  02. forSP Layout

  03. forSP Layout (max-width: 321px)

--------------------------------------------------------*/






/********************************************************************************

  01. forPC Layout

********************************************************************************/

/* ----------------------------------
  PC　SP view divergence - utility
---------------------------------- */
.u-media-pc {
  display: block;
}
.u-media-sp {
  display: none;
}

/* ============================================================ firstview */
.firstview_wrap{
  padding: 40px 0 0;
  background: #faf3df;
}

.firstview {
    width: 1200px;
    margin: 0 auto;
}

.firstview .ribbon{
  display: block;
  padding: 22px 30px;
  color: #0096e0;
  background-color: #ccc;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 32px;
  font-weight: 700;
  line-height: 1.15;
}
.firstview .ribbonYellow{
  background-color: #fff000;
}
.firstview .ribbon .ind{
/*  margin: 0 0 0 -.4em;*/
}

.firstview .substance {
  position: relative;
  padding: 0 120px 0 0;
}
.firstview h2 {
    margin: 34px 120px 0 120px;
    color: #0096e0;
    font-family: 'Noto Sans JP', sans-serif;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.15;
}
.firstview .substance img {
    float: left;
    margin: 34px 120px 230px;
}
.firstview .substance h3 {
  padding: 32px 0 0;
  font-size: 20px;
  font-weight: bold;
}
.firstview .substance h4 {
  font-size: 18px;
  font-weight: bold;
}
.firstview .substance h5 {
  font-size: 16px;
  font-weight: bold;
}

.detail_wrap{
  display: flex;
  flex-wrap: wrap;
  margin: 0 0 5px;
}
.firstview .detail_wrap dt,
.firstview .detail_wrap dd {
  padding: 14px 5px;
  border-left: 1px solid #000;
  border-top: 1px solid #000;
  font-size: 14px;
  text-align: center;
}
.firstview .detail_wrap dt {
  background: #ebebeb;
}
.firstview .detail_wrap dd {
  border-bottom: 1px solid #000;
  background: #fff;
}
.firstview .detail_wrap dl {
  box-sizing: border-box;
  flex-basis: 12.5%;
}
.firstview .detail_wrap dl.title {
  flex-basis: 37%;
}
.firstview .detail_wrap dl.title dd {
  text-align: left;
}
.firstview .detail_wrap dl:last-child {
  border-right: 1px solid #000;
}

.info_wrap{
  display: flex;
  flex-wrap: wrap;
  padding: 0 0 5px;
}
.info_wrap:last-child{
  padding: 0 0 10px;
}
.firstview .info_wrap dt,
.firstview .info_wrap dd {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  min-height: 16px;
  padding: 5px 10px;
  border-left: 1px solid #000;
  border-top: 1px solid #000;
  font-size: 14px;
  line-height: 1.1;
  text-align: center;
}
.firstview .info_wrap dt {
  flex-basis: 28%;
  justify-content: center;
  background: #ebebeb;
}
.firstview .info_wrap dd {
  flex-basis: 72%;
  background: #fff;
  text-align: left;
}
.firstview .info_wrap dl {
  box-sizing: border-box;
  flex-basis: 49.9%;
  display: flex;
}
.firstview .info_wrap dl:nth-child(2n) {
  border-right: 1px solid #000;
}
.firstview .info_wrap dl:nth-last-child(-n+2) {
  border-bottom: 1px solid #000;
}

.firstview .info_wrap dl:nth-child(2n+1) {
  flex-basis: 45%;
}
.firstview .info_wrap dl:nth-child(2n) {
  flex-basis: 55%;
}

.firstview .info_wrap dd a:link,
.firstview .info_wrap dd a:visited {
  color: #0096e0;
}
.firstview .info_wrap dd a:hover {
  opacity: 0.7;
}

/* ============================================================ catContent */
#contents_inner {
    height: auto !important;
    min-height: 500px;
    background: url(../img/common/bg_contents_inner_shou.svg) repeat;
    background-size: 1500px 1160px;
    background-position: center 0;
}

#subCat {
  padding: 25px 0;
}
#subCat .box-bg {
  width: 960px;
  margin: 0 auto;
  padding: 25px 0;
  background: transparent;
}
#subCat .subInner {
}
.box {
}
.box_align_center {
  display: flex;
  align-items: center;
}

.box_inner {
  margin: auto;
  padding: 40px;
}
.box_inner .box_inner_note {
  font-size: 13px;
  line-height: 1.4;
}
.box_inner_link a{
  display: block;
  margin: 0 0 30px;
  padding: 20px;
  background: #fff;
}
#container .box_inner_link a {
  font-weight: normal;
}
#container .box_inner_link a:hover {
  text-decoration: none;
}

#subCat h3 {
  font-size: 24px;
  font-weight: bold;
  line-height: 1.5;
}
#subCat h3.darkblue {
  color: #2f4c8b;
}
#subCat h3.pink {
  color: #e22b8b;
}

#subCat h4 {
  font-size: 21px;
  font-weight: bold;
  line-height: 1.5;
}
#subCat h4.darkblue {
  color: #2f4c8b;
}
#subCat h4.list_pink {
  position: relative;
  padding: 0 0 0 20px;
}
#subCat h4.list_pink:before {
  position: absolute;
  left: 0;
  top: 6px;
  content: '';
  height: 16px;
  width: 16px;
  border-radius: 50%;
  background: #f97c9c;
}

p {
  font-size: 16px;
  line-height: 1.8;
}

/* googleform */
.googleform_wrapper {
  position: relative;
  width: 100%;
  height: 1800px;
  /*overflow-y: scroll;*/
}
.googleform_wrapper iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#subCat .box a:hover .data_wrap {
  background:#eee;
}
#subCat .data_wrap {
  display: flex;
  flex-wrap: wrap;
  padding: 10px 20px;
  background: #fff;
  line-height: 1.4;
  font-size: 15px;
}
#subCat .data_wrap dl {
  flex-basis: 13.5%;
  margin: 0 0.5%;
}
#subCat .data_wrap dl dt{
  display: inline-block;
  padding: 2px;
  border-radius: 3px;
  background: #dfdfdf;
  font-size: 12px;
}
#subCat .data_wrap dl.data_page{
  flex-basis: 10.5%;
}
#subCat .data_wrap dl.data_category{
  flex-basis: 19.5%;
}
#subCat .data_wrap dl.data_thumbnail dd{
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  height: 80px;
  width: 142px;
  background: #faf3df;
  text-align: center;
}
#subCat_2 .data_wrap dl.data_thumbnail dd{
  color: #fd5554;
}
#subCat_3 .data_wrap dl.data_thumbnail dd{
  color: #f08c1e;
}

#subCat .data_wrap dl.data_thumbnail dd:before{
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 30px;
  width: 30px;
}
#subCat_1 .data_wrap dl.data_thumbnail dd:before{
  background: url(../img/common/ico_movie.svg);
}
#subCat_2 .data_wrap dl.data_thumbnail dd:before{
  background: url(../img/common/ico_sound.svg);
}
#subCat_3 .data_wrap dl.data_thumbnail dd:before{
  background: url(../img/common/ico_website.svg);
}

#subCat .data_wrap dl.data_section{
}
#subCat .data_wrap dl.data_section dt{
  color: #fff;
}
#subCat_1 .data_wrap dl.data_section dt{
  background: #4d983c;
}
#subCat_2 .data_wrap dl.data_section dt{
  background: #fd5554;
}
#subCat_3 .data_wrap dl.data_section dt{
  background: #f08c1e;
}

#subCat .data_wrap dl.data_description{
  flex-basis: 38%;
}
#subCat .data_wrap dl.data_description dt + dd{
  min-height: 40px;
}
#subCat_1 .data_wrap dl.data_description dd:last-child{
  position: relative;
  padding: 0 0 0 20px;
}
#subCat_1 .data_wrap dl.data_description dd:last-child:before{
  content: "";
  position: absolute;
  bottom: 4px;
  left: 0;
  height: 16px;
  width: 16px;
  background: url(../img/common/ico_time.svg);
}
#subCat .link_copy {
  position: absolute;
  right: 30px;
  top: 10px;
  z-index: 5;
  padding: 0 2px;
  background: #fff;
  border: 1px solid #dfdfdf;
  font-size: 11px;
  cursor: pointer;
}
#subCat .link_copy:hover {
  background: #ecf7fa;
  border: 1px solid #a3d5ed;
}
.subCat{
  position: relative;
  margin: 0 0 30px;
  padding: 14px 25px 16px;
  background: #f97c9c;
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 28px;
  font-weight: 500;
  line-height: 1.1;
}
.subCat:after {
    content: "";
    position: absolute;
    bottom: -20px;
    left: 42px;
    width: 0;
    height: 0;
    margin-top: 4px;
    border-style: solid;
    border-width: 18px 0 18px 18px;
    border-color: transparent transparent transparent #fa7b9c;
    transform: rotate(-45deg);
}

.subCat_linex2{
  padding: 0 25px 9px;
  line-height: 1;
}

.subCat .text-middle {
    font-size: 26px;
}
.subCat .text-ex-middle {
    font-size: 23px;
}

.subCat.ico_tablet {
  background: url(../../img/common/ico_tablet.svg) no-repeat #f97c9c right 25px center;
  background-size: auto 34px;
}
.subCat.ico_slide {
  background: url(../img/common/ico_slide.svg) no-repeat #fffde5 right 25px center;
  background-size: auto 32px;
}
.subCat.ico_movie {
  background: url(../img/common/ico_movie.svg) no-repeat #fffde5 right 25px center;
  background-size: auto 32px;
}
.subCat.ico_link {
  background: url(../img/common/ico_link.svg) no-repeat #fffde5 right 25px center;
  background-size: auto 32px;
}
.subCat.ico_post {
  background: url(../img/common/ico_post.svg) no-repeat #fffde5 right 25px center;
  background-size: auto 32px;
}
@media all and (-ms-high-contrast:none){
  *::-ms-backdrop, 
.subCat.ico_tablet {background-position: 620px center;}
.subCat.ico_slide {background-position: 620px center;}
.subCat.ico_movie {background-position: 620px center;}
.subCat.ico_link {background-position: 620px center;}
.subCat.ico_post {background-position: 620px center;}
/* IE11 */
}

#subCat h2.subCat .dl{
  position: relative;
  top: -4px;
  /*margin: 0 0 0 60px;*/
  padding: 6px 10px 6px 60px;
  background: #0096e0;
  color: #fff;
  font-size: 18px;
  transition: opacity .25s linear;
}
#subCat h2.subCat .dl:before {
  position: absolute;
  left: 20px;
  top: 50%;
  margin: -11px 0 0;
  content: "";
  height: 24px;
  width: 24px;
  background: url(../img/common/blt_arrow_disc.svg);
}
#subCat h2.subCat .dl:hover {
  opacity: 0.7;
}

#subCat h2.subCat.subCat_black{
  position: relative;
  padding: 9px 0;
  background: none;
  color: #000;
  font-family: 'Noto Sans JP', sans-serif;
  font-size: 28px;
  font-weight: 400;
  letter-spacing: .05em;
  text-align: center;
}

#subCat .ico_wrap {
	position: relative;
}
#subCat .ico_wrap .ico {
  display: flex;
  justify-content: center;
}
#subCat .ico_wrap .ico img{
  margin: 16px 45px;
}
#subCat .ico_wrap .txt {
	width: 290px;
	position: absolute;
	right: 190px;
	font-size: 14px !important;
	line-height: 1.5 !important;
}

.box_inner_img {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-around;
    align-items: center;
    padding: 5px 0 0;
    min-height: 300px;
}

.ico_circle_play, .ico_circle_pdf {
    position: relative;
    display: flex;
    border: 1px solid #c9c9ca;
}
.ico_circle_play:after {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    content: "";
    height: 80px;
    width: 80px;
    background: url(../img/common/ico_circle_play.svg) no-repeat;
    background-size: 80px 80px;
}

.popup {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  opacity: 0;
  visibility: hidden;
  transition: .6s;
}
.popup.is-show {
  opacity: 1;
  visibility: visible;
}
.popup-inner {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: 80%;
  max-width: 600px;
  padding: 50px;
  background-color: #fff;
  z-index: 2;
}
.popup-inner img {
  width: 100%;
}
.popup-inner li {
    margin: 0 0 0 1em;
    list-style: disc;
    text-align: left;
}
.close-btn {
  position: absolute;
  right: 0;
  top: 0;
  width: 50px;
  height: 50px;
  line-height: 50px;
  text-align: center;
  cursor: pointer;
}
.close-btn i {
  font-size: 20px;
  color: #333;
}
.black-background {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0,0,0,.8);
  z-index: 1;
  cursor: pointer;
}


/********************************************************************************

  02. forSP Layout
    *横幅が667px以下の場合


********************************************************************************/

@media screen and (min-width: 0px) and (max-width: 668px) {



/* ----------------------------------
  PC　SP view divergence - utility
---------------------------------- */
.u-media-pc {
  display: none;
}
.u-media-sp {
  display: block;
}

img {
  height: auto;
  width: 100%;
}

/* ============================================================ firstview */
.firstview_wrap {
    padding: 20px 0 0;
}
.firstview {
    width: 94%;
    margin: 0 auto;
}
.firstview h2 {
    margin: 34px 0 0 0;
    padding: 0 3%;
    font-size: 16px;
}
.firstview .substance h3 {
    padding: 10px 0 0;
    font-size: 16px;
    text-align: left;
}

.firstview .substance h4 {
    font-size: 15px;
    text-align: left;
}
.firstview .substance h5 {
  font-size: 14px;
  text-align: left;
}

.firstview .substance {
    padding: 0;
    text-align: center;
}
.firstview .substancep p {
    text-align: left;
}
.firstview .substance img {
    float: none;
    max-width: 200px;
    width: 60%;
    margin: 20px 20% 0;
}
.firstview .ribbon {
    padding: 8px 3%;
    font-size: 16px;
    line-height: 1.5;
}

.detail_wrap{
  flex-wrap: wrap;
}
.firstview .detail_wrap dl {
  flex-basis: 25%;
}
.firstview .detail_wrap dl.title {
  flex-basis: 75%;
}
.firstview .detail_wrap dt, .firstview .detail_wrap dd {
    padding: 7px 2px;
}
.firstview .detail_wrap dl.title dt, .firstview .detail_wrap dl.title dd {
    border-right: 1px solid #000;
}
.firstview .detail_wrap dl:nth-child(1) dd, .firstview .detail_wrap dl.title dd {
    border-bottom: none;
}

.firstview .info_wrap dl {
    flex-basis: 100%;
    border-right: 1px solid #000;
}
.firstview .info_wrap dl:nth-last-child(2) {
    border-bottom: none;
}
.firstview .info_wrap dt {
    flex-basis: 27%;
}
.firstview .info_wrap dt, .firstview .info_wrap dd {
    padding: 2px 10px;
    min-height: 31px;
}

.firstview .info_wrap dl:nth-child(2n+1) {
    flex-basis: 100%;
}
.firstview .info_wrap dl:nth-child(2n) {
    flex-basis: 100%;
}

/* ============================================================ catContent */
#catContent{
    /*position: relative;
    margin-right: auto;
    margin-left: auto;
    max-width: 400px;*/
}
#contents {
  margin: 0;
}
#subCat {
  padding: 10px 0 120px;
}
#subCat .box-bg {
  max-width: 400px;
  width: 94%;
  padding: 10px 3%;
}
#subCat .subInner {
  padding: 10px 0;
  flex-flow: column-reverse;
}

#subCat h3 {
    font-size: 16px;
}

#subCat h4 {
  font-size: 13px;
}
#subCat h4.list_pink {
    padding: 0 0 0 15px;
}
#subCat h4.list_pink:before {
    top: 10px;
    height: 12px;
    width: 12px;
}

p {
    font-size: 12px;
    line-height: 1.6;
}

.box_inner {
  padding: 15px 5%;
}

.box_inner .box_inner_note {
  font-size: 11px;
}

.box_inner_link a {
    margin: 0 0 20px;
}

.box_inner_link a:last-child {
    margin: 0 0 0;
}

/* googleform */
.googleform_wrapper {
  height: 800px;
}

#subCat .data_wrap {
    padding: 10px 0 35px;
}
#subCat_2 .data_wrap {
    padding: 10px 0 15px;
}
#subCat .data_wrap dl {
    flex-basis: 49%;
    margin: 5px 0.5%;
}
#subCat .data_wrap dl.data_page{
  flex-basis: 49%;
}
#subCat .data_wrap dl.data_category{
  flex-basis: 49%;
}
#subCat .data_wrap dl.data_thumbnail dd {
    height: auto;
    min-height: 74px;
    width: 100%;
}
#subCat .data_wrap dl.data_thumbnail dd img {
  width: 100%;
}
#subCat .data_wrap dl.data_description {
    flex-basis: 99%;
}
#subCat .link_copy {
    right: 0;
    bottom: 15px;
    top: auto;
    width: 100%;
    font-size: 14px;
    text-align: center;
}
.subCat {
  margin: 0 0 15px;
  padding: 5px 13% 7px 3%;
  font-size: 18px;
}
.subCat:after {
  left: 30px;
  transform: rotate(-45deg) scale(0.8);
  transform-origin: left center;
}

.subCat .text-middle {
    font-size: 15px;
}
.subCat .text-ex-middle {
    font-size: 13px;
}

.subCat.ico_tablet {
  background: url(../../img/common/ico_tablet.svg) no-repeat #f97c9c right 3% center;
  background-size: auto 19px;
}
.subCat.ico_slide {
  background: url(../img/common/ico_slide.svg) no-repeat #fffde5 right 3% center;
  background-size: auto 19px;
}
.subCat.ico_movie {
  background: url(../img/common/ico_movie.svg) no-repeat #fffde5 right 3% center;
  background-size: auto 19px;
}
.subCat.ico_link {
  background: url(../img/common/ico_link.svg) no-repeat #fffde5 right 3% center;
  background-size: auto 19px;
}
.subCat.ico_post {
  background: url(../img/common/ico_post.svg) no-repeat #fffde5 right 3% center;
  background-size: auto 19px;
}

#subCat h2.subCat .dl{
    display: inline-block;
    top: 0;
    margin: 5px 0;
    padding: 4px 10px 4px 34px;
    font-size: 14px;
}
#subCat h2.subCat .dl:before {
    left: 10px;
    margin: -8px 0 0;
    height: 16px;
    width: 16px;
}
.ico_wrap .ico img {
    margin: 8px 22px;
    width: 100px;
}
.box_inner_img {
    padding: 0 5%;
    min-height: auto;
}
.ico_circle_play:after {
    height: 48px;
    width: 48px;
    background-size: 48px 48px;
}

#subCat .ico_wrap {
	position: relative;
	height: auto;
}
#subCat .ico_wrap .txt {
	width: auto;
	position: relative;
	right: 0;
}

.popup-inner {
    padding: 50px 10%;
}


}




/********************************************************************************

  03. forSP Layout
    *横幅が320px以下の場合


********************************************************************************/

@media screen and (min-width: 0px) and (max-width: 321px) {








}