@charset 'shift_jis';

/*=========================================
basic design
===========================================*/
body {
  font-family: "Hiragino Kaku Gothic Pro","Meiryo","MS Pgothic",knowledge-reg,helvetica,arial,sans-serif;
}

@media screen and (min-width: 751px) {
  body {
    min-width: 1140px;
  }
}
  
@media print, screen and (min-width: 751px) {
  .rollover {
    opacity: 1;
  }
  .rollover:hover {
    opacity: 0.8;
    text-decoration: none;
  }
}
@media print, screen and (min-width: 751px) {
  .pcOnly {
    display: block;
  }
}
@media screen and (max-width: 750px) {
  .pcOnly {
    display: none;
  }
}
@media print, screen and (min-width: 751px) {
  .spOnly {
    display: none;
  }
}
@media screen and (max-width: 750px) {
  .spOnly {
    display: block;
  }
}
.txL {
  text-align: left !important;
}
.txC {
  text-align: center !important;
}
.txR {
  text-align: right !important;
}
.vaT {
  vertical-align: top;
}
.vaM {
  vertical-align: middle;
}
.vaB {
  vertical-align: bottom;
}
.fLeft {
  float: left;
}
.fRight {
  float: right;
}
.fNone {
  float: none;
}

/*=========================================
margin
===========================================*/

@media screen and (max-width: 750px) {
  .mt5p-pcOnly {
    display: none;
    margin-top: 5%;
  }
}
@media print, screen and (min-width: 751px) {
  .mt5p-spOnly {
    display: none;
    margin-top: 5%;
  }
}

.mlrauto{
  margin: 0 auto;
}

.mt10p{
  margin-top:10%;
}

.m5p{
  margin: 5%;
}

.mt5p{
  margin-top:5%;
}

.mt2p{
  margin-top:3%;
}

.mt3p{
  margin-top:3%;
}

mb5p{
  margin-bottom: 5%;
}

.ml1p{
  margin-left: 1%;
}

.mR2p{
  margin-right: 2%;
}

.mB5p{
  margin-bottom: 5%;
}

.mLR10p{
  margin-right: 10%;
  margin-left: 10%;
}
.mLR5p{
  margin-right: 5%;
  margin-left: 5%;
}

@media screen and (max-width: 750px) {
  .mLR10p{
    margin-right: 3%;
    margin-left: 3%;
  }
}

.pLR3p{
  padding: 0 3%;
}

/*=========================================
header
===========================================*/
.header {
  width: 100%;
  border-top: 2px solid #ee5561;
  background: #fff;
  position: relative;
  z-index: 2;
  box-sizing: border-box;
}
@media print, screen and (min-width: 751px) {
  .header {
    padding: 15px 0 16px;
  }
}
@media screen and (max-width: 750px) {
  .header {
    padding: 3.466666666666666% 0 4.266666666666667% 1.6%;
  }
}
@media print, screen and (min-width: 751px) {
  .header-inner {
    width: 1152px;
    margin: 0 auto;
  }
}
@media print, screen and (min-width: 751px) {
  .header-logo {
    display: inline-block;
    vertical-align: middle;
    width: 80px;
  }
}
@media screen and (max-width: 750px) {
  .header-logo {
    width: 21.333333333333336%;
    display: inline-block;
    vertical-align: middle;
  }
}
.header-logo img {
  width: 100%;
  display: block;
}
.header-logo-link {
  color: #000;
  text-decoration: none;
}
@media print, screen and (min-width: 751px) {
  .header-text {
    display: inline-block;
    vertical-align: middle;
    font-size: 12px;
  }
}
@media screen and (max-width: 750px) {
  .header-text {
    font-size: 10px;
    vertical-align: middle;
    display: inline-block;
  }
}


/*=========================================
contents
===========================================*/
.main-contents{
  margin: 0 auto;
}

@media screen and (min-width: 751px) {
  .main-contents{
    width: 1140px;
  }
}

@media screen and (max-width: 750px) {
  .main-contents{
    width: 98%;
  }
}

section{
  /*margin: 10% 0 0;*/
}

