/* ************************************************
*  all
* ************************************************ */
* {
  margin: 0px;
  padding: 0px;
  box-sizing: border-box;
}

html {
  overflow-y: scroll;
  height: 100%;
}

body {
  text-align:left;
  font-size: 12px;
  font-family: "Noto Sans JP", sans-serif;
  color: #000;
  line-height: 1.6;
}

a {
  outline: none;
  color: #000;
  text-decoration: none;
}
a:visited,:link {
  text-decoration: none;
}

a.yellow {
  color: #FFEB6E;
}

a.orange {
color: #DD8B00;
}

br.clear {
  clear: both;
  font: 0pt/0pt sans-serif;
  line-height: 0;
}

hr {
  clear: left;
  margin: 10px 0;
  border: 0;
}

img {
  border: none;
  vertical-align: middle;
  max-width: 100%;
}

ul {
  list-style: none;
}

.oswald {
  font-family: "Oswald", sans-serif;
}

.mincho {
  font-family: "Zen Old Mincho", serif;
}

.noto {
  font-family: "Noto Sans JP", sans-serif;
}

.sp-block {
  display: none;
}

@media screen and (max-width:768px) {
  .sp-block {
  display: block;
}
}

/* ************************************************
*  clearfix
* ************************************************ */

.clearfix {
  *zoom: 1;
}
.clearfix:before, .clearfix:after {
  display: table;
  content: "";
}
.clearfix:after {
  clear: both;
}

/* ************************************************
*  layout
* ************************************************ */

/*ページ全体の幅、レイアウトをセンタリング*/
#container {
  text-align:left;
}

/*コンテント*/
#contentWrap {
  display: flex;
  flex-direction: row-reverse;
  justify-content: space-between;
  max-width: 920px;
  padding-top: 50px;
  margin:0 auto;
}
/*サイド*/
#side {
  width: 180px;
}

/*メイン*/
#main {
  width: 720px;
  margin-bottom: 100px;
}

/*フッター（コピーライト）*/
#footer {
  width: 100%;
  max-width: 920px;
  margin: 0 auto;
}

#footer .footer-inner {
  width: 100%;
  max-width: 720px;
  margin-left: auto;
}

@media screen and (max-width:1000px) {
  #footer .footer-inner {
    margin-right: auto;
  }
}

/*スライダー*/
.slider{
  margin: 0 0 70px;
}


@media screen and (max-width:1000px) {
  #contentWrap{
    display: block;
    width: 85%;
    padding-top: 20px;
  }
  
  #main {
    width: 100%;
  }
  
  #side {
    display: none;
  }
}

/* ************************************************
*  header
* ************************************************ */

#header {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  padding: 20px 100px;
  width:100%;
}

#header .header-title {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: 100%;
  max-width: 550px;
}

#header .header_link {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#header .header_link ul {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#header .header_link ul.icon-nav li {
  width: 40px;
}

#header .header_link ul li {
  margin-left: 30px;
}
#header .header_link ul li i {
  display: block;
  float: left;
  margin-right: 5px;
  width: 16px;
  height: 16px;
}
#header .header_link ul li a {
  display: block;
  text-decoration: none;
}
#header .header_link ul li.my_account {
}
#header .header_link ul li.my_account i.account {
  background: url(https://img.shop-pro.jp/tmpl_img/67/icons16.png) no-repeat left -97px;
}
#header .header_link ul li.member_login_btn i.login {
  background: url(https://img.shop-pro.jp/tmpl_img/67/icons16.png) no-repeat left -225px;
}
#header .header_link ul li.member_regist_btn i.regist {
  background: url(https://img.shop-pro.jp/tmpl_img/67/icons16.png) no-repeat 0px -193px;
}
#header .header_link ul li.member_logout_btn i.logout {
  background: url(https://img.shop-pro.jp/tmpl_img/67/icons16.png) no-repeat left -210px;
}
#header .member_login_name{
  float: right;
  clear: right;
  margin: 0 0 13px;
}
#header .header_link ul li {
  position: relative;
}

#header .header_link ul li.view_cart {
}
#header .header_link ul li.view_cart i.cart {
  background: url(https://img.shop-pro.jp/tmpl_img/67/icons16.png) no-repeat 0px 0px;
}
#header .header_link ul li.view_cart span.count {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: -5px;
  right: -5px;
  width: 20px;
  height: 20px;
  padding: 5px 10px;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 50%;
  background-color: #FFEB6E;
  color: #000;
}

#header .header_delivery_price {
  float: right;
  clear: right;
  margin: 0 0 17px;
  padding: .5em 1em .3em;
  border: solid 1px #aaa;
  list-style: none;
  line-height: 1.5;
}

#header h1.logo {
  width: 100%;
  max-width: 185px;
  margin-right: 40px;
  word-wrap: break-word;
  font-size: 40px;
}
#header h1.logo a {
  display: block;
  text-decoration: none;
}
#header h1.logo img {
  max-width: 100%;
}

@media screen and (max-width:1280px) {
  #header {
    padding-left: 35px;
  }
  
  #header .header-title {
    display: block;
    width: fit-content;
  }
  
  #header h1.logo {
    max-width: 150px;
    margin-bottom: 10px;
  }
  
  #header .header-title p {
    font-size: 10px;
  }
}

@media screen and (max-width:768px) {
  #header {
    display: block;
    padding-left: 25px;
    padding-right: 25px;
  }
  
  #header .header_link {
    margin-top: 15px;
  }
  
  #header .header_link ul {
    margin: 0 auto;
  }
  
  #header .header_link ul li {
    margin: 0;
  }
  
  #header .header_link ul.side_lst {
    display: block;
  }
  
  #header .header_link ul.icon-nav li {
	margin: 0 15px;
  }
  
  #header .header_link ul.g-nav-content li {
    padding: 10px;
  }
}

/* ************************************************
*  footer
* ************************************************ */

#footer h2 {
  width: fit-content;
  margin: 0 auto 30px;
}

#footer h2 a {
  display: block;
}

#footer h2 a img {
  width: 185px;
}

#footer .footer_menu {
  display: flex;
  justify-content: center;
  margin-bottom: 25px;
}
#footer .footer_menu li {
  margin: 0 30px;
}

.footer_sns {
  display: flex;
  justify-content: center;
  list-style: none;
  margin: 0 auto 20px auto;
}
.footer_sns li {
  margin-right: 10px;
}
.footer_sns li:last-child {
  margin-right: 0;
}
.footer_sns img {
  width: 20px;
}

.copyright {
  padding: 1em 0;
  background-color: #FFEB6E;
  text-align: center;
  font-size: 9px;
}

.powered {
  display: inline;
  margin-left: 1em;
  text-align: center;
  line-height: 18px;
}
.powered a {
  color: #777;
  text-decoration: none;
}
.powered img {
  margin-left: .3em;
  width: 200px;
  height: 18px;
}

.foot_policy{
  display: flex;
  margin: 0 -30px;
}

.foot_sk_box{
  position: relative;
  padding: 20px 30px;
  width: calc(100% / 3);
  height: 300px;
  text-align: left;
  border-right: solid 1px #000;
}

.foot_sk_box:last-of-type {
  border: none;
}

.foot_sk_box>figure {
  height: 95px;
  text-align: center;
}

.foot_sk_box:nth-of-type(1)>figure img {
  width: 95px;
}

.foot_sk_box:nth-of-type(2)>figure img {
  width: 74px;
}

.foot_sk_box:nth-of-type(3)>figure img {
  width: 83px;
}
.foot_sk_box h3{
  margin: 0 0 1em;
  text-align: center;
  font-size: 18px;
}
.foot_sk_box p{
  margin-bottom: 20px;
  font-size: 10px;
  text-align: center;
}

.foot_sk_box .button-black {
  position: absolute;
  bottom: 20px;
  left: 0;
  right: 0;
  width: 180px;
  margin: 0 auto;
  border: solid 1px #000;
  text-align: center;
  border-radius: 30px;
  transition: all .5s ease;
}

.foot_sk_box .button-black a {
  display: block;
  padding: 10px;
  font-size: 11px;
}

.foot_sk_box .button-black:hover {
  background-color: #000;
}

.foot_sk_box .button-black:hover a {
  color: #FFF;
}

#mobile{
  width: 145px;
}

