﻿@charset "UTF-8";

/* --------------------------------------------------------------------
  トピック
-------------------------------------------------------------------- */
/* トピック詳細 */
h1.topic_head_ {
  margin: 28px 0 18px 0;
  font-size: 24px;
  font-weight: bold;
  text-align: center;
}

h2.topic_title_ {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
  margin: 0 0 20px;
  font-weight: bold;
  font-size: 16px;
}

h2.topic_title_ img {
  order: -1;
  height: 20px;
}

/* トピック一覧 */
.page-topicdetaillist .navipage_ ~ .navipage_ {
  display: none;
}

div.topicdetaillist_ .topicdetaillist_body_ li {
  padding: 10px 0;
  border-bottom: 1px solid var(--borderColor);
}

div.topicdetaillist_ ul.topicdetailline_ li dl dt {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 8px;
}

div.topicdetaillist_ ul.topicdetailline_ li dl dt img {
  height: 20px;
}

.page-topicdetaillist div.submit_ .btn-secondary {
  height: 40px;
  margin: 0;
  padding: 0;
}

/* トップページ */
.topiclist_ {
  padding: 24px 0 32px;
  background: var(--bgColor);
}

.topiclist_ .block-top-header {
  margin: 0 0 24px;
}

.topiclist_ .topiclist_body_ .topicline_ {
  padding: 0 16px;
}

.topiclist_ .topiclist_body_ .topicline_>li {
  padding: 12px 16px;
  background: #FFFFFF;
  border-radius: 6px;
  box-shadow: 0 0 6px rgb(0, 0, 0, 0.16);
}

.topiclist_ .topiclist_body_ .topicline_>li+li {
  margin-top: 8px;
}

.topiclist_ .topiclist_body_ .topicline_>li dl {
  line-height: 1.428;
}

.topiclist_ .topiclist_body_ .topicline_>li dl dt {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 8px;
}

.topiclist_ .topiclist_body_ .topicline_>li dl dt img {
  height: 20px;
}

.topiclist_ .topiclist_body_ .topicline_>li dl dd .link-title {
  color: var(--themeColor);
}

.topiclist_ .topicline_detaillist_ a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 200px;
  height: 40px;
  margin: 24px auto 0;
  text-align: center;
  color: var(--themeColor);
  background: #FFFFFF;
  border: 1px solid var(--themeColor);
  border-radius: 4px;
}

/* --------------------------------------------------------------------
  アンケート
-------------------------------------------------------------------- */
.navigation_ {
  margin: 10px 0;
  font-size: 12px;
}

div.questionnaire_ div.questionnaire_name_ {
  font-weight: bold;
  margin-top: 6px;
  margin-bottom: 6px;
  padding-left: 8px;
}

div.questionnaire_ h3 {
  font-weight: bold;
}

div.questionnaire_ .title_ {
  padding: 8px 0 8px 8px;
  background: #f0f0f0;
  margin-top: 5px;
  padding: 8px 0 8px 10px;
}

div.questionnaire_ .submit_ {
  margin-top: 6px;
}

div.questionnaire_ .title_.must_ {
  margin-bottom: 6px;
}

div.questionnaire_ input[name="radio1"] {
  margin-bottom: 3px;
}

div.questionnaire_ input[type="text"],
div.questionnaire_ textarea {
  max-width: 90%;
}

div.questionnaire_ li {
  padding: 12px 10px;
  word-break: break-word;
  border-top: 1px solid #cecece;
}

/* 入力画面 */
ul.questionnaire_input_ input[type="radio"] {
  vertical-align: middle;
}

/* 確認画面 */
ul.questionnaire_confirm_ {
  padding-left: 8px;
  padding-left: 10px;
}

ul.questionnaire_confirm_ .title_ {
  margin-left: 0;
  word-break: break-word;
}

/* 承認 */
div.approval_ table th {
  white-space: nowrap;
}

div.approval_ table.approvallist_.approval_r_ td {
  background-color: #fffff0;
}

div.approval_ table.approvallist_.approval_1st_ok_ td {
  background-color: #fffff0;
}

div.approval_ table.approvallist_.approval_ng_ td {
  background-color: #ffefec;
}

div.approval_ table.approvallist_.approval_sales_ng_ td {
  background-color: #f3f3f3;
}

table.approval_cart_ {
  width: 100%;
}

table.approval_cart_ tr.linespace_ {
  border-style: none;
}

table.approval_cart_ tr.linespace_ td {
  border-style: none;
  height: 10px;
}