/*------------------------
breadcrumb 
--------------------------*/
.breadcrumb {
  width: 100%;
  background: rgba(255,255,255,0.5);
  position: relative;
  z-index: 2;
  box-sizing: border-box;
  margin-bottom: 3%;
}
@media print, screen and (min-width: 751px) {
  .breadcrumb {
    padding:  0;
    background-color: #fff;
  }
}
@media screen and (max-width: 750px) {
  .breadcrumb {
    padding: 0 0 4px 3%;
    background-color: #fff;
  }
}
@media print, screen and (min-width: 751px) {
  .breadcrumb-inner {
    width: 1152px;
    margin: 0 auto;
    z-index: 2;
    padding-left:10px;
  }
}
.breadcrumb-list {
  display: inline-block;
  vertical-align: middle;
}
.breadcrumb-list:first-child::after {
  content: '>';
  font-size: 12px;
  margin-left: 6px;
  display: inline-block;
  vertical-align: middle;
}
.breadcrumb-link {
  color: #000;
  text-decoration: none;
  font-size: 12px;
}


/*------------------------
fonts
--------------------------*/

html{
  font-size: 16px;/*minimum*/
}

@media (min-width: 751px) {
  html {
    font-size: 24px;/*maximum*/
  }
}

.font80{
  font-size: 80%;
}

.font50{
  font-size: 50%;
}


h2{
  font-size: 5vw;
  text-align: center;
  font-weight: bold;
  line-height: 1.3;
}

@media screen and (min-width: 751px) {
  h2{
    font-size: 30px;
  }
  h3{
    font-size: 24px;
    font-weight: bold;
  }
  .font40{ 
    font-size:40px;
  }
  .font30{ 
    font-size:30px;
  }
  .font28{
    font-size: 28px
  }
  .font22{
    font-size: 22px;
    line-height: 1.5;
  }
  .font20{
    font-size: 20px;
  }

  .font18{
    font-size: 18px;
  }
}

@media screen and (max-width: 750px) {
  h2 {
    font-size: 20px;
  }
  .font40{ 
    font-size:30px;
  }
  .font30{ 
    font-size:20px;
  }
  .font28{
    font-size: 18px
  }
  .font22{
    font-size: 18px;
  }
  .font20{
    font-size: 16px;
    line-height: 1.5;
  }

  .font18{
    font-size: 14px;
  }
}

h2 > span{
  font-size: 150%;
}

h3{
  line-height: 1.5;
}

p{
  line-height: 1.5; 
}

.font-wb{
  font-weight: bold;
}

.text-center{
  text-align: center;
}

.indent-1{
  padding-left:1em;
  text-indent:-1em;
}

/*------------------------
border
--------------------------*/
.bt1{
  border-top: 1px solid #000;
}

/*------------------------
width
--------------------------*/

.width90p{
  width: 85%;
}

/*------------------------
a
--------------------------*/

@media screen and (min-width: 750px) {
a:hover{
    cursor:pointer;
    filter: alpha(opacity=60);        /* ie lt 8 */
    -ms-filter: "alpha(opacity=60)";  /* ie 8 */
    -moz-opacity:0.6;                 /* FF lt 1.5, Netscape */
    -khtml-opacity: 0.6;              /* Safari 1.x */
    opacity:0.6;
    zoom:1;
}
}


/*=========================================
lead
===========================================*/

