/* =================================
 Reset / Base
================================= */

/* Reset
---------------------------------------------------------- */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var, b, u, i, center,
dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline;
}
html { line-height: 1;}
ol, ul { list-style: none;}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle;
}
q, blockquote { quotes: none;}
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none;
}
a img { border: none;}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary { display: block;}
input[type="button"], input[type="submit"] { -webkit-appearance: none;}

input[type="text"] {
  width: 100%;
  padding: 10px 5px;
  border: 1px solid lightgrey;
  border-radius: 5px;
  transition: border-color ease .2s;
}
input[type="password"] {
  width: 100%;
  padding: 10px 5px;
  border: 1px solid lightgrey;
  border-radius: 5px;
  transition: border-color ease .2s;
}
select{
  width: 100%;
  padding: 10px 5px;
  background: #fff;
}
input[type="search"] {
  text-shadow: none;
  background: #fff;
}

textarea{
  border: 1px solid lightgrey;
}
/* Base
---------------------------------------------------------- */

* {
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
img {
  border-style: none;
  display: block;
  vertical-align: bottom;
  width: 100%;
}
a, a img, button {
  -webkit-transition: .4s;
  transition: .4s;
}
a img:hover { opacity: .7;}

a:link {text-decoration: none;}
a{color: #777777;}

input, button, textarea, select {
  -moz-appearance: none;
  appearance: none;
  border-radius: 5px;
  background: #fff;
  color: #333;
}
a.link{
  text-decoration: underline;
}
button{
  background: #fff;
  border-radius: 8px;
  text-decoration: none;
  border: solid 1px #faed00;
  border-bottom: solid 3px #faed00;
  padding: 3px 8px;
  color: #777;
}
button:active{
  -ms-transform: translateY(4px);
  -webkit-transform: translateY(4px);
  transform: translateY(4px);/*下に動く*/
  border-bottom: none;/*線を消す*/
}

/* Clearfix
---------------------------------------------------------- */

.clearfix { *zoom: 1;}
.clearfix:after {
  content: ".";
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}

/* =================================
 PC common
================================= */

@media (min-width: 768px){
  .sp_on { display: none;}
  .pc_on { display: block;}

  a:hover {
    cursor: pointer;
    cursor: hand;
  }
  body {
    font-family: "メイリオ", sans-serif;
    font-size: 14px;
    line-height: 1.8;
    font-weight: normal;
    color: #777777;
    min-width: 1200px;
    text-align: justify;
  }
  img {
    max-width: 100%;
  }
  header{
    margin-bottom: 15px;
  }
  header .inner{
    width: 1280px;
    margin: 0 auto;
    margin-top: 45px;
  }
  header .logo{
    float: left;
    margin-right: 70px;
    text-align: center;
    margin-top: -30px;
    font-family:'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', sans-serif;
  }
  header .logo img{
    width: 75%;
  }
  header .logo p{
    font-size: 10px;
    color: #9c9c9c;
  }
  header .category,header .serch{
    float: left;
  }
  header .category select{
    position: relative;
    width: 300px;
    height: 40px;
    padding: 10px;
    border-radius: 5px;
    border: 1px solid lightgrey;
    background: #faf9e3;
  }
  header .category{
    position: relative;
    margin-right: 20px;
  }
  header .serch input.serch_inner{
    width: 430px;
    height: 40px;
    padding: 10px;
  }
  header .serch input.serch_btn{
    width: 70px;
    height: 40px;
    background: #9c9c9c;
    color: #fff;
    border-radius: 5px;
  }
  header .header_btn{
    float: right;
  }
  header .header_btn div{
    float: left;
    margin-right: 20px;
  }
  header .header_btn div img{
    width: 40px;
  }
  header .header_btn a:last-child{
    margin-right: 0;
  }
  header .header_btn .cart{
    position: relative;
  }
  header .header_btn .cart{
    position: relative;
  }
  header .header_btn .cart .count {
    position: absolute;
    top: -13px;
    right: -10px;
    width: 22px;
    height: 18px;
    background: #faed00;
    border-radius: 10px;
    text-align: center;
    color: #fff;
    font-size: 10px;
  }
  .breadcrumb{
    border-top: solid 1px #ececec;
    border-bottom: solid 1px #ececec;
    padding: 5px 0;
    margin-bottom: 30px;
  }
  .breadcrumb li{
    display: inline-block;
  }
  .inner{
    width: 1280px;
    margin: 0 auto;
  }
  .cont{
    margin-bottom: 30px;
  }
  .cont_min{
    margin-bottom: 30px;
  }
  .input-range {
  display: none;
  }
  .range-group {
    position: relative;
  }
  .range-group a {
    display: inline-block;
  }
  .range-group a:before {
    content: "☆";
    font-size: 20px;
    color: #f5b51d;
  }
  .range-group a.on:before {
    content: "★";
    color: #f5b51d;
  }
  footer{
    position: relative;
    background: #a2a1a1;
    clear: both;
    margin-top: 100px;
  }
  footer .inner{
    padding: 55px 0;
  }
  footer .logo{
    width: 10%;
    float: left;
  }
  footer nav{
    float: right;
    margin-top: 7px;
  }
  footer nav p{
    float: left;
    margin-right: 20px;
  }
  footer nav p a{
    color: #fff;
  }
  footer .copyright{
    color: #fff;
    border-top: solid 1px #fff;
    text-align: center;
    font-size: 10px;
    padding: 10px 0;
  }
  footer .syupin{
    position: fixed;
    right: 20px;
    bottom: 130px;
  }
  footer .syupin img{
    width: 158px;
  }
  footer .pagetop{
    position: absolute;
    right: 20px;
    bottom: 20px;
  }
  footer .pagetop img{
    width: 58px;
  }
  
  /*-------------------------------
  下層共通
  -------------------------------*/
  .page main{
    width: 940px;
    margin: 0 auto;
  }
  .page .ttl_cont .ttl{
    margin-left: 0;
    width: 100%;
    margin-bottom: 10px;
  }
  .page .sub_ttl{
    background: #faed00;
    padding: 5px 10px;
    color: #777777;
    margin-bottom: 10px;
  }
  .page .sub_ttl_gray{
    background: #b4b4b4;
  }
  .page .bg_gray{
    background: #f4f3f3;
    padding: 15px 20px;
  }
  .page .bg_lightpink{
    background: #e8e6b5;
    padding: 15px 20px;
  }
  .page .must_txt{
    margin-bottom: 5px;
    color: #D13D40;
  }
  .page table{
    width: 100%;
    background: #fff;
  }
  .page table th{
    width: 17%;
    padding: 10px;
    vertical-align: top;
    background: #f4f3f3;
  }
  .page table th span{
    font-weight: bold;
    color: #D13D40;
    margin-left: 3px;
  }
  .page table td{
    padding: 10px;
  }
  .page table td img.ico{
    width: 26px;
    display: inline-block;
    vertical-align: middle;
  }
  .page table input.short{
    width: 160px;
  }
  .page .float_tr td.first{
    width: 33%;
  }
  .page.page_wide .float_tr td.first{
    width: 25%;
  }
  .page table .select_area div{
    position: relative;
  }
  .page table .select_area div.middle{
    width: 220px;
  }
  .page table .select_area.middle select{
    width: 200px;
  }
  .page table textarea{
    width: 100%;
    height: 100px;
    border: 1px solid lightgrey;
  }
  .page table.simple th{
    border-right: solid 1px #bdbdbd;
    border-bottom: solid 1px #bdbdbd;
  }
  .page table.simple th:first-child{
    border-top: solid 1px #bdbdbd;
  }
  .page table.simple td{
    border-bottom: solid 1px #bdbdbd;
  }
  .page table.simple td.top{
    border-top: solid 1px #bdbdbd;
  }
  .page .form_btn_cont{
    margin: 0 auto;
    text-align: center;
  }
  .page .form_btn_cont .form_btn{
    display: inline-block;
    vertical-align: middle;
  }
  .page .form_btn_cont .form_btn button{
    width: 270px;
    padding: 15px 0;
    border: solid 1px #faed00;
    border-radius: 5px;
    /* color: #faed00; */
    font-size: 18px;
    margin: 0 10px;
    background: #faf9e3;
    border-bottom: solid 3px #faed00;
  }
  .page .form_btn_cont .form_btn button:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
  }
  .page .form_btn_cont .form_btn button span{
    font-size: 13px;
  }
  .page .attention_ttl{
    font-size: 20px;
    color: #777777;
    margin-bottom: 10px;
  }
  .page .two_cont .cont_left{
    width: 48%;
    float: left;
  }
  .page .two_cont .cont_right{
    width: 48%;
    float: right;
  }
  .page .gray_btn{
    width: 40%;
    margin: 0 auto;
    margin-top: 20px; 
    text-align: center;
    background: #a2a1a1;
    border-radius: 5px;
    border: solid 1px #848383;
    border-bottom: solid 3px #848383;
  }
  .page .gray_btn:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
  }
  .page .gray_btn a{
    padding: 10px 0;
    display: block;
    color: #ffffff;
    font-weight: bold;
  }
  .page .green_btn{
    width: 40%;
    margin: 0 auto;
    margin-top: 20px; 
    text-align: center;
    background: #d4f9e9;
    border-radius: 5px;
    border: solid 1px #42bc87;
    border-bottom: solid 3px #42bc87;
  }
  .page .green_btn:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
  }
  .page .green_btn a{
    padding: 10px 0;
    display: block;
  }
  .page main.main_side{
    margin: 0;
  }
  .page .kouyu_btn{
    background: #faf9e3;
    border: solid 1px #faed00;
    border-radius: 5px;
    width: 40%;
    margin: 0 auto;
    margin-top: 30px;
    border-bottom: solid 3px #faed00;
  }
  .page .kouyu_btn:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
  }
  .page .kouyu_btn a{
    display: block;
    padding: 15px 0;
    /*color: #faed00;*/
    text-align: center;
    font-weight: bold;
  }
  .page .star{
    font-size: 18px;
    color: #f5b51d;
  }
  table.color th{
    background: #faed00;
    text-align: center;
    color: #777777;
    padding: 5px 10px;
    border-right: solid 1px #fff;
  }
  .page table.rireki th{
    width: 10%;
    font-size: 11px;
    vertical-align: middle;
  }
  .page table.rireki01 th{
    font-size: 14px;
  }
  .page table.rireki02 th{
    font-size: 14px;
  }
  table.min th{
    width: 10%;
    font-size: 13px;
  }
  .two_cont table th{
    width: 29%;
  }
  table th span.th_explain{
    font-size: 10px;
  }
  table tr.gokei{
    background: #ffeeec;
  }
  .pagenation{
    text-align: center;
    margin-top: 50px;
  }
  .pagenation li{
    display: inline-block;
  }
  .pagenation li a{
    background: #eeeeee;
    padding: 10px 20px;
    display: block;
  }

  /* 商品詳細画像 */
  .item_image_box {
    position: relative;
    display: inline-block;
  }
  .item_image_box img {
    display: block;
    max-width: 100%;
    height: auto;
  }
  .item_image_box img:nth-of-type(2){
      position: absolute;
      top: 0;
      /*left: 0.5em;*/
      width: 20%;
      height: auto;
  }
}