@media screen and (max-width:768px) {
  .foot_policy {
    display: block;
  }
  
  .foot_sk_box {
    width: 100%;
    height: auto;
    border-right: none;
    border-bottom: solid 1px #000;
  }
  
  .foot_sk_box:first-of-type {
    border-top: solid 1px #000;
  }
  
  .foot_sk_box:last-of-type {
    border-bottom: solid 1px #000;
  }
  
  .foot_sk_box>figure {
    height: auto;
    margin-bottom: 10px;
  }
  
  .foot_sk_box h3 {
    margin-bottom: 10px;
  }
  
  .foot_sk_box .button-black {
    position: relative;
    bottom: 0;
  }
  
  #footer .footer_menu {
    display: block;
    margin-bottom: 0;
  }
  
  #footer .footer_menu li {
    text-align: center;
    border-top: solid 1px #000;
  }
  
  #footer .footer_menu li a {
    display: inline-block;
    padding: 10px;
  }
}

/* ************************************************
*  main
* ************************************************ */

#main .box {
  clear: both;
  margin-bottom: 130px;
  overflow: hidden;
}
#main .box h3 {
  font-size: 13px;
  vertical-align: middle;
}

.header_block .title{
  float: left;
  text-align: left;
}
.header_block h3{
  padding: 0;
  border: none;
  text-align: left;
}
.header_block p{
  margin-top: 4px;
  color: #999;
}
#main .header_block{
  margin: 0 0 30px;
}
#main .header_block .icon{
  padding: 0;
}


@media screen and (max-width: 1000px) {
  #main .box {
    margin-bottom: 70px;
  }
}

/* ************************************************
*  item_box
* ************************************************ */
.item_box_wrap {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}

.item_box {
  padding: 0 20px;
  margin: 0 0 45px;
  width: calc(100% / 3);
  vertical-align:top;
  text-align: left;
}
.item_box .item_image {
  margin: 0px;
}
.item_box .item_image img.item {
  max-width: 100%;
  border-radius: 50%;
}
.item_box .item_detail {
  margin: 15px 0 0;
  padding-left: 0;
}
.item_box .item_detail p{
  width: 100%;
  text-align: center;
}

.item_box .item_detail p.item_name {
  margin-bottom: 5px;
  font-size: 12px;
  line-height: 1.8;
}

.item_box .item_detail p.item_price {
  font-size: 10px;
  font-weight: 600;
  text-align: center;
}

.item_box .item_detail p.item_description{
  text-overflow: initial;
  overflow: visible;
  white-space: normal;
}

p.item_regular_price, p.item_price, p.item_discount {
  margin-bottom: 10px;
  font-family:'Lucida Grande',
  'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3',
  Meiryo, メイリオ, sans-serif;
}

.box_small .item_box {
  display:inline-block;
  padding: 0 ;
  margin: 0 10px 45px;
  width: calc((100% - 100px) / 5);
  vertical-align:top;
  text-align: left;
  /display:inline;
  /zoom:1;
}
.box_small p {
  overflow: hidden;
  width: 100%;
  text-overflow: ellipsis;
  white-space: nowrap;
  -o-text-overflow: ellipsis;
}
.box_small .item_box .item_detail a {
  margin-bottom: 5px;
  font-size: 12px;
  font-weight: 600;
}

.box_small .box_last {
  margin-right: 0;
}

.stock_error{
  display:none;
  padding:10px 0;
  color:#DA5858;
  font-weight:bold;
}

@media screen and (max-width: 768px) {  
  .item_box {
    width: calc(100% / 2);
    padding: 0 10px;
  }
  
  .box_small .item_box {
  width: calc((100% - 40px) / 2);
}
  
  .item_box .item_detail p {
    text-align: left;
  }
  
  .item_box .item_detail p.item_price {
    text-align: left;
    font-size: 12px;
  }
}

/* ************************************************
*  Top_Page
* ************************************************ */

#main #box_info p {
  line-height: 20px;
}

#main #box_free {
  padding: 20px;
  border: #aaa solid 1px;
}
#main #box_free p {
  line-height: 20px;
}

#main #box_news .header_block{
  margin-bottom: 0;
}
#main #box_news ul{
  margin-left: 0;
  list-style: none;
}
#main #box_news ul li{
  border-top:#ddd solid 1px;
}
#main #box_news ul li:first-child{
  border-top:none;
}
#main #box_news  ul li div{
  padding: 1.6em 0 1.4em;
}
#main #box_news  p.news_date{
  float: left;
  margin-right: 20px;
  width: 70px;
}
#main #box_news  p.news_message{
  float: left;
}

/* ************************************************
*  product_detail_page
* ************************************************ */

h2.product_name {
  margin-bottom: 0.8em;
  padding-bottom: 0.6em;
  background: transparent url("https://img.shop-pro.jp/tmpl_img/67/border_bottom.png") repeat-x left bottom;
  font-size: 18px;
}

.product_form{
  margin: 0 0 62px;
}

.product_detail_area {
  position: relative;
  width: 100%;
}

.product_detail_column {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin-bottom: 20px;
  border-bottom: solid 1px #CCC;
}

.product_images {
  max-width: 400px;
}
.product_images div img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height:auto;
  border: 1px solid #ddd;
}
.product_images div p.detail {
  margin-top: 10px;
  line-height: 20px;
}

.add_cart {
  overflow: hidden;
  width: 270px;
}

table.add_cart_table {
  margin-bottom: 10px;
  width: 100%;
  table-layout:fixed;
}
table.add_cart_table th {
  display: inline-block;
  overflow: hidden;
  padding: 12px 4px 12px 18px;
  width: 35%;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 14px;
  -webkit-text-overflow: ellipsis;
  -o-text-overflow: ellipsis;
}
table.add_cart_table td {
  display: inline-block;
  overflow: hidden;
  padding: 10px 0;
  width: 55%;
  text-align: left;
  text-overflow: ellipsis;
  white-space: nowrap;
  -webkit-text-overflow: ellipsis;
  -o-text-overflow: ellipsis;
}
table.add_cart_table td input {
  padding: 0 4px;
  width: 38px;
  height: 26px;
  font-size: 15px;
  line-height: 26px;
  vertical-align: middle;
}
table.add_cart_table td strong.price {
  font-size: 14px;
}
table.add_cart_table td input.text-titles-list__detail-text {
  width: 130px;
}

table#option_tbl {
  margin-bottom: 10px;
  width: 100%;
}
table#option_tbl th,
table#option_tbl td.none {
  background: whiteSmoke;
}
table#option_tbl th,
table#option_tbl td {
  padding: 10px;
  border: 1px solid #ccc;
  text-align: center;
}
table#option_tbl th {
  background: whiteSmoke;
}
table#option_tbl td div input {
  margin-bottom: 5px;
}

ul.option_price {
  margin: 0 0 20px 0;
}
ul.option_price li {
  list-style-type: none;
  color: red;
}

.item_info {
  border-bottom: solid 1px #CCC;
}

.option_box{
  clear: both;
  width: 100%;
  overflow: hidden;
}

table td.pur_block{
  margin: 0 5px 0 0;
  width: auto;
  white-space: normal;
}

.button_area input {
  width: 100%;
}

.product_description {
  clear: both;
  padding: 0 15px;
  margin-bottom: 20px;
  word-wrap: break-word;
  font-size: 12px;
  line-height: 22px;
}

.product_image_extra {
  margin-bottom: 20px;
  text-align: center;
}
.product_image_extra img.item {
  margin-bottom: 20px;
}

.product_link_area {
  margin: 20px 0 0;
  padding: 20px 0 0;
  border-top: #ccc solid 1px;
}
.product_link_area div.twitter {
  float: left;
  width: 100px;
}
.product_link_area div.pinterest {
  float: left;
  margin-right: 30px;
}
.product_link_area div.fb-like {
  float: left;
  width: 200px;
}
.product_link_area ul.other_link {
  clear: both;
  margin-top: 20px;
  margin-left: 20px;
}
.product_link_area ul.other_link li {
  margin-bottom: 10px;
}

.share{
  margin: 15px 0 0;
  list-style: none;
}
.share li{
  display: inline-block;
  float: left;
  margin: 0 10px 10px 0;
  max-width: 125px;
}
.calamel-link{
  margin-top: 10px;
}

#tb_cap_tb{
  margin-top: 20px;
}

.tb {
  padding-top: 10px;
  padding-bottom: 10px;
  border-top: 1px solid #CCC;
}
#tb_stitle {
  margin-bottom: 20px;
}

.tb_date, .tb_title, .tb_body, .tb_state {
  margin-bottom: 5px;
}

/* ************************************************
*  cloud_zoom
* ************************************************ */
/* This is the moving lens square underneath the mouse pointer. */
.cloud-zoom-lens {
  margin:-4px;  /* Set this to minus the border thickness. */
  border: 4px solid #888;
  background-color:#fff;
  cursor:move;
}