table.approval_cart_ .goods_name_ {
  width: auto;
}

table.approval_cart_ td.money_ {
  text-align: right;
  width: 80px;
}

table.approval_cart_ td.money_ ul {
  width: 100%;
}

table.approval_cart_ li.money_ {
  white-space: nowrap;
  text-align: right;
  width: 80px;
}

table.approval_cart_ li.qty_ {
  white-space: nowrap;
  text-align: right;
  width: 80px;
}

table.approval_cart_ td.button_ {
  text-align: center;
  width: 66px;
}

table.approval_cart_ td.cancel_dt_ {
  color: #c00;
  font-weight: bold;
  width: 66px;
}

.reapproval_ td.reapproval_mod_ {
  background-color: #ffffe0;
}

td.doapproval_ {
  background-color: #ffffe0;
}

table.approval_comment_ {
  width: 100%;
}

table.approval_comment_ td {
  border-style: none;
  padding: 3px;
}

table.approval_comment_ th {
  padding: 3px;
  text-align: left;
}

table.approval_comment_ textarea {
  box-sizing: border-box;
}

table.approval_purchase_,
table.approval_date_,
table.approval_approval_,
table.approval_ap_user_,
table.approval_cart_ {
  margin-bottom: 10px;
  width: 100%;
  font-size: 12px;
  border: 1px solid #ccc;
}

table.approval_purchase_ th,
table.approval_date_ th,
table.approval_approval_ th,
table.approval_ap_user_ th {
  width: 30%;
  white-space: nowrap;
  background-color: #f0f0f0;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  padding: 3px;
  font-weight: normal;
  text-align: left;
  padding: 8px 8px 6px;
}

table.approval_purchase_ td,
table.approval_date_ td,
table.approval_approval_ td,
table.approval_ap_user_ td,
table.approval_cart_ td {
  border-bottom: 1px solid #ccc;
  padding: 3px;
  text-align: left;
  padding: 8px 8px 6px;
}

table.approval_cart_ th {
  white-space: nowrap;
  background-color: #eef8f5;
  border-right: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  padding: 3px;
  font-weight: normal;
  text-align: left;
}

table.approvallist_ input[type="text"],
table.approvallist_ textarea,
table.approval_comment_ input[type="text"],
table.approval_comment_ textarea {
  width: 100%;
}

.approval_cart_ td.price_,
div.quickorder_ table td.amt_ {
  color: #c30;
  font-weight: bold;
  text-align: right;
}

/* --------------------------------------------------------------------
  ユーザー定義　トップページ　現在の配送先
--------------------------------------------------------------------- */
#block_of_cart_dest_ {
  margin: 40px 0;
  border: 0;
  background: #f5f5f5;
}

#block_of_cart_dest_ h2 {
  display: flex;
  align-items: center;
  width: 100%;
  padding: 7px 8px 7px 20px;
  border-left: 8px solid #707070;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  box-sizing: border-box;
  background: #222;
}

#block_of_cart_dest_ h2 input[type="button"] {
  display: block;
  margin: 0 0 0 auto;
  padding: 6px 10px;
  border: 1px solid #cecece;
  border-radius: 2px;
  font-size: 12px;
  font-weight: bold;
  color: #505050;
  background: #eaeaea;
}

#block_of_cart_dest_ .block_of_cart_dest_inner_ {
  padding: 24px 16px;
  word-break: break-word;
}

/* --------------------------------------------------------------------
  ユーザー定義　トップページお問い合わせ一覧
--------------------------------------------------------------------- */
#block_of_contact_ {
  margin: 40px 0;
  border: 0;
  background: #f5f5f5;
}

#block_of_contact_ h2 {
  display: block;
  width: 100%;
  padding: 11px 8px 11px 20px;
  border-left: 8px solid #707070;
  font-size: 16px;
  font-weight: bold;
  color: #fff;
  box-sizing: border-box;
  background: #222;
}

#block_of_contact_ .top_contact_most_recent_ {
  padding: 24px 16px 32px;
}

#block_of_contact_ .top_contact_most_recent_ .submit_ input {
  margin: 0;
}

#block_of_contact_ .top_contact_most_recent_ {
  padding: 10px;
}

#block_of_contact_ ul li {
  padding: 4px 0;
  font-size: 14px;
}

#block_of_contact_ ul li .subject_ {
  font-weight: bold;
}

#block_of_contact_ .top_contact_most_recent_ ul {
  margin-bottom: 20px;
}

#block_of_contact_ .top_contact_most_recent_ textarea {
  width: 100%;
}

