﻿@charset "UTF-8";

/* ----ツールチップ---- */

.balloontip {
  min-width: 20px;
  padding: 10px;
  border-radius: 6px;
  opacity: 1;
  z-index: 32767;
  text-align: left;
  font-size: 12px;
  border: 1px solid rgb(119, 119, 119);
  box-shadow: rgb(85, 85, 85) 4px 4px 4px;
  color: rgb(255, 255, 255);
  background: #333;
}

strong {
  font-weight: bold;
}

td[align="right"] > input:hover {
  opacity: 0.7;
}

th,
td {
  word-wrap: break-word;
}

/* --------------------------------------------------------------------
  common　汎用クラス
-------------------------------------------------------------------- */
/* 文字サイズ */
.xlarge_ {
  font-size: 144%;
}

.small_ {
  font-size: 80%;
}

.xsmall_ {
  font-size: 64%;
}

/* ----clearfix---- */
.clearfix_:before,
.clearfix_:after {
  content: "";
  display: table;
}

.clearfix_:after {
  clear: both;
}

.clearfix_ {
  zoom: 1;
}

/* 共通クラス(その他) */
.disp_none_ {
  display: none;
}

.hidden_ {
  visibility: hidden;
  clear: both;
  margin: 9px 0;
}

.nocell_ {
  border: none !important;
  background-color: transparent !important;
}

.hiddenEnter_ {
  width: 0;
  height: 0;
  display: inline;
  float: left;
  display: none;
}

/* 価格表示 */
span.price_pop_ {
  color: #c00;
  font-size: 10px;
  display: block;
  display: none;
}

span.price_ {
  color: #333;
  font-size: 15px;
  font-weight: bold;
  overflow-wrap: break-word;
}

#sidebox_cart span.price_ {
  color: #333;
}

/* 税区分フロント名称 */
span.tax_class_name_ {
  color: #333;
  font-size: 11px;
  margin: 0 8px;
  padding: 2px;
}

/* --------------------------------------------------------------------
  common　ヘッドライン
-------------------------------------------------------------------- */
h1.goods_name_ {
  margin: 0 0 6px;
  font-size: 28px;
  font-weight: bold;
  color: #222;
  word-break: break-all;
}

h1.supplier_name_ {
  margin: 0 0 5px 0;
  color: #333;
  font-size: 18px;
  font-weight: bold;
  line-height: 130%;
  padding: 9px 7px 8px 0;
  font-size: 28px;
  word-break: break-word;
}

h1.category_name_ {
  margin: 0 0 11px;
  padding: 0;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.5;
  color: #222;
}

h1.category_name_img_ {
  /* タイトルを画像にした場合 */
  margin-bottom: 10px;
}

h1.event_name_ {
  margin: 0 0 5px 0;
  color: #333;
  font-size: 18px;
  font-weight: bold;
  line-height: 130%;
  padding: 9px 7px 8px 15px;
  font-size: 28px;
}

h1.event_name_img_ {
  /* タイトルを画像にした場合 */
  margin-bottom: 10px;
}

h1.genre_name_ {
  margin: 0 0 5px 0;
  color: #333;
  font-size: 18px;
  font-weight: bold;
  line-height: 130%;
  padding: 9px 7px 8px 15px;
  font-size: 28px;
}

h1.topic_head_ {
  margin: 0 0 5px 0;
  color: #333;
  font-size: 18px;
  font-weight: bold;
  line-height: 130%;
  padding: 9px 7px 8px 0;
  font-size: 28px;
}

h1.maker_name_ {
  margin: 0 0 5px 0;
  color: #333;
  font-size: 18px;
  font-weight: bold;
  line-height: 130%;
  padding: 9px 7px 8px 15px;
  font-size: 28px;
}

/* 汎用ヘッドライン */
.common_headline1_ {
  /* h1相当 */
  margin: 0;
  padding: 9px 0 11px;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.5;
  color: #222;
}

.col1_ .common_headline1_ {
  /* .col1_ 1カラムの場合 */
  width: 815px;
}