/* This is for the title text. */
.cloud-zoom-title {
  position:absolute !important;
  top:0px;
  padding:3px;
  width:100%;
  background-color:#000;
  color:#fff;
  text-align:center;
  font-weight:bold;
  font-size:10px;
  font-family:Arial, Helvetica, sans-serif;
}

/* This is the zoom window. */
.cloud-zoom-big {
  overflow:hidden;
  border: 4px solid #c86464;
}

/* This is the loading message. */
.cloud-zoom-loading {
  padding:3px;
  border:1px solid #000;
  background:#222;
  color:white;
}

/* Feature section in ZoomEngine page */
.zoom-section {
  clear:both;
}

* html .zoom-section {
  display:inline;
  clear:both;
}

.zoom-small-image {
  margin-top: 4px;
  max-width: 400px;
  max-height: 400px;
  margin-bottom: 20px;
}
.zoom-small-image #wrap {
  position: relative;
  top: 0px;
  z-index: 9999;
}

.cloud-zoom {
  margin-bottom: 20px;
}

.zoom-small-image .mousetrap {
  position: absolute;
  top:0px;
  left:0px;
  z-index:999;
  width: 100% !important;
}

/* Feature descriptions in ZoomEngine page */
.zoom-desc {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -5px;
}

a.cloud-zoom-gallery {
  display: block;
  margin: 0 5px 10px;
  cursor: pointer;
  width: calc((100% - 40px) / 4);
}
.zoom-tiny-image {
  padding: 3px;
  width: 100%;
  height: auto;
  border: 1px solid #ccc;
  background: #efefef;
}
.zoom-tiny-image.selected {
  border: 1px solid #c86464;
  background: #c86464;
}
.zoom-tiny-image:hover {
  border: 1px solid #c86464;
}

a.gallery_last{
  margin-right: 0;
}


@media screen and (max-width: 768px) {
  a.cloud-zoom-gallery {
    width: calc((100% - 30px) / 3);
  }
}

/* ************************************************
*  product_option_window
* ************************************************ */

#product_option {
  margin: 20px;
  padding: 20px;
  background: #fff;
}
#product_option h2 {
  margin-bottom: 20px;
}

table.table_option {
  margin-bottom: 20px;
  border-top: 1px solid #ccc;
  border-right: 1px solid #ccc;
  background: #fff;
}
table.table_option th {
  padding: 10px;
  border-bottom: 1px solid #ccc;
  border-left: 1px solid #ccc;
  background: #f5f5f5;
}
table.table_option td {
  padding: 10px;
  border-bottom: 1px solid #ccc;
  border-left: 1px solid #ccc;
}

/* ************************************************
*  product_list_page
* ************************************************ */

.sub_category_area,
.sub_group_area {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 30px;
}

.sub_category_area div.sub_category,
.sub_group_area div.sub_group {
  width: calc((100% - 50px) / 5);
  margin: 0 5px 10px;
  border: solid 1px #000;
  border-radius: 30px;
  text-align: center;
  transition: all .5s ease;
}

.sub_category_area div.sub_category a,
.sub_group_area div.sub_group a {
  display: block;
  padding: 10px;
  font-weight: 700;
}

.sub_category_area div.sub_category:hover {
  background-color: #000;
}

.sub_category_area div.sub_category:hover a {
  color: #FFF;
}

.sub_category_area div.sub_category img,
.sub_group_area div.sub_group img {
  margin-right: 10px;
  border: solid 1px #ccc;
}

@media screen and (max-width:768px) {
  .sub_category_area div.sub_category,
  .sub_group_area div.sub_group {
    width: calc((100% - 20px) / 2);
  }
}

/* ************************************************
*  search_page
* ************************************************ */

.search_result {
  margin: 20px 0;
  padding: 10px 0;
  background: #ddd;
  text-align: center;
}

.none {
  margin: 50px 0;
  text-align: center;
}

/* ************************************************
*  policy
* ************************************************ */

#policy {
  line-height: 1.8;
  font-size: 14px;
}
#policy h2 {
  margin-bottom: 30px;
}

.policy_box,
#policy_lead{
  margin-bottom: 30px;
}

.sk_box {
  margin-bottom: 70px;
}
.sk_box h3 {
  margin-bottom: 1em;
  font-size: 16px;
}
.sk_box table {
  width: 100%;
  border-top: 1px solid #ccc;
  border-collapse: separate;
  empty-cells:show;
}

.sk_box th {
  padding: 20px 40px 20px 0;
  width: 170px;
  text-align: left;
}
.sk_box th img.poricy_img {
  margin-bottom: 5px;
}
.sk_box td {
  padding: 20px 0;
  zoom: 1;
  content: ' ';
}
.sk_box th,
.sk_box td {
  vertical-align: top;
  line-height: 1.8;
  position: relative;
  border-bottom: solid 1px #ccc;
}

#payment_method {
  margin-top: 40px;
}
#payment_method table.table {
  width: 100%;
}
#payment_method table.table th {
  width: 200px;
  text-align: center;
}

#shipping_method {
  margin-top: 40px;
}
#shipping_method table.table {
  width: 100%;
}
#shipping_method table.table th {
  width: 200px;
  text-align: center;
}

/* ************************************************
*  side
* ************************************************ */

#side .box {
  clear: both;
  margin-bottom: 20px;
  word-wrap: break-word;
  position: relative;
}
#side .box h3 {
  padding-bottom: 10px;
  text-align: left;
  font-size: 16px;
}
#side .box ul {
  padding-bottom: 20px;
  margin-left: 0px;
  list-style: none;
  border-bottom: solid 1px #000;
}
#side .box ul li {
  border-top:#838383 dotted 1px;
}
#side .box ul li:first-child {
  border-top:none;
}

#side #side_nav {
  padding: 0;
  border-top: none;
  border-right: solid 2px #ccc;
  border-bottom: none;
}
#side #side_nav ul{
  margin-right: 10px;
}
#side #side_nav ul li {
  margin: 0;
}
#side #side_nav .nav_item{
  clear: both;
  padding: .9em 0 .9em;
  cursor: pointer;
}
#side #side_nav .nav_item .nav_icon{
  float: left;
  padding: inherit;
  width: 20px;
  height: auto;
}
#side #side_nav .nav_item .nav_icon img{
  max-width: 100%;
}
#side #side_nav .nav_item .nav_title{
  float: right;
  text-align: right;
}
#side #side_nav .nav_item h3{
  margin-bottom: 4px;
  padding: 0;
  border: none;
  text-align: right;
}
#side #side_nav .nav_item p{
  color: #999;
}

.box_default ul li div{
  position: relative;
  padding: 1.2em 0 1em;
  text-align: left;
}
.box_default ul li div img{
  border: solid #ddd 1px;
}
.box_default ul li div p{
  line-height : 1.6;
}

#side #box_cart {
}
#side #box_cart .cart_button {
  text-align: right;
}

#side #box_owner .inner{
  padding: 1.2em 0 1em;
}
#side #box_owner .owner_photo{
  margin: 0 0 10px;
  width: 100px;
  max-width: 100%;
  height: auto;
  border: solid #ddd 1px;
}
#side #box_owner p.name {
  font-size: 14px;
}
#side #box_owner p.memo {
  font-size: 11px;
  line-height: 18px;
}
#side #box_owner p.website {
  padding-left: 20px;
}

#qr_code{
  padding: 20px 0;
}

#box_sellers .seller_box{
  padding: 2.2em 0;
}
#box_sellers li{
  position: relative;
  display: block;
}
#box_sellers  .top_seller:before{
  position: absolute;
  top: 18px;
  left: -6px;
  content: url(https://img.shop-pro.jp/tmpl_img/67/rank1.png);
}
#box_sellers  .rank_2:before{
  content: url(https://img.shop-pro.jp/tmpl_img/67/rank2.png);
}
#box_sellers  .rank_3:before{
  content: url(https://img.shop-pro.jp/tmpl_img/67/rank3.png);
}
#box_sellers .seller_image{
  float: left;
  margin: 0 10px 0 0;
  width: 80px;
  border: solid #ddd 1px;
}
#box_sellers .seller_detail{
  float: right;
  width: 104px;
}
#box_sellers .seller_rank{
  margin: 0 0 10px;
  font-size: 12px;
}
#box_sellers .seller_rank > strong{
  font-size: 15px;
}
#box_sellers .seller_name{
  font-size: 13px;
}
#box_sellers .seller_teika{
  float: left;
  font-family: 'Lucida Grande', 'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, sans-serif;
}
#box_sellers .more_seller{
  display: none;
}

.more_btn{
  padding: 8px 0;
  border-top: solid 1px #999;
  text-align: center;
  cursor: pointer;
}