.lead_box{
  /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#fafbf0+0,edc54c+25,eed377+40,eee1a1+55,efefcb+80,fafbf0+100 */
  background: #fff; /* Old browsers */
  background: -moz-linear-gradient(top, #fff 0%, #edc54c 25%, #eed377 40%, #eee1a1 55%, #efefcb 80%, #fff 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top, #fff 0%,#edc54c 25%,#eed377 40%,#eee1a1 55%,#efefcb 80%,#fff 100%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, #fff 0%,#edc54c 25%,#eed377 40%,#eee1a1 55%,#efefcb 80%,#fff 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fafbf0', endColorstr='#fafbf0',GradientType=0 ); /* IE6-9 */
  padding: 5% 6%;
}

.lead_box_title{
  margin-top: -10%;
}

.lead_box_btn{
  margin-top: 3%;
  margin-bottom: 7%;
}

@media screen and (min-width: 751px) {
  .lead_box_btn{
    width: 80%;
    margin: 4% auto 7%;
  }
}

/*=========================================
item_category
===========================================*/
.item_category_box{
  background: #135e1f;
  padding: 0 3% 3% 3%;
  margin-top: 10%;
  position: relative;
}

.item_category_title{
  position: absolute;
  margin-top: -5%;
}

@media screen and (max-width: 750px) {
  .item_category_box{
    padding: 5% 3% 3% 3%;
  }

  .item_category_title{
    margin-top: -10%;
    left: -10%;
    max-width: 100%;
    overflow: hidden;
  }

  .item_category_title img{
    width: 120%;
  }
}

@media screen and (min-width: 751px) {
  .item_category_contents li{
  width: 30%!important;
  background: #fff;
  margin-top: 40px!important;
  }
}

 .item_category_contents {
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    flex-wrap:wrap;
  }

.item_category_contents li{
  margin-right: 0;
  margin-top: 3%;
  width: 48%;
}

.item_category_contents li .item_category_contents_box{
  background: #940001;
  border: 4px solid #ffde85;
  padding: 2%;
  display:table-cell;
  width: 325px;
}

@media screen and (max-width: 750px) {
  .item_category_contents li .item_category_contents_box{
    padding: 5%;
    text-align: center;
    text-decoration: none!important;
  }
}

.item_category_contents li .item_category_contents_box::after{
  content: "";
  clear: both;
  display: block;
}

.item_category_contents_box > span{
  margin-left: 5px;
}

@media screen and (max-width: 750px) {
  .item_category_contents_text , .item_category_contents_text2{
    float: none!important;
    margin:0!important;
    margin-bottom: 3%!important;
    font-size: 100%!important;
  }
}

.item_category_contents_text{
  font-size: 80%;
  font-weight: bold;
  color: #ffde85;
  float: left;
  margin-top: 12%;
}

.item_category_contents_text2{
  font-size: 80%;
  font-weight: bold;
  color: #ffde85;
  float: left;
  margin-top: 8%;
}

.item_category_contents_text::before, .item_category_contents_text2::before{
  content: url(../images/choose_arrow.png);
  position : relative ;
  /*bottom : -0.16em ;
  margin-right : 0.1em ;*/
}

.item_category_contents_img{
  width: 100px;
  float: right;
}

@media screen and (max-width: 750px) {
  .item_category_contents_img{
    width: 100%;
    float: none;
    text-align: center;
    background-color: #fff;
    padding: 10px 0;
  }

  .item_category_contents_img img{
    width: 100px;
  }

  .item_category_contents_text::before, .item_category_contents_text2::before{
    content: none!important;
  }
}


/*=========================================
item_contents
===========================================*/

.item_contents_title{
  margin-top: 10%;
}

@media screen and (max-width: 750px) {
  .item_contents_title{
    margin-left: -10%;
    max-width: 100%;
    overflow: hidden;
  }

  .item_contents_title img{
    width: 120%;
  }
}

@media screen and (min-width: 751px) {
  .item_contents_box{
    display: flex;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    flex-wrap:wrap;
  }
}

@media screen and (max-width: 750px) {
  .item_contents_box h3{
    font-size: 95%;
  }
}

.item_contents_box{
  background: #940001;
  padding: 0 0 3% 3%;
  margin-top: 5%;
}



@media screen and (max-width: 750px) {
  .item_contents_box{
    padding: 3%;
  }
  .item_contents_box_mini{
    width: 94%;
   display: block;
   padding: 3%!important;
   margin-top: 3%;
  }
}

@media screen and (min-width: 751px) {
  .item_contents_box_mini{
    width: 28%;
    margin-right: 3%;
    margin-top: 40px;
    padding-left: 1%!important;
    padding-right: 1%!important;
    padding-top: 10px!important;
    padding-bottom: 10px!important;
  }
}

.item_contents_box_mini{
  background: #135e1f;
  color: #fff;
  padding: 1%;
  text-decoration: none;
}

.item_contents_box_mini img{
  max-width: 100%;
}

.item_contents_box_mini:hover{
  text-decoration: none;
}

.item_contents_box_mini_none{
  width: 30%;
  margin-right: 3%;
}

.item_contents_box_mini h3{
  margin-bottom: 3%;
}

.item_contents_box_mini p{
  margin-top: 3%;
  font-size: 80%;
}


/*=========================================
footer
===========================================*/

.footer {
  width: 100%;
  background: #fff;
  position: relative;
  z-index: 2;
}
@media print, screen and (min-width: 751px) {
  .footer {
    padding: 50px 0 40px;
  }
}
@media screen and (max-width: 750px) {
  .footer {
    padding: 12% 0 4%;
  }
}
@media print, screen and (min-width: 751px) {
  .footer-inner {
    width: 1152px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 750px) {
  .footer-inner {
    width: 93.33333333333333%;
    margin: 0 auto;
  }
}
.footer-anchor {
  text-align: right;
}
@media print, screen and (min-width: 751px) {
  .footer-anchor {
    padding-bottom: 75px;
    width: 50px;
    margin-left: auto;
  }
}
@media screen and (max-width: 750px) {
  .footer-anchor {
    width: 14.285714285714285%;
    margin-left: auto;
    padding-bottom: 8.571428571428571%;
  }
}
.footer-anchor img {
  width: 100%;
  display: block;
}
.footer-text {
  text-align: center;
  font-size: 10px;
}