.mainframe_ .common_headline1_ {
  /* .mainframe_ 2カラムの場合 */
  width: 755px;
}

.contents_ .mainframe_ .common_headline1_ {
  /* .contents_ .mainframe_ 3カラムの場合 */
  width: 575px;
}

.common_headline2_ {
  /* h2相当 */
  margin: 50px 0 15px;
  padding: 6px 20px;
  border-left: 8px solid #707070;
  box-sizing: border-box;
  font-weight: bold;
  color: #fff;
  background: #222;
}

.common_headline3_ {
  /* h3相当 */
  margin: 0 0 6px 0;
  padding: 5px 0;
  font-size: 14px;
  font-weight: bold;
  border-bottom: 1px solid #ccc;
}

/* --------------------------------------------------------------------
  common　イベント
-------------------------------------------------------------------- */
/* イベントへのリンク */
.event_ {
  width: 100%;
  overflow: hidden;
  margin-bottom: 10px;
}

.event_banner_ {
  margin: 0 5px 10px 5px;
}

.contents_ .event_banner_ {
  float: left;
  display: inline;
}

.event_title_ {
  position: relative;
  max-width: 1600px;
  width: 100%;
  margin: 100px auto 40px;
  padding: 0 0 0 24px;
  box-sizing: border-box;
  font-size: 28px;
  font-weight: bold;
  line-height: 1.0;
  color: #333;
  background: none;
}

.event_title_::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 8px;
  height: 100%;
  color: #333;
  background: #707070;
  content: "";
}

.event_title_ a {
  color: #333;
}

.event_title_ a::before {
  display: none;
}

*:first-child + html .event_title_ {
  padding: 9px 4px 11px 20px;
}

.event_ div.StyleP_Frame_ div.StyleP_Item_ {
  position: relative;
  display: flex;
  flex-direction: column;
}

.event_ div.StyleP_Frame_ .comment_ {
  display: none;
}

.event_ div.StyleP_Frame_ span.price_pop_ {
  display: none;
}

/* --------------------------------------------------------------------
  common　ナビゲーション
-------------------------------------------------------------------- */
/* パンくず */
.navitopicpath_ {
  margin: 0 0 6px 0;
  font-size: 14px;
  font-weight: 500;
}

.page-goods .navitopicpath_ {
  margin-top: 7px;
  margin-bottom: 36px;
}

.container_ > .navitopicpath_ {
  margin-top: 7px;
  margin-bottom: 36px;
}

.navitopicpath_ a {
  margin: 0 0.5em;
  color: #222;
}

.navitopicpath_ a.topicpath_home_ {
  color: #3763ba;
}

.navigation_ img {
  display: none;
}

.navigation_ {
  font-size: 12px;
}

.navigation_ a {
  margin: 0 0.5em;
  color: #333;
}

.navitopicpath_ span.current_ {
  margin: 0 0.5em;
  font-weight: bold;
}

.navitopicpath_ li {
  display: inline;
}

/* ページジャンプ */
.navipage_ {
  text-align: right;
  margin: 10px 0;
}

.navipage_.top_ {
  /* ページジャンプ上部 */
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-top: 24px;
  margin-bottom: 32px;
}

.navipage_.bottom_ {
  /* ページジャンプ下部 */
  display: flex;
  align-items: center;
  justify-content: flex-end;
  margin-top: 30px;
  margin-bottom: 50px;
}

.navipage_ .navipage_frame_ {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 4px;
}

.navipage_ .navipage_first_ a,
.navipage_ .navipage_prev_ a,
.navipage_ .navipage_next_ a,
.navipage_ .navipage_last_ a {
  position: relative;
  font-size: 0;
}

.navipage_ .navipage_reverse_,
.navipage_ .navipage_forward_ {
  display: flex;
  align-items: center;
  gap: 4px;
}

.navipage_ .navipage_first_ a::before {
  position: absolute;
  top: calc(50% - 4px);
  left: 17px;
  width: 8px;
  height: 8px;
  border-top: 1.5px solid #111;
  border-left: 1.5px solid #111;
  box-sizing: border-box;
  transform: rotate(-45deg);
  content: "";
}