.updown{
  display: inline-block;
  margin: 0 3px 0 0;
  width: 13px;
  height: 8px;
  background: url(https://img.shop-pro.jp/tmpl_img/67/down_icon.png);
  background-repeat: no-repeat;
}

.more_up{
  background: url(https://img.shop-pro.jp/tmpl_img/67/up_icon.png);
}



/* ************************************************
*  Common Elements
* ************************************************ */
/* @group Common Elements */

table {
  border-spacing: 0;
  border-collapse: collapse;
}
table.table {
  margin-bottom: 20px;
  border-top: 1px solid #ccc;
  border-right: 1px solid #ccc;
}
table.table th {
  padding: 5px;
  border-bottom: 1px solid #ccc;
  border-left: 1px solid #ccc;
  background: #f5f5f5;
}
table.table td {
  padding: 5px;
  border-bottom: 1px solid #ccc;
  border-left: 1px solid #ccc;
}

.footstamp {
  margin-bottom: 30px;
  padding-bottom: 10px;
  border-bottom: 1px solid #ddd;
}
.footstamp span {
  margin: 0 5px;
  color: #999;
}

.sort {
  float: right;
  margin-bottom: 40px;
  text-align: right;
}
.sort strong {
  margin-right: 5px;
}
.sort a {
  margin-right: 5px;
  text-decoration: underline;
}
.sort span {
  margin-right: 5px;
  background: #eee;
  text-decoration: none;
  font-weight: bolder;
}

.pager {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  clear: both;
  margin: 20px 0 130px;
  text-align: center;
}
.pager a{
  margin: 0 25px;
}

.none {
  clear: both;
  margin: 50px 0;
  text-align: center;
}

.sold_out {
  color: #DA5858;
  font-family:'Lucida Grande',
  'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3',
  Meiryo, メイリオ, sans-serif;
}

.to_top{
  float: right;
  clear: both;
  text-align: center;
  margin: 0 0 20px;
  padding: 1.3em 1em;
  border: solid 1px #aaa;
  font-size: 14px;
  color: #888;
}
.to_top:hover {
  text-decoration: none;
  color: #c86464;
  border-color: #c86464;
}

.tbl_calendar {
  margin: 20px 0;
  width: 100%;
  border: none !important;
  border-spacing: 0 !important;
  border-collapse: collapse !important;
}
.tbl_calendar th, .tbl_calendar td {
  padding: 4px !important;
  border-bottom: 1px solid #ccc !important;
  text-align: center !important;
}

/* @group button */
.btn {
  display: block;
  margin-top: 1em;
  border: none;
  border-radius: 0;
  color: #fff;
  text-align: center;
  font-weight: bold;
  font-size: 15px;
  font-family:'Lucida Grande',
  'Hiragino Kaku Gothic ProN', 'ヒラギノ角ゴ ProN W3',
  Meiryo, メイリオ, sans-serif;
  line-height: 1;
  cursor: pointer;
  -webkit-appearance:none;
}
.btn:link,
.btn:visited,
.btn:hover,
.btn:active{
  color: #fff;
  text-decoration: none;
}
.btn-primary {
  margin: 1.2em 0 .9em;
  padding: 1.4em 0;
  background-color: #c86464;
}
.btn-contact {
  margin: 0.5em 0.3em;
  padding: 1.3em 0;
  background-color: #a0a0a0;
  font-weight: normal;
  font-size: 13px;
}
.btn-quick {
  margin: 0.9em 0;
  padding: 1.3em 0;
  background-color: #64b4c8;
  font-size: 13px;
}

/* 追記 */
.search {
  max-width: 300px;
  margin-bottom: 30px;
}

.search form#search {
  display: flex;
}

.search input[type="text"] {
  width: calc(100% - 40px);
  padding: 8px 0 8px 15px;
  background-color: #000;
  border: none;
  border-radius: 30px 0 0 30px;
  color: #FFF;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 2px;
}

.search .right-nav {
  position: relative;
  width: 40px;
}

.search .right-nav:before {
  content: "";
  position: absolute;
  z-index: 1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 3px;
  width: 22px;
  height: 22px;
  margin: auto;
  background-image: url(https://img21.shop-pro.jp/PA01475/891/etc_base64/aWNvbi1zZWFyY2g.gif?cmsp_timestamp=20240423135759);
  background-repeat: no-repeat;
  background-size: 100%;
  pointer-events: none;
}

.search input[type="submit"] {
  position: relative;
  width: 100%;
  padding: 8px;
  background-color: #000;
  border-radius: 0 30px 30px 0;
  border: none;
  border-left: solid 1px #FFF;
}

.search input::placeholder {
  color: #FFF;
}

/* おすすめ商品 */
.swiper-item_image {
  margin-bottom: 20px;
}

.swiper-item_image img {
  width: 100%;
  border-radius: 50%;
}

.swiper-item_detail {
  text-align: center;
}

.swiper-item_detail .swiper-item_name {
  margin-bottom: 10px;
  font-size: 12px;
  font-weight: 600;
}

.swiper-item_detail .swiper-item_price {
  font-size: 10px;
  font-weight: 700;
}

#box_category .side_section_category h4 {
  position: relative;
  padding: 10px 0 10px 30px;
  margin-top: 15px;
  font-size: 16px;
}

#box_category .side_section_category h4:nth-of-type(1):before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 23px;
  height: 24px;
  background-image: url(https://kohbunsha1975.com/kamicolle_parts/img/icon-housou.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  margin: auto 0;
}

#box_category .side_section_category h4:nth-of-type(2):before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 23px;
  height: 19px;
  background-image: url(https://kohbunsha1975.com/kamicolle_parts/img/icon-neko.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  margin: auto 0;
}

#box_category .side_section_category h4:nth-of-type(3):before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 19px;
  height: 26px;
  background-image: url(https://kohbunsha1975.com/kamicolle_parts/img/icon-kikaku.svg);
  background-size: 100%;
  background-repeat: no-repeat;
  margin: auto 0;
}

#box_category ul.side_lst li {
  padding: 5px 0 5px 30px;
  border: none;
  font-size: 14px;
} 

#box_category .header_block {
  border-bottom: solid 1px #000;
}

.banner-area li {
  margin-bottom: 20px;
}


@media screen and (max-width: 1000px) {
  .banner-area li {
    text-align: center;
  }
}


/* box_recentlychecked */
#box_recentlychecked figure {
  text-align: center;
}

#box_recentlychecked figure img {
  width: 100%;
  max-width: 300px;
}

/* box_recommend */
#box_recommend figure {
  text-align: center;
}

#box_recommend figure img {
  width: 100%;
  max-width: 225px;
}

/* quantity */
ul.quantity {
  display: flex;
  align-items: center;
  margin-top: 10px;
}

ul.quantity li {
  width: 100%;
  max-width: 100px;
  margin-right: 10px;
  text-align: center;
}

ul.quantity li.select {
  display: block;
  padding: 5px 20px;
  box-sizing: border-box;
  color: #FFF;
  transition: all .5s ease;
  border: solid 1px #000;
  border-radius: 30px;
  background-color: #000;
}

ul.quantity li a {
  display: block;
  padding: 5px 20px;
  box-sizing: border-box;
  color: #000;
  transition: all .5s ease;
  border: solid 1px #000;
  border-radius: 30px;
}

ul.quantity li:hover a {
  color: #FFF;
  background-color: #000;
}


/*========= ハンバーガーメニュー ===============*/

#header .sp-menu {
  display: none;
}

@media screen and (max-width: 1000px) {
  #header #g-nav{
    position:fixed;
    z-index: 10000;
    top:0;
    right: -120%;
    width:100%;
    background:#FFEB6E;
    transition: all 0.6s;
    padding: 30px;
  }

  #header #g-nav.panelactive{
    right: 0;
  }

  #header #g-nav.panelactive #g-nav-list{
    z-index: 10000; 
    width: 100%;
    height: 100vh;
    overflow: auto;
    -webkit-overflow-scrolling: touch;
  }

  #header #g-nav ul {
    z-index: 10000;
    margin-bottom: 30px;
  }
  
  #header #g-nav ul.g-nav-content {
    display: block;
  }

  #header .openbtn{
    position:fixed;
    z-index: 10001;/*ボタンを最前面に*/
    top: 25px;
    right: 20px;
    cursor: pointer;
    width: 50px;
    height:50px;
  }

  #header .openbtn span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
    background-color: #666;
    width: 45%;
    }

  #header .openbtn span:nth-of-type(1) {
    top:15px; 
  }

  #header .openbtn span:nth-of-type(2) {
    top:23px;
  }

  #header .openbtn span:nth-of-type(3) {
    top:31px;
  }

  #header .openbtn.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
  }

  #header .openbtn.active span:nth-of-type(2) {
    opacity: 0;
  }

  #header .openbtn.active span:nth-of-type(3){
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
  }
  
  #header .sp-menu {
    display: block;
  }
}


