* {
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  body {
    font-size: 3.7vw;
  }
 .contents,
 .sec-shop {
  background: #f9f9f9;
 }
}
h1, h2, h3, h4, h5, h6, strong, em {
    font-size: 100%;
    font-weight: normal;
}
.mod-breadcrumb {
  background-color: #fff;
}
.mod-breadcrumb .inner {
  width: 1205px;
  margin: 0 auto;
  padding: 10px 0;
  overflow: hidden;
}
.mod-breadcrumb .list-breadcrumb {
  float: left;
  overflow: hidden;
}
.mod-breadcrumb .list-breadcrumb .item {
  float: left;
  position: relative;
  padding-right: 25px;
  margin-right: 13px;
  line-height: 1;
}
.mod-breadcrumb .list-breadcrumb .item:last-child {
  padding-right: 0;
  margin-right: 0;
}
.mod-breadcrumb .list-breadcrumb .item:after {
  content: ">";
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  font-size: 16px;
  color: #d3d3d3;
  line-height: 1.1;
}
.mod-breadcrumb .list-breadcrumb .item:last-child:after { display: none; }
.mod-breadcrumb .list-breadcrumb a {
  display: inline-block;
  font-size: 12px;
  line-height: 1.7;
  text-decoration: underline;
}
.mod-breadcrumb .list-breadcrumb a:hover { text-decoration: none; }
.mod-breadcrumb .list-breadcrumb span {
  font-size: 12px;
  line-height: 1.7;
}
.mod-breadcrumb .txt-note {
  float: right;
  line-height: 1.7;
  font-size: 10px;
}
.box-carousel .slider .item > a {
 text-decoration: none;
}
.box-carousel .slider .item > a:hover {
 text-decoration: underline;
}
@media screen and (max-width: 767px) {
  .mod-breadcrumb {
    display: none;
  }
}
@media screen and (min-width: 768px){
  .contents {
      padding: 0 20px;
  }
}
@media screen and (max-width: 1244px) and (min-width: 768px){
  .main {
    width: 1205px;
    min-width: 1205px;
    overflow: hidden;
  }
}
@media screen and (min-width: 768px) {
  .area-banner {
    width: 1205px;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .area-banner {
    padding: 0 5%;
  }
}
.sec-rank{}
  .sec-rank .box-category-select{
    width: 450px;
    height: 35px;
    margin: 0 auto 30px;
    border:1px solid #e5e5e5;
  }
    .sec-rank .box-category-select .form-category-select{
      width: 470px;
      height: 35px;
      text-indent : 8px;
      color:#000;
    }
  .sec-rank .rank{
    margin-bottom: 3px;
    padding: 5px 0 0;
    width: 23px;
    height: 23px;
    background: url(https://img.dinos.co.jp/images/common/ico_ranking_bg.png) no-repeat 0 0;
    background-size: 23px auto;
    line-height: 1.8;
    color:#fff;
    text-align:center;
  }
.sec-carousel{
  padding: 30px 25px;
}
  .sec-carousel .title{
    margin-bottom: 30px;
    font-weight:bold;
    line-height: 1.43;
    text-align:center;
  }
    .sec-carousel .title .txt{
      display:block;
      font-weight: normal;
      line-height: 1.43;
    }
  .sec-carousel .inner { 
   position: relative;
}
  .sec-carousel .btn{
    width: 341px;
    height: 35px;
    margin: 0 auto;
  }
    .sec-carousel .btn a{
      display:block;
      padding: 5px 0;
      background-color: #fff;
      border: solid 2px #eee;
      line-height: 1.7;
      text-align:center;
      color:#000;
      border-radius: 18px;
    }
    .sec-carousel .btn a:hover{
      text-decoration:none;
      background-color:#eee;
    }

.box-carousel{
  position:relative;
}
  .box-carousel .slider{
    overflow:hidden;
    margin: 0 0 0 -20px;
  }
  .box-carousel .slider .item {
    width: 145px;
    margin: 0 0 0 20px;
  }
    .box-carousel .slider .item a{
      color:#000;
      outline: none;
      text-decoration: none;
    }
    .box-carousel .slider .item a:hover dl{
      text-decoration: underline;
    }
  .box-carousel .img{
    overflow:hidden;
  }
    .box-carousel .img img{
      border-radius: 5px;
    }
  .box-carousel .text{
    padding: 13px 0 25px;
  }
    .box-carousel .text .ttl{
      line-height: 1.65;
      color:#333;
	  display: -webkit-box;
      overflow: hidden;
      -webkit-line-clamp: 2;
      -webkit-box-orient: vertical;
    }
.box-carousel .text .price{
 color:#333;
 font-weight: bold;
}
.box-carousel .text .price.yen::first-letter {
 font-weight: normal;
}

      .box-carousel .text .price:before{
        content:'';
      }
      .box-carousel .text .price:after{
        content:'';
        line-height: 1.67;
      }
.box-carousel .text .star{
  margin-top: 4px;
  color: #333333;
}
.box-carousel .text .star img {
  width: 90px;
  max-width: 100%;
  display: inline-block;
  margin-right: 6px;
  vertical-align: middle;
}
.box-carousel .text .star span{
 color: #333;
}
  .sec-carousel .btn-left,
  .sec-carousel .btn-right,
  .box-carousel .btn-left,
  .box-carousel .btn-right,
  .box-catalog .btn-left,
  .box-catalog .btn-right {
    position:absolute;
    top: 40px;
    width: 32px;
    height: 73px;
    cursor: pointer;
    text-indent: -9999px;
    overflow: hidden;
    background-position: 0 0;
    background-repeat: no-repeat;
    background-size: 32px 73px;
  }
  .sec-carousel .btn-left,
  .box-carousel .btn-left,
  .box-catalog .btn-left {
    left: -26px;
    background-image: url(https://img.dinos.co.jp/images/v1/top/ico_arrow_left_pc.png);
  }
  
  .sec-carousel .btn-right,
  .box-carousel .btn-right,
  .box-catalog .btn-right {
    right: -26px;
    background-image: url(https://img.dinos.co.jp/images/v1/top/ico_arrow_right_pc.png);
  }
  
  .sec-carousel .slider-btn .btn-left.slick-disabled,
  .box-carousel .slider-btn .btn-left.slick-disabled,
  .box-catalog .btn-left.slick-disabled { background-image: url(https://img.dinos.co.jp/images/v1/top/ico_arrow_left_pc_disabled.png); cursor: default; }
  
  .sec-carousel .slider-btn .btn-right.slick-disabled,
  .box-carousel .slider-btn .btn-right.slick-disabled,
  .box-catalog .btn-right.slick-disabled { background-image: url(https://img.dinos.co.jp/images/v1/top/ico_arrow_right_pc_disabled.png); cursor: default; }
    
.box-carousel .text .link {}
      .box-carousel .text .link a {
        color: #86be24;
      }
    .box-carousel .text .txt{
      line-height: 1.53;
      color:#333;
	  display: -webkit-box;
      overflow: hidden;
      -webkit-line-clamp: 4;
      -webkit-box-orient: vertical;
    }

@media screen and (min-width: 768px) {
  .sec-rank .box-category-select .form-category-select{
    font-size: 16px;
  }
  .sec-rank .rank{
    font-size: 10px;
  }
  .sec-carousel .title{
    font-size: 21px;
  }
  .sec-carousel .title .txt{
    font-size: 14px;
  }
  .sec-carousel .btn a{
    font-size: 14px;
  }
  .box-carousel .text .ttl{
    font-size: 12px;
  }
  .box-carousel .text .price:after{
    font-size: 12px;
  }
  .box-carousel .text .txt{
    font-size: 12px;
  }
  .box-rank .slider .text .ttl{
    font-size: 12px;
  }
  .box-rank .slider .text .price{
    font-size: 14px;
  }
  .box-rank .slider .text .price .fee{
    font-size: 12px;
  }
  .box-rank .slider-btn .btn-left,
  .box-rank .slider-btn .btn-right {
   top: 65px;
  }
}
/* sp
---------------------------------------------------------- */
@media screen and (max-width: 767px) {
  .sec-cmn-01 {
    padding: 0 0 10px;
  }
  .sec-carousel{
    padding: 30px 3%;
  }
  .sec-carousel .title{
    margin-bottom: 20px;
    line-height: 1.2;
  }
  .sec-carousel .title .txt{
    line-height: 1.5;
  }
  .sec-carousel .btn {
    width: auto;
  }
  .sec-carousel .btn a{
    padding: 13px 0;
    border: solid 1px #ddd;
    line-height: 0.95;
    border-radius: 26px;
  }
  .box-pop-featured .box-carousel .text .star img {
    width: 40%;
  }
  .sec-rank{
    margin: 0 -3%;
    padding: 20px 3% 30px;
    border:none !important;
    border-radius: 0 !important;
  }
  .sec-rank .box-category-select{
    width: 100%;
    height: 35px;
    margin: 0 auto 20px;
  }
  .sec-rank .box-category-select .form-category-select{
    width: 100%;
    height: 35px;
  }
  .box-category-select ~ div .box-carousel ~ .btn {
    padding: 0 12px;
  }
  .sec-rank .rank{
    margin-left: 3%;
  }
  .box-carousel-sp{
    margin: 0 0 3%;
  }
  .box-carousel-sp .slider{
    height:auto;
    margin: 0;
  }
  .box-carousel-sp .slider .item {
    clear: both;
    width: 100%;
    margin: 0 0 5%;
    overflow: hidden;
  }
  .box-carousel-sp .slider .img{
    float: left;
    width: 37.12%;
  }
  .box-carousel-sp .text{
    float: left;
    width: 62.88%;
    padding: 0 0 0 3%;
  }
  .box-carousel-sp .text .ttl,
  .box-carousel-sp .text .price{
    line-height: 1.4;
  }
  .box-carousel-sp .text .price .fee{
    line-height: 1.75;
  }
  .box-carousel-sp .text .star{
    margin: 3px 0 6px;
  }
  .box-carousel-sp .text .txt{
    line-height: 1.33;
  }
  .box-rank {
    margin: 0 calc(50% - 50vw);
  }
  .box-rank .slider{
    height: auto;
    margin: 0;
  }
  .box-rank .slider .slick-track {
   padding-left: 3vw;
  }
  .box-rank .slider .item {
    margin: 0;
  }
  .box-rank .slider .item dl{
    margin: 0 3vw 0 0;
  }
  .box-rank .slider .text{
    padding: 6px 0 35px;
  }
  .box-rank .slider .text .ttl{
    line-height: normal;
  }
  .box-rank .slider .text .price{
    line-height: 1.43;
    color:#333;
  }
  .box-rank .slider .text .price .fee{
    line-height: 1.67;
  }
  .box-rank .slider .text .star{
    margin-bottom: 0;
  }
  .box-rank .slider .text .txt{
    display:none;
  }
  .box-rank .slider-btn .btn-left,
  .box-rank .slider-btn .btn-right {
    margin-top: 26px;
  }
  .box-recommend{
    margin: 0;
  }
  .box-recommend .slider-wrap {
   width: 100vw;
   margin: 0 calc(50% - 50vw);
  }
  .box-recommend .slider{
    height: auto;
    margin: 0;
  }
  .box-recommend .slider .slick-track {
   padding-left: 3vw;
  }
  .box-recommend .slider .item {
    width: 160px;
    margin: 0 3vw 0 0;
    height: auto;
  }
  .box-recommend .slider .text{
    padding: 6px 0 35px;
  }
  .box-recommend .slider .text .ttl{
    line-height: 1.5;
  }
  .box-recommend .slider .text .price{
    line-height: 1.43;
    color:#333;
  }
  .box-recommend .slider .text .price .fee{
    line-height: 1.67;
  }
  .box-recommend .slider .text .star{
    margin-bottom: 0;
  }
  .box-recommend .slider .text .txt{
    display:none;
  }
  .box-pop-featured .slider .item:nth-child(n+4),
  .box-favorite .slider .item:nth-child(n+4) {
    display: none;
  }
  .sec-carousel .btn-left,
  .box-carousel .btn-left,
  .box-catalog .btn-left,
  .sec-carousel .btn-right,
  .box-carousel .btn-right,
  .box-catalog .btn-right {
   top: 0;
   transform: translateY(calc(35.666vw / 2 - 50%));
   width: 28px;
   height: 56px;
   background-size: 28px 56px;
  }
  .sec-carousel .btn-left,
  .box-carousel .btn-left,
  .box-catalog .btn-left {
   left: 0;
  }
  .sec-carousel .btn-right,
  .box-carousel .btn-right,
  .box-catalog .btn-right {
   right: 0;
  }
  .box-catalog .btn-left,
  .box-catalog .btn-right {
   transform: translateY(calc(41.957vw - 29.6vw));
  }
  .box-pop-featured .btn {
    margin-top: 2.612%;
    margin-bottom: 3%;
  }
}
/* reset slider style
-----------------------------------------------------------*/
.sec-carousel {
  padding-right: 20px;
  padding-left: 20px;
}
.sec-carousel .inner {
  padding: 0 2px;
}
.box-carousel .text {
  padding-bottom: 0;
  text-align: left;
}
.box-carousel .text .ttl {
 display: -webkit-box;
 overflow: hidden;
 -webkit-line-clamp: 2;
 -webkit-box-orient: vertical;
}
.box-carousel .text .star {
  width: 100%;
  margin-bottom: 0;
}
.box-carousel .slider {
  margin: 0 -12px;
}
.box-carousel .slider .item {
  margin-left: 0;
  padding: 0 12px;
}
.box-carousel .img {
  position: relative;
  z-index: 1;
  overflow: hidden;
  border-radius: 5px;
}
.slider-control {
  position: absolute;
  top: 37px;
  width: 37px;
  height: 73px;
}
.slider-control.prev {
  left: -20px;
}
.slider-control.next {
  right: -20px;
}
.slider-control .btn {
  position: absolute;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
  width: 37px;
  height: 73px;
  overflow: hidden;
  background-size: 100% auto;
  background-position: 0 0;
  background-repeat: no-repeat;
  text-indent: -9999px;
  cursor: pointer;
}
.slider-control.prev .btn {
  left: 0;
  background-image: url('https://img.dinos.co.jp/images/v1/mypage/ico_arrow_left_pc.png');
}
.slider-control.next .btn {
  right: 0;
  background-image: url('https://img.dinos.co.jp/images/v1/mypage/ico_arrow_right_pc.png');
}
.slider-control.prev .btn.slick-disabled {
  background-image: url('https://img.dinos.co.jp/images/v1/mypage/ico_arrow_left_pc_disabled.png');
}
.slider-control.next .btn.slick-disabled {
  background-image: url('https://img.dinos.co.jp/images/v1/mypage/ico_arrow_right_pc_disabled.png');
}
@media screen and (min-width: 768px) {
 .box-carousel .text {
  padding-top: 13px;
 }
 .box-carousel .text .star img { 
  width: 94px;
 }
 .box-carousel .text .ttl {
  font-size: 12px;
 }
 .box-carousel .text .price {
  font-size: 14px;
  line-height: 1.5;
  margin-top: 3px;
 }
 .box-carousel .text .price::first-letter{
  font-size: 12px;
 }
}
@media screen and (max-width: 767px) {
  .sec-carousel {
   width: 100vw;
   margin: 0 calc(50% - 50vw);
   padding: 30px 0;
  }
 .sec-carousel.box-cmn {
  border: none;
  border-radius: 0;
 }
  .sec-carousel .inner {
   width: 100%;
   margin: 0;
  }
  .sec-carousel .ttl-sec {
   margin: 0;
  }
  .sec-carousel .title {
    padding-left: 10px;
    text-align: left;
    font-weight: normal;
  }
  .sec-carousel .inner {
    padding: 0 0 20px 0;
  }
  .sec-carousel .link-area {
    border-top: 1px solid #eee;
  }
  .sec-carousel .box-empty ~.link-area {
   border-top: none;
  }
  .box-carousel .slider {
    margin: 0;
  }
  .box-carousel .slider .item {
    margin-left: 0;
    padding: 0;
   margin-right: 3vw;
  }
  .box-carousel .slider .item  a {
   display: inline-block;
  }
  .box-carousel .text {
   padding-top: 6px;
  }
  .box-carousel .text .price::first-letter{
   font-size: .8em;
  }
  .box-carousel .text .star img {
   width: 17.066vw;
   vertical-align: middle;
  }
  .box-carousel .text .ttl,
  .box-carousel .text .star {
   width: 100%;
  }
  .slider-control,
  .slider-control .btn {
   width: 28px;
   height: 56px;
  }
  .slider-control {
    position: absolute;
    top: calc((35.666vw - 56px) / 2);
  }
  .slider-control.prev {
    left: 0;
  }
  .slider-control.next {
    right: 0;
  }
}
/* text
-----------------------------------------------------------*/
.txt-orange { color: #ff6600 !important; }
.txt-red { color: #ff0000 !important; }

.sec-carousel .inner {
    position: relative;
}
@media screen and (max-width: 767px) {
  .sec-rank {
      margin: 0 -3%;
      padding: 20px 3% 30px;
      border: none !important;
      border-radius: 0 !important;
  }
}
 /* box-login
---------------------------------------------------------- */  
.box-login{
  padding: 0 0 18px 0;
  background-color:#444;
  border-radius: 5px;
}
  .box-login .list-login{
    padding: 13px 0 21px;
    text-align:center;
  }
    .box-login .list-login li{
      display:inline;
      border-left:1px solid #eee;
    }
    .box-login .list-login li:first-child{
      border:none;
    }
      .box-login .list-login li a{
        display:inline-block;
        width: 32%;
        padding: 6px 0;
        line-height: 2;
        color:#fff;
      }
        .box-login .list-login li a:hover{ text-decoration:underline;}
  .box-login .btn-login{
    width: 163px;
    height: 28px;
    margin: 0 auto;
    background-color:#333;
    border-radius: 14px;
    text-align:center;
  }
    .box-login .btn-login a{
      display:block;
      line-height: 2;
      color:#fff;
    }
  .mod-logout{
    padding: 19px;
  }
    .mod-logout .text{
      margin: 15px 0 0;
    }
  .mod-login{
  }
  .mod-regis{
    border-top:1px solid #eee;
  }
    .mod-login .text{
      margin-bottom: 8px;
      background: url(https://img.dinos.co.jp/images/v1/common/ico_arrow_04.jpg) no-repeat right center;
      background-size: 14px auto;
      line-height: 1.43;
    }
      .mod-login .text a{
        color:#000;
      }
    .mod-regis .text{
      line-height: 1.5;
      letter-spacing: -0.05em;
    }
      .mod-regis .txt{
        color:#cc0000;
        font-weight:bold;
      }
      
  .mod-logout .btn{
    display:block;
    width: 202px;
    height: 35px;
    margin: 0 auto;
    line-height: 2.5;
    text-align:center;
    border-radius: 17px 18px 18px 17px;
  }
  a.btn-login{
    background-color:#333;
    color:#fff;
  }
  a.btn-login:visited{
    color:#fff;
  }
  .btn-regis{
    background-color: #c5fd5d;
    color:#000;
  }

.box-tv{
  margin: 8vw 0 7vw;
} 
  .box-tv a {
    display: block;
    overflow: hidden;
  }
@media screen and (min-width: 768px) {
  .box-login .list-login li a{
    font-size: 14px;
  }
  .box-login .btn-login a{
    font-size: 14px;
  }
  .mod-login .text{
    font-size: 14px;
  }
  .mod-regis .text{
    font-size: 16px;
  }
  .mod-logout .btn{
    font-size: 14px;
  }
}
/*トップ用のCSS除外するまでの暫定措置*/
.box-carousel .slider .slick-list {
 padding-right: 0;
}
.box-carousel .text .ttl {
 text-overflow: unset;
 white-space: normal;
}
.box-carousel .img img {
 overflow: clip;
 border: none;
}
@media screen and (min-width: 768px) {
 .sec-carousel {
  margin-bottom: 0;
 }
}
@media screen and (max-width: 767px) {
 .sec-carousel:not(.box-pop-featured) .box-carousel .slider {
  white-space: unset;
  overflow-x: hidden;
  display: block;
  padding-right: 0;
  padding-bottom: 0; 
 }
	.sec-carousel:not(.box-pop-featured) .inner {
  position: relative;
  width: 100vw;
  margin: 0 calc(50% - 50vw);
 }
	.sec-carousel:not(.box-pop-featured) .box-carousel .slider .item {
		margin-left: 0;
  display: block;
  border-radius: 0;
	}
	.box-carousel .slider .item a {
		width: 100%;
	}
	.sec-carousel .item .img {
		margin-bottom: 0;
	}
	.sec-carousel .item .text {
		padding-top: 6px;
	}
	.box-carousel .text .star {
		margin-top: 0;
	}
}
/*ここまで　トップ用のCSS除外するまでの暫定措置*/