.navipage_ .navipage_first_ a::after {
  position: absolute;
  top: calc(50% - 4px);
  left: 11px;
  width: 8px;
  height: 8px;
  border-top: 1.5px solid #111;
  border-left: 1.5px solid #111;
  box-sizing: border-box;
  transform: rotate(-45deg);
  content: "";
}

.navipage_ .navipage_prev_ a::before {
  position: absolute;
  top: calc(50% - 4px);
  left: 14px;
  width: 8px;
  height: 8px;
  border-top: 1.5px solid #111;
  border-left: 1.5px solid #111;
  box-sizing: border-box;
  transform: rotate(-45deg);
  content: "";
}

.navipage_ .navipage_next_ a::before {
  position: absolute;
  top: calc(50% - 4px);
  right: 14px;
  width: 8px;
  height: 8px;
  border-top: 1.5px solid #111;
  border-right: 1.5px solid #111;
  box-sizing: border-box;
  transform: rotate(45deg);
  content: "";
}

.navipage_ .navipage_last_ a::before {
  position: absolute;
  top: calc(50% - 4px);
  right: 17px;
  width: 8px;
  height: 8px;
  border-top: 1.5px solid #111;
  border-right: 1.5px solid #111;
  box-sizing: border-box;
  transform: rotate(45deg);
  content: "";
}

.navipage_ .navipage_last_ a::after {
  position: absolute;
  top: calc(50% - 4px);
  right: 11px;
  width: 8px;
  height: 8px;
  border-top: 1.5px solid #111;
  border-right: 1.5px solid #111;
  box-sizing: border-box;
  transform: rotate(45deg);
  content: "";
}

.navipage_ a {
  display: block;
  width: 32px;
  height: 32px;
  margin: 0;
  padding: 0;
  border-radius: 50%;
  font-size: 14px;
  font-weight: normal;
  line-height: 32px;
  text-align: center;
  color: #bbb;
  white-space: nowrap;
  background: #fff;
}

.navipage_now_ {
  display: block;
  width: 32px;
  height: 32px;
  margin: 0;
  padding: 0;
  border-radius: 50%;
  font-size: 12px;
  font-weight: bold;
  line-height: 32px;
  font-weight: bold;
  text-align: center;
  color: #fff;
  text-decoration: none;
  background: #222;
  border: 0;
}

/* 表示切替・並び替え */
.navistyle_,
.navisort_ {
  display: flex;
  width: 100%;
  padding: 15px 20px;
  font-size: 14px;
  overflow: hidden;
  box-sizing: border-box;
  border-top: 1px solid #dedede;
  border-bottom: 1px solid #dedede;
}

.navistyle_ {
  padding-bottom: 5px;
  border-bottom: 0;
}

.navistyle_ + .navisort_ {
  padding-top: 5px;
  border-top: 0;
}

.navisort_ dt,
.navistyle_ dt {
  width: 6.0em;
  color: #333;
}

.navisort_ dd,
.navistyle_ dd {
  display: flex;
  flex-wrap: wrap;
  gap: 4px 1px;
  width: calc(100% - 6.0em);
}

.navisort_ .navisort_now_,
.navistyle_ .navistyle_now_,
.navisort_ a,
.navistyle_ a {
  position: relative;
  padding: 0 14px;
}

.navisort_ .navisort_now_::after,
.navistyle_ .navistyle_now_::after,
.navisort_ a::after,
.navistyle_ a::after {
  position: absolute;
  top: 4px;
  right: -1px;
  width: 1px;
  height: calc(100% - 8px);
  background: #bbb;
  content: "";
}

.navisort_ .navisort_now_:first-child,
.navistyle_ .navistyle_now_:first-child,
.navisort_ a:first-child,
.navistyle_ a:first-child {
  padding-left: 0;
}

.navisort_ .navisort_now_:last-child,
.navistyle_ .navistyle_now_:last-child,
.navisort_ a:last-child,
.navistyle_ a:last-child {
  padding-right: 0;
}