@media screen and (max-width: 768px) {
    #header .openbtn {
    top: 0;
    right: 0;
  }
}

/*フリーページ 新着情報*/
#newssingle {
  max-width: 700px;
  width: 100%;
  margin: 80px auto 120px;
}

#newssingle p {
  line-height: 2;
}

/*フリーページ*/
#freepage {
  overflow: hidden;
}

#freepage .inner {
  max-width: 1000px;
  width: 90%;
  margin: 0 auto 100px;
}

#freepage figure {
  margin: 0;
}

#freepage ul.column {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  margin: 0;
  padding: 30px;
}

#freepage ul.column li {
  width: calc((100% - 30px) / 2);
  background: #FFF;
}

#freepage h2 {
  color: #62122F;
  font-weight: bold;
  text-align: center;
  font-size: 26px;
}

#freepage .bgRedtea h2 {
  color: #FFF;
}

#freepage section {
  margin-bottom: 100px;
}

#freepage h3 {
  font-weight: bold;
  font-size: 18px;
  margin-top: 0;
  margin-bottom: 30px;
}

#freepage p {
  margin-bottom: 20px;
  font-size: 16px;
  line-height: 1.8;
}

#freepage .headImg {
  margin-bottom: 120px;
  text-align: center;
}

#freepage section>p {
  margin-bottom: 40px;
  font-size: 18px;
  text-align: center;
}

#freepage section .inner p {
  font-size: 18px;
  text-align: center;
}

#freepage section.bgRedtea .inner p {
  color: #FFF;
}

#freepage table {
  width: 100% !important;
}

#freepage .cartjs_box {
  padding: 0 !important;
}

#freepage .textBox {
  padding: 20px 40px 30px;
}
#freepage .textBox dl {
  display: flex;
  width: 100%;
}

#freepage .textBox dt,
#freepage .textBox dd {
  margin-left: 0;
  font-size: 15px;
  font-weight: normal;
  line-height: 1.6;
}

#freepage .textBox dt {
  width: 90px;
}

#freepage .textBox dd {
  width: calc(100% - 90px);
}

#freepage .textBox th {
  width: 90px;
}

#freepage .cartjs_cart_in input {
  width: 100% !important;
}

#freepage input[type="submit"] {
  background-color: #62122F !important;
  height: 50px !important;
}

#freepage .buttonBox a {
  background: #62122F;
  height: 50px;
  display: flex;
  border-radius: 6px;
  color: #FFF;
  align-items: center;
  text-align: flex;
  justify-content: center;
  font-size: 16px;
  text-decoration: none;
}

#freepage .bgRedtea {
  position: relative;
  padding: 50px 0;
}

#freepage .bgRedtea:after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: -100%;
  width: 300%;
  height: 100%;
  margin: 0 auto;
  background: #62122F; 
}

@media (max-width: 768px) {
  #freepage h3 {
   font-size: 16px; 
  }
  
  #freepage ul.column {
    padding: 0;
  }
  
  #freepage ul.column li {
    width: 100%;
  }
  
  #freepage .textBox {
    padding: 20px;
  }
}

@media (max-width: 480px) {
    #freepage ul.column {
    display: block;
  }
  
  #freepage h2 {
    font-size: 22px;
  }

  #freepage .bgRedtea {
    padding: 30px 0;
  }

  #freepage section .inner p {
    margin-bottom: 30px;
    font-size: 15px;
  }
  
  #freepage ul.column li {
    margin-bottom: 50px;
  }
}

/* ねこ特集 */
#freepage.neko-tokushu {
  overflow: visible;
}

#freepage.neko-tokushu h2 {
  color: #000;
  margin-top: 0;
}

#freepage.neko-tokushu h3 {
  color: #000;
}

.neko-tokushu p {
  font-size: 16px;
}

#freepage.neko-tokushu ul.column li {
  position: relative;
  background: unset;
}

.neko-tokushu .button-wrap {
  margin-top: 80px;
  text-align: center;
}

.neko-tokushu .button {
  width: 300px;
  text-align: center;
  border-radius: 40px;
  margin: 0 auto 10px;
}

.neko-tokushu .button a {
  display: block;
  padding: 15px 20px;
  background: #DD9A15;
  color: #FFF;
  font-size: 18px;
  font-weight: bold;
  transition: all .5s ease;
  border-radius: 40px;
}

.neko-tokushu .button a:hover {
  text-decoration: none;
  opacity: 0.8;
}

.neko-tokushu ul {
  margin: 0;
}

#freepage table td {
  text-align: center;
  border: solid 1px #000;
  background: #FFF;
  padding: 15px;
  line-height: 1.6;
  font-size: 15px;
  font-weight: bold;
  letter-spacing: 1px;
  vertical-align: middle;
}

#freepage table tr.top-cell td {
  background: #DDD;
}

.neko-tokushu #hero {
  width: 100%;
  text-align: center;
  margin-bottom: 0;
}

.neko-tokushu #type {
  width: 100%;
  background: #F5F0E4 url(https://img21.shop-pro.jp/PA01475/891/etc_base64/bmVrb3Rva3VzaHUtYXNoaWF0bw.gif?cmsp_timestamp=20230703155651);
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: bottom right;
}

.neko-tokushu #type h2 {
  margin-bottom: 80px;
}

.neko-tokushu #type .inner {
  padding: 120px 0;
}

.neko-tokushu #type ul li:nth-of-type(2) {
  margin-top: 200px;
}

.neko-tokushu #type ul li:before {
  content: "";
  position: absolute;
  width: 147px;
  height: 113px;
  background: url(https://img21.shop-pro.jp/PA01475/891/etc_base64/bmVrby10b2t1c2h1LWtpcmE.gif?cmsp_timestamp=20230630164145);
}

.neko-tokushu #type ul li:nth-of-type(1):before {
  top: -80px;
  left: -80px;
}

.neko-tokushu #type ul li:nth-of-type(2):before {
  transform: rotate(70deg);
  top: -75px;
  right: -90px;
}

.neko-tokushu #type ul li h3 {
  position: absolute;
  width: 100%;
  font-size: 44px;
  text-align: center;
  z-index: 0;
}

.neko-tokushu #type ul li h3::after {
  content: "";
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 50%;
  background: #FFF100;
  bottom: 0;
  left: 0;
  right: 0;
  margin: 0 auto;
}

.neko-tokushu #type ul li:nth-of-type(2) h3::after {
  background: #00B3FF;
}

.neko-tokushu #type ul li:nth-of-type(1) h3 {
  left: 100%;
}

.neko-tokushu #type ul li:nth-of-type(2) h3 {
  left: -100%;
  bottom: 30px;
}

.neko-tokushu #option {
  padding: 70px 0 120px;
  width: 100%;
  background: #F5F0E4 url(https://img21.shop-pro.jp/PA01475/891/etc_base64/bmVrb3Rva3VzaHUtYXNoaWF0bzAy.gif?cmsp_timestamp=20230703160049);
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: 75px 50px;
}

.neko-tokushu #option .inner>p {
  margin-bottom: 25px;
  text-align: center;
  font-size: 20px;
}

.neko-tokushu #option ul li {
  width: calc((100% - 60px) / 3);
  text-align: center;
}

.neko-tokushu #option ul li h3 {
  margin-top: 10px;
}

.neko-tokushu #price-wrap {
  padding: 120px 0;
}

.neko-tokushu .price-content {
  margin-top: 50px;
}

#freepage.neko-tokushu .price-content h3 {
  font-size: 24px;
  text-align: center;
}

#freepage #price-wrap .souryo table {
  max-width: 500px;
  margin: 0 auto;
}

.neko-tokushu #price-wrap .souryo .caption {
  margin-top: 10px;
  text-align: center;
}

.neko-tokushu #flow {
  padding: 120px 0 50px;
  width: 100%;
  background-color: #F5F0E4;
}

.neko-tokushu #flow h2 {
  margin-bottom: 80px;
}

.neko-tokushu #flow h3 {
  position: relative;
  padding-bottom: 10px;
  padding-left: 55px;
  font-size: 26px;
  border-bottom: dotted 5px #DD9A15;
}

.neko-tokushu #flow h3:before {
  content: "";
  position: absolute;
  top: -5px;
  bottom: 0;
  left: 0;
  width: 45px;
  height: 47px;
  background: url(https://img21.shop-pro.jp/PA01475/891/etc_base64/bmVrb3Rva3VzaHUtaWNvbg.gif?cmsp_timestamp=20230703102736);
  background-repeat: no-repeat;
  background-size: 100%;
}