#block_of_contact_ div.top_contact_list_footer_ {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin: 10px 0 0;
}

#block_of_contact_ div.top_contact_list_footer_ a {
  display: block;
  min-width: calc(50% - 20px);
  padding: 11px 4px;
  border-radius: 4px;
  font-size: 14px;
  font-weight: 500;
  color: #fff;
  text-align: center;
  background: #111;
}

#block_of_contact_ div.top_contact_list_ {
  padding: 20px 16px 32px;
}

#block_of_contact_ div.contactlist_line_ {
  margin: 0;
  margin-bottom: 10px;
}

div.contact_ ul.contact_ textarea,
div.contact_ .contact_reform_ textarea {
  width: 100%;
}

div.contact_ ul.contact_ input {
  max-width: 90%;
}

div.page_ {
  clear: both;
  background-color: #fff;
}

ul.pagelist_frame_ {
  overflow: hidden;
  text-align: left;
  background-color: #fff;
  -webkit-border-radius: 8px;
  -moz-border-radius: 8px;
  border-radius: 8px;
}

ul.pagelist_frame_ li {
  width: 100%;
  border-bottom: 1px solid #cbcbcb;
  padding: 9px 0 9px 10px;
}

ul.pagelist_frame_ li .block_ {
  display: block;
  padding-left: 110px;
  padding-top: 4px;
  padding-right: 10px;
  background-repeat: no-repeat;
  background-position: 5px 50%;
  background-size: 100px auto;
  background-size: contain;
}

ul.pagelist_frame_ li .block_ a {
  color: #000;
}

ul.pagelist_frame_ li:last-child {
  border-bottom-style: none;
}

ul.pagelist_frame_ .name_,
ul.pagelist_frame_ .comment_ {
  color: #333;
}

ul.pagelist_frame_ li a > div {
  max-height: 65px;
  min-height: 65px;
}

/* ----Cookieポリシー同意---- */
.block-cookie-consent {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: fixed;
  bottom: 0;
  width: 100%;
  font-size: 14px;
  color: #fff;
  background: rgba(0, 0, 0, 0.7);
  padding: 1.2em;
  box-sizing: border-box;
  visibility: visible;
  text-align: left;
  z-index: 10000;
}

.block-cookie-consent--text a {
  color: #fff;
}

.block-cookie-consent--btn {
  display: inline-block;
  min-width: 100px;
  color: #fff;
  background: dodgerblue;
  padding: 0.5em 1.5em;
  cursor: pointer;
  text-align: center;
}

/* --------------------------------------------------------------------
  メーカー一覧（メーカー）
--------------------------------------------------------------------- */
.maker_initial_ {
  position: relative;
  color: #3c3c3c;
  font-size: 4.266vw;
  font-weight: bold;
  padding: 2vw 3.2vw;
}

.maker_item_ {
  padding: 2vw 3.2vw;
  font-size: 4.266vw;
}

.maker_nav_ dt {
  margin-right: 10px;
}

.maker_nav-item_ a,
.maker_item_ a {
  margin-right: 10px;
  color: #404040;
}

div.maker_contents_ .img_show_::before,
div.maker_contents_ .img_show_::after,
div.maker_contents_ .img_hidden_::before,
div.maker_contents_ .img_hidden_::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  width: 11px;
  height: 2px;
  border: 0;
  margin: 0;
  transition: all 0.3s;
  background-color: #afafaf;
}

div.maker_contents_ .img_hidden_::after {
  transform: rotate(-90deg);
}

.maker_name_ {
  display: grid;
  margin-left: 10px;
  align-content: center;
  word-break: break-all;
  padding: 1vw 0vw;
}

div.maker_contents_ div.name_ {
  line-height: 28px;
  background: #ededed;
}

div.maker_contents_ div.maker_initial_ > div.name_ {
  line-height: 28px;
}

div.maker_contents_ .img_ {
  float: left;
  margin: 0;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  content: "";
  border-style: solid;
  border-width: 6px 0 6px 8px;
  border-color: transparent transparent transparent #fff;
}

div.maker_contents_ .img_show_ {
  content: none;
  border: none;
  width: 60px;
  height: 61px;
  right: 0;
  left: unset;
}

div.maker_contents_ .img_hidden_ {
  content: none;
  border: none;
  width: 60px;
  height: 61px;
  right: 0;
  left: unset;
}

div.maker_contents_ div.maker_line_ > div.name_ {
  background: #fff;
  position: relative;
  border-right: none;
  border-left: none;
}