.navisort_ .navisort_now_:last-child::after,
.navistyle_ .navistyle_now_:last-child::after,
.navisort_ a:last-child::after,
.navistyle_ a:last-child::after {
  display: none;
}

.navisort_ .navisort_now_,
.navistyle_ .navistyle_now_ {
  font-weight: bold;
  color: #333;
}

/* ブランド絞込 */
.brand_name_ {
  width: 100%;
  overflow: hidden;
}

.brand_name_now_ {
  color: #c30;
  text-decoration: none;
  margin: 2px 5px;
  white-space: nowrap;
}

.brand_name_ a {
  margin: 2px 5px;
  white-space: nowrap;
}

/* メーカー絞込 */
.maker_name_ {
  width: 100%;
  overflow: hidden;
}

.maker_name_now_ {
  color: #c30;
  text-decoration: none;
  margin: 2px 2px 2px 2px;
  white-space: nowrap;
}

.maker_name_ a {
  margin: 2px 2px 2px 2px;
  white-space: nowrap;
}

/* フロート */
.leftfloat_ {
  float: left;
  display: inline;
}

.rightfloat_ {
  float: right;
  display: inline;
}

img.leftfloat_ {
  margin: 0 10px 10px 0;
}

img.rightfloat_ {
  margin: 0 0 10px 10px;
}

/* 文整列 */
.lefttext_ {
  text-align: left;
}

.righttext_ {
  text-align: right;
}

.centertext_ {
  text-align: center;
}

div.notice_ .centertext_ {
  color: #4cae8d;
}

/* 特定メッセージ（ブロック） */
div.block_message_,
table.block_message_ {
  font-weight: bold;
  background-color: #fff;
  border: solid 1px #666;
  padding: 8px 8px 4px 8px;
  margin: 4px auto;
  text-align: left;
}

div.error_,
table.error_ {
  background-color: #fff;
  border: solid 1px #f50;
  padding: 8px 8px 4px 8px;
  margin: 4px auto;
  text-align: left;
}

div.notice_,
table.notice_ {
  background-color: #fff;
  border: solid 1px #3763ba;
  padding: 8px 8px 4px 8px;
  margin: 4px auto;
  text-align: left;
  max-width: 680px;
}

div.info_,
table.info_ {
  background-color: #fff;
  border: solid 1px #666;
  padding: 8px 8px 4px 8px;
  margin: 4px auto;
  text-align: left;
  max-width: 680px;
}

div.approval_info_ {
  background-color: #fff;
  border: solid 1px #666;
  padding: 8px 8px 4px 8px;
  margin: 4px auto;
  text-align: left;
  font-weight: bold;
}

ul.error_ {
  margin-left: 16px;
}

/* --------------------------------------------------------------------
  Ajax　Zip
-------------------------------------------------------------------- */
#suggestZipArea {
  background-color: #fff;
  border: 1px solid #999;
  display: none;
  padding: 2px 0;
  font-size: 12px;
  position: absolute;
  z-index: 9999;
}

#suggestZipArea .itemNotFound {
  padding: 0 4px;
  height: 20px;
  line-height: 20px;
  text-align: center;
  color: #999;
  font-style: italic;
}

#suggestZipArea .itemLine {
  padding: 0 4px;
  height: 20px;
  line-height: 20px;
  list-style: none;
  white-space: nowrap;
  cursor: default;
  color: #000;
  font-size: 12px;
}

#suggestZipArea .selected {
  background-color: #fdd;
  color: #c00000;
}

#suggestZipArea .itemLine .itemCode {
  float: left;
  font-weight: bold;
  margin-right: 4px;
  font-size: 11px;
}

/* --------------------------------------------------------------------
  注文拡張項目
--------------------------------------------------------------------- */
table.sales_append_ {
  width: 100%;
}

table.sales_append_ th {
  width: 30%;
}

/* --------------------------------------------------------------------
  ユーザー定義　得意先拡張項目
--------------------------------------------------------------------- */
form[name="frmBiz"] .customer_rank_select select {
  max-width: 200px;
}