.neko-tokushu #flow ul li {
  position: relative;
  background: #FFF;
  border-radius: 10px;
  padding: 25px 30px;
  margin-bottom: 100px;
}

.neko-tokushu #flow ul li:after {
  content: "";
  position: absolute;
  bottom: -80px;
  left: 0;
  right: 0;
  width: 72px;
  height: 60px;
  margin: 0 auto;
  background: url(https://img21.shop-pro.jp/PA01475/891/etc_base64/bmVrb3Rva3VzaHUtYXJyb3c.gif?cmsp_timestamp=20230703104559);
  background-repeat: no-repeat;
  background-size: 100%;
}

.neko-tokushu #flow ul li:last-of-type:after {
  content: none;
}

.neko-tokushu #flow ul li p {
  margin-bottom: 0;
}

.neko-tokushu #caution {
  padding: 120px 0;
}

.neko-tokushu #caution h2 {
  width: 80%;
  margin: 0 auto 80px;
}

.neko-tokushu #caution ul li {
  margin-bottom: 40px;
}

.neko-tokushu #caution ul li h3 {
  margin-bottom: 5px;
}

.neko-tokushu #work {
  padding-bottom: 120px;
  width: 100%;
  background: #F5F0E4;
  background-size: 100%;
  background-repeat: no-repeat;
  background-position: bottom right;
}

.neko-tokushu #work h2 {
  margin-bottom: 70px;
}

.neko-tokushu #work .column {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 15px;
}

.neko-tokushu #work .illust-box {
  margin: 0 auto;
}

.neko-tokushu #work .illust-box.no-width {
  width: 100%;
}

.neko-tokushu #work ul {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  justify-content: center;
}

.neko-tokushu #work ul li {
  width: calc((100% - 30px) / 2);
  text-align: center;
  background: #FFF;
  padding: 30px;
  box-sizing: border-box;
  border-radius: 15px;
}

.neko-tokushu #work ul li img {
  height: auto;
  max-height: 267px;
  border: solid 1px #DDD;
  object-fit: cover;
}

.neko-tokushu #work h3 {
  position: relative;
  border-radius: 20px;
  width: 90%;
  max-width: 180px;
  padding: 3px 0;
  margin: -15px auto 0;
}

.neko-tokushu #work h3.photo-base {
  background: #EEE;
}

.neko-tokushu #work h3.real {
  background: #FFF100;
}

.neko-tokushu #work h3.pop {
  background: #00B3FF;
}

.neko-tokushu #work .img-wrap .img-box.no-width {
  width: 100%;
}

.neko-tokushu #work .img-wrap {
  position: relative;
  border-bottom: solid 1px #CCC;
  padding-bottom: 25px;
  margin-bottom: 25px;
}

.neko-tokushu #work .img-wrap:after {
  content: "";
  position: absolute;
  bottom: -35px;
  left: 0;
  right: 0;
  width: 62px;
  height: 50px;
  margin: 0 auto;
  background: url(https://img21.shop-pro.jp/PA01475/891/etc_base64/bmVrb3Rva3VzaHUtYXJyb3c.gif?cmsp_timestamp=20230703104559);
  background-repeat: no-repeat;
  background-size: 100%;
}

.neko-tokushu #work .img-box {
  max-width: 100%;
  width: max-content;
  margin: 0 auto;
}

@media (max-width: 768px) {
  .neko-tokushu #work ul li{
    width: 100%;
  }
}

@media (max-width: 480px) {
  .neko-tokushu #type h2 {
    margin-bottom: 40px;
  }
  
  #freepage table td {
    padding: 5px;
    font-size: 12px;
  }
  
  .neko-tokushu #type ul li h3 {
    font-size: 35px;
  }
  
  .neko-tokushu #type ul li:nth-of-type(2) {
    margin-top: 120px;
  }
  
  .neko-tokushu #type ul li:nth-of-type(1) h3 {
    position: relative;
    left: -7%;
  }
  
  .neko-tokushu #type ul li:nth-of-type(2) h3 {
    position: relative;
    left: auto;
    right: -7%;
    bottom: auto;
  }
  
  .neko-tokushu #type ul li:nth-of-type(1):before {
    top: 100px;
    left: 0;
  }
  
  .neko-tokushu #type ul li:nth-of-type(2):before {
    top: 100px;
    right: 0;
  }
  
  .neko-tokushu #option {
    padding: 0 0 80px;
  }
  
  .neko-tokushu #option ul li h3 {
    font-size: 20px;
  }
  
  .neko-tokushu #option .inner>p {
    font-size: 16px;
    text-align: left;
  }
  
  .neko-tokushu #option ul li {
    width: 100%;
  }
  
  .neko-tokushu #caution {
    padding: 80px 0;
  }
  
  .neko-tokushu #caution h2 {
    width: 100%;
    margin-bottom: 50px;
  }
  
  .neko-tokushu #flow h2 {
    width: 60%;
    margin: 0 auto 50px;
  }
  
  .neko-tokushu #flow h3 {
    padding-left: 55px;
    font-size: 20px;
  }
  
  .neko-tokushu #flow ul li p {
    font-size: 14px;
  }
  
  .neko-tokushu #flow h3:before {
    width: 40px;
    height: 37px;
  }
  
  .neko-tokushu #work h2 {
    width: 60%;
    margin: 0 auto 50px;
  }
}

/**/
.osada-tokushu #hero {
  margin-bottom: 100px;
}

.osada-tokushu .banner {
  margin-bottom: 70px;
}

#freepage.osada-tokushu ul.itemList li {
  width: calc((100% - 60px) / 3);
}

.osada-tokushu .cartjs_product_img,
.osada-tokushu .cartjs_cart_in{
  width: 100% !important;
}

.osada-tokushu #profile .column {
  display: flex;
  flex-wrap: wrap;
  max-width: 850px;
  margin: 0 auto;
}

.osada-tokushu #profile .imgWrap {
  width: 300px;
}

.osada-tokushu #profile .textWrap {
  width: calc(100% - 300px);
  padding: 20px 20px 20px 50px;
  box-sizing: border-box;
}

.osada-tokushu #profile .textWrap h2 {
  text-align: left;
  font-size: 22px;
}

.osada-tokushu #profile .textWrap .button {
  margin: 20px auto 0;
  max-width: 300px;
}

.osada-tokushu .button {
  width: auto;
}

.osada-tokushu .button a {
  border-radius: 5px;
  background-color: #62122F;
  padding: 10px 20px;
  font-size: 16px;
  font-weight: normal;
}

.osada-tokushu #profile {
  margin: 100px 0 80px;
}

.osada-tokushu #relatedItem {
  overflow: hidden;
}

.osada-tokushu h2.titleHeading {
  position: relative;
  width: max-content;
  margin: 0 auto;
}

.osada-tokushu h2.titleHeading:before {
  content: "";
  position: absolute;
  width: 300px;
  height: 1px;
  background-color: #000;
  top: 0;
  bottom: 0;
  left: -320px;
  margin: auto 0;
}

.osada-tokushu h2.titleHeading:after {
  content: "";
  position: absolute;
  width: 300px;
  height: 1px;
  background-color: #000;
  top: 0;
  bottom: 0;
  right: -320px;
  margin: auto 0;
}

.osada-tokushu .cartjs_cart_in {
  text-align: left !important;
}

.osada-tokushu #banner02 {
  margin-bottom: 100px;
  text-align: center;
}

@media (max-width: 768px) {
  .osada-tokushu #hero {
    margin-bottom: 50px;
  }
  
  .osada-tokushu .banner {
    margin-bottom: 40px;
  }
  
  #freepage.osada-tokushu ul.itemList li {
    width: calc((100% - 30px) / 2);
  }
  
  .osada-tokushu strong.cartjs_product_name {
    font-size: 15px !important;
  }
  
  .osada-tokushu .cartjs_product_table td {
    font-size: 15px !important;
  }
  
  .osada-tokushu  #mai-pop-item h2 {
    margin-bottom: 30px;
  }
  
  .osada-tokushu #profile .imgWrap {
    width: 100%;
    margin-bottom: 25px;
    text-align: center;
  }
  
  .osada-tokushu #profile .imgWrap img {
    max-width: 300px;
  }
  
  .osada-tokushu #profile .textWrap {
    width: 100%;
    padding: 0;
  }
  
  .osada-tokushu #relatedItem h2 {
    margin-bottom: 30px;
  }
}

@media (max-width: 480px) {
#freepage.osada-tokushu ul {
  display: flex;
  }
}

/*nenga2024-movie*/
.nenga2024-movie img {
  max-width: 100%;
}