/* =================================
 SP common
================================= */

@media (max-width: 767px){
  .sp_on {
    display: block;
  }
  .pc_on {
    display: none;
  }

  a:hover {
    cursor: pointer;
  }

  body {
    font-family: "メイリオ", sans-serif;
    font-size: 12px;
    line-height: 1.8;
    font-weight: 200;
    color: #777777;
    text-align: justify;
    margin-bottom: 100px;
  }
  img {
    max-width: 100%;
  }
  button{
    color: #777;
    font-size: 13px;
  }
  button.button_100{
    width: 100%;
    padding: 10px 0;
  }
  header .inner{
    width: 100%;
    margin: 0 auto;
    margin-top: 20px;
    padding: 0 10px;
  }
  header .logo{
    width: 35%;
    float: left;
    margin-right: 60px;
  }
  header .logo img{
    width: 75%;
  }
  header .category,header .serch{
    float: left;
  }
  header .category select{
    position: relative;
    width: 100%;
    height: 40px;
    padding: 10px;
    background: #faf9e3;
    border-radius: 5px;
  }
  header .category{
    width: 100%;
    position: relative;
    margin-right: 20px;
  }
  header .category_inner{
    padding: 10px;
  }
  header .serch input.serch_inner{
    width: 100%;
    height: 40px;
    padding: 10px;
  }
  header .serch input.serch_btn{
    width: 70px;
    height: 40px;
    background: #9c9c9c;
    color: #fff;
  }
  header .header_btn{
    float: right;
  }
  header .header_btn div{
    float: left;
    margin-right: 10px;
  }
  header .header_btn div img{
    width: 40px;
  }
  header .header_btn a:last-child{
    margin-right: 0;
  }
  header .header_btn .cart{
    position: relative;
  }
  header .header_btn .cart{
    position: relative;
  }
  header .header_btn .cart .count {
    position: absolute;
    top: -13px;
    right: -10px;
    width: 23px;
    height: 18px;
    background: #faed00;
    border-radius: 10px;
    text-align: center;
    color: #fff;
    font-size: 10px;
  }
  .inner{
    width: 100%;
    margin: 0 auto;
  }
  .cont{
    margin-bottom: 30px;
  }
  .cont_min{
    margin-bottom: 15px;
  }
  .input-range {
  display: none;
  }
  .range-group {
    position: relative;
  }
  .range-group a {
    display: inline-block;
  }
  .range-group a:before {
    content: "☆";
    font-size: 20px;
    color: #f5b51d;
  }
  .range-group a.on:before {
    content: "★";
    color: #f5b51d;
  }
  footer{
    position: fixed;
    bottom: 0;
    background: #a2a1a1;
    clear: both;
  }
  footer li{
    /*width : calc(100% / 5) ;*/
    width : calc(100% / 4) ;
    float: left;
  }
  footer li:nth-child(2){
    background: #8f8f8f;
  }
  footer li:nth-child(3){
    background: #faed00;
  }
  footer li:nth-child(4){
    background: #8f8f8f;
  }
  
  /*-------------------------------
  下層共通
  -------------------------------*/
  .page main{
    width: 100%;
    margin: 0 auto;
    margin-bottom: 70px;
  }
  .page .ttl_cont .ttl{
    margin-left: 0;
    width: 100%;
    margin-bottom: 10px;
  }
  .page .sub_ttl{
    background: #faed00;
    padding: 5px 10px;
    color: #777777;
    margin-bottom: 10px;
  }
  .page .sub_ttl_gray{
    background: #b4b4b4;
  }
  .page .bg_gray{
    background: #f4f3f3;
    padding: 10px 0;
  }
  .page .bg_gray_min{
    padding: 10px;
  }
  .page .bg_lightpink{
    background: #e8e6b5;
    padding: 10px;
  }
  .page .must_txt{
    margin-bottom: 5px;
    color: #D13D40;
  }
  .page table{
    width: 100%;
  }
  .page table th{
    width: 100%;
    padding: 5px 10px 0;
    vertical-align: top;
    display: block;
  }
  .page table th span{
    font-weight: bold;
    color: #D13D40;
  }
  .page table td{
    padding: 0 10px 8px;
    display: block;
  }
  .page table td img.ico{
    width: 26px;
    display: inline-block;
    vertical-align: middle;
    margin-left: 10px;
  }
  .page table input.short{
    width: 85%;
  }
  .page .float_tr td.first{
    width: 100%;
  }
  .page table .select_area div{
    position: relative;
  }
  .page table .select_area div.middle{
    width: 100%;
  }
  .page table .select_area.middle select{
    width: 200px;
  }
  .page table textarea{
    width: 100%;
    height: 100px;
    border: 1px solid lightgrey;
  }
  .page table.simple th:first-child{
    border-top: solid 1px #bdbdbd;
  }
  .page table.td_white th{
    padding: 10px;
  }
  .page table.td_white td{
    background: #fff;
    padding: 10px;
  }
  .page .form_btn_cont{
    margin: 0 auto;
    text-align: center;
  }
  .page .form_btn_cont .form_btn{
    display: block;
  }
  .page .form_btn_cont .form_btn button{
    width: 100%;
    padding: 15px 0;
    border: solid 1px #faed00;
    border-radius: 5px;
    /* color: #faed00; */
    background: #faf9e3;
    border-bottom: solid 3px #faed00;
    margin-bottom: 15px;
  }
  .page .form_btn_cont .form_btn button:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
  }
  .page .form_btn_cont .form_btn button span{
    font-size: 13px;
  }
  .page .attention_ttl{
    font-size: 18px;
    color: #777777;
    margin-bottom: 10px;
  }
  .page .two_cont .cont_left{
    width: 100%;
    margin-bottom: 30px;
  }
  .page .two_cont .cont_right{
    width: 100%;
  }
  .page .gray_btn{
    background: #a2a1a1;
    text-align: center;
    border-radius: 5px;
    border: solid 1px #848383;
    border-bottom: solid 3px #848383;
  }
  .page .gray_btn:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
  }
  .page .gray_btn a{
    padding: 15px 0;
    display: block;
    color: #ffffff;
    font-weight: bold;
  }
  .page .kouyu_btn{
    background: #faf9e3;
    border: solid 1px #faed00;
    border-radius: 5px;
    margin-top: 10px;
    border-bottom: solid 3px #faed00;
  }
  .page .kouyu_btn:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);/*下に動く*/
    border-bottom: none;/*線を消す*/
  }
  .page .kouyu_btn a{
    display: block;
    padding: 15px 0;
    /* color: #faed00; */
    text-align: center;
    font-weight: bold;
  }
  .page .star{
    font-size: 25px;
    color: #f5b51d;
  }
  table tr.gokei{
    background: #ffeeec;
  }
  .pagenation{
    text-align: center;
  }
  .pagenation li{
    display: inline-block;
  }
  .pagenation li a{
    background: #eeeeee;
    padding: 10px 20px;
    display: block;
  }

  /* 商品詳細画像 */
  .item_image_box {
    position: relative;
    display: inline-block;
  }
  .item_image_box img {
    display: block;
    max-width: 100%;
    height: auto;
  }
  .item_image_box img:nth-of-type(2){
      position: absolute;
      top: 0;
      /*left: 0.5em;*/
      width: 20%;
      height: auto;
  }
}