form[name="frmBiz"] .pwd_ReRegist input[type="text"] {
  width: 100px !important;
}

form[name="frmBiz"] dd.customer_savecard_ {
  word-wrap: break-word;
  line-height: 1.28;
}

form[name="frmBiz"] div.bt_customer_form_ {
  padding-bottom: 20px;
}

form[name="frmBiz"] div.biz_append_ dl {
  display: block;
}

form[name="frmBiz"] div.biz_append_ dt,
form[name="frmBiz"] div.biz_append_ dd {
  display: block;
  height: auto !important;
  word-wrap: break-word;
  word-break: break-all;
}

form[name="frmBiz"] div.biz_append_ dd label {
  white-space: normal;
}

form[name="frmBiz"] div.biz_append_ dt {
  width: auto;
  float: none;
}

form[name="frmBiz"] div.biz_append_ dd {
  margin-bottom: 10px;
}

.biz_append_ input,
.biz_append_ textarea,
.biz_append_ select {
  max-width: 400px;
}

/* --------------------------------------------------------------------
  bxslider
  --------------------------------------------------------------------- */

.bx-wrapper {
  box-shadow: none;
}

.slider-wrapper {
  min-height: 350px;
  padding-bottom: 40px;
}

.bx-wrapper img {
  width: 100%;
}

.bx-wrapper .bx-controls-direction a {
  background: inherit;
  display: block;
  width: 15px;
  height: 30px;
  width: 16px;
  opacity: 1;
  top: 46%;
  z-index: 2 !important;
}

.bx-wrapper .bx-controls-direction a.bx-next::after {
  content: "";
  width: 7px;
  height: 7px;
  margin-top: -5px;
  border-top: solid 1px #707070;
  border-right: solid 1px #707070;
  transform: rotate(45deg);
  position: absolute;
  right: 6px;
  top: 52%;
  z-index: 2 !important;
}

.bx-wrapper .bx-controls-direction a.bx-prev::after {
  content: "";
  width: 7px;
  height: 7px;
  margin-top: -5px;
  border-top: solid 1px #707070;
  border-right: solid 1px #707070;
  transform: rotate(225deg);
  position: absolute;
  right: 2px;
  top: 51%;
  z-index: 2 !important;
}

.bx-wrapper .bx-pager {
  width: 100%;
  text-align: center;
  position: relative;
  z-index: 5;
  padding: 0;
  bottom: -8px;
}

.bx-wrapper .bx-pager.bx-default-pager a {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: #dcdcdc;
  margin: 0 6px;
  display: inline-block;
}

.wrapper_ .bx-wrapper .bx-pager.bx-default-pager a:hover,
.wrapper_ .bx-wrapper .bx-pager.bx-default-pager a.active,
.wrapper_ .bx-wrapper .bx-pager.bx-default-pager a:focus {
  background: #707070;
}

.wrapper_ .bx-wrapper .bx-pager.bx-default-pager a {
  background: #cecece;
}

.bx-wrapper {
  box-shadow: inherit;
}

.search-history-content {
  display: flex;
  width: 100%;
  padding: 4px 0;
}

.search-history-item {
  display: block;
  padding-left: 5px;
  margin-right: auto;
  width: inherit;
  overflow: hidden;
  text-overflow: ellipsis;
}

.search-history-delete {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0 10px;
  appearance: none;
  float: right;
}

#search_history_area_,
#search_suggest_area_ {
  position: absolute;
  display: block;
  z-index: 1000;
  text-align: left;
  background-color: #fff;
  border: solid 1px #ccc;
  padding: 5px;
  max-height: 60vh;
  overflow-y: auto;
}

.top_layout_1_ #search_suggest_area_ {
  position: absolute;
  display: block;
  z-index: 0;
  text-align: left;
  background-color: #fff;
  border: solid 1px #ccc;
  padding: 5px;
  max-height: 600px;
  overflow-y: auto;
  z-index: 999;
}

#search_history_area_ a,
#search_suggest_area_ a {
  text-decoration: none;
}