.nenga2024-movie .cartjs_cart_in {
width: 100% !important;
margin-top: 10px !important;
}

.nenga2024-movie #hero {
  margin-bottom: 120px;
}

.nenga2024-movie #step h2 {
  margin-bottom: 60px;
}

.nenga2024-movie #step h3 {
  font-size: 20px;
}

.nenga2024-movie #step ul.column li {
  position: relative;
  width: calc((100% - 60px) / 3);
}

.nenga2024-movie #step ul.column li:after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: -24px;
  margin: auto 0;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 37.5px 0 37.5px 16px;
  border-color: transparent transparent transparent #aaaaaa;
}

.nenga2024-movie #step ul.column li:last-of-type:after {
  content: none;
}

.nenga2024-movie #sample {
  margin: 0 calc(50% - 50vw);
  padding: 120px 0 50px;
  width: 100vw;
  background-color: #F5F0E4;
}

.nenga2024-movie #sample ul li {
  width: calc((100% - 60px) / 3);
}

.nenga2024-movie #sample ul li iframe {
  width: 100%;
  height: 500px;
}

.nenga2024-movie .caution {
  border: solid 2px red;
  text-align: center;
  padding: 20px 30px;
  color: red;
  margin: 0 auto 60px;
  width: fit-content;
}

.nenga2024-movie .caution h3 {
  color: red !important;
}

@media (max-width: 480px) {
  .nenga2024-movie img {
  max-width: 100% !important
  }
  
  .nenga2024-movie #hero {
    margin-bottom: 50px;
  }
  
  .nenga2024-movie #step {
    padding-top: 80px;
  }
  
  .nenga2024-movie #step ul.column li {
  width: 100%;
  }
  
  .nenga2024-movie #step ul.column li:after {
    border-width: 16px 37.5px 0 37.5px;
    border-color: #aaaaaa transparent transparent transparent;
    right: 0;
    left: 0;
    top: auto;
    bottom: -40px;
    margin: 0 auto;
  }
  
  .nenga2024-movie #hinoki p {
    width: 100%;
    font-size: 18px;
  }
  
  .nenga2024-movie #sample ul li {
  width: 100%;
}
  
  .nenga2024-movie #step ul.column li img {
    width: 100%;
  }
  
    .nenga2024-movie .caution {
      margin-bottom: 40px;
  }
  
    .nenga2024-movie .caution h3 {
      font-size: 20px !important;
  }
  
  .nenga2024-movie .caution p {
    text-align: left;
    font-size: 14px;
  }
}

/*フリーページ 新着情報*/
#newssingle {
  max-width: 700px;
  width: 100%;
  margin: 80px auto 120px;
}

#newssingle h2 {
  margin-bottom: 30px;
}

#newssingle p {
  line-height: 2;
  margin-bottom: 15px;
}

/* ************************************************
*  .yuimemo(結MEMO)
* ************************************************ */
#yuimemo {
color: #333;
}

#yuimemo a {
color: #00A5E3;
}

#yuimemo .inner {
  width: 90%;
  margin: 0 auto;
}

#yuimemo .titleWrap {
  padding: 10px 25px;
  margin-bottom: 30px;
  background-color: #00A5E3;
  border-radius: 10px;
}

#yuimemo .titleWrap h2 {
  color: #FFF;
  font-size: 28px;
}

#yuimemo .titleWrap p {
  color: #FFF;
  font-size: 16px;
  font-weight: 600;
}

#yuimemo .sp-hidden {
  display: block;
}

#yuimemo .sp-block {
  display: none;
}

@media screen and (max-width:768px) {
  #yuimemo {
    margin: 0 -9%;  
  }
  
  #yuimemo .titleWrap {
    margin: 0 10px 40px;
  }
  
  #yuimemo .titleWrap h2 {
    font-size: 22px;
  }
  
  #yuimemo .titleWrap p {
    font-size: 14px;
  }
  
  #yuimemo .sp-hidden {
    display: none;
  }
  
  #yuimemo .sp-block {
    display: block;
  }
}

#yuimemo #step {
  margin-bottom: 60px;
}

#yuimemo #step .stepContent {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  margin-bottom: 20px;
}

#yuimemo #step .stepContent .leftBox {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: 145px;
}

#yuimemo #step .stepContent .leftBox p {
  color: #00A5E3;
  background-color: #C7E8FA;
}

#yuimemo #step .stepContent .leftBox p:first-of-type {
  padding: 3px 30px 5px 15px;
  margin-right: -25px;
  font-size: 18px;
  font-weight: 700;
  border-radius: 100px;
}

#yuimemo #step .stepContent .leftBox p.number {
  position: relative;
  z-index: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 50px;
  width: 50px;
  font-size: 30px;
  font-weight: 700;
  border-radius: 50%;
}

#yuimemo #step .stepContent .leftBox p.number:after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  height: 85%;
  width: 85%;
  margin: auto;
  background-color: #FFF;
  border-radius: 50%;
}

#yuimemo #step .stepContent .rightBox {
  width: calc(100% - 150px);
  padding-left: 10px;
}

#yuimemo #step .stepContent .rightBox h3 {
  margin-bottom: 5px;
  font-size: 22px;
  line-height: 1.4;
}
#yuimemo #step .stepContent .rightBox p {
  font-size: 14px;
}

@media screen and (max-width:768px) {
  #yuimemo #step .stepContent {
    display: block;
    padding-bottom: 20px;
    margin-bottom: 20px;
    border-bottom: solid 1px #CCC;
  }
  
  #yuimemo #step .stepContent:last-of-type {
    border: none;
  }
  
  #yuimemo #step .stepContent .leftBox {
    margin-bottom: 10px;
  }
  
  #yuimemo #step .stepContent .rightBox {
    width: 100%;
  }
}
  
#yuimemo #option {
  margin-bottom: 60px;
}

#yuimemo #option .titleWrap {
  display: flex;
  flex-wrap: wrap;
  padding-top: 15px;
  padding-bottom: 15px;
}

#yuimemo #option .titleWrap h2 {
  width: calc(100% - 270px);
  padding-left: 20px;
}

#yuimemo #option .titleWrap h3 {
  display: flex;
  align-items: center;
  width: 270px;
  padding: 3px 25px;
  background-color: #FFF;
  color: #00A5E3;
  font-size: 24px;
  text-align: center;
  border-radius: 10px;
}

#yuimemo #option ul.optionList {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px;
}

#yuimemo #option ul.optionList li {
  position: relative;
  width: calc((100% - 90px) / 3);
  margin: 0 15px 15px;
}

#yuimemo #option ul.optionList li:nth-of-type(2):before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: -23px;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-right: 15px solid #00a5e3;
  border-left: 0;
}

#yuimemo #option ul.optionList li:nth-of-type(2):after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  right: -23px;
  width: 0;
  height: 0;
  margin: auto 0;
  border-style: solid;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 15px solid #00a5e3;
  border-right: 0;
}

#yuimemo #option ul.optionList li h4 {
  font-size: 16px;
  text-align: center;
}

#yuimemo #option ul.optionList li h4 span.small {
  font-size: 14px;
}

#yuimemo #option p.borderText {
  padding-top: 10px;
  margin-top: 10px;
  font-size: 13px;
  border-top: solid 1px #000;
}

@media screen and (max-width:768px) {
  #yuimemo #option .titleWrap {
    display: block;
    padding-left: 15px;
    padding-right: 15px;
  }
  
  #yuimemo #option .titleWrap h2 {
    width: 100%;
    padding-left: 0;
  }
  
  #yuimemo #option .titleWrap h3 {
    display: block;
    width: 100%;
    margin-bottom: 5px;
    font-size: 20px;
  }
  
  #yuimemo #option ul.optionList {
    margin: 0;
  }
  
  #yuimemo #option ul.optionList li {
    width: 100%;
    margin-bottom: 40px;
  }
  
  #yuimemo #option ul.optionList li:nth-of-type(2):before {
    top: -40px;
    left: 0;
    right: 0;
    transform: rotate(90deg);
    margin: 0 auto;
  }
  
  #yuimemo #option ul.optionList li:nth-of-type(2):after {
    transform: rotate(90deg);
    right: 0;
    margin: 0 auto;
    top: auto;
    bottom: -40px;
    left: 0;
  }
  
  #yuimemo #option ul.optionList li figure {
    margin-bottom: 10px;
  }
  
}

#yuimemo #template {
  padding: 30px 0;
  background-color: #C7E8FA;
}

#yuimemo #template h2 {
  margin-bottom: 40px;
  font-size: 32px;
  text-align: center;
}