.suggest_keyword_ {
  padding: 2px;
  word-break: break-all;
}

.suggest_keyword_entry_ {
  display: block;
  color: #000;
  text-decoration: none;
}

.suggest_goods_container_ {
  padding: 15px 5px;
}

.suggest_goods_ {
  width: 100%;
  min-height: 60px;
  clear: both;
  display: flex;
}

.suggest-goods-info-wrapper {
  margin-left: 10px;
  word-break: break-all;
  width: inherit;
}

.suggest-goods-info-wrapper p.suggest_semiclosed_value_ {
  word-break: break-all;
}

.suggest_goods_img_ {
  display: inline-block;
  width: 60px;
  flex-shrink: 0;
}

.suggest_goods_img_ img {
  width: 60px;
  height: 60px;
}

.suggest_keyword_:focus,
.suggest_keyword_:focus-visible,
.suggest_goods_container_:focus,
.suggest_goods_container_:focus-visible,
.search-history-content:hover,
.suggest_keyword_:hover,
.suggest_goods_container_:hover {
  background-color: #dedede;
  cursor: pointer;
  cursor: hand;
  outline: none;
}

.suggest_goods_cart_ {
  display: flex;
  justify-content: end;
  padding: 10px 10px 0 10px;
}

.suggest_goods_cart_ .qty_ {
  margin-right: 10px;
  align-content: center;
}

.suggest_goods_cart_ .qty_ input[type="text"] {
  padding: 2px 1px;
  width: 46px;
  margin: 3px;
  text-align: right;
}

.suggest_goods_detail_ {
  padding-right: 10px;
  float: right;
}

.sg_detail_button_ {
  color: #333!important;
  background-color: #ccc;
  padding: 10px 0 10px 0;
  font-size: 13px;
  position: relative;
  border-radius: 4px;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  border: 0;
  width: 80px;
  height: 20px;
}

.cart_sg_button_ {
  color: #fff!important;
  background-color: #577cc6;
  padding: 10px 0 10px 15px;
  font-size: 13px;
  position: relative;
  border-radius: 4px;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  border: 0;
  width: 135px;
  height: 20px;
}

.cart_sg_button_::before {
  content: "";
  position: absolute;
  left: 10px;
  top: calc(50% - 8px);
  background-image: url(../../img/usr/btn_cart.png);
  width: 16px;
  height: 16px;
}

.dragover {
  background: rgb(255, 228, 200);
}

.gallery {
  display: flex;
  flex-wrap: wrap;
}

.gallery > * {
  margin: 2px;
  display: inline-block;
  width: 100px;
  height: 100px;
  text-align: center;
  position: relative;
}

.gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: relative;
}

.gallery .working img {
  filter: blur(2px);
}

.gallery .working::after {
  content: "UPLOADING";
  font-size: 10px;
  line-height: 100px;
  text-align: center;
  display: block;
  background: rgba(255, 255, 255, 0.8);
  width: 100px;
  height: 100px;
  position: absolute;
  top: 0;
}

.input_image_file {
  background: rgba(0, 0, 0, 0.1);
  box-shadow: 0 2px 8px;
  color: rgba(0, 0, 0, 0.7);
  transition-duration: 0.4s;
  margin: 0 auto;
}

.input_image_file:hover {
  background: rgba(228, 100, 30, 0.1);
  color: rgba(228, 100, 30, 0.8);
  transition-duration: 0.2s;
}

.input_image_file:active {
  background: rgba(255, 60, 10, 0.1);
  color: rgba(255, 60, 10, 0.8);
  transition-duration: 0s;
}

.input_image_file input[type="file"] {
  display: none;
}

.input_image_file .material-icons {
  font-size: 40px;
  line-height: 96px;
  /* Support for IE. */
  font-feature-settings: "liga";
}

/* --------------------------------------------------------------------
  GA4 goodslist
--------------------------------------------------------------------- */
.ec-ga-js-cart-goodslist,
.ec-ga-suggest-goodslist,
.ec-ga-goodslist {
  display: none;
}