#yuimemo #template ul.templateList {
  display: flex;
  flex-wrap: wrap;
  margin: 0 -15px;
}

#yuimemo #template ul.templateList li {
  width: calc((100% - 90px) / 3);
  margin: 0 15px 30px;
}

#yuimemo #template ul.templateList li figure {
  margin-bottom: 10px;
}

#yuimemo #template ul.templateList li img {
  border: solid 3px #FFF;
  border-radius: 15px;
}

#yuimemo #template ul.templateList li h3 {
  margin-bottom: 5px;
  font-size: 20px;
  text-align: center;
}

#yuimemo #template ul.templateList li a {
  background-color: #00A5E3;
  color: #FFF;
  text-align: center;
  display: block;
  padding: 3px 15px 5px;
  margin: 0 auto;
  font-weight: 600;
  border-radius: 5px;
  margin-top: 10px;
  transition: all .5s ease;
}

#yuimemo #template ul.templateList li a:hover {
  transition: all .5s ease;
  background-color: #000;
}

@media screen and (max-width:768px) {
  #yuimemo #template h2 {
    font-size: 24px;    
  }
  
  #yuimemo #template ul.templateList {
    margin: 0 -10px;
  }
  
  #yuimemo #template ul.templateList li {
    width: calc((100% - 40px) / 2);
    margin: 0 10px 30px;
  }
}

#yuimemo .contact {
  background-color: #00A5E3;
  padding: 20px 30px;
  margin: 0 auto 60px;
  color: #FFF;
}

#yuimemo .contact h3 {
  display: flex;
  align-items: flex-end;
  margin-bottom: 5px;
  font-size: 30px;
  line-height: 1;
}

#yuimemo .contact h3 span.quantity {
  background-color: #FFF;
  color: #00A5E3;
  font-size: 20px;
  padding: 3px 5px;
  margin: 0 8px 0 10px;
}

#yuimemo .contact span.oswald {
  margin-right: 3px;
  font-size: 150%;
  font-weight: 500;
}

#yuimemo .contact span.tax {
  font-size: 50%;
  font-weight: 500;
}

#yuimemo .contact h4 {
  border-top: solid 1px #FFF;
  padding-top: 10px;
  margin-top: 10px;
  font-size: 24px;
}

#yuimemo .contact p {
  font-size: 16px;
  font-weight: 600;
}

#yuimemo .contact a {
  color: yellow;
}
#yuimemo .contact .column {
  display: flex;
  flex-wrap: wrap;
}

#yuimemo .contact p.caution {
  font-size: 14px;
}

#yuimemo .contact .price {
  width: calc(100% - 240px);
  padding-right: 30px;
}

#yuimemo .contact .contactButton {
  display: flex;
  width: 240px;
  align-items: center;
  background-color: #FFF;
  color: #00A5E3;
  text-align: center;
  font-size: 20px;
  font-weight: 700;
  padding: 10px 20px;
  border-radius: 10px;
}

#yuimemo .contact .contactButton .button {
  margin-top: 10px;
}

#yuimemo .contact .contactButton a {
  background-color: #00A5E3;
  color: #FFF;
  font-size: 16px;
  display: block;
  padding: 5px 15px;
  border-radius: 5px;
  transition: all .5s ease;
}

#yuimemo .contact .contactButton a:hover {
  background-color: #000;
  transition: all .5s ease;
}

@media screen and (max-width:768px) {
  #yuimemo .contact .column {
    display: block;
  }
  
  #yuimemo .contact .price {
    width: 100%;
    padding-right: 0;
  }
  
  #yuimemo .contact h3 {
    font-size: 22px;
  }
  
  #yuimemo .contact h4 {
    font-size: 18px;
  }
  
  #yuimemo .contact .contactButton {
    width: 100%;
    margin-top: 20px;
  }
  
  #yuimemo .contact .contactButton {
    display: block;
    width: 100%;
    font-size: 16px;
  }
}

/* ************************************************
*  #super-flower(スーパーフラワー 胡蝶蘭)
* ************************************************ */
#super-flower .inner {
  width: 85%;
  margin: 0 auto;
}

#super-flower .column {
  display: flex;
  flex-wrap: wrap;
}

#super-flower .sp-hidden {
  display: block;
}

#super-flower .sp-block {
  display: none;
}

@media screen and (max-width:768px) {
  #super-flower {
    overflow: hidden;
    margin: 0 -9%;  
  }
  
  #super-flower .sp-hidden {
    display: none;
  }

  #super-flower .sp-block {
    display: block;
  }
}

#super-flower #info {
  padding: 60px 0 30px;
  margin-bottom: 60px;
  background-color: #C82132;
  color: #FFF;
}

#super-flower #info .infoContent {
  margin-bottom: 40px;
}

#super-flower #info h2 {
  padding-top: 3px;
  padding-bottom: 3px;
  margin-bottom: 15px;
  font-size: 24px;
  font-weight: 500;
  border-top: solid 1px #FFF;
  border-bottom: solid 1px #FFF;
}

#super-flower #info p {
  font-size: 15px;
  line-height: 1.7;
}

@media screen and (max-width:768px) {
  #super-flower #info h2 {
    padding-top: 7px;
    padding-bottom: 7px;
    font-size: 20px;
  }
  
  #super-flower #info p {
    font-size: 14px;
    line-height: 1.6;
  }
}

#super-flower #list {
  overflow: hidden;
  padding: 30px 0 50px;
  background-color: #060304;
  color: #FFF;
}

#super-flower #list h2 {
  margin-bottom: 10px;
  font-size: 40px;
  font-weight: normal;
}

#super-flower #list h2 span {
  letter-spacing: -6px;
}

#super-flower #list h3 {
  position: relative;
  z-index: 0;
  padding: 3px 0;
  margin-bottom: 20px;
  font-size: 16px;
  font-weight: normal;
  text-align: right;
}

#super-flower #list h3:after {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  bottom: 0;
  right: -9%;
  height: 100%;
  width: 100%;
  margin: auto 0;
  background-image: linear-gradient(90deg, rgba(80, 80, 80, 0), rgba(80, 80, 80, 1) 50%);
}

#super-flower #list ul {
  align-items: flex-end;
  margin: 0 -15px;
}

#super-flower #list ul li {
  width: calc((100% - 90px) / 3);
  margin: 0 15px 40px;
}

#super-flower #list ul li figure {
  margin-bottom: 10px;
}

#super-flower #list ul li p {
  font-size: 16px;
  text-align: center;
}

#super-flower #list ul li p span.small {
  margin: 0 2px;
  font-size: 85%;
}

@media screen and (max-width:768px) {
  #super-flower #list h2 {
    font-size: 28px;
  }
  
  #super-flower #list h2 span {
    letter-spacing: -4px;
  }
  
  #super-flower #list h3 {
    font-size: 15px;
  }
  
  #super-flower #list ul li {
    width: calc((100% - 40px) / 2);
    margin: 0 10px 40px;
  }
}

#super-flower .contact {
  padding: 15px 25px;
  border: solid 1px #FFF;
}

#super-flower .contact h4 {
  margin-bottom: 15px;
  font-size: 24px;
  font-weight: 500;
}

#super-flower .contact p {
  font-size: 15px;
}

#super-flower .contact p.caution {
  font-size: 14px;
}

#super-flower .contact p.caution a {
  color: yellow;
}

#super-flower .contact .column {
  margin-top: 20px;
  margin-bottom: 10px;
}

#super-flower .contact .reijo {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: calc((100% - 30px) / 2);
  padding: 15px 20px;
  background-color: #FFF;
  margin-right: 15px;
  color: #000;
}

#super-flower .contact .reijo h5 {
  font-size: 20px;
  text-align: center
}

#super-flower .contact .reijo p {
  font-weight: 600;
  text-align: center;
}

#super-flower .contact .download {
  display: flex;
  align-items: center;
  justify-content: center;
  width: calc((100% - 30px) / 2);
  margin-left: 15px;
}

#super-flower .contact .download a {
  display: block;
  width: 100%;
  padding: 15px 20px;
  background-color: #FFF;
  font-size: 18px;
  font-weight: 600;
  text-align: center;
  transition: all .5s ease;
}

#super-flower .contact .download a:hover {
  background-color: #C82132;
  transition: all .5s ease;
  color: #FFF;
}

@media screen and (max-width:768px) {
  #super-flower .contact .column {
    display: block;
  }
  
  #super-flower .contact .reijo {
    width: 100%;
    margin-right: 0;
    margin-bottom: 15px;
  }
  
  #super-flower .contact .download {
    width: 100%;
    margin-left: 0;
  }
  
  #super-flower .contact h4 {
    font-size: 20px;
    text-align: center;
  }
}