@charset "UTF-8";
html {
  scroll-behavior: smooth;
  scroll-padding-top: 90px;
}
body {
  color: #171717;
  font-size: 14px;
  font-family: 'Noto Sans JP', sans-serif;
  font-weight: 400;
}
a {
  color: inherit;
}
a,
button,
input[type="submit"],
input[type="button"] {
  transition: 0.3s;
}
@media (hover: hover) {
  a:hover,
  button:hover,
  input[type="submit"]:hover,
  input[type="button"]:hover {
    opacity: 0.7;
  }
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: top;
}
select,
label,
button,
input[type="submit"],
input[type="button"],
input[type="radio"],
input[type="checkbox"] {
  cursor: pointer;
}
input,
button,
select {
  outline: none;
}
ul,
ol {
  line-height: inherit;
  font-size: inherit;
}
#sysFooter {
  margin: 0;
  padding: 120px 110px;
  color: #fff;
  background: #171717;
}
.footer-buynow {
  position: sticky;
  width: 90px;
  left: calc(100% - 71px - 90px);
  bottom: 88px;
  margin: 0 0 24px;
  z-index: 100;
}
.footer-buynow-btn a {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 8px 0;
  height: 90px;
  border-radius: 5px 0 0 5px;
  color: #fff;
  font-weight: 700;
  text-align: center;
  text-decoration: none;
  background: #ba0402;
}
.footer-buynow-btn a:before {
  content: "";
  display: block;
  width: 22px;
  height: 22px;
  background: url("/img/common/icon_cart.svg") no-repeat 0 0/100% 100%;
}
.pagetop {
  position: sticky;
  width: 90px;
  left: calc(100% - 71px - 90px);
  bottom: 40px;
  margin: 0 0 40px;
  z-index: 100;
}
.pagetop .footer-page-top {
  padding: 0 0 8px;
  border-bottom: 1px solid #171717;
  color: #171717;
  font-size: 12px;
  font-weight: 700;
  transition: 0.3s;
  cursor: pointer;
}
.pagetop .footer-page-top:before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  vertical-align: top;
  margin: 3px 8px 0 0;
  background: url("/img/common/icon_arrow_06.svg") no-repeat 0 0/100% 100%;
}
@media (hover: hover) {
  .pagetop .footer-page-top:hover {
    opacity: 0.7;
  }
}
.footer {
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
  border: none;
}
.footer .sysContent {
  padding: 0;
}
.footer-ttl {
  display: flex;
  align-items: center;
  margin: 0 0 40px;
  font-size: 20px;
  font-weight: 700;
}
.footer-ttl:before {
  content: "";
  display: block;
  width: 17px;
  height: 17px;
  margin: 0 8px 0 0;
  background: url("/img/common/icon_guide.svg") no-repeat 0 0/100% 100%;
}
.footer-ttl span {
  display: block;
  margin: 0 0 0 16px;
  font-size: 10px;
  font-weight: 400;
}
.footer-item {
  display: flex;
  align-items: flex-start;
  gap: 0 24px;
  margin: 0 0 16px;
}
.footer-item-label {
  width: 200px;
  padding: 10px;
  border-radius: 5px;
  font-weight: 700;
  text-align: center;
  background: #2e2e2e;
}
.footer-item-txt {
  flex: 1;
}
.footer-item-txt small {
  display: inline-block;
  margin: 8px 0 0;
  font-size: 12px;
}
.footer-payment .footer-item-txt {
  display: flex;
  flex-direction: row-reverse;
  align-items: flex-start;
  gap: 0 24px;
}
.footer-payment .footer-item-txt .footer-item-img {
  width: 220px;
  padding: 10px;
  border-radius: 5px;
  background: #fff;
}
.footer-payment .footer-item-txt .footer-item-inner {
  flex: 1;
}
.footer-btn {
  position: absolute;
  top: -16px;
  right: 0;
}
.footer-btn a {
  display: flex;
  align-items: center;
  gap: 0 16px;
  padding: 20px 32px;
  border: 1px solid #fff;
  border-radius: 40px;
  color: #fff;
  text-decoration: none;
}
.footer-btn a:after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #fff;
  transition: 0.3s;
}
@media (hover: hover) {
  .footer-btn a:hover {
    color: #171717;
    background: #fff;
    opacity: 1;
  }
  .footer-btn a:hover:after {
    background: #171717;
  }
}
.footer-nav {
  position: relative;
  max-width: 1100px;
  margin: 56px auto 0;
  padding: 56px 0 0;
  border-top: 1px solid #3c3c3c;
}
.footer-nav-inner {
  display: flex;
  align-items: flex-start;
}
.footer-nav-logo {
  margin: 0 auto 0 0;
}
.footer-nav-logo img {
  filter: brightness(0) invert(1);
}
.footer-nav-list {
  margin: 0 56px 0 0;
  padding: 0 0 0 96px;
  border-left: 1px solid #3c3c3c;
}
.footer-nav-list li {
  position: relative;
  padding: 0 0 0 1em;
}
.footer-nav-list li:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
.footer-nav-list li + li {
  margin: 20px 0 0;
}
.footer-nav-list li a {
  color: #fff;
  text-decoration: none;
}
.footer-nav-list li a .is-line {
  color: #07b53b;
}
@media (hover: hover) {
  .footer-nav-list li a:hover {
    text-decoration: underline;
    opacity: 1;
  }
}
.footer-nav-bnr a {
  display: block;
  overflow: hidden;
  margin: 0 0 24px;
  border-radius: 6px;
}
.footer-nav-copyright {
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: 12px;
}
@media screen and (max-width: 1200px) {
  .footer-nav-logo img {
    width: 200px;
  }
  .footer-nav-list {
    padding: 0 0 0 40px;
  }
  .footer-nav-bnr a img {
    width: 200px;
  }
}
.ai_chat_btn {
  z-index: 100;
  transition: 0.3s;
  cursor: pointer;
  position: sticky;
  left: calc(100% - 71px - 90px);
  bottom: 82px;
  width: 100px;
  height: 100px;
  margin: 0 0 16px;
  background: url(/img/common/icon_dify.png) no-repeat 0 0 / 100% 100%;
}
body:has(.footer-buynow) .ai_chat_btn {
  bottom: 194px;
}
.ai_chat_btn:hover {
  background-image: url(/img/common/icon_dify_hover.png);
}
.ai_chat_modal {
  transition: 0.3s;
  opacity: 0;
  pointer-events: none;
  display: none;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 99999;
  width: 80%;
  height: 80%;
  min-width: 641px;
}
.ai_chat_modal::after {
  pointer-events: none;
  content: "";
  position: absolute;
  cursor: pointer;
  width: 50px;
  height: 50px;
  top: -60px;
  right: 10px;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-image: url(/img/common/icon_new_close.png);
}
.ai_chat_modal.active {
  opacity: 1;
  pointer-events: all;
  display: block;
}
.ai_chat_modal .ai_chat_modal_inner {
  height: 100%;
  width: 100%;
}
.ai_chat_modal .ai_chat_modal_inner iframe {
  min-height: auto !important;
}
.ai_chat_modal .ai_chat_modal_inner iframe button[style="background-color: rgb(28, 100, 242);"] {
  background-color: #EA5504 !important;
}
.ai_chat_modal_bg {
  display: block !important;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  transition: all 0.3s;
  opacity: 0;
  pointer-events: none;
  display: none;
  background-color: rgba(51, 51, 51, 0.3);
}
.ai_chat_modal_bg.active {
  opacity: 1;
  pointer-events: all;
  display: block;
  z-index: 9999;
}
#sysHeader {
  height: 100px;
  margin: 0 0 56px;
  padding: 0;
}
#sysHeader #cartInfo {
  display: none;
}
.header {
  background: #f3f0ec;
  box-shadow: 0px -4px 10px 0px rgba(60,38,9,0.051) inset;
}
.header .sysContent {
  padding: 0;
}
.header-inner {
  display: flex;
  align-items: center;
  gap: 0 32px;
  height: 100px;
  margin: 0 auto;
  padding: 0 40px;
  transition: 0.3s;
}
.header-tel {
  line-height: 1;
}
.header-tel a {
  display: block;
  position: relative;
  margin: 0 0 4px;
  padding: 0 0 0 20px;
  font-size: 24px;
  font-weight: 700;
  text-decoration: none;
}
.header-tel a:before {
  content: "";
  position: absolute;
  top: 7px;
  left: 0;
  width: 14px;
  height: 14px;
  background: url("/img/common/icon_tel.svg") no-repeat 0 0/100% 100%;
}
.header-tel span {
  font-size: 10px;
}
.header-nav {
  display: flex;
  position: absolute;
  top: 0;
  right: 71px;
}
.header-nav li {
  border-left: 1px solid #e3ddd4;
}
.header-nav li a {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  width: 160px;
  height: 100px;
  font-weight: 700;
  text-decoration: none;
}
.header-nav li a:after {
  content: "";
  position: absolute;
  right: 10px;
  bottom: 10px;
  width: 6px;
  height: 6px;
  mask: url("/img/common/icon_nav.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transition: 0.3s;
}
@media (hover: hover) {
  .header-nav li a:hover {
    color: #ba0402;
    opacity: 1;
  }
  .header-nav li a:hover:after {
    background: #ba0402;
  }
}
.header.is-scroll {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 101;
}
.header.is-scroll .header-inner {
  height: 70px;
}
.header.is-scroll .header-nav li a {
  height: 70px;
}
.right-nav {
  position: fixed;
  top: 0;
  right: 0;
  z-index: 1000;
}
.right-nav-wrap {
  position: relative;
  height: 100vh;
  border-left: 1px solid #fff;
  background: #f3f0ec;
  box-shadow: -4px 0px 10px 0px rgba(0,0,0,0.102);
  z-index: 100;
}
.right-nav-main {
  margin: 0 0 24px;
}
.right-nav-main li a,
.right-nav-main li span {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 4px 0;
  position: relative;
  width: 70px;
  height: 70px;
  font-size: 10px;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}
.right-nav-main-item-01 a {
  color: #3c2609;
  background: #fff;
}
.right-nav-main-item-02 a {
  color: #fff;
  background: #ba0402;
}
.right-nav-main-item-03,
.right-nav-main-item-04 {
  border-bottom: 1px solid #4d3a22;
}
.right-nav-main-item-03 a,
.right-nav-main-item-04 a {
  color: #fff;
  background: #3c2609;
}
.right-nav-main-item-05 {
  border-bottom: 1px solid #4d3a22;
}
.right-nav-main-item-05 span {
  color: #fff;
  background: #3c2609;
  transition: 0.3s;
}
@media (hover: hover) {
  .right-nav-main-item-05 span:hover {
    opacity: 0.7;
  }
}
.right-nav-main .cart_in {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 8px;
  right: 8px;
  width: 20px;
  height: 20px;
  line-height: 1;
  border-radius: 100%;
  color: #ba0402;
  font-size: 10px;
  font-weight: 700;
  background: #fff;
}
.right-nav-sub {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px 0;
}
.right-nav-sub li a {
  display: flex;
  align-items: center;
  gap: 0 4px;
  font-size: 10px;
  font-weight: 700;
  text-decoration: none;
  writing-mode: vertical-rl;
}
.right-nav-search {
  position: absolute;
  top: 0;
  right: 71px;
  width: 400px;
  height: 100vh;
  overflow: auto;
  padding: 20px;
  background: #fff;
  transform: translateX(100%);
  transition: 0.3s;
  z-index: 10;
}
.right-nav-search.is-open {
  transform: translateX(0);
  box-shadow: -4px 0px 10px 0px rgba(0,0,0,0.102);
}
.right-nav-search-close1 {
  position: relative;
  width: 14px;
  height: 14px;
  margin: 0 0 24px auto;
  cursor: pointer;
  transition: 0.3s;
}
.right-nav-search-close1:before,
.right-nav-search-close1:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 2px;
  background: #3c2609;
}
.right-nav-search-close1:before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.right-nav-search-close1:after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
@media (hover: hover) {
  .right-nav-search-close1:hover {
    opacity: 0.7;
  }
}
.right-nav-search-keyword {
  line-height: 1;
  margin: 0 0 24px;
}
.right-nav-search-keyword form {
  display: flex;
  gap: 0 10px;
}
.right-nav-search-keyword input[type="search"] {
  flex: 1;
  padding: 15px 16px;
  border: none;
  border-radius: 5px;
  background: #f3f0ec;
}
.right-nav-search-keyword input[type="search"]::placeholder {
  color: #9c9c9c;
}
.right-nav-search-keyword button[type="submit"] {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  width: 88px;
  border: none;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  background: #3c2609;
}
.right-nav-search-keyword button[type="submit"]:before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  background: url("/img/common/icon_search.svg") no-repeat 0 0/100% 100%;
}
.right-nav-search-category {
  margin: 0 0 32px;
}
.right-nav-search-category select {
  width: 100%;
  padding: 13px 32px 13px 16px;
  border: 2px solid #171717;
  border-radius: 5px;
  background: url("/img/common/icon_arrow_05.svg") no-repeat center right 16px/10px auto;
}
.right-nav-search-favorite {
  margin: 0 0 32px;
  padding: 24px 0 0;
  border-top: 1px dashed #3c2609;
}
.right-nav-search-favorite .side-search-ttl {
  margin: 0;
}
.right-nav-search-favorite .sysFuncItemCategory[class*="side_navi_"] .sysHeadline {
  height: 64px;
}
.right-nav-search-close2 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 8px;
  width: 226px;
  margin: 0 auto;
  padding: 14px 16px;
  border: 1px solid #171717;
  border-radius: 40px;
  font-weight: 700;
  cursor: pointer;
  transition: 0.3s;
}
.right-nav-search-close2 i {
  display: block;
  position: relative;
  width: 14px;
  height: 14px;
}
.right-nav-search-close2 i:before,
.right-nav-search-close2 i:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 2px;
  background: #3c2609;
  transition: 0.3s;
}
.right-nav-search-close2 i:before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.right-nav-search-close2 i:after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
@media (hover: hover) {
  .right-nav-search-close2:hover {
    color: #fff;
    background: #171717;
  }
  .right-nav-search-close2:hover i:before,
  .right-nav-search-close2:hover i:after {
    background: #fff;
  }
}
.header-nav-category {
  display: none;
}
.header-btn {
  display: none;
}
.header-hbg {
  display: none;
}
@media screen and (max-width: 1360px) {
  .header-nav li a {
    width: 136px;
  }
}
#sysHeader .sysFuncItemCategory[class*="side_navi_"] {
  display: none;
}
#sysAll {
  max-width: inherit;
  overflow: clip;
  padding: 0;
}
#sysWrap {
  display: flex;
  flex-direction: row-reverse;
  flex-wrap: wrap;
  gap: 0 80px;
  max-width: 1100px;
  margin: 0 auto 40px;
}
div#sysMain {
  float: none;
  width: 800px;
  margin: 0;
  padding: 0;
}
div#sysAside {
  position: relative;
  float: none;
  width: 220px;
  margin: 0;
  padding: 0;
  z-index: 10;
}
.side-keyword {
  line-height: 1;
  margin: 0 0 40px;
}
.side-keyword form {
  display: flex;
}
.side-keyword input[type="search"] {
  width: calc(100% - 48px);
  padding: 15px 8px;
  border: none;
  border-radius: 5px 0 0 5px;
  background: #f3f0ec;
}
.side-keyword input[type="search"]::placeholder {
  color: #9c9c9c;
}
.side-keyword button[type="submit"] {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 4px;
  width: 48px;
  border: none;
  border-radius: 0 5px 5px 0;
  color: #fff;
  font-size: 12px;
  background: #3c2609;
}
.side-keyword button[type="submit"]:before {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  background: url("/img/common/icon_search.svg") no-repeat 0 0/100% 100%;
}
.side-type {
  margin: 0 0 40px;
  border-bottom: 1px solid #e5e5e5;
}
.side-type-bnr {
  margin: 0 0 8px;
}
.side-type-bnr a img {
  border-radius: 5px;
}
.side-type-nav {
  margin: 0 0 24px;
}
.side-type-nav:last-child {
  margin: 0;
}
.side-type-nav li + li {
  border-top: 1px solid #e5e5e5;
}
.side-type-nav li a {
  display: block;
  position: relative;
  padding: 16px 24px 16px 0;
  font-weight: 700;
  text-decoration: none;
}
.side-type-nav li a img {
  vertical-align: top;
  margin: 4px 0 0 8px;
}
.side-type-nav li a span {
  font-size: 12px;
  font-weight: 400;
}
.side-type-nav li a:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media (hover: hover) {
  .side-type-nav li a:hover {
    color: #ba0402;
    opacity: 1;
  }
  .side-type-nav li a:hover:after {
    background: #ba0402;
  }
}
.side-search-ttl {
  position: relative;
  margin: 40px 0 0;
  padding: 0 0 16px 32px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 18px;
  font-weight: 700;
}
.side-search-ttl:before {
  content: "";
  position: absolute;
  top: 6px;
  left: 8px;
  width: 16px;
  height: 16px;
  mask: url("/img/common/icon_search.svg") no-repeat 0 0/100% 100%;
  background: #171717;
}
.side-search-ttl p {
  margin: 0;
}
.sysFuncItemCategory[class*="side_navi_"] {
  border-bottom: 1px solid #e5e5e5;
}
.sysFuncItemCategory[class*="side_navi_"] .sysHeadline {
  display: flex;
  align-items: center;
  position: relative;
  height: 80px;
  padding: 0 24px 0 42px;
  font-weight: 700;
  text-decoration: none;
  transition: 0.3s;
}
.sysFuncItemCategory[class*="side_navi_"] .sysHeadline:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 34px;
  height: 34px;
  background: no-repeat 0 0/100% 100%;
  transform: translateY(-50%);
}
.sysFuncItemCategory[class*="side_navi_"] .sysHeadline:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 6px;
  height: 6px;
  border-right: 2px solid #171717;
  border-bottom: 2px solid #171717;
  transform: translateY(-50%) rotate(45deg);
  transition: 0.3s;
}
@media (hover: hover) {
  .sysFuncItemCategory[class*="side_navi_"] .sysHeadline:hover {
    color: #ba0402;
    opacity: 1;
  }
  .sysFuncItemCategory[class*="side_navi_"] .sysHeadline:hover:after {
    border-color: #ba0402;
  }
}
.sysFuncItemCategory[class*="side_navi_"] nav {
  margin: 0 0 24px;
  padding: 20px 16px;
  border-radius: 5px;
  background: #f3f0ec;
}
.sysFuncItemCategory[class*="side_navi_"] nav ul li + li {
  margin: 12px 0 0;
}
.sysFuncItemCategory[class*="side_navi_"] nav ul li a {
  display: block;
  position: relative;
  overflow: visible;
  padding: 0 0 0 1em;
  text-decoration: none;
  text-overflow: inherit;
  white-space: inherit;
}
.sysFuncItemCategory[class*="side_navi_"] nav ul li a:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
@media (hover: hover) {
  .sysFuncItemCategory[class*="side_navi_"] nav ul li a:hover {
    color: #ba0402;
    opacity: 1;
  }
}
.sysFuncText[class*="side_navi_"] {
  border-bottom: 1px solid #e5e5e5;
}
.sysFuncText[class*="side_navi_"] a {
  display: flex;
  align-items: center;
  position: relative;
  height: 80px;
  padding: 0 24px 0 42px;
  font-weight: 700;
  text-decoration: none;
}
.sysFuncText[class*="side_navi_"] a:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 34px;
  height: 34px;
  background: no-repeat 0 0/100% 100%;
  transform: translateY(-50%);
}
.sysFuncText[class*="side_navi_"] a:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: translateY(-50%);
  transition: 0.3s;
}
@media (hover: hover) {
  .sysFuncText[class*="side_navi_"] a:hover {
    color: #ba0402;
    opacity: 1;
  }
  .sysFuncText[class*="side_navi_"] a:hover:after {
    background: #ba0402;
  }
}
.side_navi_1 .sysHeadline:before {
  background-image: url("/img/common/icon_roasted_01.svg") !important;
}
.side_navi_2 .sysHeadline:before {
  background-image: url("/img/common/icon_green_01.svg") !important;
}
.side_navi_3 .sysHeadline:before {
  background-image: url("/img/common/icon_special_02.svg") !important;
}
.side_navi_4 .sysHeadline:before {
  background-image: url("/img/common/icon_roasting.svg") !important;
}
.side_navi_5 .sysHeadline:before {
  background-image: url("/img/common/icon_country_01.svg") !important;
}
.side_navi_6 .sysHeadline:before {
  background-image: url("/img/common/icon_country_02.svg") !important;
}
.side_navi_7 a:before {
  background-image: url("/img/common/icon_cat_01.png") !important;
}
.side_navi_8 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_02.png") !important;
}
.side_navi_9 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_03.png") !important;
}
.side_navi_10 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_04.png") !important;
}
.side_navi_11 a:before {
  background-image: url("/img/common/icon_cat_05.png") !important;
}
.side_navi_12 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_06.png") !important;
}
.side_navi_13 a:before {
  background-image: url("/img/common/icon_cat_07.png") !important;
}
.side_navi_14 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_08.png") !important;
}
.side_navi_15 a:before {
  background-image: url("/img/common/icon_cat_09.png") !important;
}
.side_navi_16 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_10.png") !important;
}
.side_navi_17 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_11.png") !important;
}
.side_navi_18 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_12.png") !important;
}
.side_navi_19 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_13.png") !important;
}
.side_navi_20 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_14.png") !important;
}
.side_navi_21 a:before {
  background-image: url("/img/common/icon_cat_15.png") !important;
}
.side_navi_22 .sysHeadline:before {
  background-image: url("/img/common/icon_cat_16.png") !important;
}
.side_navi_23 a:before {
  background-image: url("/img/common/icon_cat_17.png") !important;
}
.side_navi_24 a:before {
  background-image: url("/img/common/icon_cat_18.png") !important;
}
.side_navi_25 a:before {
  background-image: url("/img/common/icon_cat_19.png") !important;
}
.side_navi_26 a:before {
  background-image: url("/img/common/icon_cat_20.png") !important;
}
.side-cat-ttl {
  position: relative;
  margin: 40px 0 0;
  padding: 0 0 16px 32px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 18px;
  font-weight: 700;
}
.side-cat-ttl:before {
  content: "";
  position: absolute;
  top: 9px;
  left: 9px;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_category.svg") no-repeat 0 0/100% 100%;
  background: #171717;
}
.side-cat-ttl p {
  margin: 0;
}
.side-bnr {
  margin: 40px 0;
}
.side-bnr ul li {
  margin: 0 0 16px;
}
.side-bnr ul li a img {
  border-radius: 5px;
}
.side-calendar {
  margin: 0 0 40px;
}
.side-calendar:last-child {
  margin: 0;
}
.side-calendar-ttl {
  margin: 0 0 16px;
  padding: 10px 16px;
  border-radius: 5px;
  color: #fff;
  font-weight: 700;
  text-align: center;
  background: #171717;
}
.side-calendar-wrapper {
  margin: 0 0 8px;
}
.side-calendar-wrapper table {
  width: 100%;
}
.side-calendar-wrapper table th {
  position: relative;
  padding: 0 0 8px;
  font-weight: 400;
  text-align: center;
}
.side-calendar-wrapper table th .cal_ui {
  position: absolute;
  top: 0;
  left: 50%;
  width: 140px;
  transform: translateX(-50%);
}
.side-calendar-wrapper table th .cal_ui button {
  position: absolute;
  top: 3px;
  width: 16px;
  height: 16px;
  border: none;
  background: none;
}
.side-calendar-wrapper table th .cal_ui button:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 8px;
  height: 8px;
  border-top: 1px solid #171717;
  border-right: 1px solid #171717;
}
.side-calendar-wrapper table th .cal_ui button:first-child {
  left: 0;
}
.side-calendar-wrapper table th .cal_ui button:first-child:before {
  transform: translate(-50%, -50%) rotate(-135deg);
}
.side-calendar-wrapper table th .cal_ui button:last-child {
  right: 0;
}
.side-calendar-wrapper table th .cal_ui button:last-child:before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.side-calendar-wrapper table th p {
  margin: 0;
  padding: 0 0 8px;
  border-bottom: 1px solid #e5e5e5;
}
.side-calendar-wrapper table .headline {
  display: none;
}
.side-calendar-wrapper table td {
  padding: 1px 0;
  font-size: 10px;
  text-align: center;
}
.side-calendar-wrapper table td div {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 28px;
  height: 28px;
  line-height: 1;
  margin: 0 auto;
  border-radius: 100%;
}
.side-calendar-wrapper table td .Today {
  background: #f3f0ec;
}
.side-calendar-wrapper table td .Sat,
.side-calendar-wrapper table td .Sun,
.side-calendar-wrapper table td .Holiday {
  color: #ba0402;
  background: #fff1f5;
}
.side-calendar-holiday {
  text-align: center;
}
.side-calendar-holiday span {
  color: #ba0402;
}
:root {
  --sys-color-primary-button: #ba0402 !important;
}
body.sysCheckoutBody div#sysMain {
  width: auto !important;
  margin: 0 !important;
  padding: 0 !important;
  color: inherit !important;
  font-size: inherit !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaTop .cart-notice {
  margin: 0 0 40px !important;
  padding: 48px !important;
  background: #FFF7EB;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaTop .cart-notice-ttl {
  margin: 0 0 40px !important;
  color: #ba0402;
  font-size: 20px;
  font-weight: 700;
  text-align: center;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaTop .cart-notice-subttl {
  margin: 0 0 24px !important;
  padding: 0 0 16px !important;
  border-bottom: 1px solid #c5beb3;
  color: #3c2609;
  font-weight: 700;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present {
  margin: 24px 0 0 !important;
  padding: 40px !important;
  border-radius: 5px !important;
  background: #FFF7EB !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .ttl {
  width: fit-content !important;
  margin: 0 auto 32px !important;
  padding: 0 0 8px !important;
  border-bottom: 1px solid #3c2609 !important;
  font-size: 20px !important;
  font-weight: 700 !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .ttl span {
  color: #ba0402 !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img {
  display: flex !important;
  flex-direction: row-reverse !important;
  justify-content: center !important;
  align-items: flex-start !important;
  gap: 0 48px !important;
  margin: 0 0 32px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img1 {
  width: 164px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img2 {
  width: 198px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img3 {
  width: 198px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .btn a {
  display: block !important;
  max-width: 470px !important;
  margin: 0 auto !important;
  padding: 16px !important;
  border-radius: 5px !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  text-align: center !important;
  background: #3c2609 !important;
  transition: 0.3s !important;
}
@media (hover: hover) {
  body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .btn a:hover {
    opacity: 0.7;
  }
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .applied {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 0 48px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout button {
  cursor: pointer;
}
body.sysCheckoutBody div#sysMain .sysCheckoutProgressBar {
  background: none !important;
}
body.sysCheckoutBody div#sysMain .border-gray-300,
#sysCheckout .\[\&\:has\(input\:checked\)\]\:bg-primary-active:has(input:checked) {
  background: #FFF7EB !important;
}
body.sysCheckoutBody div#sysMain .border-gray-300,
#sysCheckout .\[\&\:has\(input\:checked\)\]\:bg-primary-active:has(input:checked) {
  border-color: #FFF7EB !important;
}
body.sysCheckoutBody div#sysMain .sysCheckoutDeliverySummaryCardContent .sysCheckoutDeliveryAddressSummaryHeader,
body.sysCheckoutBody div#sysMain .sysCheckoutDeliverySummaryCardContent .sysCheckoutDeliveryMethodSummaryHeader,
body.sysCheckoutBody div#sysMain .sysCheckoutDeliverySummaryCardContent .sysCheckoutProductsSummaryHeader {
  background: #fff !important;
}
body.sysCheckoutBody #sysAside {
  width: auto;
  max-width: 900px;
  margin: 0 auto 80px;
}
body.sysCheckoutBody #sysAside .top-special {
  position: relative;
  margin: 0 0 72px;
  padding: 72px 0 96px;
  z-index: 0;
}
body.sysCheckoutBody #sysAside .top-special:before {
  content: "";
  position: absolute;
  top: 0;
  right: -100vw;
  bottom: 0;
  left: -100vw;
  background: #f3f0eb;
  z-index: -1;
}
body.sysCheckoutBody #sysAside .top-special .sysHeadline {
  line-height: 1.5;
  margin: 0 0 48px;
  padding: 0;
  border: none;
  color: #3c2609;
  text-align: center;
}
body.sysCheckoutBody #sysAside .top-special .sysHeadline:before {
  display: block;
  position: static;
  width: 45px;
  height: 45px;
  margin: 0 auto 8px;
}
body.sysCheckoutBody #sysAside .top-special .sysHeadline:after {
  content: "Feature";
  display: block;
  position: static;
  width: auto;
  height: auto;
  font-size: 15px;
  font-weight: 500;
  font-family: "Roboto", sans-serif;
  background: none;
}
body.sysCheckoutBody #sysAside .top-special .sysContent ul {
  margin: 0;
}
body.sysCheckoutBody #sysAside .top-special .sysContent ul li a img {
  margin: 0;
}
@media (hover: hover) {
  body.sysCheckoutBody #sysAside .top-special .sysContent ul li a:hover {
    opacity: 0.7;
  }
}
body.sysCheckoutBody #sysAside .cart-history .sysHeadline {
  line-height: 1.5;
  margin: 0 0 48px;
  color: #3c2609;
  font-size: 24px;
  text-align: center;
}
body.sysCheckoutBody #sysAside .cart-history .sysHeadline:before {
  content: "";
  display: block;
  width: 45px;
  height: 45px;
  margin: 0 auto 8px;
  background: url("/img/common/icon_check.svg") no-repeat 0 0/100% 100%;
}
body.sysCheckoutBody #sysAside .cart-history .sysHeadline span {
  display: block;
  font-size: 15px;
  font-weight: 500;
  font-family: "Roboto", sans-serif;
}
body.sysCheckoutBody #sysAside .cart-history .sysItemBlock .sysHorizontal {
  grid-template-columns: repeat(5, 1fr);
  gap: 20px;
}
body.sysCheckoutBody #sysAside .cart-history .sysItemBlock .sysHorizontal li .sysItemName {
  font-size: inherit;
  font-weight: 400;
}
body.sysCheckoutBody:not(:has(.cart-notice)) #sysAside {
  display: none;
}
.regi-login-txt,
.regi-login-reminder,
.regi-registration-txt {
  margin: 0 0 24px !important;
}
.regi-registration-guide {
  margin: 24px 0 0 !important;
  text-align: center !important;
}
.regi-registration-guide a {
  text-decoration: underline !important;
}
@media (hover: hover) {
  .regi-registration-guide a:hover {
    text-decoration: none !important;
  }
}
.sysCheckoutOrderCompleteSection {
  border: none !important;
  color: #171717 !important;
  background: #FFF7EB !important;
  box-shadow: none !important;
}
.sysCheckoutOrderCompleteSection .sysCheckoutText {
  color: #171717 !important;
}
.sysCheckoutOrderCompleteSectionError a {
  color: inherit !important;
  font-size: inherit !important;
}
#sysItemDetail article .sysPr {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  margin: 0 0 16px;
}
#sysItemDetail article .sysPr span:empty {
  display: none;
}
#sysItemDetail article > .sysItemName {
  position: relative;
  margin: 0 0 32px;
  padding: 0 0 8px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 24px;
}
#sysItemDetail article > .sysItemName:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 96px;
  height: 1px;
  background: #171717;
}
#sysItemDetail article > .sysExplanation {
  margin: 0 0 40px;
}
#sysItemDetail article > .sysExplanation .item-explanation {
  margin: 0 0 40px;
  padding: 30px;
  border-radius: 10px;
}
#sysItemDetail article > .sysExplanation .item-explanation p {
  margin: 0 0 1.5em;
}
#sysItemDetail article > .sysExplanation .item-explanation p:last-child {
  margin: 0;
}
#sysItemDetail article > .sysExplanation .item-explanation > img {
  max-width: none;
  width: revert-layer;
  height: revert-layer;
}
#sysItemDetail article > .sysExplanation .item-explanation-img {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  margin: 32px 0 0;
  padding: 32px 0 0;
  border-top: 1px dashed #3c2609;
}
#sysItemDetail article > .sysExplanation .item-explanation-img:has(img:nth-child(4)) {
  grid-template-columns: repeat(4, 1fr);
}
#sysItemDetail article > .sysExplanation .item-explanation-img img {
  display: block;
  width: 100%;
  border-radius: 5px;
}
#sysItemDetail:has(.bean-type-green) .item-explanation {
  background: #f1f8f4;
}
#sysItemDetail:has(.bean-type-roasted) .item-explanation {
  background: #FCF1EB;
}
#sysItemDetail:has(.bean-type-roasted) .sysVariationSelects {
  display: none;
}
#sysItemDetail:has(.bean-type-roasted) .sysVariationOptions {
  margin: 0 0 40px;
  color: #ba0402;
  text-align: right;
}
#sysItemDetail:has(.bean-type-roasted) .sysVariationOptions span {
  display: inline-block;
  line-height: 1;
  margin: 0 4px 0 12px;
  font-size: 35px;
  font-weight: 700;
  font-family: "Roboto", sans-serif;
  transform: translateY(2px);
}
#sysItemDetail .sysBlock.orderArea {
  display: flex;
  gap: 0 30px;
}
#sysItemDetail .sysBlock.orderArea .sysItemImages {
  width: 300px;
}
#sysItemDetail .sysBlock.orderArea .sysBlock.orderArea {
  flex: 1;
  display: block;
}
#sysItemDetail .sysBlock.orderArea .sysBlock.orderArea .sysItemNameWrap {
  margin: 40px 0 0;
  padding: 40px 0 0;
  border-top: 1px solid #e5e5e5;
}
#sysItemDetail .sysBlock.orderArea .sysBlock.orderArea .sysItemName {
  margin: 0 0 8px;
  font-size: 24px;
  font-weight: 700;
}
#sysItemDetail .sysMainImage {
  overflow: hidden;
  margin: 0 0 24px;
  border-radius: 10px;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
#sysItemDetail .sysImageList {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 15px;
}
#sysItemDetail .sysImageList:after {
  content: none;
}
#sysItemDetail .sysImageList li {
  position: relative;
  float: none;
  width: auto;
  height: auto;
  margin: 0;
  line-height: inherit;
}
#sysItemDetail .sysImageList li.sysCurrent:before {
  content: "";
  position: absolute;
  inset: 0;
  border: 2px solid #171717;
  border-radius: 4px;
}
#sysItemDetail .sysImageList li img {
  border: none;
  border-radius: 4px;
}
#sysItemDetail .print-button {
  margin: 32px 0 0;
}
#sysItemDetail .print-button button {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  width: 210px;
  height: 40px;
  border: none;
  border-radius: 40px;
  font-weight: 700;
  background: #f3f0ec;
}
#sysItemDetail .print-button button:before {
  content: "";
  display: block;
  width: 14px;
  height: 14px;
  mask: url("/img/detail/icon_print.svg") no-repeat 0 0/100% 100%;
  background: #171717;
}
#sysItemDetail .sysModalItemImages .sysModalImageList li {
  position: relative;
}
#sysItemDetail .sysModalItemImages .sysModalImageList li.sysCurrent:before {
  content: "";
  position: absolute;
  inset: 0;
  border: 2px solid #171717;
  border-radius: 4px;
}
#sysItemDetail .sysModalItemImages .sysModalImageList li img {
  border: none;
  border-radius: 4px;
}
#sysItemDetail .sysSpecifications {
  margin: 0 0 32px;
}
#sysItemDetail .sysSpecifications .sysSpecTable {
  margin: 0 !important;
  border: none !important;
  border-top: 1px solid #e5e5e5 !important;
}
#sysItemDetail .sysSpecifications .sysSpecTable td {
  border: none;
}
#sysItemDetail .sysSpecifications .sysSpecTable td.sysSpecItemFieldName {
  position: relative;
  width: 200px;
  padding: 16px 24px 16px 16px;
  border: none;
  border-bottom: 1px solid #e5e5e5;
  background: none;
}
#sysItemDetail .sysSpecifications .sysSpecTable td.sysSpecItemFieldName:before {
  content: "";
  position: absolute;
  top: 23px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background: #171717;
}
#sysItemDetail .sysSpecifications .sysSpecTable td.sysSpecItemFieldContent {
  padding: 16px 0;
  border-bottom: 1px solid #e5e5e5;
}
#sysItemDetail #sysMain:has(.bean-type-roasted) .sysSpecifications .sysSpecTable td.sysSpecItemFieldName:before {
  background: #8b540e;
}
#sysItemDetail #sysMain:has(.bean-type-green) .sysSpecifications .sysSpecTable td.sysSpecItemFieldName:before {
  background: #178242;
}
#sysItemDetail .sysItemId,
#sysItemDetail .custom-item-info {
  margin: 0 0 16px;
}
#sysItemDetail .sysItemId span {
  display: inline-block;
  margin-right: 1em;
}
#sysItemDetail .sysRetailPrice {
  display: none;
}
#sysItemDetail .sysForm {
  overflow: hidden;
}
#sysItemDetail .sysForm + .sysForm {
  margin: 40px 0 0;
  padding: 40px 0 0;
  border-top: 1px dashed #3c2609;
}
#sysItemDetail .label-purchase {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  line-height: 1;
  margin: 0 0 16px;
  padding: 10px 24px;
  border-radius: 4px;
  color: #fff;
  font-size: 18px;
}
#sysItemDetail .label-purchase span {
  font-weight: 700;
  font-size: 24px;
}
#sysItemDetail .label-purchase:before {
  content: "";
  display: block;
  width: 15px;
  height: 15px;
  margin: 0 12px 0 0;
}
#sysItemDetail .sysItemNameWrap.is-beans .label-purchase {
  background: #633e31;
}
#sysItemDetail .sysItemNameWrap.is-beans .label-purchase:before {
  background: url("/img/detail/icon_beans.svg") no-repeat 0 0/100% 100%;
}
#sysItemDetail .sysItemNameWrap.is-beans + .sysItemId + .sysForm .sysVariationCartBlock:nth-child(3) {
  display: none;
}
#sysItemDetail .sysItemNameWrap.is-ground .label-purchase {
  background: #e18618;
}
#sysItemDetail .sysItemNameWrap.is-ground .label-purchase:before {
  background: url("/img/detail/icon_ground.svg") no-repeat 0 0/100% 100%;
}
#sysItemDetail .sysItemNameWrap.is-ground + .sysItemId + .sysForm .sysVariationCartBlock:nth-child(2) {
  display: none;
}
#sysItemDetail .sysItemNameWrap.is-jute .label-purchase {
  color: #8B540E;
  background: #E2CEB4;
}
#sysItemDetail .sysItemNameWrap.is-jute .label-purchase:before {
  width: 16px;
  height: 24px;
  background: url("/img/detail/icon_jute.svg") no-repeat 0 0/100% 100%;
}
#sysItemDetail .sysItemNameWrap.is-10kg .label-purchase {
  color: #178242;
  background: #e8f3ed;
}
#sysItemDetail .sysItemNameWrap.is-10kg .label-purchase:before {
  width: 16px;
  height: 24px;
  background: url("/img/detail/icon_10kg.svg") no-repeat 0 0/100% 100%;
}
#sysItemDetail .sysVariationCartBlock .sysCartButton {
  width: 100%;
  height: 70px;
  padding: 0 0 0 50px;
  border: none;
  border-radius: 5px;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  background: #ba0402 url("/img/common/icon_cart.svg") no-repeat calc(50% - 64px) 50%/25px 25px;
}
#sysItemDetail #sysSelections {
  margin: 16px 0;
  padding: 24px 0 0;
  border-top: 1px solid #e5e5e5;
}
#sysItemDetail #sysSelections label {
  display: inline-block;
  position: relative;
  margin: 0 0 0 16px;
  padding: 0 0 0 28px;
}
#sysItemDetail #sysSelections label:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #3c2609;
  border-radius: 100%;
  transform: translateY(-50%);
}
#sysItemDetail #sysSelections label:has(input:checked):after {
  content: "";
  position: absolute;
  top: 50%;
  left: 6px;
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background: #3c2609;
  transform: translateY(-50%);
}
#sysItemDetail #sysSelections label input[type="radio"] {
  position: absolute;
  z-index: -1;
  opacity: 0;
}
#sysItemDetail #sysNumber {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 0 0 24px;
}
#sysItemDetail #sysNumber select[name="num"] {
  width: 120px;
  height: 50px;
  padding: 0 8px;
  border: 2px solid #171717;
  border-radius: 5px;
  background: url("/img/common/icon_arrow_05.svg") no-repeat center right 8px/10px 5px;
}
#sysItemDetail #sysNumber .sysNumArea {
  display: flex;
  gap: 0 6px;
}
#sysItemDetail #sysNumber .sysNumArea button {
  display: block;
  position: relative;
  height: 50px;
  line-height: 1;
  padding: 0 24px;
  border: none;
  border-radius: 5px;
  color: #3c2609;
  background: #3c2609;
}
#sysItemDetail #sysNumber .sysNumArea button:before {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  inset: 0;
  border-radius: 5px;
  color: #fff;
  background: #3c2609;
}
#sysItemDetail #sysNumber .sysNumArea button.sysBtnPlus {
  width: 133px;
}
#sysItemDetail #sysNumber .sysNumArea button.sysBtnPlus:before {
  content: "＋　数量追加";
}
#sysItemDetail #sysNumber .sysNumArea button.sysBtnMinus {
  width: 162px;
}
#sysItemDetail #sysNumber .sysNumArea button.sysBtnMinus:before {
  content: "－　数量を減らす";
}
#sysItemDetail .greenbean-login-link {
  margin: 0 0 24px;
  border-radius: 5px;
  background: #ffcfcf;
}
#sysItemDetail .greenbean-login-link a {
  display: block;
  position: relative;
  padding: 20px 40px 20px 20px;
  color: #ba0402;
  font-weight: 700;
  text-decoration: none;
}
#sysItemDetail .greenbean-login-link a:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 20px;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #ba0402;
  transform: translateY(-50%);
}
#sysItemDetail .greenbean-jute-notice {
  display: none;
  margin: 16px 0 40px;
}
#sysItemDetail .greenbean-jute-notice span {
  color: #ba0402;
}
#sysItemDetail .greenbean-10kg-notice {
  display: none;
  margin: 16px 0 40px;
}
#sysItemDetail .greenbean-10kg-process {
  display: none;
  margin: 0 0 24px;
  padding: 16px;
  color: #178242;
  font-weight: 700;
  border: 1px dashed #178242;
}
#sysItemDetail .greenbean-10kg-unitprice {
  display: none;
  margin: 0 0 40px;
}
#sysItemDetail .greenbean-10kg-unitprice-label {
  display: block;
  padding: 15px;
  border: 1px solid #e5e5e5;
  border-bottom: none;
  border-radius: 5px 5px 0 0;
  font-weight: 700;
  text-align: center;
  background: #f7f7f7;
}
#sysItemDetail .greenbean-10kg-unitprice table {
  width: 100%;
  margin: 0 0 24px;
  border-top: 1px solid #e5e5e5;
  border-collapse: separate;
  text-align: center;
}
#sysItemDetail .greenbean-10kg-unitprice table th {
  padding: 15px;
  border-right: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  font-weight: 400;
}
#sysItemDetail .greenbean-10kg-unitprice table th:first-child {
  border-left: 1px solid #e5e5e5;
}
#sysItemDetail .greenbean-10kg-unitprice table td {
  padding: 15px;
  border-right: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
  font-size: 16px;
  color: #ba0402;
}
#sysItemDetail .greenbean-10kg-unitprice table td:first-child {
  border-left: 1px solid #e5e5e5;
  border-radius: 0 0 0 5px;
}
#sysItemDetail .greenbean-10kg-unitprice table td:last-child {
  border-radius: 0 0 5px 0;
}
#sysItemDetail #sysSubtotal {
  margin: 0 0 40px;
  text-align: right;
}
#sysItemDetail #sysSubtotal .sysSubtotalPrice {
  color: #ba0402;
}
#sysItemDetail #sysSubtotal .sysSubtotalPrice span {
  display: inline-block;
  line-height: 1;
  margin: 0 4px 0 12px;
  font-size: 35px;
  font-weight: 700;
  font-family: "Roboto", sans-serif;
  transform: translateY(2px);
}
#sysItemDetail #sysSubmit {
  margin: 0 0 32px;
}
#sysItemDetail #sysSubmit input[type=submit] {
  width: 100%;
  height: 70px;
  padding: 0 0 0 50px;
  border: none;
  border-radius: 5px;
  color: #fff;
  font-size: 18px;
  font-weight: 500;
  background: #ba0402 url("/img/common/icon_cart.svg") no-repeat calc(50% - 64px) 50%/25px 25px;
}
#sysItemDetail #sysSubmit input[type=submit][disabled],
#sysItemDetail .sysVariationCartBlock input[type=submit][disabled] {
  cursor: default;
  color: #171717;
  background: #e5e5e5 url("/img/common/icon_cart_02.svg") no-repeat calc(50% - 48px) 50%/25px 25px;
}
#sysItemDetail #sysSubmit input[type=submit][disabled]:hover,
#sysItemDetail .sysVariationCartBlock input[type=submit][disabled]:hover {
  opacity: 1;
}
#sysItemDetail .sysForm:has(#sysSubmit input[type=submit][disabled]) #sysNumber {
  display: none;
}
#sysItemDetail .sysForm:has(#sysSubmit input[type=submit][disabled]) #sysSubtotal {
  display: none;
}
#sysItemDetail #sysWishlist {
  float: left;
  width: 227px;
}
#sysItemDetail #sysWishlist .sysWishListButtonFormAjax button {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  width: 100%;
  height: 50px;
  border: 1px solid #171717;
  border-radius: 40px;
  font-weight: 700;
  background: #fff;
}
#sysItemDetail #sysWishlist .sysWishListButtonFormAjax button:not([disabled="disabled"]).sysWishListButton {
  cursor: pointer;
}
#sysItemDetail #sysWishlist .sysWishListButtonFormAjax button:before {
  content: "";
  display: block;
  width: 16px;
  height: 16px;
  background: url("/img/common/icon_favorite.svg") no-repeat 0 0/100% 100%;
}
#sysItemDetail .sysShowWishlistButton {
  display: block;
  width: 400px;
  margin: 24px auto;
  padding: 14px;
  border: none;
  border-radius: 5px;
  color: #fff;
  background: #3c2609;
}
#sysItemDetail .sysFreeForm {
  float: right;
  width: 227px;
}
#sysItemDetail .sysFreeForm input[type="submit"] {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 50px;
  padding: 0 0 0 24px;
  border: 1px solid #171717;
  border-radius: 40px;
  font-weight: 700;
  background: #fff url("/img/detail/icon_mail.svg") no-repeat 30px 50%/17px 14px;
}
#sysItemDetail .modaal-content-container {
  padding: 0;
}
#sysItemDetail .mdl-dialog__content {
  padding: 0;
  color: inherit;
}
#sysItemDetail .rating-coffee {
  margin: 40px 0 0;
  padding: 40px 0 0;
  border-top: 1px solid #e5e5e5;
}
#sysItemDetail .rating-coffee-contents {
  margin: 0 0 24px;
  font-weight: 700;
}
.rating-coffee-label {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  width: 164px;
  padding: 12px 0 0;
  border-radius: 6px 6px 0 0;
  color: #8b540e;
  font-weight: 700;
  background: #f3f0ec;
}
.rating-coffee-label:before {
  content: "";
  display: block;
  width: 16px;
  height: 11px;
  background: url("/img/detail/rating_01.svg") no-repeat 0 0/100% 100%;
}
.rating-coffee-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px 20px;
  padding: 20px;
  border-radius: 0 6px 6px 6px;
  background: #f3f0ec;
}
.rating-coffee-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.rating-coffee-item-name {
  position: relative;
  padding: 0 0 0 16px;
  font-weight: 700;
}
.rating-coffee-item-name:before {
  content: "";
  position: absolute;
  top: 7px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background: #8b540e;
}
.rating-coffee-item-num {
  position: relative;
  width: 81px;
  height: 13px;
  background: url("/img/detail/rating_02.svg") no-repeat 0 0/100% 100%;
}
.rating-coffee-item-num:after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  background: url("/img/detail/rating_03.svg") no-repeat 0 0/81px 13px;
}
.rating-coffee-item-num[data-num="1"]:after {
  width: 20%;
}
.rating-coffee-item-num[data-num="2"]:after {
  width: 40%;
}
.rating-coffee-item-num[data-num="3"]:after {
  width: 60%;
}
.rating-coffee-item-num[data-num="4"]:after {
  width: 80%;
}
.rating-coffee-item-num[data-num="5"]:after {
  width: 100%;
}
.detail-yamato {
  margin: 80px 0;
}
.detail-history {
  margin: 0 0 80px;
  padding: 80px 0 0;
  border-top: 1px dashed #171717;
}
.detail-history .sysHeadline {
  display: flex;
  align-items: center;
  margin: 0 0 32px;
  font-size: 20px;
  font-weight: 700;
}
.detail-history .sysHeadline:before {
  content: "";
  display: block;
  width: 13px;
  height: 13px;
  margin: 0 8px 0 0;
  mask: url("/img/common/icon_bean_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
}
.detail-history .sysHeadline span {
  display: block;
  margin: 0 0 0 16px;
  font-size: 10px;
  font-weight: 400;
}
#sysMain:has(.bean-type-roasted) .detail-history .sysHeadline:before,
#sysMain:has(.bean-type-roasted) .detail-recommend .sysHeadline:before {
  background: #8b540e;
}
#sysMain:has(.bean-type-green) .detail-history .sysHeadline:before,
#sysMain:has(.bean-type-green) .detail-recommend .sysHeadline:before {
  background: #178242;
}
.detail-recommend .sysHeadline {
  display: flex;
  align-items: center;
  margin: 0 0 32px;
  font-size: 20px;
  font-weight: 700;
}
.detail-recommend .sysHeadline:before {
  content: "";
  display: block;
  width: 13px;
  height: 13px;
  margin: 0 8px 0 0;
  mask: url("/img/common/icon_bean_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
}
.detail-recommend .sysHeadline span {
  display: block;
  margin: 0 0 0 16px;
  font-size: 10px;
  font-weight: 400;
}
.detail-commercial-baked,
.detail-commercial-green {
  margin: 0 0 80px;
}
.detail-commercial-baked .sysHeadline,
.detail-commercial-green .sysHeadline {
  position: relative;
  margin: 0 0 32px;
  padding: 0 0 8px 48px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 24px;
}
.detail-commercial-baked .sysHeadline:before,
.detail-commercial-green .sysHeadline:before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  width: 34px;
  height: 34px;
  background: url("/img/common/icon_special_02.svg") no-repeat 0 0/100% 100%;
}
.detail-commercial-baked .sysHeadline:after,
.detail-commercial-green .sysHeadline:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 96px;
  height: 1px;
  background: #171717;
}
.commercial-subttl {
  margin: 0 0 24px;
  padding: 10px 16px;
  border-radius: 4px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
}
.commercial-lead {
  margin: 0 0 40px;
}
.commercial-feature {
  display: flex;
  align-items: center;
  gap: 0 24px;
  margin: 0 0 24px;
}
.commercial-feature-img {
  width: 350px;
}
.commercial-feature-img img {
  border-radius: 10px;
}
.commercial-feature-body {
  flex: 1;
}
.commercial-feature-ttl {
  margin: 0 0 16px;
  font-size: 18px;
  font-weight: 700;
}
.commercial-feature-ttl span {
  display: inline-block;
  vertical-align: top;
  margin: 3px 8px 0 0;
  padding: 3px 10px;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  background: #ba0402;
}
.commercial-feature-txt {
  font-weight: 700;
}
.commercial-feature-txt span {
  color: #ba0402;
}
.detail-commercial-baked .commercial-subttl {
  background: #8b540e;
}
.detail-commercial-green .commercial-subttl {
  background: #178242;
}
body[data-member-login="true"] #sysMain:has(.bean-type-green) .greenbean-login-link {
  display: none !important;
}
body:not([data-member-login="true"])#sysItemDetail #sysMain:has(.bean-type-green) .sysItemId,
body:not([data-member-login="true"])#sysItemDetail #sysMain:has(.bean-type-green) .greenbean-10kg-unitprice,
body:not([data-member-login="true"])#sysItemDetail #sysMain:has(.bean-type-green) #sysNumber,
body:not([data-member-login="true"])#sysItemDetail #sysMain:has(.bean-type-green) #sysSubtotal,
body:not([data-member-login="true"])#sysItemDetail #sysMain:has(.bean-type-green) #sysSubmit {
  display: none !important;
}
.inquiry-guide {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  margin: 0 0 24px;
}
.form-inquiry .sysForm,
.form-products .sysForm,
.form-original-drip .sysForm,
.sysMemberRegister .sysForm {
  margin: 40px 0 0;
}
.form-inquiry .sysFormItem,
.form-products .sysFormItem,
.form-original-drip .sysFormItem,
.sysMemberRegister .sysFormItem {
  margin: 0 0 32px;
}
.form-inquiry .sysFormLabel,
.form-products .sysFormLabel,
.form-original-drip .sysFormLabel,
.sysMemberRegister .sysFormLabel {
  display: block;
  position: relative;
  margin: 0 0 16px;
  padding: 0 0 0 16px;
  font-weight: 600;
}
.form-inquiry .sysFormLabel:before,
.form-products .sysFormLabel:before,
.form-original-drip .sysFormLabel:before,
.sysMemberRegister .sysFormLabel:before {
  content: "";
  position: absolute;
  top: 8px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background: #3c2609;
}
.form-inquiry .sysRequired,
.form-products .sysRequired,
.form-original-drip .sysRequired,
.sysMemberRegister .sysRequired {
  line-height: 1;
  vertical-align: top;
  margin: 2px 0 0 8px;
  padding: 4px 8px;
  border-radius: 3px;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  background: #ba0402;
}
.form-inquiry .sysRequired:before,
.form-products .sysRequired:before,
.form-original-drip .sysRequired:before,
.sysMemberRegister .sysRequired:before,
.form-inquiry .sysRequired:after,
.form-products .sysRequired:after,
.form-original-drip .sysRequired:after,
.sysMemberRegister .sysRequired:after {
  content: none;
}
.form-inquiry .sysFormField,
.form-products .sysFormField,
.form-original-drip .sysFormField,
.sysMemberRegister .sysFormField {
  overflow: hidden;
}
.form-inquiry .sysFormField input[type="text"],
.form-products .sysFormField input[type="text"],
.form-original-drip .sysFormField input[type="text"],
.sysMemberRegister .sysFormField input[type="text"],
.form-inquiry .sysFormField input[type="email"],
.form-products .sysFormField input[type="email"],
.form-original-drip .sysFormField input[type="email"],
.sysMemberRegister .sysFormField input[type="email"],
.form-inquiry .sysFormField input[type="tel"],
.form-products .sysFormField input[type="tel"],
.form-original-drip .sysFormField input[type="tel"],
.sysMemberRegister .sysFormField input[type="tel"],
.form-inquiry .sysFormField input[type="password"],
.form-products .sysFormField input[type="password"],
.form-original-drip .sysFormField input[type="password"],
.sysMemberRegister .sysFormField input[type="password"],
.form-inquiry .sysFormField textarea,
.form-products .sysFormField textarea,
.form-original-drip .sysFormField textarea,
.sysMemberRegister .sysFormField textarea {
  width: 100%;
  margin: 0;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.sysMemberRegister .sysFormField input[type="text"]::placeholder,
.sysMemberRegister .sysFormField input[type="email"]::placeholder,
.sysMemberRegister .sysFormField input[type="tel"]::placeholder {
  color: #D9D5D0;
}
.form-inquiry .sysFormField textarea,
.form-products .sysFormField textarea,
.form-original-drip .sysFormField textarea,
.sysMemberRegister .sysFormField textarea {
  height: 200px;
}
.form-inquiry .sysFormField select,
.form-products .sysFormField select,
.form-original-drip .sysFormField select,
.sysMemberRegister .sysFormField select {
  appearance: auto;
  margin: 0;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.form-inquiry .sysFormField input[name="item[4][answer][0]"],
.form-products .sysFormField input[name="item[4][answer][0]"],
.form-original-drip .sysFormField input[name="item[4][answer][0]"],
.sysMemberRegister .sysFormField input[name="item[4][answer][0]"] {
  float: left;
  width: 160px;
}
.form-inquiry .sysFormField button[name="getAddress"],
.form-products .sysFormField button[name="getAddress"],
.form-original-drip .sysFormField button[name="getAddress"],
.sysMemberRegister .sysFormField button[name="getAddress"] {
  width: auto;
  margin: 0 0 0 16px;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.form-inquiry .sysFormField label:has(input[type="radio"]),
.form-products .sysFormField label:has(input[type="radio"]),
.form-original-drip .sysFormField label:has(input[type="radio"]),
.sysMemberRegister .sysFormField label:has(input[type="radio"]) {
  position: relative;
  width: fit-content;
  padding: 0 0 0 32px;
}
.form-inquiry .sysFormField label:has(input[type="radio"]):before,
.form-products .sysFormField label:has(input[type="radio"]):before,
.form-original-drip .sysFormField label:has(input[type="radio"]):before,
.sysMemberRegister .sysFormField label:has(input[type="radio"]):before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #3c2609;
  border-radius: 100%;
  background: #fff;
}
.form-inquiry .sysFormField label:has(input[type="radio"]) input[type="radio"],
.form-products .sysFormField label:has(input[type="radio"]) input[type="radio"],
.form-original-drip .sysFormField label:has(input[type="radio"]) input[type="radio"],
.sysMemberRegister .sysFormField label:has(input[type="radio"]) input[type="radio"] {
  position: absolute;
  opacity: 0;
}
.form-inquiry .sysFormField label:has(input[type="radio"]:checked):after,
.form-products .sysFormField label:has(input[type="radio"]:checked):after,
.form-original-drip .sysFormField label:has(input[type="radio"]:checked):after,
.sysMemberRegister .sysFormField label:has(input[type="radio"]:checked):after {
  content: "";
  position: absolute;
  top: 6px;
  left: 6px;
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background: #FF8400;
}
.form-inquiry .sysFormField label:has(input[type="checkbox"]),
.form-products .sysFormField label:has(input[type="checkbox"]),
.form-original-drip .sysFormField label:has(input[type="checkbox"]),
.sysMemberRegister .sysFormField label:has(input[type="checkbox"]) {
  position: relative;
  width: fit-content;
  margin: 0 0 24px;
  padding: 0 0 0 24px;
}
.form-inquiry .sysFormField label:has(input[type="checkbox"]):before,
.form-products .sysFormField label:has(input[type="checkbox"]):before,
.form-original-drip .sysFormField label:has(input[type="checkbox"]):before,
.sysMemberRegister .sysFormField label:has(input[type="checkbox"]):before {
  content: "";
  position: absolute;
  top: 3px;
  left: 0;
  width: 16px;
  height: 16px;
  border: 1px solid #e5e5e5;
  border-radius: 2px;
  background: #fff;
}
.form-inquiry .sysFormField label:has(input[type="checkbox"]) input[type="checkbox"],
.form-products .sysFormField label:has(input[type="checkbox"]) input[type="checkbox"],
.form-original-drip .sysFormField label:has(input[type="checkbox"]) input[type="checkbox"],
.sysMemberRegister .sysFormField label:has(input[type="checkbox"]) input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}
.form-inquiry .sysFormField label:has(input[type="checkbox"]:checked):before,
.form-products .sysFormField label:has(input[type="checkbox"]:checked):before,
.form-original-drip .sysFormField label:has(input[type="checkbox"]:checked):before,
.sysMemberRegister .sysFormField label:has(input[type="checkbox"]:checked):before {
  border-color: #171717;
  background: #171717;
}
.form-inquiry .sysFormField label:has(input[type="checkbox"]:checked):after,
.form-products .sysFormField label:has(input[type="checkbox"]:checked):after,
.form-original-drip .sysFormField label:has(input[type="checkbox"]:checked):after,
.sysMemberRegister .sysFormField label:has(input[type="checkbox"]:checked):after {
  content: "";
  position: absolute;
  top: 5px;
  left: 5px;
  width: 6px;
  height: 9px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.form-inquiry .sysNextSubmit,
.form-products .sysNextSubmit,
.form-original-drip .sysNextSubmit,
.sysMemberRegister .sysNextSubmit {
  display: block;
  width: 470px;
  height: 65px;
  margin: 0 auto;
  padding: 0;
  border: none;
  border-radius: 5px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  background: #ff8400;
}
.form-inquiry .pp,
.form-products .pp,
.form-original-drip .pp,
.sysMemberRegister .pp {
  height: 200px;
  overflow: auto;
  margin: 0 0 16px;
  padding: 24px;
  border: 1px solid #e5e5e5;
}
.form-inquiry .sysItemNameByFreeform,
.form-products .sysItemNameByFreeform,
.form-original-drip .sysItemNameByFreeform,
.sysMemberRegister .sysItemNameByFreeform {
  margin: 0 0 16px;
  font-weight: 700;
}
.form-inquiry .sysItemThumnailByFreeform,
.form-products .sysItemThumnailByFreeform,
.form-original-drip .sysItemThumnailByFreeform,
.sysMemberRegister .sysItemThumnailByFreeform {
  width: 240px;
}
.form-inquiry .sysItemThumnailByFreeform img,
.form-products .sysItemThumnailByFreeform img,
.form-original-drip .sysItemThumnailByFreeform img,
.sysMemberRegister .sysItemThumnailByFreeform img {
  border-radius: 5px;
}
#sysFormConfirm #sysMain {
  padding-bottom: 88px;
}
#sysFormConfirm .sysButton {
  display: block;
  width: 130px;
  min-width: auto;
  height: 50px;
  line-height: 1;
  border: 1px solid #583c32;
  border-radius: 4px;
  font-size: 12px;
  background: #fff;
  transform: translateY(155px);
}
.form-thanks-tel {
  max-width: 420px;
  margin: 80px auto;
  padding: 24px 16px;
  text-align: center;
  background: #f3f0ec;
}
.form-thanks-tel-ttl {
  margin: 0 0 16px;
  font-weight: 700;
}
.form-thanks-tel-num {
  margin: 0 0 8px;
}
.form-thanks-tel-num a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  font-size: 20px;
  font-weight: 700;
  font-family: "Roboto", sans-serif;
  text-decoration: none;
}
.form-thanks-tel-num a:before {
  content: "";
  display: block;
  width: 14px;
  height: 14px;
  background: url("/img/common/icon_tel.svg") no-repeat 0 0/100% 100%;
}
.form-thanks-tel-notes {
  font-size: 10px;
  font-weight: 700;
}
.form-thanks-back {
  text-align: center;
}
.list-ttl {
  position: relative;
  margin: 0 0 32px;
  padding: 0 0 8px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 24px;
}
.list-ttl:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 96px;
  height: 1px;
  background: #171717;
}
.list-search {
  display: none;
  margin: 0 0 24px;
}
.list-search .sysItemSearchForm {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0;
  padding: 20px;
  border-radius: 6px;
  background: #f3f0ec;
}
.sysItemSearchFormWord {
  width: 100%;
}
.sysItemSearchFormWord input[type="search"] {
  width: 100%;
  padding: 12px 16px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  font-size: 12px;
  background: #fff;
  appearance: none;
}
.sysItemSearchFormRange {
  display: none;
}
.sysItemSearchFormCategory select,
.sysItemSearchFormPrice select {
  width: 200px;
  padding: 12px 32px 12px 16px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  font-size: 12px;
  background: #fff url("/img/common/icon_arrow_05.svg") no-repeat center right 16px/10px auto;
}
.sysItemSearchFormItemCategoryGroups .sysItemSearchFormItemCategoryGroupsTitle,
.sysItemSearchFormItemCategoryGroups .itemCategoryGroupTitle0 {
  display: none;
}
.sysItemSearchFormItemPrGroups .sysItemSearchFormItemPrGroupsTitle,
.sysItemSearchFormItemPrGroups .itemPrGroupTitle0,
.sysItemSearchFormItemPrGroups .itemPrGroupTitle1 {
  display: none;
}
.sysItemSearchFormItemCategoryGroups,
.sysItemSearchFormItemPrGroups {
  position: relative;
}
.sysItemSearchFormItemPrGroups {
  display: flex;
  gap: 16px;
}
.sysItemSearchFormItemCategoryGroups label,
.sysItemSearchFormItemPrGroups label {
  display: block;
  position: relative;
  padding: 0 0 0 32px;
  font-size: 12px;
}
.sysItemSearchFormItemCategoryGroups label:before,
.sysItemSearchFormItemPrGroups label:before {
  content: "";
  position: absolute;
  top: -4px;
  left: 0;
  width: 26px;
  height: 26px;
  border: 1px solid #e5e5e5;
  border-radius: 2px;
  background: #fff;
}
.sysItemSearchFormItemCategoryGroups input[type="checkbox"],
.sysItemSearchFormItemPrGroups input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}
.sysItemSearchFormItemCategoryGroups input[type="checkbox"]:checked + label:before,
.sysItemSearchFormItemPrGroups input[type="checkbox"]:checked + label:before {
  border-color: #171717;
  background: #171717;
}
.sysItemSearchFormItemCategoryGroups input[type="checkbox"]:checked + label:after,
.sysItemSearchFormItemPrGroups input[type="checkbox"]:checked + label:after {
  content: "";
  position: absolute;
  top: 1px;
  left: 9px;
  width: 7px;
  height: 12px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.sysSearchButton {
  width: 102px;
  height: 40px;
  line-height: 1;
  margin: 0 0 0 auto;
  padding: 0 0 0 22px;
  border: none;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  background: #171717 url("/img/common/icon_search.svg") no-repeat 16px 50%/18px 18px;
}
.sysItemSearchForm {
  margin: 0 0 24px;
}
.sysItemSearchFormInput {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px;
  padding: 20px;
  border-radius: 6px;
  background: #f3f0ec;
}
.sysItemCategoryForm {
  display: none;
  float: right;
}
.sysItemListDisp {
  margin: 0 0 24px;
  padding: 8px 0 24px;
  border-bottom: 1px solid #e5e5e5;
}
.sysItemCategoryCtl {
  margin: 0;
  padding: 0;
  border: none;
}
.pd_wrap {
  position: relative;
  width: 178px;
  border-radius: 5px;
  border: 1px solid #e5e5e5;
  background: #fff;
}
.pd_wrap.open {
  border-radius: 5px 5px 0 0;
}
.pd_wrap.open .pd_ttl:after {
  transform: translateY(-50%) rotate(180deg);
}
.pd_wrap.open .pd_list {
  opacity: 1;
  pointer-events: auto;
}
.pd_ttl {
  position: relative;
  padding: 10px 32px 10px 40px;
  font-size: 12px;
  cursor: pointer;
}
.pd_ttl:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 16px;
  width: 12px;
  height: 15px;
  background: url("/img/common/icon_sort.svg") no-repeat 0 0/100% 100%;
  transform: translateY(-50%);
}
.pd_ttl:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 10px;
  height: 6px;
  background: #171717;
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  transform: translateY(-50%);
  transition-duration: 0.3s;
}
.pd_list {
  display: flex;
  flex-direction: column;
  position: absolute;
  right: -1px;
  bottom: 0;
  left: -1px;
  z-index: 1;
  padding: 0 16px 12px;
  border: 1px solid #e5e5e5;
  border-top: none;
  border-radius: 0 0 5px 5px;
  transform: translateY(100%);
  background: #fff;
  opacity: 0;
  pointer-events: none;
  transition-duration: 0.3s;
}
.pd_list .sysCurrent {
  font-weight: 700;
}
.pd_list a {
  display: block;
  position: relative;
  padding: 4px 0;
  font-size: 12px;
  text-decoration: none;
}
.pd_list a:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 0;
  width: 4px;
  height: 4px;
  border-right: 1px solid #171717;
  border-bottom: 1px solid #171717;
  transform: translateY(-50%) rotate(-45deg);
  transition: 0.3s;
}
.sysItemBlock ul.sysHorizontal,
.sysItemList ul.sysList {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 40px;
}
.sysItemBlock ul.sysHorizontal:after,
.sysItemList ul.sysList:after {
  content: none;
}
.sysItemBlock ul.sysHorizontal li,
.sysItemList ul.sysList li {
  float: none !important;
  width: auto !important;
  padding: 0 !important;
  border: none !important;
}
.sysItemBlock ul.sysHorizontal li .sysItemLink,
.sysItemList ul.sysList li .sysItemLink {
  display: flex;
  flex-direction: column;
  height: 100%;
  text-decoration: none;
}
@media (hover: hover) {
  .sysItemBlock ul.sysHorizontal li .sysItemLink:hover,
  .sysItemList ul.sysList li .sysItemLink:hover {
    opacity: 1;
  }
  .sysItemBlock ul.sysHorizontal li .sysItemLink:hover .sysThumbnailImage img,
  .sysItemList ul.sysList li .sysItemLink:hover .sysThumbnailImage img,
  .sysItemBlock ul.sysHorizontal li .sysItemLink:hover .sysItemImage img,
  .sysItemList ul.sysList li .sysItemLink:hover .sysItemImage img {
    transform: scale(1.07);
  }
  .sysItemBlock ul.sysHorizontal li .sysItemLink:hover .sysItemName span,
  .sysItemList ul.sysList li .sysItemLink:hover .sysItemName span {
    text-decoration-color: currentColor;
  }
}
.sysItemBlock ul.sysHorizontal li .sysThumbnailImage,
.sysItemList ul.sysList li .sysThumbnailImage,
.sysItemBlock ul.sysHorizontal li .sysItemImage,
.sysItemList ul.sysList li .sysItemImage {
  float: none;
  width: auto;
  overflow: hidden;
  margin: 0 0 18px;
  border-radius: 5px;
}
.sysItemBlock ul.sysHorizontal li .sysThumbnailImage img,
.sysItemList ul.sysList li .sysThumbnailImage img,
.sysItemBlock ul.sysHorizontal li .sysItemImage img,
.sysItemList ul.sysList li .sysItemImage img {
  transition: 0.3s;
}
.sysItemBlock ul.sysHorizontal li .sysItemPrArea,
.sysItemList ul.sysList li .sysItemPrArea {
  display: flex;
  flex-wrap: wrap;
  gap: 3px;
  margin: 0 0 8px;
}
.sysItemBlock ul.sysHorizontal li .sysItemName,
.sysItemList ul.sysList li .sysItemName {
  margin: 0 0 4px;
  font-size: 18px;
  font-weight: 700;
}
.sysItemBlock ul.sysHorizontal li .sysItemName span,
.sysItemList ul.sysList li .sysItemName span {
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  text-decoration-color: rgba(23,23,23,0);
  transition: text-decoration-color 0.3s ease;
}
.sysItemBlock ul.sysHorizontal li #sysDescriptionPc,
.sysItemList ul.sysList li #sysDescriptionPc,
.sysItemBlock ul.sysHorizontal li #sysDescriptionMobile,
.sysItemList ul.sysList li #sysDescriptionMobile {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin: 0 0 10px;
  text-overflow: ellipsis;
  -webkit-line-clamp: 3;
}
.sysItemBlock ul.sysHorizontal li .sysItemPrice,
.sysItemList ul.sysList li .sysItemPrice,
.sysItemBlock ul.sysHorizontal li .sysRetailPrice,
.sysItemList ul.sysList li .sysRetailPrice {
  margin: auto 0 0;
  color: #ba0402;
  font-size: 20px;
  font-weight: 700;
}
.sysItemBlock ul.sysHorizontal li .sysItemPrice span:not(.sysItemBlockVariationPrice),
.sysItemList ul.sysList li .sysItemPrice span:not(.sysItemBlockVariationPrice),
.sysItemBlock ul.sysHorizontal li .sysRetailPrice span:not(.sysItemBlockVariationPrice),
.sysItemList ul.sysList li .sysRetailPrice span:not(.sysItemBlockVariationPrice) {
  font-size: 12px;
}
.sysItemPr {
  display: block;
  width: auto;
  height: auto;
  line-height: inherit;
  margin: 0;
  padding: 4px 8px;
  border: none;
  border-radius: 3px;
  font-size: 12px;
  font-weight: 700;
}
.sysItemPr[data-pr="SOLDOUT"] {
  background: #e5e5e5;
}
.sysItemPr[data-pr="ニュークロップ"] {
  color: #fff;
  background: #0f7426;
}
.sysItemPr[data-pr="農園指定"] {
  color: #fff;
  background: #f66bf4;
}
.sysItemPr[data-pr="準備中"] {
  color: #fff;
  background: #0000ff;
}
.sysItemPr[data-pr="SALE"] {
  color: #fff;
  background: #d90000;
}
.sysItemPr[data-pr="数量限定"] {
  color: #fff;
  background: #00af76;
}
.sysItemPr[data-pr="送料無料"] {
  color: #fff;
  background: #008000;
}
.sysItemPr[data-pr="取り寄せ品"] {
  color: #fff;
  background: #8749a5;
}
.sysItemPr[data-pr="麻袋"] {
  color: #fff;
  background: #8f0f0f;
}
.sysItemPr[data-pr="おすすめ"] {
  color: #fff;
  background: #fe963f;
}
.sysItemPr[data-pr="NEW"] {
  color: #fff;
  background: #62b0ff;
}
.sysItemPr[data-pr="焼豆"] {
  color: #fff;
  background: #000000;
}
.sysItemPr[data-pr="生豆"] {
  color: #fff;
  background: #3cb371;
}
.sysItemPr[data-pr="受注生産品"] {
  color: #fff;
  background: #ff00ff;
}
.sysItemPr[data-pr="特別焙煎品"] {
  color: #fff;
  background: #00ffff;
}
.sysItemPr[data-pr="定番品"] {
  color: #fff;
  background: #ff0000;
}
.sysItemPr[data-pr="スペシャリティ"] {
  color: #fff;
  background: #606060;
}
.sysPagination {
  margin: 40px 0;
}
.sysPagination ul {
  display: flex;
  justify-content: center;
  gap: 0 10px;
}
.sysPagination ul li {
  display: block;
  width: auto;
  padding: 0;
}
.sysPagination ul li a {
  width: 36px;
  height: 36px;
  line-height: 36px;
  border: none;
  border-radius: 3px;
  font-size: 12px;
  text-align: center;
  text-decoration: none !important;
  background: #f3f0ec;
}
.sysPagination ul li a.sysCurrent {
  color: #fff;
  background: #3c2609;
}
.sysMemberRegister #sysAside {
  display: none;
}
.sysMemberRegister #sysMain {
  width: auto;
  max-width: 900px;
  margin: 0 auto 80px;
  padding: 0;
}
.sysMemberRegister #sysMain > h2 {
  display: none;
}
.sysMemberRegister #sysMain .sysHeadline {
  margin: 0 0 48px;
  color: #3c2609;
  font-size: 24px;
  font-family: inherit;
  text-align: center;
}
.sysMemberRegister #sysMain .sysHeadline span {
  display: block;
  font-size: 15px;
  font-weight: 500;
  font-family: "Roboto", sans-serif;
}
.sysMemberRegister #sysMain .sysForm {
  padding: 48px;
  border-radius: 5px;
  background: #f3f0eb;
}
.sysMemberRegister #sysMain .sysForm:has(input[value="戻る"]) {
  padding: 0;
  border-radius: 0;
  background: none;
}
.sysMemberRegister #sysMain .point-present {
  position: relative;
  margin: 0 0 80px;
  padding: 16px;
  font-size: 24px;
  font-weight: 500;
  text-align: center;
  z-index: 0;
}
.sysMemberRegister #sysMain .point-present:before {
  content: "";
  position: absolute;
  top: 0;
  right: -100vw;
  bottom: 0;
  left: -100vw;
  background: #f3f0eb;
  z-index: -1;
}
.sysMemberRegister #sysMain .regist-line {
  margin: 0 0 80px;
  text-align: center;
}
.sysMemberRegister #sysMain .regist-line-label {
  margin: 0 0 32px;
  font-size: 18px;
  font-weight: 700;
}
.sysMemberRegister #sysMain .regist-line-btn a {
  display: block;
  width: 470px;
  margin: 0 auto;
  padding: 19px;
  border-radius: 5px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  background: #07b53b;
}
.sysMemberRegister .sysZipcode {
  overflow: hidden;
}
.sysMemberRegister .sysZipcode .sysFormField {
  float: left;
  width: 160px;
}
.sysMemberRegister .sysZipcode button {
  width: auto;
  margin: 0 0 0 16px;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.sysMemberRegister .sysFormField + .sysFormLabel {
  margin-top: 32px;
}
.sysMemberRegister .sysFormCaution {
  margin-top: 8px;
}
.sysMemberRegister .sysFormCaution li {
  list-style: none;
}
.sysMemberRegister .sysBirthday .sysFormField {
  display: flex;
  align-items: center;
  gap: 0 8px;
}
.sysMemberRegister .sysBirthday .sysFormField input[type="text"] {
  width: auto;
}
.sysMemberRegister .sysGender ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0 24px;
}
.sysMemberRegister .sysMemberAgreement {
  height: 200px;
  overflow: auto;
  margin: 0 0 16px;
  padding: 24px;
  border: 1px solid #e5e5e5;
  background: #fff;
}
.sysMemberRegister input[value="戻る"] {
  display: block;
  width: 130px;
  min-width: auto;
  height: 50px;
  line-height: 1;
  margin: 32px 0 0;
  border: 1px solid #583c32;
  border-radius: 4px;
  font-size: 12px;
  background: #fff;
}
.sysMemberRegister .sysFormField label {
  display: inline-block;
}
.sysMemberRegister .sysFormField label:has(input[type="checkbox"]) {
  margin: 0;
}
.sysCategoryPankuzu,
.sysItemCategoryPankuzu,
.staticPankuzu {
  margin: 0 0 32px;
}
#sysItemDetail .sysCategoryPankuzu {
  margin: 80px 0;
}
.sysCategoryPankuzu .sysPankuzuRow,
.sysItemCategoryPankuzu .sysPankuzuRow,
.staticPankuzu .sysPankuzuRow {
  margin: 0 0 8px;
}
.sysCategoryPankuzu .sysPankuzuUrl,
.sysItemCategoryPankuzu .sysPankuzuUrl,
.staticPankuzu .sysPankuzuUrl {
  display: inline-block;
  font-size: 12px;
  text-decoration: none;
}
.sysCategoryPankuzu .sysPankuzuUrl + .sysPankuzuUrl:before,
.sysItemCategoryPankuzu .sysPankuzuUrl + .sysPankuzuUrl:before,
.staticPankuzu .sysPankuzuUrl + .sysPankuzuUrl:before {
  content: "";
  display: inline-block;
  width: 8px;
  height: 8px;
  vertical-align: top;
  margin: 5px 16px 0;
  border-top: 2px solid #3c2609;
  border-right: 2px solid #3c2609;
  transform: rotate(45deg);
}
.sysCategoryPankuzu .sysPankuzuUrl:last-child,
.sysItemCategoryPankuzu .sysPankuzuUrl:last-child,
.staticPankuzu .sysPankuzuUrl:last-child {
  font-weight: 700;
}
.btn-01 {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 0 16px;
  min-width: 234px;
  padding: 19px 24px 19px 32px;
  border: 1px solid #171717;
  border-radius: 40px;
  color: #171717;
  text-decoration: none;
  background: #fff;
}
.btn-01:after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transition: 0.3s;
}
@media (hover: hover) {
  .btn-01:hover {
    color: #fff;
    background: #171717;
    opacity: 1;
  }
  .btn-01:hover:after {
    background: #fff;
  }
}
.btn-back {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 0 16px;
  min-width: 234px;
  padding: 19px 32px 19px 24px;
  border: 1px solid #171717;
  border-radius: 40px;
  color: #171717;
  text-decoration: none;
  background: #fff;
}
.btn-back:before {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transition: 0.3s;
  transform: rotate(180deg);
}
@media (hover: hover) {
  .btn-back:hover {
    color: #fff;
    background: #171717;
    opacity: 1;
  }
  .btn-back:hover:before {
    background: #fff;
  }
}
.btn-pdf {
  display: inline-block;
  padding: 14px 24px;
  border: 1px solid #171717;
  border-radius: 40px;
  color: #171717;
  text-decoration: none;
  background: #fff;
}
.btn-pdf:after {
  content: "";
  display: inline-block;
  width: 24px;
  height: 13px;
  vertical-align: top;
  margin: 4px 0 0 8px;
  background: url("/img/common/icon_pdf.svg") no-repeat 0 0/100% 100%;
}
@media (hover: hover) {
  .btn-pdf:hover {
    color: #fff;
    background: #171717;
    opacity: 1;
  }
}
body.sysMypage div#sysAside {
  display: none;
}
body.sysMypage div#sysMain {
  width: auto;
  max-width: 900px;
  margin: 0 auto 80px;
  padding: 0 !important;
  border: none;
  font-size: inherit;
}
body.sysMypage div#sysMain a {
  color: inherit;
}
body.sysMypage div#sysMain .sysHeadline {
  margin: 0 0 48px;
  color: #3c2609;
  font-size: 24px;
  font-family: inherit;
  text-align: center;
}
body.sysMypage div#sysMain .sysHeadline span {
  display: block;
  font-size: 15px;
  font-weight: 500;
  font-family: "Roboto", sans-serif;
}
body.sysMypage div#sysMain > .sysMypageMajorHeadLine,
body.sysMypage div#sysMain > .sysMypageMinorHeadLine {
  display: none;
}
body.sysMypage .sysLoginForm {
  display: flex;
  gap: 0 24px;
  padding: 40px;
  border-radius: 5px;
  background: #f3f0eb;
}
body.sysMypage .sysLoginFormLogin {
  flex: 1;
}
body.sysMypage .sysLoginFormLogin .sysFormItem + .sysFormItem {
  margin: 16px 0 0;
}
body.sysMypage .sysLoginFormLogin .sysFormLabel {
  display: block;
  margin: 0 0 8px;
}
body.sysMypage .sysLoginFormLogin .sysFormField input[type="email"],
body.sysMypage .sysLoginFormLogin .sysFormField input[type="password"] {
  width: 100%;
  margin: 0;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
body.sysMypage .sysLoginFormLogin .sysIsUseAutoLogin label {
  position: relative;
  width: fit-content;
  margin: 0 0 24px;
  padding: 0 0 0 24px;
}
body.sysMypage .sysLoginFormLogin .sysIsUseAutoLogin label:before {
  content: "";
  position: absolute;
  top: 3px;
  left: 0;
  width: 16px;
  height: 16px;
  border: 1px solid #e5e5e5;
  border-radius: 2px;
  background: #fff;
}
body.sysMypage .sysLoginFormLogin .sysIsUseAutoLogin input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}
body.sysMypage .sysLoginFormLogin .sysIsUseAutoLogin input[type="checkbox"]:checked + label:before {
  border-color: #171717;
  background: #171717;
}
body.sysMypage .sysLoginFormLogin .sysIsUseAutoLogin input[type="checkbox"]:checked + label:after {
  content: "";
  position: absolute;
  top: 5px;
  left: 5px;
  width: 6px;
  height: 9px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
body.sysMypage .sysLoginFormLogin .sysLoginButton {
  width: 300px;
  height: 65px;
  margin: 16px auto 0;
  padding: 0;
  border: none;
  border-radius: 40px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  background: #3c2609;
}
body.sysMypage .sysLoginFormLogin input[value="パスワードをお忘れの方はこちら"] {
  width: 100%;
  min-width: auto;
  height: auto;
  margin: 0;
  border: none;
  color: #3c2609;
  font-size: 18px;
  text-decoration: underline;
  white-space: inherit;
  background: none;
}
body.sysMypage .mypage-login-reminder {
  margin: 24px 0;
}
body.sysMypage .mypage-registration-area {
  flex: 1;
}
body.sysMypage .mypage-login-label,
body.sysMypage .mypage-registration-label,
body.sysMypage .sysFormAmazonLoginLabel {
  margin: 0 0 16px;
  padding: 0 0 16px;
  border-bottom: 1px solid #3c2609;
  color: #3c2609;
  font-size: 18px;
  font-weight: 700;
}
body.sysMypage .mypage-login-txt,
body.sysMypage .mypage-registration-txt {
  margin: 0 0 24px;
}
body.sysMypage .mypage-registration-btn1 {
  margin: 0 0 16px;
}
body.sysMypage .mypage-registration-btn1 a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 300px;
  height: 65px;
  margin: 0 auto;
  border-radius: 40px;
  color: #fff !important;
  font-size: 18px;
  font-weight: 700;
  text-decoration: none;
  background: #ff8400;
}
body.sysMypage .mypage-registration-btn2 a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 300px;
  height: 65px;
  margin: 0 auto;
  border: 1px solid #3c2609;
  border-radius: 40px;
  text-decoration: none;
  background: #fff;
}
body.sysMypage .sysAmazonLogin {
  margin: 40px 0 0;
}
body.sysMypage .sysFormAmazonLoginNotice {
  margin: 0 0 16px;
}
body.sysMypage .sysAmazonLoginButton {
  margin: 0;
}
.mypage-wrap {
  padding: 40px 48px;
  border-radius: 5px;
  background: #f3f0eb;
}
.mypage-wrap .sysMypageMinorHeadLine {
  margin: 0 0 16px;
  padding: 0 0 8px;
  border-bottom: 1px solid #3c2609;
  color: #3c2609;
  font-size: 18px;
  font-weight: 700;
}
.mypage-wrap .sysOrderList {
  margin: 16px 0 24px;
  padding: 24px;
  border: none;
  background: #fff;
}
.mypage-wrap .sysOrderList .sysOrders + .sysOrders {
  margin: 24px 0 0;
}
.sysMypageNav {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 24px;
}
.sysMypageNav > form input[type="submit"] {
  width: 100%;
  padding: 16px;
  border: none;
  border-radius: 5px;
  color: #fff;
  background: #3c2609;
}
.sysMypageNav > form input[type="submit"][value="ログアウトする"] {
  background: #838282;
}
.sysMypage .sysForm {
  padding: 48px;
  border-radius: 5px;
  background: #f3f0eb;
}
.sysMypage .sysFormItem {
  margin: 0 0 32px;
}
.sysMypage .sysFormLabel {
  display: block;
  position: relative;
  margin: 0 0 8px;
  padding: 0 0 0 16px;
  font-weight: 600;
}
.sysMypage .sysFormLabel:before {
  content: "";
  position: absolute;
  top: 8px;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background: #3c2609;
}
.sysMypage .sysFormLabel .sysRequired {
  line-height: 1;
  vertical-align: top;
  margin: 2px 0 0 8px;
  padding: 4px 8px;
  border-radius: 3px;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  background: #ba0402;
}
.sysMypage .sysFormLabel .sysRequired:before,
.sysMypage .sysFormLabel .sysRequired:after {
  content: none;
}
.sysMypage .sysFormField input[type="text"],
.sysMypage .sysFormField input[type="email"],
.sysMypage .sysFormField input[type="tel"],
.sysMypage .sysFormField input[type="password"] {
  width: 100%;
  margin: 0;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.sysMypage .sysFormField select {
  appearance: auto;
  margin: 0;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.sysMypage .sysZipcode {
  overflow: hidden;
}
.sysMypage .sysZipcode input[name="zipcode"] {
  float: left;
  width: 160px;
}
.sysMypage .sysZipcode button[name="searchAddress"] {
  width: 120px;
  margin: 0 0 0 16px;
  padding: 14px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.sysMypage .sysBirthday .sysFormField {
  display: flex;
  align-items: center;
  gap: 0 8px;
}
.sysMypage .sysBirthday .sysFormField input[type="text"] {
  width: auto;
}
.sysMypage .sysMemberPassword .sysMemberPasswordDescription {
  margin: 0 0 16px;
}
.sysMypage .sysMemberPassword .sysFormField {
  margin: 0 0 32px;
}
.sysMypage .sysMemberPassword .sysFormCaution {
  margin: 8px 0 0;
}
.sysMypage .sysMemberPassword .sysPasswordCaution li {
  list-style: none;
}
.sysMypage .sysGender .sysFormField label {
  display: inline-block;
  position: relative;
  margin: 0 16px 0 0;
  padding: 0 0 0 28px;
}
.sysMypage .sysGender .sysFormField label:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 20px;
  height: 20px;
  border: 1px solid #3c2609;
  border-radius: 100%;
  background: #fff;
  transform: translateY(-50%);
}
.sysMypage .sysGender .sysFormField label:has(input:checked):after {
  content: "";
  position: absolute;
  top: 50%;
  left: 6px;
  width: 8px;
  height: 8px;
  border-radius: 100%;
  background: #3c2609;
  transform: translateY(-50%);
}
.sysMypage .sysGender .sysFormField label input[type="radio"] {
  position: absolute;
  z-index: -1;
  opacity: 0;
}
.sysMypage .sysAcceptMailmagazine .sysFormField label {
  position: relative;
  width: fit-content;
  margin: 0 0 24px;
  padding: 0 0 0 24px;
}
.sysMypage .sysAcceptMailmagazine .sysFormField label:before {
  content: "";
  position: absolute;
  top: 3px;
  left: 0;
  width: 16px;
  height: 16px;
  border: 1px solid #e5e5e5;
  border-radius: 2px;
  background: #fff;
}
.sysMypage .sysAcceptMailmagazine .sysFormField input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}
.sysMypage .sysAcceptMailmagazine .sysFormField label:has(:checked):before {
  border-color: #171717;
  background: #171717;
}
.sysMypage .sysAcceptMailmagazine .sysFormField label:has(:checked):after {
  content: "";
  position: absolute;
  top: 5px;
  left: 5px;
  width: 6px;
  height: 9px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.sysMypage input[value="戻る"] {
  display: block;
  width: 130px;
  min-width: auto;
  height: 50px;
  line-height: 1;
  margin: 32px 0 0;
  border: 1px solid #583c32;
  border-radius: 4px;
  font-size: 12px;
  background: #fff;
}
.sysMypage .sysNextSubmit {
  display: block;
  width: 470px;
  margin: 0 auto;
  padding: 16px;
  border: none;
  border-radius: 4px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  background: #ff8400;
}
.sysMypage .sysSelectAddress {
  margin: 0 0 24px;
}
.sysMypage .sysSelectAddress button {
  position: relative;
  padding: 16px 48px 16px 16px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  background: #fff;
}
.sysMypage .sysSelectAddress button:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 24px;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: translateY(-50%);
}
.sysMypage .sysItemListDisp {
  display: none;
}
.sysMypage .sysItemList {
  margin: 0 0 40px;
}
.sysMypage .sysItemList ul.sysList li .sysItemLink .sysCartButton {
  display: none;
}
.sysMypage label:has([name="deleted_flag"]) {
  display: block;
  position: relative;
  width: fit-content;
  margin: 24px 0;
  padding: 0 0 0 24px;
}
.sysMypage label:has([name="deleted_flag"]):before {
  content: "";
  position: absolute;
  top: 3px;
  left: 0;
  width: 16px;
  height: 16px;
  border: 1px solid #e5e5e5;
  border-radius: 2px;
  background: #fff;
}
.sysMypage input[type="checkbox"] {
  position: absolute;
  opacity: 0;
}
.sysMypage label:has([name="deleted_flag"]:checked):before {
  border-color: #171717;
  background: #171717;
}
.sysMypage label:has([name="deleted_flag"]:checked):after {
  content: "";
  position: absolute;
  top: 5px;
  left: 5px;
  width: 6px;
  height: 9px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}
.sysMypage input[value="お気に入りから削除する"] {
  display: block;
  width: 100%;
  margin: 24px 0 0;
  padding: 14px;
  border: none;
  border-radius: 5px;
  background: #f3f0ec;
}
.sysMypage .sysSPTable {
  width: 100%;
  margin: 24px 0;
}
.sysMypage .sysSPTable th {
  text-align: left;
}
.sysMypage .sysWithdrawal {
  text-align: center;
}
.sysMypage .sysWithdrawal form {
  margin: 24px 0;
}
.sysMypage .sysWithdrawal form .sysButton {
  display: block;
  max-width: 400px;
  margin: 0 auto;
  padding: 14px;
  border: none;
  border-radius: 5px;
}
.sysMypage .sysWithdrawal form .sysButton[value="退会する"] {
  background: #f3f0ec;
}
.sysMypage .sysWithdrawal form .sysButton[value="退会しない"] {
  color: #fff;
  background: #ff8400;
}
body#sysMypageWithdrawalConfirm .sysWithdrawal >p:nth-child(2) {
    display: none;
}
.news_all ul li a {
  display: flex;
  align-items: flex-start;
  gap: 0 24px;
  position: relative;
  padding: 23px 48px 23px 20px;
  border-radius: 5px;
  font-weight: 700;
  text-decoration: none;
}
.news_all ul li a time {
  flex-shrink: 0;
  display: block;
  padding: 1px 0 0;
  font-size: 12px;
  font-weight: 400;
}
.news_all ul li a span {
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  text-decoration-color: rgba(23,23,23,0);
  transition: text-decoration-color 0.3s ease;
}
.news_all ul li a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 24px;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: translateY(-50%);
}
@media (hover: hover) {
  .news_all ul li a:hover {
    opacity: 1;
  }
  .news_all ul li a:hover span {
    text-decoration-color: currentColor;
  }
}
.news_all ul li:nth-child(2n-1) a {
  background: #f3f0ec;
}
.topics-detail-pankuzu,
.topics-detail-ttl,
.topics-detail-btn {
  display: none;
}
.topics-detail-btn {
  margin: 40px 0 0;
  text-align: center;
}
.page-nav {
  margin: 0 0 40px;
}
.page-nav ul {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
.page-nav ul li a {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  padding: 14px 24px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  text-decoration: none;
}
.page-nav ul li a:after {
  content: "";
  display: block;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: rotate(90deg);
}
.static-page h1,
#sysInformation .topics-detail-ttl {
  position: relative;
  margin: 0 0 32px;
  padding: 0 0 8px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 24px;
}
.static-page h1:after,
#sysInformation .topics-detail-ttl:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 96px;
  height: 1px;
  background: #171717;
}
.static-page h2,
.sysNewsDetail h2 {
  margin: 80px 0 40px;
  font-size: 18px;
  font-weight: 700;
}
.static-page h2:first-child,
.sysNewsDetail h2:first-child {
  margin-top: 0;
}
.static-page h2:after,
.sysNewsDetail h2:after {
  content: "";
  display: block;
  width: 20px;
  height: 1px;
  margin: 32px 0 0;
  background: #171717;
}
.static-page h1 + h2,
.sysNewsDetail h1 + h2 {
  margin-top: 0;
}
.static-page h3,
.sysNewsDetail h3 {
  margin: 40px 0 24px;
  padding: 8px 16px;
  border-radius: 4px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  background: #3c2609;
}
.static-page p,
.sysNewsDetail p {
  margin: 0 0 1.5em;
}
.static-page p:last-child,
.sysNewsDetail p:last-child {
  margin: 0;
}
.static-page .note,
.sysNewsDetail .note {
  margin: 0 0 1.5em;
}
.static-page .note:last-child,
.sysNewsDetail .note:last-child {
  margin: 0;
}
.static-page .note li,
.sysNewsDetail .note li {
  position: relative;
  padding-left: 1em;
  font-size: 12px;
}
.static-page .note li:before,
.sysNewsDetail .note li:before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.static-page .attention,
.sysNewsDetail .attention {
  color: #ba0402;
}
.static-page .table-01,
.sysNewsDetail .table-01 {
  width: 100%;
  margin: 0 0 1.5em;
  border-top: 1px solid #e5e5e5;
}
.static-page .table-01:last-child,
.sysNewsDetail .table-01:last-child {
  margin: 0;
}
.static-page .table-01 th,
.sysNewsDetail .table-01 th {
  position: relative;
  width: 176px;
  vertical-align: middle;
  padding: 16px;
  border-bottom: 1px solid #e5e5e5;
  text-align: left;
}
.static-page .table-01 th:before,
.sysNewsDetail .table-01 th:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background: #3c2609;
  transform: translateY(-50%);
}
.static-page .table-01 td,
.sysNewsDetail .table-01 td {
  padding: 16px 0;
  border-bottom: 1px solid #e5e5e5;
}
.static-page .table-02,
.sysNewsDetail .table-02 {
  width: 100%;
  margin: 0 0 1.5em;
  border: 1px solid #e5e5e5;
  table-layout: fixed;
}
.static-page .table-02:last-child,
.sysNewsDetail .table-02:last-child {
  margin: 0;
}
.static-page .table-02 th,
.sysNewsDetail .table-02 th {
  padding: 16px;
  border: 1px solid #e5e5e5;
  text-align: center;
  background: #f7f7f7;
}
.static-page .table-02 th span,
.sysNewsDetail .table-02 th span {
  display: inline-block;
  margin-left: 1em;
  font-size: 12px;
  font-weight: 400;
}
.static-page .table-02 td,
.sysNewsDetail .table-02 td {
  vertical-align: top;
  padding: 16px;
  border: 1px solid #e5e5e5;
}
.static-page ul.list,
.sysNewsDetail ul.list {
  margin: 0 0 1.5em;
}
.static-page ul.list:last-child,
.sysNewsDetail ul.list:last-child {
  margin: 0;
}
.static-page ul.list li,
.sysNewsDetail ul.list li {
  position: relative;
  padding-left: 1em;
}
.static-page ul.list li + li,
.sysNewsDetail ul.list li + li {
  margin-top: 4px;
}
.static-page ul.list li:before,
.sysNewsDetail ul.list li:before {
  content: "・";
  position: absolute;
  top: 0;
  left: 0;
}
.static-page ol.list,
.sysNewsDetail ol.list {
  counter-reset: num;
  margin: 0 0 1.5em;
}
.static-page ol.list:last-child,
.sysNewsDetail ol.list:last-child {
  margin: 0;
}
.static-page ol.list li,
.sysNewsDetail ol.list li {
  position: relative;
  padding-left: 1.5em;
}
.static-page ol.list li + li,
.sysNewsDetail ol.list li + li {
  margin-top: 4px;
}
.static-page ol.list li:before,
.sysNewsDetail ol.list li:before {
  counter-increment: num;
  content: counter(num) ".";
  position: absolute;
  top: 0;
  left: 0;
}
.faq-item {
  overflow: hidden;
  border-bottom: 1px dashed #b3b3b3;
  interpolate-size: allow-keywords;
}
.faq-item::details-content {
  block-size: 0;
  transition: block-size 0.3s, content-visibility 0.3s;
  transition-behavior: allow-discrete;
}
.faq-item-q {
  position: relative;
  padding: 20px 20px 20px 48px;
  font-weight: 700;
  cursor: pointer;
}
.faq-item-q:before {
  content: "Q";
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 15px;
  left: 0;
  width: 30px;
  height: 30px;
  line-height: 1;
  border-radius: 3px;
  font-size: 12px;
  background: #f3f0ec;
}
.faq-item-q:after {
  content: "";
  position: absolute;
  top: 23px;
  right: 2px;
  width: 8px;
  height: 8px;
  border-right: 1px solid #171717;
  border-bottom: 1px solid #171717;
  transform: rotate(45deg);
  transition: 0.3s;
}
.faq-item[open] {
  padding: 0 0 20px;
}
.faq-item[open]::details-content {
  block-size: auto;
}
.faq-item[open] .faq-item-q:after {
  top: 28px;
  transform: rotate(-135deg);
}
.faq-item-a {
  position: relative;
  padding: 20px 20px 20px 64px;
  background: #fbf2f2;
}
.faq-item-a:before {
  content: "A";
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 20px;
  left: 20px;
  width: 30px;
  height: 30px;
  line-height: 1;
  border-radius: 3px;
  color: #fff;
  font-size: 12px;
  background: #ba0402;
}
.sysFuncBanner.feature .sysContent ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px 20px;
  margin: 0 0 32px;
}
.sysFuncBanner.feature .sysContent ul li {
  margin: 0;
}
.sysFuncBanner.feature .sysContent ul li a {
  display: block;
  text-decoration: none;
}
.sysFuncBanner.feature .sysContent ul li a img {
  display: block;
  margin: 0 0 8px;
}
.sysFuncBanner.feature .sysContent ul li a span {
  font-size: 12px;
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  text-decoration-color: rgba(23,23,23,0);
  transition: text-decoration-color 0.3s ease;
}
@media (hover: hover) {
  .sysFuncBanner.feature .sysContent ul li a:hover {
    opacity: 1;
  }
  .sysFuncBanner.feature .sysContent ul li a:hover span {
    text-decoration-color: currentColor;
  }
}
.feature-kv {
  margin: 0 0 30px;
}
.feature-product {
  display: flex;
  align-items: flex-start;
  gap: 0 30px;
}
.feature-product + .feature-product {
  margin: 80px 0 0;
  padding: 80px 0 0;
  border-top: 1px solid #e5e5e5;
}
.feature-product-img {
  width: 300px;
  overflow: hidden;
  border-radius: 10px;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.feature-product-data {
  flex: 1;
}
.feature-product-data .rating-coffee {
  margin: 32px 0 0;
}
.feature-product-name {
  margin: 0 0 16px;
  font-size: 24px;
  font-weight: 700;
}
.feature-product-price {
  float: left;
  margin: 40px 0 0;
  color: #ba0402;
}
.feature-product-price span {
  display: inline-block;
  line-height: 1;
  margin: 0 4px 0 0;
  font-size: 35px;
  font-weight: 700;
  font-family: "Roboto", sans-serif;
  transform: translateY(2px);
}
.feature-product-btn {
  margin: 32px 0 0;
  text-align: right;
}
.decaffeinated-points {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin: 0 0 56px;
  padding: 30px 20px;
  border-radius: 5px;
  background: #f3f0ec;
}
.decaffeinated-point {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 24px 0;
  padding: 30px;
  border-radius: 5px;
  font-weight: 700;
  text-align: center;
  background: #fff;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.decaffeinated-steps {
  margin: 0 0 80px;
  padding: 0 0 80px 40px;
  border-bottom: 1px solid #e5e5e5;
}
.decaffeinated-step {
  position: relative;
  margin: 0 0 20px;
  padding: 30px 176px 30px 30px;
  border-radius: 10px;
  background: #f3f0ec;
}
.decaffeinated-step:before {
  content: "";
  position: absolute;
  top: 34px;
  bottom: -50px;
  left: -36px;
  width: 36px;
  border-top: 1px solid #e5e5e5;
  border-left: 1px solid #e5e5e5;
}
.decaffeinated-step:after {
  content: "";
  position: absolute;
  top: 30px;
  left: -40px;
  width: 9px;
  height: 9px;
  border-radius: 100%;
  background: #3c2609;
}
.decaffeinated-step span {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 55px;
  height: 31px;
  line-height: 1;
  margin: 0 0 16px;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  background: #3c2609;
}
.decaffeinated-step img {
  position: absolute;
  top: 50%;
  right: 30px;
  transform: translateY(-50%);
}
.decaffeinated-step:last-child {
  margin: 0;
}
.decaffeinated-step:last-child:before {
  bottom: auto;
  border-left: none;
}
.stick-list .sysItemName {
  font-size: inherit !important;
}
.reason-kv {
  margin: 0 0 32px;
}
.reason-kv img {
  border-radius: 5px;
}
.reason-lead {
  margin: 0 0 80px;
  padding: 0 0 48px;
  border-bottom: 1px solid #e5e5e5;
}
.reason-point {
  display: flex;
  align-items: center;
  gap: 0 48px;
  flex-wrap: wrap;
}
.reason-point + .reason-point {
  margin: 80px 0 0;
}
.reason-point-img {
  position: relative;
  width: 340px;
  overflow: hidden;
  border-radius: 0 5px 5px 5px;
}
.reason-point-num {
  position: absolute;
  top: 0;
  left: 0;
  width: 60px;
  height: 60px;
  line-height: 1;
  padding: 8px 0 0;
  font-size: 16px;
  font-weight: 100;
  font-family: "Roboto", sans-serif;
  background: url("/img/reason/img_09.png") no-repeat 0 0/100% 100%;
}
.reason-point-num span {
  display: inline-block;
  margin: 0 0 0 4px;
  font-size: 24px;
}
.reason-point-content {
  flex: 1;
}
.reason-point-quality {
  width: 100%;
}
.reason-point-02,
.reason-point-04 {
  flex-direction: row-reverse;
}
.reason-point-02 .reason-point-img,
.reason-point-04 .reason-point-img {
  border-radius: 5px 0 5px 5px;
}
.reason-point-02 .reason-point-num,
.reason-point-04 .reason-point-num {
  right: 0;
  left: auto;
  text-align: right;
  background-image: url("/img/reason/img_10.png");
}
.reason-point-quality {
  margin: 32px 0 0;
  padding: 20px;
  border-radius: 5px;
  background: #f3f0ec;
}
.reason-point-quality-ttl {
  margin: 0 0 16px;
  font-size: 18px;
  font-weight: 700;
}
.reason-point-quality-ttl:before {
  content: "";
  display: inline-block;
  width: 13px;
  height: 13px;
  vertical-align: top;
  margin: 7px 8px 0 0;
  mask: url("/img/common/icon_bean_01.svg") no-repeat 0 0/100% 100%;
  background: #8b540e;
}
.reason-point-quality-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
.reason-point-quality-item span {
  display: block;
  margin: 8px 0 0;
  font-size: 12px;
}
.original-kv {
  margin: 0 0 32px;
}
.original-kv img {
  border-radius: 5px;
}
.original-lead {
  margin: 0 0 40px;
}
.original-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 11px;
  margin: 0 0 80px;
  padding: 30px 20px;
  border-radius: 5px;
  background: #f3f0ec;
}
.original-features-item {
  padding: 0 16px 16px;
  border-radius: 5px;
  text-align: center;
  background: #fff;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.original-features-item img {
  display: block;
  margin: -10px auto 16px;
}
.original-features-item span {
  color: #ba0402;
  font-weight: 700;
}
.original-dripbags {
  display: flex;
  align-items: flex-start;
  gap: 80px 40px;
  flex-wrap: wrap;
  margin: 0 0 80px;
}
.original-dripbags-main {
  flex: 1;
}
.original-dripbags-img {
  width: 211px;
}
.original-dripbags-point {
  width: 100%;
  overflow: hidden;
  padding: 0 0 24px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
}
.original-dripbags-point h3.original-dripbags-point-ttl {
  margin: 0;
  border-radius: 0;
  font-size: inherit;
  text-align: center;
}
.original-dripbags-point-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.original-dripbags-point-item {
  padding: 32px 0;
  text-align: center;
}
.original-dripbags-point-item + .original-dripbags-point-item {
  border-left: 1px dashed #cdcdcd;
}
.original-dripbags-point-item img {
  display: block;
  margin: 0 auto 16px;
}
.original-dripbags-point-item span {
  color: #ba0402;
  font-weight: 700;
}
.original-dripbags-point-up {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 16px;
  margin: 0 20px;
  padding: 12px;
  border-radius: 5px;
  color: #fff;
  font-size: 18px;
  font-weight: 700;
  text-align: center;
  background: #ba0402;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.original-dripbags-point-up:before {
  content: "";
  display: block;
  width: 25px;
  height: 15px;
  background: url("/img/original/img_09.png") no-repeat 0 0/100% 100%;
}
.original-flow {
  padding: 0 0 0 40px;
}
.original-flow-item {
  display: flex;
  align-items: center;
  gap: 0 24px;
  position: relative;
  margin: 0 0 20px;
  padding: 30px;
  border-radius: 10px;
  background: #f3f0ec;
}
.original-flow-item:before {
  content: "";
  position: absolute;
  top: 34px;
  bottom: -50px;
  left: -36px;
  width: 36px;
  border-top: 1px solid #e5e5e5;
  border-left: 1px solid #e5e5e5;
}
.original-flow-item:after {
  content: "";
  position: absolute;
  top: 30px;
  left: -40px;
  width: 9px;
  height: 9px;
  border-radius: 100%;
  background: #3c2609;
}
.original-flow-item:last-child {
  margin: 0;
}
.original-flow-item:last-child:before {
  bottom: auto;
  border-left: none;
}
.original-flow-item-main {
  flex: 1;
}
.original-flow-item-ttl {
  margin: 0 0 16px;
  font-weight: 700;
}
.original-flow-item-ttl span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 55px;
  height: 31px;
  line-height: 1;
  margin: 0 16px 0 0;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  background: #3c2609;
}
.original-flow-item-img {
  width: 180px;
}
.original-flow-notes {
  position: relative;
  margin: 16px 0 0;
  padding: 0 0 0 1em;
}
.original-flow-notes:before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.original-flow-notes span {
  color: #ba0402;
}
.original-examples {
  position: relative;
  margin: 0 0 64px;
  padding: 0 20px;
  border-radius: 5px;
  background: #f3f0ec;
}
.original-examples-slides {
  overflow: hidden;
  padding: 30px 0;
}
.original-examples-item {
  position: relative;
  height: auto;
  padding: 24px 0;
  border-radius: 5px;
  background: #fff;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.original-examples-item-label {
  position: absolute;
  top: 0;
  left: 50%;
  line-height: 1;
  padding: 6px 12px;
  border-radius: 3px;
  color: #fff;
  font-size: 10px;
  background: #3c2609;
  transform: translate(-50%, -50%);
}
.original-examples-item-img {
  margin: 0 0 16px;
  text-align: center;
}
.original-examples-item-ttl {
  margin: 0 0 16px;
  text-align: center;
}
.original-examples-item-tbl {
  overflow: hidden;
  margin: 0 24px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
  font-size: 12px;
}
.original-examples-item-tbl table {
  width: 100%;
}
.original-examples-item-tbl th {
  padding: 8px;
  border-right: 1px solid #e5e5e5;
  background: #f7f7f7;
}
.original-examples-item-tbl td {
  padding: 8px;
}
.original-examples-item-tbl tr + tr td {
  border-top: 1px solid #e5e5e5;
}
.original-examples .swiper-button-next,
.original-examples .swiper-button-prev {
  top: 50%;
  width: 56px;
  height: 56px;
  margin: 0;
  border-radius: 100%;
  background: #fff;
  box-shadow: 0px 0px 4px 0px rgba(0,0,0,0.149);
}
.original-examples .swiper-button-next svg,
.original-examples .swiper-button-prev svg {
  width: 16px;
  height: 16px;
  color: #171717;
}
.original-examples .swiper-button-next {
  right: 0;
  transform: translate(50%, -50%);
}
.original-examples .swiper-button-prev {
  left: 0;
  transform: translate(-50%, -50%);
}
.original-examples .swiper-pagination {
  display: flex;
  justify-content: center;
  gap: 0 10px;
  top: auto;
  right: 0;
  bottom: -24px;
  left: 0;
  line-height: 1;
  transform: none;
  transition: none;
}
.original-examples .swiper-pagination .swiper-pagination-bullet {
  display: block;
  width: 5px;
  height: 5px;
  margin: 0;
  background: #d9d9d9;
  transition: 0.3s;
  opacity: 1;
}
.original-examples .swiper-pagination .swiper-pagination-bullet-active {
  background: #171717;
}
.original-examples-btns {
  display: flex;
  gap: 40px;
}
.original-examples-btns .btn-01 {
  flex: auto;
}
.original-contact a[href^="tel:"] {
  display: inline-block;
  font-size: 20px;
  font-weight: 700;
  text-decoration: none;
}
.original-contact a[href^="tel:"]:before {
  content: "";
  display: inline-block;
  width: 14px;
  height: 14px;
  vertical-align: top;
  margin: 9px 8px 0 0;
  background: url("/img/common/icon_tel.svg") no-repeat 0 0/100% 100%;
}
.original-formbtn {
  margin: 32px 0 80px;
}
.liquid-kv {
  margin: 0 0 32px;
}
.liquid-kv img {
  border-radius: 5px;
}
.liquid-jas img {
  float: right;
  margin: 0 0 0 32px;
}
.liquid-needs {
  margin: 40px 0 80px;
  overflow: hidden;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
}
h2.liquid-needs-ttl {
  margin: 0;
  padding: 12px;
  color: #fff;
  font-size: inherit;
  font-weight: 700;
  text-align: center;
  background: #3c2609;
}
h2.liquid-needs-ttl:after {
  content: none;
}
.liquid-needs-inner {
  display: flex;
  gap: 0 64px;
  position: relative;
  padding: 32px;
}
.liquid-needs-inner:before {
  content: "";
  position: absolute;
  top: 32px;
  bottom: 32px;
  left: 50%;
  border-left: 1px dashed #3c2609;
}
.liquid-needs-list {
  flex: 1;
}
.liquid-needs-item {
  position: relative;
  padding: 0 0 0 32px;
}
.liquid-needs-item:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 20px;
  height: 20px;
  background: url("/img/liquid/img_03.png") no-repeat 0 0/100% 100%;
}
.liquid-needs-item + .liquid-needs-item {
  margin: 16px 0 0;
}
.liquid-needs-item b {
  color: #ba0402;
}
.liquid-points {
  position: relative;
}
.liquid-points:before {
  content: "";
  position: absolute;
  top: 0;
  right: 24px;
  width: 163px;
  height: 148px;
  background: url("/img/liquid/img_04.png") no-repeat 0 0/100% 100%;
  z-index: 10;
}
h2.liquid-points-ttl {
  margin: 0 0 24px;
  font-size: 24px;
}
h2.liquid-points-ttl:after {
  content: none;
}
h2.liquid-points-ttl span {
  display: block;
  width: fit-content;
  margin: 0 0 8px;
  padding: 0 0 4px;
  border-bottom: 1px solid #3c2609;
  font-size: 14px;
}
.liquid-points-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  padding: 30px 20px;
  border-radius: 5px;
  background: #f3f0ec;
  letter-spacing: 0.06em;
}
.liquid-point {
  position: relative;
  padding: 20px 30px;
  border-radius: 5px;
  background: #fff;
  z-index: 0;
}
.liquid-point:nth-child(1) {
  grid-column: span 2;
  padding-right: 128px;
}
.liquid-point:nth-child(1) .liquid-point-figure {
  position: absolute;
  top: 30px;
  right: 20px;
  text-align: center;
}
.liquid-point:nth-child(1) .liquid-point-figure figcaption {
  margin: 8px 0 0;
  font-size: 12px;
}
.liquid-point:nth-child(5) .liquid-point-body {
  padding-right: 96px;
}
.liquid-point:nth-child(5) .liquid-point-figure {
  position: absolute;
  top: 50%;
  right: 0;
  z-index: -1;
  transform: translateY(-50%);
}
.liquid-point-head {
  position: relative;
  padding: 8px 0 0 48px;
}
.liquid-point-no {
  position: absolute;
  top: 0;
  left: 0;
  line-height: 1;
  color: #3c2609;
  font-size: 30px;
  font-weight: 200;
  font-family: "Roboto", sans-serif;
  text-align: center;
}
.liquid-point-no span {
  display: block;
  margin: 0 0 4px;
  font-size: 8px;
  font-weight: 700;
}
h3.liquid-point-ttl {
  margin: 0 0 16px;
  padding: 0;
  border-radius: 0;
  color: #3c2609;
  font-size: 18px;
  font-weight: 700;
  background: none;
}
.liquid-point-body b {
  color: #ba0402;
}
.liquid-point-dl {
  display: flex;
  margin: 0 0 16px;
  padding: 16px 0;
  border-top: 1px solid #e5e5e5;
  border-bottom: 1px solid #e5e5e5;
}
.liquid-point-dl dt {
  position: relative;
  width: 120px;
  padding: 0 0 0 16px;
  font-weight: 700;
}
.liquid-point-dl dt:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0;
  width: 6px;
  height: 6px;
  border-radius: 100%;
  background: #8b540e;
  transform: translateY(-50%);
}
.liquid-point-dl dd {
  flex: 1;
}
.liquid-point-note {
  margin: 0;
  font-size: 12px;
}
.gas-kv {
  margin: 0 0 32px;
}
.gas-kv img {
  border-radius: 5px;
}
.gas-lead {
  margin: 0 0 40px;
}
.gas-features {
  margin: 0 0 40px;
}
.gas-features li {
  position: relative;
  padding: 0 0 0 32px;
}
.gas-features li:before {
  content: "";
  position: absolute;
  top: 2px;
  left: 0;
  width: 18px;
  height: 18px;
  background: url("/img/common/icon_check.svg") no-repeat 0 0/100% 100%;
}
.gas-features li + li {
  margin: 16px 0 0;
}
.gas-spec {
  display: flex;
  align-items: flex-start;
  gap: 0 32px;
}
.gas-spec table {
  flex: 1;
}
.gas-spec-img {
  width: 240px;
}
.gas-secret img {
  float: right;
  margin: 0 0 0 40px;
}
.gas-exp {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0 14px;
  margin: 0 0 40px;
  padding: 30px 20px;
  border-radius: 5px;
  background: #f3f0ec;
}
.gas-exp-item {
  padding: 20px 30px 40px;
  border-radius: 5px;
  background: #fff;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.gas-exp-item-img {
  margin: 0 0 16px;
  text-align: center;
}
.gas-exp-item-ttl {
  margin: 0 0 8px;
  font-weight: 700;
  text-align: center;
}
.gas-exp-item-notes {
  position: relative;
  margin: 4px 0 0;
  padding-left: 1em;
  color: #ba0402;
  font-size: 12px;
}
.gas-exp-item-notes:before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.gas-exp-notes {
  padding: 12px 16px;
  border-radius: 4px;
  color: #fff;
  font-weight: 700;
  background: #ba0402;
}
.gas-flow-intro {
  display: flex;
  align-items: flex-start;
  gap: 0 32px;
  margin: 0 0 40px;
}
.gas-flow-intro-img {
  flex-shrink: 0;
  width: 270px;
}
.gas-flow {
  margin: 0 0 40px;
  padding: 0 0 0 40px;
}
.gas-flow-item {
  display: flex;
  align-items: center;
  gap: 0 24px;
  position: relative;
  margin: 0 0 20px;
  padding: 30px;
  border-radius: 10px;
  background: #f3f0ec;
}
.gas-flow-item:before {
  content: "";
  position: absolute;
  top: 34px;
  bottom: -50px;
  left: -36px;
  width: 36px;
  border-top: 1px solid #e5e5e5;
  border-left: 1px solid #e5e5e5;
}
.gas-flow-item:after {
  content: "";
  position: absolute;
  top: 30px;
  left: -40px;
  width: 9px;
  height: 9px;
  border-radius: 100%;
  background: #3c2609;
}
.gas-flow-item:last-child {
  margin: 0;
}
.gas-flow-item:last-child:before {
  bottom: auto;
  border-left: none;
}
.gas-flow-item-main {
  flex: 1;
}
.gas-flow-item-ttl {
  font-weight: 700;
}
.gas-flow-item-ttl span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 55px;
  height: 31px;
  line-height: 1;
  margin: 0 16px 0 0;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  background: #3c2609;
}
.gas-flow-item-txt {
  margin: 16px 0 0;
}
.gas-flow2 .gas-flow-item-main {
  display: flex;
  align-items: center;
}
.gas-flow2 .gas-flow-item-txt {
  margin: 0;
}
.gas-contact {
  text-align: center;
}
.drip-kv {
  margin: 0 0 32px;
}
.drip-point {
  position: relative;
  margin: 40px 0 80px;
  padding: 48px 32px;
  border: 1px solid #ba0402;
  border-radius: 5px;
}
.drip-point li {
  position: relative;
  padding: 0 0 0 32px;
}
.drip-point li:before {
  content: "";
  position: absolute;
  top: 2px;
  left: 0;
  width: 18px;
  height: 18px;
  mask: url("/img/common/icon_check.svg") no-repeat 0 0/100% 100%;
  background: #ba0402;
}
.drip-point li + li {
  margin: 16px 0 0;
}
.drip-point img {
  position: absolute;
  top: 50%;
  right: 40px;
  transform: translateY(-50%);
}
.drip-example {
  margin: 0 0 80px;
  overflow: hidden;
  padding: 0 0 24px;
  border-radius: 5px;
  background: #f3f0ec;
}
.drip-example .label {
  margin: 0 0 24px;
  padding: 12px 16px;
  color: #fff;
  font-weight: 700;
  text-align: center;
  background: #3c2609;
}
.drip-example .img {
  margin: 0 0 24px;
  text-align: center;
}
.drip-example .txt {
  padding: 0 30px;
}
.drip-example .txt li {
  position: relative;
  padding-left: 1em;
}
.drip-example .txt li:before {
  content: "※";
  position: absolute;
  top: 0;
  left: 0;
}
.drip-example .txt li span {
  color: #ba0402;
  font-weight: 700;
}
.drip-tel {
  margin: 0 0 80px;
  padding: 24px;
  border-radius: 5px;
  color: #fff;
  text-align: center;
  background: #3c2609;
}
.drip-tel .label {
  margin: 0 0 8px;
  font-weight: 700;
}
.drip-tel .tel {
  line-height: 1;
}
.drip-tel .tel a {
  font-size: 40px;
  font-weight: 700;
  text-decoration: none;
}
.drip-tel .tel a:before {
  content: "";
  display: inline-block;
  width: 23px;
  height: 23px;
  vertical-align: top;
  margin: 12px 12px 0 0;
  mask: url("/img/common/icon_tel.svg") no-repeat 0 0/100% 100%;
  background: #fff;
}
.drip-tel .hours {
  margin: 8px 0 0;
  font-size: 10px;
  font-weight: 700;
}
.form-original-drip .sysFormItem {
  padding: 32px 0 0;
  border-top: 1px solid #e5e5e5;
}
.form-original-drip .sysFormField:has(input[value="77188"]),
.form-original-drip .sysFormField:has(input[value="77184"]) {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
  padding: 30px 20px;
  border-radius: 5px;
  background: #f3f0ec;
}
.form-original-drip .sysFormField:has(input[value="77188"]) label,
.form-original-drip .sysFormField:has(input[value="77184"]) label {
  display: flex;
  align-items: center;
  gap: 0 48px;
  width: auto;
  padding: 16px 24px;
  border: 2px solid #fff;
  border-radius: 5px;
  font-weight: 700;
  background: #fff;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.form-original-drip .sysFormField:has(input[value="77188"]) label:has(input[type="radio"]):before,
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]):before {
  top: 50%;
  left: 176px;
  transform: translateY(-50%);
}
.form-original-drip .sysFormField:has(input[value="77188"]) label:has(input[type="radio"]:checked),
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]:checked) {
  border-color: #3c2609;
}
.form-original-drip .sysFormField:has(input[value="77188"]) label:has(input[type="radio"]:checked):after,
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]:checked):after {
  top: 50%;
  left: 182px;
  transform: translateY(-50%);
}
.form-original-drip .sysFormField:has(input[value="77184"]) label {
  align-items: flex-start;
  padding: 32px 24px 24px;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]):before {
  top: 32px;
  transform: none;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]:checked) {
  border-color: #3c2609;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]:checked):after {
  top: 38px;
  transform: none;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label img {
  margin-top: -4px;
}
.form-original-drip .sysFormField .type {
  display: flex;
  gap: 5px;
  position: absolute;
  top: -2px;
  left: 18px;
  transform: translateY(-50%);
}
.form-original-drip .sysFormField .type .type1,
.form-original-drip .sysFormField .type .type2 {
  line-height: 1;
  padding: 7px 8px;
  border-radius: 3px;
  color: #fff;
  font-size: 10px;
}
.form-original-drip .sysFormField .type .type1 {
  background: #d77b02;
}
.form-original-drip .sysFormField .type .type2 {
  background: #dd2d77;
}
.form-original-drip .sysFormField .num {
  position: absolute;
  top: 64px;
  left: 176px;
  font-size: 12px;
  font-weight: 400;
}
.form-original-drip .sysFormField:has(input[value="77190"]) {
  display: flex;
  flex-wrap: wrap;
  gap: 16px 24px;
}
.form-original-drip .sysFormField br + textarea[name="item[4][answer][0]"],
.form-original-drip .sysFormField br + select[name="item[5][answer][0]"],
.form-original-drip .sysFormField br + input[name="item[12][answer][0]"] {
  margin-top: 16px;
}
.form-original-drip .sysFormField input[name="item[9][answer][0]"] {
  width: 160px;
}
.notfound {
  text-align: center;
}
.notfound .ttl-en {
  margin: 0 0 40px;
  color: #3c2609;
  font-size: 24px;
  font-weight: 700;
}
.notfound .ttl-en span {
  font-size: 48px;
}
.notfound .ttl-ja {
  margin: 0 0 72px;
  color: #3c2609;
  font-size: 24px;
  font-weight: 700;
}
.notfound .txt {
  margin: 0 0 80px;
  font-size: 18px;
}
.notfound .btn a {
  display: inline-block;
  padding: 16px 32px;
  border: 1px solid #171717;
  border-radius: 40px;
  text-decoration: none;
}
.notfound .btn a:before {
  content: "";
  display: inline-block;
  width: 12px;
  height: 12px;
  vertical-align: top;
  margin: 4px 16px 0 0;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: rotate(180deg);
  transition: 0.3s;
}
@media (hover: hover) {
  .notfound .btn a:hover {
    color: #fff;
    background: #171717;
    opacity: 1;
  }
  .notfound .btn a:hover:before {
    background: #fff;
  }
}
body:has(.notfound) #sysWrap {
  display: block;
}
body:has(.notfound) #sysMain {
  width: auto;
}
body:has(.notfound) #sysAside {
  display: none;
}
.static-page:has(.yamato-intro) {
  position: relative;
}
.yamato-free {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  position: absolute;
  top: 8px;
  right: 0;
  width: 150px;
  height: 144px;
  font-size: 12px;
  font-weight: 700;
  background: url("/img/yamato/img_01.svg") no-repeat 0 0/100% 100%;
  z-index: 1;
}
.yamato-free span {
  font-size: 24px;
}
.yamato-intro {
  position: relative;
  margin: 0 0 40px;
  padding: 32px 32px 32px 160px;
  border-radius: 5px;
  background: #f3f0ec;
}
.yamato-intro-logo {
  position: absolute;
  top: 32px;
  left: 32px;
}
.yamato-intro-txt {
  margin: 0 0 16px;
  font-weight: 700;
}
.yamato-intro-txt span {
  color: #ba0402;
}
.yamato-merit {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 11px;
  margin: 0 0 40px;
  padding: 30px 20px 20px;
  border-radius: 5px;
  background: #f3f0ec;
}
.yamato-merit-item {
  position: relative;
  padding: 40px 0 24px;
  border-radius: 5px;
  text-align: center;
  background: #fff;
  box-shadow: 4px 4px 30px 0px rgba(0,0,0,0.059);
}
.yamato-merit-item-label {
  position: absolute;
  top: -12px;
  left: 20px;
  padding: 8px 12px;
  border-radius: 5px;
  color: #fdd000;
  font-size: 12px;
  background: #000;
  z-index: 0;
}
.yamato-merit-item-label:after {
  content: "";
  position: absolute;
  left: 32px;
  bottom: -14px;
  width: 14px;
  height: 24px;
  background: #000;
  transform: rotate(-40deg);
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
  z-index: -1;
}
.yamato-merit-item-txt {
  font-size: 15px;
}
.yamato-merit-item-txt span {
  color: #ba0402;
  font-weight: 700;
}
.yamato-img {
  margin: 40px 0;
}
.yamato-flow {
  margin: 0 0 40px;
  padding: 0 0 0 40px;
}
.yamato-flow-item {
  display: flex;
  align-items: center;
  gap: 0 24px;
  position: relative;
  margin: 0 0 20px;
  padding: 30px;
  border-radius: 10px;
  background: #f3f0ec;
}
.yamato-flow-item:before {
  content: "";
  position: absolute;
  top: 34px;
  bottom: -50px;
  left: -36px;
  width: 36px;
  border-top: 1px solid #e5e5e5;
  border-left: 1px solid #e5e5e5;
}
.yamato-flow-item:after {
  content: "";
  position: absolute;
  top: 30px;
  left: -40px;
  width: 9px;
  height: 9px;
  border-radius: 100%;
  background: #3c2609;
}
.yamato-flow-item:last-child {
  margin: 0;
}
.yamato-flow-item:last-child:before {
  bottom: auto;
  border-left: none;
}
.yamato-flow-item-main {
  flex: 1;
}
.yamato-flow-item-ttl {
  font-weight: 700;
}
.yamato-flow-item-ttl span {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 55px;
  height: 31px;
  line-height: 1;
  margin: 0 16px 0 0;
  border-radius: 5px;
  color: #fdd000;
  font-size: 12px;
  font-weight: 700;
  background: #000;
}
.yamato-flow-item-txt {
  margin: 16px 0 0;
}
.yamato-flow-item .table-01 {
  margin: 16px 0 0 !important;
}
.yamato-bnr {
  margin: 80px 0 0;
}
.top-slide {
  position: relative;
  height: 400px;
  margin: 0 0 40px;
}
.top-slide .sysContent {
  opacity: 0;
}
.top-slide-inner {
  position: relative;
}
.top-slide-inner:before {
  content: "";
  position: absolute;
  top: -1px;
  right: 100%;
  bottom: -1px;
  width: 100vw;
  background: #fff;
  z-index: 10;
}
.top-slide .swiper-slide {
  width: 680px;
}
.top-slide .swiper-slide a {
  display: block;
  position: relative;
}
.top-slide .swiper-slide a:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 60px;
  height: 60px;
  background: url("/img/common/icon_arrow_02.png") no-repeat 0 0/100% 100%;
}
.top-slide .swiper-slide a img {
  border-radius: 5px;
}
.top-slide .swiper-button-next,
.top-slide .swiper-button-prev {
  top: 50%;
  width: 56px;
  height: 56px;
  margin: 0;
  border-radius: 100%;
  background: #fff;
  box-shadow: 0px 0px 4px 0px rgba(0,0,0,0.149);
}
.top-slide .swiper-button-next svg,
.top-slide .swiper-button-prev svg {
  width: 16px;
  height: 16px;
  color: #171717;
}
.top-slide .swiper-button-next {
  left: 680px;
  transform: translate(-50%, -50%);
}
.top-slide .swiper-button-prev {
  left: 0;
  transform: translate(-50%, -50%);
}
.top-slide .swiper-pagination {
  display: flex;
  gap: 0 10px;
  top: auto;
  bottom: 0;
  line-height: 1;
  transform: none;
  transition: none;
}
.top-slide .swiper-pagination .swiper-pagination-bullet {
  display: block;
  width: 5px;
  height: 5px;
  margin: 0;
  background: #d9d9d9;
  transition: 0.3s;
  opacity: 1;
}
.top-slide .swiper-pagination .swiper-pagination-bullet-active {
  background: #171717;
}
.top-type {
  margin: 0 0 40px;
}
.top-type-inner {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 20px;
}
.top-type-inner a {
  display: block;
  overflow: hidden;
  border-radius: 4px;
}
.top-pickup {
  display: flex;
  align-items: flex-start;
  gap: 0 24px;
  margin: 0 0 80px;
  padding: 19px 24px;
  border: 1px solid #e5e5e5;
  border-radius: 5px;
}
.top-pickup .sysHeadline {
  flex-shrink: 0;
  position: relative;
  padding: 2px 0 0 24px;
  font-weight: 700;
  font-family: "Roboto", sans-serif;
}
.top-pickup .sysHeadline:before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  width: 18px;
  height: 18px;
  background: url("/img/common/icon_check.svg") no-repeat 0 0/100% 100%;
}
.top-pickup .sysContent {
  flex: 1;
  border-left: 1px solid #e5e5e5;
}
.top-pickup .sysContent ul {
  padding: 0 0 0 24px;
}
.top-pickup .sysContent li a {
  display: flex;
  align-items: flex-start;
  gap: 0 24px;
  position: relative;
  overflow: visible;
  padding: 0 24px 0 0;
  font-weight: 700;
  text-decoration: none;
  white-space: wrap;
}
.top-pickup .sysContent li a time {
  flex-shrink: 0;
  display: block;
  padding: 1px 0 0;
  font-size: 12px;
  font-weight: 400;
}
.top-pickup .sysContent li a span {
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  text-decoration-color: rgba(23,23,23,0);
  transition: text-decoration-color 0.3s ease;
}
.top-pickup .sysContent li a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 0;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: translateY(-50%);
}
@media (hover: hover) {
  .top-pickup .sysContent li a:hover {
    opacity: 1;
  }
  .top-pickup .sysContent li a:hover span {
    text-decoration-color: currentColor;
  }
}
.top-baked {
  margin: 0 0 104px;
}
.top-baked .sysHeadline {
  position: relative;
  margin: 0 0 32px;
  padding: 0 0 8px 48px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 24px;
}
.top-baked .sysHeadline:before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  width: 34px;
  height: 34px;
  background: url("/img/common/icon_roasted_01.svg") no-repeat 0 0/100% 100%;
}
.top-baked .sysHeadline:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 96px;
  height: 1px;
  background: #8b540e;
}
.top-baked .sysHeadline span {
  color: #8b540e;
}
.top-baked .sysContent ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px 20px;
}
.top-baked .sysContent ul li a {
  display: block;
  text-decoration: none;
}
@media (hover: hover) {
  .top-baked .sysContent ul li a:hover {
    opacity: 1;
  }
  .top-baked .sysContent ul li a:hover .top-baked-img img {
    transform: scale(1.07);
  }
  .top-baked .sysContent ul li a:hover .top-baked-ttl span {
    text-decoration-color: currentColor;
  }
}
.top-baked-img {
  position: relative;
  overflow: hidden;
  margin: 0 0 18px;
  border-radius: 5px;
}
.top-baked-img img {
  transition: 0.3s;
}
.top-baked-img:after {
  content: "";
  position: absolute;
  right: 0;
  bottom: 0;
  width: 40px;
  height: 40px;
  background: url("/img/common/icon_arrow_02.png") no-repeat 0 0/100% 100%;
}
.top-baked-ttl {
  margin: 0 0 4px;
  font-size: 18px;
  font-weight: 700;
}
.top-baked-ttl span {
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  text-decoration-color: rgba(23,23,23,0);
  transition: text-decoration-color 0.3s ease;
}
.top-baked-featured {
  position: relative;
  margin: 0 0 144px;
  z-index: 0;
}
.top-baked-featured:before {
  content: "";
  position: absolute;
  top: -48px;
  right: -100vw;
  bottom: -48px;
  left: 0px;
  border-radius: 10px 0 0 10px;
  background: #f3f0ec;
  z-index: -1;
}
.top-baked-featured .sysHeadline {
  display: flex;
  align-items: center;
  margin: 0 0 32px;
  font-size: 20px;
  font-weight: 700;
}
.top-baked-featured .sysHeadline:before {
  content: "";
  display: block;
  width: 13px;
  height: 13px;
  margin: 0 8px 0 0;
  mask: url("/img/common/icon_bean_01.svg") no-repeat 0 0/100% 100%;
  background: #8b540e;
}
.top-baked-featured .sysHeadline span {
  display: block;
  margin: 0 0 0 16px;
  font-size: 10px;
  font-weight: 400;
}
.top-raw {
  margin: 0 0 72px;
}
.top-raw .sysHeadline {
  position: relative;
  margin: 0 0 32px;
  padding: 0 0 8px 48px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 24px;
}
.top-raw .sysHeadline:before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  width: 34px;
  height: 34px;
  background: url("/img/common/icon_green_01.svg") no-repeat 0 0/100% 100%;
}
.top-raw .sysHeadline:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 96px;
  height: 1px;
  background: #178242;
}
.top-raw .sysHeadline span {
  color: #178242;
}
.top-ranking {
  margin: 0 0 80px;
  padding: 40px 0 0;
  border-top: 1px solid #e5e5e5;
}
.top-ranking-tab {
  display: flex;
  justify-content: center;
  gap: 0 16px;
  margin: 0 0 32px;
}
.top-ranking-tab-item {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0 8px;
  width: 286px;
  padding: 16px;
  border: 1px solid #e5e5e5;
  border-radius: 40px;
  font-size: 18px;
  font-weight: 700;
  transition: 0.3s;
  cursor: pointer;
}
.top-ranking-tab-item.is-active {
  border-color: #171717;
  color: #fff;
  background: #171717;
}
.top-ranking-tab-item:before {
  content: "";
  display: block;
  width: 13px;
  height: 13px;
  mask: url("/img/common/icon_bean_01.svg") no-repeat 0 0/100% 100%;
}
.top-ranking-tab-item.is-baked:before {
  background: #8b540e;
}
.top-ranking-tab-item.is-raw:before {
  background: #178242;
}
.top-ranking-content {
  display: none;
}
.top-ranking-content.is-active {
  display: block;
}
.top-ranking-content .sysIconRank {
  line-height: 1;
  margin: 0 0 16px;
  text-align: center;
}
.top-ranking-content .sysIconRank img {
  width: 35px;
}
.top-ranking-btn {
  text-align: center;
  margin: 40px 0 0px;
}
.top-special {
  margin: 0 0 120px;
}
.top-special .sysHeadline {
  position: relative;
  margin: 0 0 32px;
  padding: 0 0 8px 48px;
  border-bottom: 1px solid #e5e5e5;
  font-size: 24px;
}
.top-special .sysHeadline:before {
  content: "";
  position: absolute;
  top: 1px;
  left: 0;
  width: 34px;
  height: 34px;
  background: url("/img/common/icon_special_02.svg") no-repeat 0 0/100% 100%;
}
.top-special .sysHeadline:after {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 96px;
  height: 1px;
  background: #171717;
}
.top-special .sysContent ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 30px 20px;
  margin: 0 0 32px;
}
.top-special .sysContent ul li {
  margin: 0;
}
.top-special .sysContent ul li a {
  display: block;
  text-decoration: none;
}
.top-special .sysContent ul li a img {
  display: block;
  margin: 0 0 8px;
}
.top-special .sysContent ul li a span {
  font-size: 12px;
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  text-decoration-color: rgba(23,23,23,0);
  transition: text-decoration-color 0.3s ease;
}
@media (hover: hover) {
  .top-special .sysContent ul li a:hover {
    opacity: 1;
  }
  .top-special .sysContent ul li a:hover span {
    text-decoration-color: currentColor;
  }
}
.top-special-btn {
  text-align: center;
}
.top-tea {
  position: relative;
  margin: 0 0 144px;
  z-index: 0;
}
.top-tea:before {
  content: "";
  position: absolute;
  top: -48px;
  right: -100vw;
  bottom: -48px;
  left: 0px;
  border-radius: 10px 0 0 10px;
  background: #fff1f5;
  z-index: -1;
}
.top-tea .sysHeadline {
  display: flex;
  align-items: center;
  margin: 0 0 32px;
  font-size: 20px;
  font-weight: 700;
}
.top-tea .sysHeadline span {
  display: block;
  margin: 0 0 0 16px;
  font-size: 10px;
  font-weight: 400;
}
.top-tea-comment {
  display: inline-block;
  position: relative;
  vertical-align: top;
  margin: 0 0 12px;
  padding: 9px 16px;
  border-radius: 5px;
  color: #fff;
  font-size: 12px;
  background: #de1d54;
}
.top-tea-comment:after {
  content: "";
  position: absolute;
  bottom: -14px;
  left: 32px;
  width: 10px;
  height: 20px;
  background: #de1d54;
  transform: rotate(-40deg);
  clip-path: polygon(0 0, 100% 0%, 50% 100%);
}
.top-news {
  padding: 32px 40px 40px;
  border: 1px solid #e5e5e5;
  border-radius: 10px;
}
.top-news .sysHeadline {
  display: flex;
  align-items: center;
  margin: 0 0 32px;
  font-size: 20px;
  font-weight: 700;
}
.top-news .sysHeadline:before {
  content: "";
  display: block;
  width: 17px;
  height: 17px;
  margin: 0 8px 0 0;
  mask: url("/img/common/icon_guide.svg") no-repeat 0 0/100% 100%;
  background: #171717;
}
.top-news .sysHeadline span {
  display: block;
  margin: 0 0 0 16px;
  font-size: 10px;
  font-weight: 400;
}
.top-news ul {
  margin: 0 0 32px;
}
.top-news ul li a {
  display: flex;
  align-items: flex-start;
  gap: 0 24px;
  position: relative;
  padding: 23px 48px 23px 20px;
  border-radius: 5px;
  font-weight: 700;
  text-decoration: none;
}
.top-news ul li a time {
  flex-shrink: 0;
  display: block;
  padding: 1px 0 0;
  font-size: 12px;
  font-weight: 400;
}
.top-news ul li a span {
  text-decoration-line: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  text-decoration-color: rgba(23,23,23,0);
  transition: text-decoration-color 0.3s ease;
}
.top-news ul li a:after {
  content: "";
  display: block;
  position: absolute;
  top: 50%;
  right: 24px;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: translateY(-50%);
}
@media (hover: hover) {
  .top-news ul li a:hover {
    opacity: 1;
  }
  .top-news ul li a:hover span {
    text-decoration-color: currentColor;
  }
}
.top-news ul li:nth-child(2n-1) a {
  background: #f3f0ec;
}
.top-news-btn {
  text-align: center;
}
/* 基本設定
 *----------------------------------------------------------------------*/
.sp_only {
  display: none;
}
.sysContent {
  padding: 0 !important;
  text-align: left !important;
}
h1,
h2,
h3,
h4,
h5 {
  margin: 0;
  padding: 0;
  line-height: 1.6;
  font-weight: bold;
  letter-spacing: inherit;
  font-family: inherit;
}
p {
  margin: 10px auto;
}
p.indent {
  margin: 5px 0 !important;
  text-indent: 1em;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-size: inherit;
}
.clearfix:after {
  content: "";
  clear: both;
  display: block;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
/* フォーム要素の基本レイアウト */
/**
 * Owl Carousel v2.2.1
 * Copyright 2013-2017 David Deutsch
 * Licensed under  ()
 */
/*
 *  Owl Carousel - Core
 */
.owl-carousel {
  display: none;
  width: 100%;
  -webkit-tap-highlight-color: transparent;
/* position relative and z-index fix webkit rendering fonts issue */
  position: relative;
  z-index: 1;
}
.owl-carousel .owl-stage {
  position: relative;
  -ms-touch-action: pan-Y;
  -moz-backface-visibility: hidden;
/* fix firefox animation glitch */
}
.owl-carousel .owl-stage:after {
  content: ".";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
  height: 0;
}
.owl-carousel .owl-stage-outer {
  position: relative;
  overflow: hidden;
/* fix for flashing background */
  -webkit-transform: translate3d(0px, 0px, 0px);
}
.owl-carousel .owl-wrapper,
.owl-carousel .owl-item {
  -webkit-backface-visibility: hidden;
  -moz-backface-visibility: hidden;
  -ms-backface-visibility: hidden;
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
}
.owl-carousel .owl-item {
  position: relative;
  min-height: 1px;
  float: left;
  -webkit-backface-visibility: hidden;
  -webkit-tap-highlight-color: transparent;
  -webkit-touch-callout: none;
}
.owl-carousel .owl-item img {
  display: block;
  width: 100%;
}
.owl-carousel .owl-nav .owl-prev,
.owl-carousel .owl-nav .owl-next,
.owl-carousel .owl-dot {
  cursor: pointer;
  cursor: hand;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.owl-carousel.owl-loaded {
  display: block;
}
.owl-carousel.owl-loading {
  opacity: 0;
  display: block;
}
.owl-carousel.owl-hidden {
  opacity: 0;
}
.owl-carousel.owl-refresh .owl-item {
  visibility: hidden;
}
.owl-carousel.owl-drag .owl-item {
  -webkit-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
}
.owl-carousel.owl-grab {
  cursor: move;
  cursor: grab;
}
.owl-carousel.owl-rtl {
  direction: rtl;
}
.owl-carousel.owl-rtl .owl-item {
  float: right;
}
/* No Js */
.no-js .owl-carousel {
  display: block;
}
/*
 *  Owl Carousel - Animate Plugin
 */
.owl-carousel .animated {
  animation-duration: 1000ms;
  animation-fill-mode: both;
}
.owl-carousel .owl-animated-in {
  z-index: 0;
}
.owl-carousel .owl-animated-out {
  z-index: 1;
}
.owl-carousel .fadeOut {
  animation-name: fadeOut;
}
/*
 *  Owl Carousel - Auto Height Plugin
 */
.owl-height {
  transition: height 500ms ease-in-out;
}
/*
 *  Owl Carousel - Lazy Load Plugin
 */
.owl-carousel .owl-item .owl-lazy {
  opacity: 0;
  transition: opacity 400ms ease;
}
.owl-carousel .owl-item img.owl-lazy {
  transform-style: preserve-3d;
}
/*
 *  Owl Carousel - Video Plugin
 */
.owl-carousel .owl-video-wrapper {
  position: relative;
  height: 100%;
  background: #000;
}
.owl-carousel .owl-video-play-icon {
  position: absolute;
  height: 80px;
  width: 80px;
  left: 50%;
  top: 50%;
  margin-left: -40px;
  margin-top: -40px;
/*background: url("owl.video.play.png") no-repeat;*/
  cursor: pointer;
  z-index: 1;
  -webkit-backface-visibility: hidden;
  transition: transform 100ms ease;
}
.owl-carousel .owl-video-play-icon:hover {
  -ms-transform: scale(1.3, 1.3);
  transform: scale(1.3, 1.3);
}
.owl-carousel .owl-video-playing .owl-video-tn,
.owl-carousel .owl-video-playing .owl-video-play-icon {
  display: none;
}
.owl-carousel .owl-video-tn {
  opacity: 0;
  height: 100%;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  transition: opacity 400ms ease;
}
.owl-carousel .owl-video-frame {
  position: relative;
  z-index: 1;
  height: 100%;
  width: 100%;
}
.owl-controls {
  margin-top: 10px;
  text-align: center;
  -webkit-tap-highlight-color: transparent;
}
.owl-controls .owl-nav [class*=owl-] {
  color: #fff;
  font-size: 14px;
  margin: 5px;
  padding: 4px 7px;
  background: #d6d6d6;
  display: inline-block;
  cursor: pointer;
  -webkit-border-radius: 3px;
  -moz-border-radius: 3px;
  border-radius: 3px;
}
.owl-controls .owl-nav [class*=owl-]:hover {
  background: #869791;
  color: #fff;
  text-decoration: none;
}
.owl-controls .owl-nav .disabled {
  opacity: 0.5;
  cursor: default;
}
.owl-dots {
  text-align: center;
}
.owl-dots .owl-dot {
  display: inline-block;
  zoom: 1;
  *display: inline;
  position: relative;
  top: 10px;
}
.owl-dots .owl-dot span {
  width: 20px;
  height: 20px;
  margin: 5px 12.5px;
  background: #999;
  display: block;
  -webkit-backface-visibility: visible;
  -webkit-transition: opacity 200ms ease;
  -moz-transition: opacity 200ms ease;
  -ms-transition: opacity 200ms ease;
  -o-transition: opacity 200ms ease;
  transition: opacity 200ms ease;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  border-radius: 30px;
}
.owl-dots .owl-dot.active span,
.owl-dots .owl-dot:hover span {
  background: #000;
}
.owl-nav {
  margin-top: 10px;
  text-align: center;
  -webkit-tap-highlight-color: transparent;
}
.owl-nav [class*=owl-] {
  position: absolute;
  top: 98%;
  margin-top: -18.5px;
  outline: 0;
  width: 20px;
  height: 37px;
  padding: 0;
  text-indent: -9999px;
  z-index: 9999;
  border: none;
  border-radius: none;
  cursor: pointer;
}
.owl-nav .owl-prev {
  left: 35%;
  background: url("/img/common/controls.png") no-repeat 0 0;
  background-size: 40px;
}
.owl-nav .owl-next {
  right: 35%;
  background: url("/img/common/controls.png") no-repeat -20px 0;
  background-size: 40px;
}
.owl-nav .owl-prev:hover {
  background-position: 0 0;
}
.owl-nav .owl-next:hover {
  background-position: -20px 0;
}
/* 検索ボックス */
.search_bx form {
  overflow: hidden;
  border: 1px solid #ddd;
}
.search_bx .sysItemSearchFormWord {
  float: left;
  width: 70%;
}
.search_bx input[type="search"] {
  height: 40px;
  border: none;
  padding: 5px;
  width: 100%;
}
.search_bx .sysSearchButton {
  overflow: hidden;
  float: left;
  display: block;
  width: 30%;
  height: 40px;
  margin: 0;
  padding: 0;
  text-indent: -999px;
  border-radius: 0px;
  border: none;
  background: #222 url("/img/common/ico_search.png") no-repeat center center;
  background-size: 70px;
  cursor: pointer;
}
/* submitボタンの調整 */
/* 商品カテゴリページ */
#sysItemCategory h1.itemCategory {
  margin-left: 5px;
  border-left: 5px solid #222;
  padding-left: 10px;
  font-size: 18px;
  margin: 20px 0 10px;
}
.sysSelectionDescription {
  margin: 2px 0 10px;
}
/* 4-1-3 Category View Mode */
/* PRアイコン設定 */
/*PRアイコン(商品詳細ページ)*/
span.icon_online,
span.icon_kyobashi {
  display: inline-block;
  background: #ff1000;
  border: 3px solid #ff1000;
  color: #fff;
}
span.icon_book {
  display: inline-block;
  border: 3px solid #ff1000;
  color: #ff1000;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
span.icon_chilled {
  display: inline-block;
  background: #4472c4;
  border: 3px solid #4472c4;
  color: #fff;
  text-indent: 0.5em;
  letter-spacing: 0.5em;
}
/* カートボタン */
/* アーカイブリスト */
/* 4-1-7  商品サムネイル画像 */
/* 商品ぺージ */
/* 商品画像 */
.sysThumbnailImage > span,
.sysThumbnailImage > br {
  display: none;
}
/* 商品ページのタイトル */
/* 商品説明 */
/* 買い物フォーム */
#sysItemDetail .sysShare {
  padding: 5px 0 0 2%;
}
#sysCartInForm {
  width: 100%;
}
/* ログインボタン */
/* カートボタン */
/* フォームページの基本レイアウト*/
/* フォーム確認ぺージ */
/* マイページ */
/* 購入履歴 */
.sysOrderList {
  border: 1px solid #d4d4d4;
  padding: 10px;
  max-height: 400px;
  overflow-y: scroll;
}
.sysOrderList li {
  border-bottom: 1px dotted #d4d4d4;
  margin-bottom: 5px;
  padding-bottom: 5px;
}
/* Member Profile Editor */
/* Special Point */
.sysSpecialPoint {
  overflow: hidden;
  letter-spacing: -0.4em;
}
.sysSpecialPoint > div:nth-child(2n) {
  width: 60%;
}
.sysSpecialPoint > div {
  display: inline-block;
  letter-spacing: normal;
  padding: 5px 10px;
  border-bottom: 1px solid #d5d5d5;
}
.sysSpecialPoint > div:nth-child(2n+1) {
  width: 40%;
}
/* 4-5-4 Coupon List */
.sysCoupon {
  border: 1px solid #d5d5d5;
  margin: 10px;
}
/* マイページ（複数配送先編集画面）*/
.sysSelectAddress {
  background: none;
}
.sysSelectAddress a {
  display: block;
  text-decoration: none;
  border: 0px solid;
  padding: 10px;
}
.sysSelectAddress {
  margin: 10px 0;
}
/***********************************
  商品詳細ページ
***********************************/
/*商品番号*/
/*価格表示*/
/*通常価格*/
#sysItemDetail .sysSuggestedRetailPrice {
  margin-bottom: 5px;
  text-align: right;
}
#sysItemDetail .sysSuggestedRetailPrice span {
  font-size: 1.1rem;
}
/*送料区分*/
#sysItemDetail .sysShippingCost {
  display: inline-block;
  width: auto;
  margin-left: auto;
  margin-top: 5px;
  padding: 0 5px;
  color: #da4636;
  font-weight: bold;
  font-size: 1.1rem;
  border: 1px solid #da4636;
  border-radius: 3px;
}
/*PRアイコン(カテゴリーページ)*/
#sysItemCategory input[type=submit] {
  margin-top: 0px;
}
.sysAddSelection div {
  margin-bottom: 10px;
}
.sysAddSelection {
  clear: both;
}
.sysAddSelection input,
.sysAddSelection select {
  margin: 5px 0;
}
#sysItemDetail .sysShare {
  padding: 5px 0 0 2%;
}
#sysCartInForm {
  width: 100%;
  margin-left: auto;
}
/*バリエーション*/
#sysItemDetail .sysFormVariationName {
  background-color: #fdf5f5;
}
#sysItemDetail .sysFormVariationTable {
  width: 100%;
  max-width: 500px;
}
/*下部フォーム*/
#sysItemDetail .order_bottom {
  margin: 0 auto 40px;
  text-align: right;
}
/*簡易商品説明*/
/*商品詳細*/
#sysItemDetail .itempage_cap {
  margin-bottom: 30px;
  font-size: 12px;
}
#sysItemDetail .itempage_cap .i_ttl {
  margin-bottom: 20px;
  font-size: 120%;
  font-weight: bold;
}
#sysItemDetail .itempage_detail h3 {
  font-size: 18px;
  font-weight: normal;
}
#sysItemDetail .itempage_detail table {
  width: 100%;
  margin-bottom: 10px;
  border-top: 1px solid #ccc;
}
#sysItemDetail .itempage_detail table tr {
  border-bottom: 1px solid #ccc;
}
#sysItemDetail .itempage_detail table th,
#sysItemDetail .itempage_detail table td {
  padding: 10px;
  font-size: 12px;
  line-height: 1.6;
  text-align: center;
}
#sysItemDetail .itempage_detail table th {
  width: 30%;
  border-right: 1px solid #ccc;
}
#sysItemDetail .itempage_detail table td {
  width: 70%;
  text-align: left;
  background: #fff;
}
#sysItemDetail .itempage_detail_ttl {
  position: relative;
  margin-top: 40px;
  padding: 5px 0;
  font-weight: bold;
  font-size: 18px;
}
#sysItemDetail .itempage_detail_ttl:after {
  content: "　";
  display: block;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -30px;
  width: 60px;
  height: 2px;
  background-color: #000;
}
/*数量増減*/
/*カートに入れる*/
#sysItemDetail .sysGoCartButton {
  background: #da4636 url("/img/layout/system/btn_cart2.png") center center no-repeat;
  background-size: 127px;
}
/*お気に入り*/
.modaal-container {
  max-width: 750px !important;
  padding: 40px;
  box-shadow: none !important;
}
.modaal-container .sysWishlistThumbnailGroup {
  margin: 0 0 24px;
}
.modaal-container .sysWishlistMessageGroup,
.modaal-container .sysWishlistInformationGroup {
  margin: 0 0 16px;
  text-align: center;
}
.modaal-container .sysWishlistLoginGroup {
  margin: 0 0 24px;
  text-align: center;
}
.modaal-container .sysWishlistLoginButton,
.modaal-container .sysWishlistMemberRegistButton {
  width: 246px;
  line-height: 1;
  padding: 16px 24px;
  border: none;
  border-radius: 5px;
  color: #fff;
  background: #3c2609;
  cursor: pointer;
}
.modaal-container .sysWishlistMemberRegisterGroup {
  margin: 0 0 24px;
  text-align: center;
}
.modaal-container .sysWishlistCloseBottomButtonGroup {
  text-align: center;
}
.modaal-container .sysWishlistCloseBottomButtonGroup .sysWishlistCloseBottomButton {
  width: auto;
  border: none;
  background: none;
  cursor: pointer;
}
/* お気に入り登録時の画面 */
/* バツボタン */
.modaal-close {
  position: absolute;
  top: 24px;
  right: 24px;
  width: 40px;
  height: 40px;
}
.modaal-close:after,
.modaal-close:before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 2px;
  height: 22px;
  background: #171717 !important;
}
.modaal-close:after {
  transform: translate(-50%, -50%) rotate(45deg);
}
.modaal-close:before {
  transform: translate(-50%, -50%) rotate(-45deg);
}
button,
input,
optgroup,
select,
textarea {
  font: inherit;
}
/* サンプルイメージ */
.mdl-dialog__image::before {
  content: "お気に入り登録完了";
  display: block;
  margin: 0 0 16px;
  font-size: 16px;
  font-weight: 700;
  text-align: center;
}
.mdl-dialog__image {
  width: 88.81%;
  max-width: 250px;
  margin: auto;
}
/* ログインボタン */
:after,
:before {
  text-decoration: inherit;
  vertical-align: inherit;
  background-repeat: no-repeat;
  box-sizing: inherit;
}
/* 会員登録ボタン */
.sysWishlistMemberRegisterGroup::before {
  content: "会員登録をされていないお客様はこちら";
  display: block;
  margin: 0 0 16px;
}
/* この画面を閉じるボタン */
/*SNSボタン*/
#sysItemDetail .sysShare {
  padding: 5px 0 0 2%;
  text-align: right;
}
#sysItemDetail .sysShare .sysFacebook {
  position: relative;
  top: 2px;
}
#sysItemDetail .sysShare .sysGoogleplus {
  width: 58px;
}
#sysItemDetail .sysShare .sysLine,
#sysItemDetail .sysShare .sysDisplayPcNone {
  display: inline-block !important;
}
#sysItemDetail .sysShare .sysLine {
  position: relative;
  top: 0px;
}
/*.sysReview*/
#sysItemDetail .sysReview {
  margin: 20px 0 40px;
}
/*テーブルデザイン*/
/*商品ページ用おすすめ商品*/
.itempage_recommend .sysItemBlock .sysHorizontal li {
  width: 25%;
  padding: 0 10px;
}
.itempage_recommend .sysItemName {
  margin-bottom: 0;
  font-size: 14px;
  text-align: left;
}
.itempage_recommend .sysItemPrice {
  text-align: left;
}
/*商品ページ成分表*/
#sysItemDetail .show_bx {
  margin-bottom: 30px;
}
#sysItemDetail .show_bx_inner {
  margin-bottom: 10px;
}
#sysItemDetail .btn_tr {
  padding: 10px 0 10px 35px !important;
  background: #e4e4e4 url("/img/layout/system/ico_plus.png") 10px center no-repeat !important;
  background-size: 18px !important;
  cursor: pointer;
}
#sysItemDetail .active {
  background: #e4e4e4 url("/img/layout/system/ico_minus.png") 10px center no-repeat !important;
  background-size: 18px !important;
}
#sysItemDetail .contents_tr {
  background-color: #f5f5f5;
}
#sysItemDetail .contents_tr td {
  background-color: #f5f5f5 !important;
}
#sysItemDetail .contents_tr table {
  margin-bottom: 0;
}
/***********************************
  カートページ
***********************************/
/*カートページ内レイアウト調整*/
.sysSelectPayment li:last-child,
.sysSelectDelivery li:last-child,
.sysSelectOption li:last-child,
.sysCart .sysDetail li:last-child,
.sysRemarks,
.sysCart .sysOrder .nav li:last-child {
  border-bottom: none;
}
.sysCart .sysAcceptDomainArea input {
  padding: 0 10px !important;
}
/*登録せずに購入*/
#sysBillingAddress .input-append input[type="text"] {
  display: inline-block;
}
/*都道府県*/
#sysBillingAddress .sysPrefState select {
  width: 200px;
}
/*性別*/
#sysBillingAddress .sysGender {
  margin-bottom: 20px;
}
#sysBillingAddress .sysGender input {
  vertical-align: middle;
}
#sysBillingAddress .sysGender label {
  display: inline-block;
  margin-right: 20px;
}
/*メルマガ*/
#sysBillingAddress .sysAcceptMailmagazine {
  margin-bottom: 20px;
}
/*注文完了ページ*/
.cart_completion {
  text-align: center;
}
/*ご注文番号*/
#sysThanks #sysMain .sysOrderNumber {
  font-size: 1.5rem;
  font-weight: bold;
}
/*お買い物を続ける*/
body#sysBasket .sysBackButton2 {
  font-weight: bold;
  background: #b4f4ff !important;
  border-color: #000 !important;
}
/***********************************
  ワンページカート
***********************************/
.mdl_btn_.opcDialog,
form.opcUseAmazon {
  width: 100%;
  padding-right: 0;
}
.sysCart #sysMain h3 {
  font-size: 20px;
}
.sysCart #sysMain #show-dlg-2,
.sysCart #sysMain #show-dlg-3 {
  display: block;
  width: 100% !important;
  padding: 10px;
  margin: 0 0 30px !important;
  color: #fff !important;
  font-size: 1.2rem;
  line-height: 1;
  text-shadow: none;
  box-shadow: none;
  border: none !important;
  border-radius: 5px;
  background: #000 !important;
}
.sysCart #sysMain #show-dlg-3 {
  color: #fff !important;
  background: #da4636 !important;
}
.sysCart #sysMain .next_btn {
  color: #fff !important;
  font-size: 1rem;
  line-height: 1;
  border: none !important;
  background: #000 !important;
}
.sysCart #sysMain #order_price_confirm_btn {
  color: #fff !important;
  width: 100% !important;
  box-shadow: none;
  background: #000 !important;
}
.sysCart #sysMain .mdl-js-button {
  box-shadow: none;
}
.sysCart #sysMain #change-to-billAddr,
.sysCart #sysMain #show-dlg-addrList,
.sysCart #sysMain #show-dlg-inputAddr {
  line-height: 1;
  border: none !important;
  background: #000 !important;
}
.sysCart #sysMain p.user_type {
  font-size: 1.2rem;
}
.sysOpcProduct .sysOpcItemName {
  font-size: 1.2rem;
}
/*情報入力ページ調整*/
input[type="button"],
select {
  box-sizing: border-box;
  -moz-box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -webkit-appearance: none;
}
.sysCheckoutProductListItemVariation {
  color: #ba0402 !important;
  font-weight: bold !important;
}
.sysCheckoutFieldProductQuantityDecrement,
.sysCheckoutFieldProductQuantityIncrement,
.sysCheckoutButtonSecondary {
  color: #171717 !important;
  border: 1px solid #171717 !important;
  background: #fff !important;
}
.sysCheckoutInformationPurchaserView .sysCheckoutLink {
  padding-block: calc(var(--spacing) * 1.5) !important;
  padding-inline: calc(var(--spacing) * 3) !important;
  font-size: calc(var(--sys-text-base) * .8125) !important;
  line-height: var(--tw-leading, 1.6) !important;
  border-radius: var(--radius-md) !important;
  justify-content: center !important;
  align-items: center !important;
  display: inline-flex !important;
  color: #171717 !important;
  border: 1px solid #171717 !important;
  background: #fff !important;
  text-decoration: none !important;
}
/*完了ページ調整*/
/***********************************
  検索ページ
***********************************/
/***********************************
  お問い合わせ
***********************************/
/***********************************
  新規会員登録
***********************************/
/***********************************
  マイページ
***********************************/
/* マイページボタン */
/***********************************
  カート情報
***********************************/
#cartInfo {
  float: left;
  position: relative;
  margin-top: 15px;
  margin-left: 5px;
  width: 120px;
  height: 30px;
  line-height: 28px;
  font-weight: bold;
  font-size: 12px;
  border-radius: 20px;
  border: 1px solid #222;
  background: #222;
  color: #fff;
  text-align: center;
  cursor: pointer;
  padding-top: -10px;
}
#cartInfo p.cartTxt {
  margin: -2px;
  line-height: 21px;
  padding-top: 5px;
  font-size: 10px;
}
#cartInfo p img {
  width: 20px;
  height: 20px;
  display: inline-block;
  margin-right: 5px;
}
#cartInfo i {
  margin-right: 5px;
}
.h_cart {
  display: none;
  width: 280px;
  height: 145px;
  position: absolute;
  top: 40px;
  right: 5px;
  border: 1px solid #aaa;
  background: #fff;
  color: #000;
  z-index: 110;
  padding: 10px 20px;
}
.h_cart dl {
  font-size: 12px;
  margin-bottom: 0px;
}
.h_cart dl:after {
  display: block;
  content: "";
  clear: both;
}
.h_cart dt,
.h_cart dd {
  float: left;
}
.h_cart dd span {
  display: inline-block;
  color: #da4636;
  font-weight: bold;
  padding: 0 5px;
}
.h_cart .sysCartInfoCartIn a {
  display: block;
  background: #000;
  color: #fff;
  width: 100%;
  margin: 10px 0% 5px;
  height: 50px;
  padding: 12px 0 0;
  font-size: 15px;
  font-weight: bold;
  text-align: center;
  border-radius: 5px;
}
.h_cart .sysCartInfoCartIn a img {
  display: inline-block;
  width: 25px;
  height: 25px;
  margin-right: 5px;
}
.h_cart .sysCartInfoCartIn a i {
  margin-right: 5px;
}
/* カート内商品数表示 */
button.itemCount {
  display: none;
  border: none;
  width: 20px;
  height: 20px;
  line-height: 20px;
  text-align: center;
  font-weight: bold;
  margin-left: 5px;
  color: #222;
  background: #fff;
  border-radius: 10px;
}
/***********************************
  ナビゲーション
***********************************/
.h_navi {
  width: 100%;
  height: 60px;
  margin-bottom: 10px;
}
#headNavigation {
  max-width: 1100px;
  margin: 0 auto;
  height: 60px;
}
#headNavigation .pcnone {
  display: none;
}
#headNavigation li.tab1 {
  width: 220px;
  float: left;
  text-align: center;
}
#headNavigation li a {
  display: block;
  font-weight: 700;
}
#headNavigation li a span {
  display: block;
  font-size: 10px;
}
.tabmenu .border:after {
  background-color: #000;
  content: " ";
  height: 15px;
  margin-top: -35px;
  position: absolute;
  right: 0;
  top: 42px;
  width: 1px;
}
/*ナビゲーショントグル*/
.tabmenu:before {
  display: block;
  content: "";
  clear: both;
}
.tabmenu {
  margin: 10px 0 0;
}
.toggleNav {
  display: none;
  width: 220px;
  position: absolute;
  height: 0px; /*heightはjs制御*/
  top: 50px;
  left: 0;
  background: #fff;
  z-index: 110;
  box-shadow: 2px 2px 4px 0px #ccc;
  -moz-box-shadow: 2px 2px 4px 0px #ccc;
  -webkit-box-shadow: 2px 2px 4px 0px #ccc;
}
.toggleNav:hover {
  overflow: visible !important;
}
.tabmenu li.tab1 {
  position: relative;
}
.tabmenu li.tab1 a {
  font-size: 14px;
}
.tabmenu li.tab2 {
  text-align: left;
  height: 35px;
  border-bottom: 1px dotted #ccc;
  position: relative;
}
.tabmenu li.tab2:hover {
  background: #ededed;
}
.tabmenu li.tab2 a {
  display: block;
  position: relative;
  padding: 10px;
  font-size: 12px !important;
  line-height: 15px;
  font-weight: bold;
}
.tabmenu li.tab2 a i {
  position: absolute;
  right: 10px;
  top: 10px;
}
.tabmenu li.tab2 .subCategory {
  position: absolute;
  width: 200px;
  left: 200px;
  top: 0px;
  background: #fff;
  visibility: hidden;
  transition: all 0.1s ease;
  z-index: 120;
  box-shadow: 2px 2px 4px 0px #ccc;
  -moz-box-shadow: 2px 2px 4px 0px #ccc;
  -webkit-box-shadow: 2px 2px 4px 0px #ccc;
}
.tabmenu li.tab2:hover .subCategory {
  visibility: visible;
}
.tabmenu li.tab3 {
  font-size: 14px;
  height: 35px;
  border-bottom: 1px dotted #ccc;
  font-weight: bold;
}
/***********************************
  サイド
***********************************/
/*検索ボックス*/
.side_search {
  margin-bottom: 30px;
}
.side_search form {
  border: none;
}
.side_search input[type="search"] {
  height: 40px;
  border: 1px solid #ddd;
  margin-bottom: 5px;
}
.side_search .sysItemSearchFormWord {
  float: none;
  width: 100%;
  margin-bottom: 5px;
}
.side_search .sysSearchButton {
  float: none;
  width: 100% !important;
  height: 40px;
  border-radius: 5px;
  background: #000 url("/img/common/ico_search.png") no-repeat center center;
  background-size: 70px;
  text-indent: -999px;
}
.side_navi .sysHeadline,
.side_navi_item .sysHeadline {
  font-size: 14px;
  margin: 0 !important;
  text-align: left;
  font-weight: bold;
  letter-spacing: 2px;
  width: auto;
  border-bottom: 1px solid #222;
}
.side_navi .sysHeadline:before,
.side_navi_item .sysHeadline:before {
  content: none;
}
.side_navi a {
  position: relative;
  padding: 7px 5px 7px 20px !important;
  letter-spacing: 1px;
  border-bottom: 1px dotted #cdcdcd !important;
}
.side_navi a:after {
  position: absolute;
  top: 7px;
  right: 10px;
  content: ">";
  font-size: 14px;
}
.side_navi {
  margin-bottom: 30px;
}
/*商品別*/
.side_navi_item {
  margin-bottom: 0;
  border-bottom: 1px solid #000;
}
.side_navi_item .sysHeadline,
.side_navi_item .sysContent {
  width: 90% !important;
  margin-left: auto !important;
}
.side_navi_item a {
  position: relative;
  padding: 7px 5px !important;
  letter-spacing: 1px;
  border-bottom: 1px dotted #cdcdcd !important;
}
.side_navi_item a:after {
  position: absolute;
  top: 7px;
  right: 10px;
  content: ">";
  font-size: 14px;
}
.side_navi_item li:last-child a {
  border-bottom: none !important;
}
.side_navi_item .sysHeadline {
  font-size: 13px;
  padding: 0;
  border-bottom: 1px dotted #cdcdcd !important;
}
.side_navi_item .sysHeadline a {
  display: block;
  border-bottom: none !important;
}
/*お買い物ガイド 最後2つ*/
.side_navi_guide li:nth-last-child(1),
.side_navi_guide li:nth-last-child(2) {
  font-size: 14px;
  font-weight: bold;
  border-bottom: 1px solid #222;
  margin-bottom: 10px;
}
.side_navi_guide li:nth-last-child(1) a,
.side_navi_guide li:nth-last-child(2) a {
  padding: 7px 5px !important;
  border: none !important;
}
.side_navi_guide li:nth-last-child(1) a:hover,
.side_navi_guide li:nth-last-child(2) a:hover {
  background-color: #fff;
}
.side_navi_guide li:nth-last-child(3) {
  margin-bottom: 10px;
}
/***********************************
  共通パーツ
***********************************/
hr.style01 {
  width: 100%;
  height: 1px;
  background: #222;
  margin: 50px auto;
  padding: 0;
  border: 0;
}
.sysTitle {
  width: 600px;
  margin: 30px auto !important;
  position: relative;
  text-align: center;
  font-size: 23px;
  letter-spacing: 3px;
}
.sysTitle b {
  display: block;
  font-size: 14px;
  text-align: center;
}
.sysTitle span {
  position: relative;
  z-index: 2;
  display: inline-block;
  margin: 0 2.5em;
  padding: 0 40px;
  background-color: #fff;
  text-align: center;
}
.sysTitle::before {
  position: absolute;
  top: 50%;
  z-index: 1;
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  background-color: #222;
}
.contentsWrap {
  width: 1100px;
  margin: 0 auto;
}
/***********************************
  特商法テーブルレイアウト
***********************************/
#main_tradelaw,
.main_tradelaw {
  border: 1px solid #ddd;
  margin: 0 auto 30px;
  max-width: 1100px;
}
#main_tradelaw dl,
.main_tradelaw dl {
  background: #ededed;
  border-bottom: 1px dotted #bfbfbf;
  overflow: hidden;
}
#main_tradelaw dl:last-child,
.main_tradelaw dl:last-child {
  border: 0px;
}
#main_tradelaw dt,
.main_tradelaw dt {
  padding: 15px 0 15px 20px;
  float: left;
  clear: both;
  font-weight: bolder;
}
#main_tradelaw dd,
.main_tradelaw dd {
  margin-left: 200px;
  padding: 15px;
  background: #fff;
}
.shipFee {
  max-width: 1100px;
  margin: 20px auto;
}
.shipFee .tableTitle {
  font-size: 16px;
  height: 70px;
  padding: 10px;
  color: #424242;
  margin: 50px 0 0px;
  border: 0px !important;
  text-align: leftr;
}
table.shipFeeTable {
  border-collapse: collapse;
  margin-bottom: 30px;
  text-align: left;
  line-height: 1.5;
  text-align: center;
}
table.shipFeeTable .eyeCatch {
  width: 120px;
  display: block;
  margin: 5px auto;
  height: 25px;
  line-height: 25px;
  color: #000;
  border-bottom: 1px solid #aaa;
  padding-bottom: 5px;
}
table.shipFeeTable thead {
  background: #555;
  text-align: center;
}
.spThead {
  display: none;
}
table.shipFeeTable thead th {
  padding: 10px;
  vertical-align: top;
  font-weight: normal;
  color: #fff;
}
table.shipFeeTable tbody .sum {
  position: relative;
}
table.shipFeeTable tbody .sum i {
  position: absolute;
  color: #888;
  font-size: 35px;
  right: -15px;
  bottom: 30px;
  z-index: 20;
}
table.shipFeeTable tbody th {
  width: 600px;
  padding: 10px;
  vertical-align: top;
  background: #fff;
  font-weight: normal;
  border-bottom: 1px solid #ddd;
  border-left: 1px solid #ddd;
  border-right: 1px solid #ddd;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
table.shipFeeTable td {
  width: 500px;
  padding: 10px;
  vertical-align: top;
  border-right: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
  background: #eee;
}
table.shipFeeTable b {
  color: #d42e30;
  display: inline-block;
  padding: 0 3px;
  font-size: 1.2em;
}
div#main_tradelaw a {
  display: inline-block;
  color: #068acc;
  text-decoration: underline;
}
/***********************************
  2カラムレイアウト
***********************************/
.column2Wrap {
  width: 1100px;
  margin: 0 auto;
}
.column2Wrap:after {
  display: block;
  content: "";
  clear: both;
}
.sideWrap {
  width: 180px;
  height: 1000px;
  background: #aaa;
  margin-right: 20px;
  float: left;
}
.mainWrap {
  width: 900px;
  margin-left: 200px;
}
.col2Style h2.pattern01 {
  font-size: 18px;
  border-left: 5px solid #3d3d3d;
  padding-left: 5px;
  margin: 15px 0;
}
.col2Style h2.pattern02 {
  font-size: 18px;
  border-bottom: 1px solid #3d3d3d;
  padding-left: 5px;
  padding-bottom: 5px;
  margin: 15px 0;
}
.col2Style h2.pattern03 {
  height: 35px;
  line-height: 35px;
  font-size: 18px;
  padding: 0 0px 3px 30px;
  margin: 0 0 15px;
  border-bottom: 1px solid #6843ac;
}
.col2Style h3.pattern01 {
  font-size: 14px;
  border-bottom: 0px solid #aaa !important;
  padding: 0px 0px 3px;
  margin: 15px 0 5px;
}
.col2Style h4.style01 {
  font-size: 15px;
  padding-bottom: 3px;
  margin: 20px 0;
  border-bottom: 0px solid #3d3d3d !important;
}
.col2Style .txtBlock {
  margin: 30px 0;
}
.col2Style .imgWrap {
  margin: 30px 0;
}
.col2Style .txtBlock a,
#forbusiness .txtBlock a,
#relocation .txtBlock a,
#privacypolicy .txtBlock a {
  color: #068acc;
  height: 25px;
  line-height: 25px;
  padding-bottom: 1px;
  border-bottom: 1px solid #068acc;
}
#shoplist td a,
#corporate dd a {
  color: #068acc;
  height: 25px;
  line-height: 25px;
  padding-bottom: 1px;
  border-bottom: 1px solid #068acc;
}
.col2Style .txtBlock li {
  margin: 5px 0;
  font-size: 12px;
}
.col2Style .txtBlock li .larger {
  font-size: 14px;
  margin-bottom: 10px;
}
.col2Style .txtBlock li span {
  width: 20px;
  display: inline-block;
}
.col2Style .imgWrap img {
  width: 40%;
  margin: 10px 0;
}
.col2Style .floatWrap {
  margin: 20px 0;
}
.col2Style .floatWrap:after {
  display: block;
  content: "";
  clear: both;
}
.col2Style .floatWrap img {
  width: 150px;
  float: left;
}
.col2Style .floatWrap .txt {
  padding-top: 5px;
  margin-left: 170px;
}
.col2Style .floatImg {
  text-align: center;
}
.col2Style .floatImg:after {
  display: block;
  content: "";
  clear: both;
}
.col2Style .floatImg .imgWrap {
  width: 50%;
  float: left;
}
.col2Style .floatImg .imgWrap img {
  width: 60%;
  margin: 20px 10%;
}
/***********************************
   お買い物ガイド
***********************************/
/***********************************
   ボタンデザイン
***********************************/
.common_btn {
  width: 250px;
  margin: 20px auto 50px;
  position: relative;
}
.common_btn a {
  display: block;
  padding: 15px 0;
  font-size: 16px;
  color: #fff;
  text-align: center;
  border-radius: 5px;
  background: #000;
}
.common_btn a i {
  display: inline-block;
  margin-left: 10px;
  font-size: 20px;
}
/***********************************
  TOPページ
***********************************/
/*新着アイテム*/
.top_newarrival ul {
  font-size: 0;
  text-align: left;
}
.top_newarrival li {
  float: none !important;
  display: inline-block;
  width: 23% !important;
  margin: 5px 1% 20px !important;
  padding: 10px;
  font-size: 12px;
  text-align: center;
  vertical-align: top;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
.top_newarrival li img {
  width: 100%;
}
.top_newarrival .sysItemName {
  font-size: 16px;
  font-weight: 500;
  padding-top: 10px;
}
/*特集一覧*/
.top_features {
  overflow: hidden;
}
.top_features ul {
  font-size: 0;
  text-align: left;
}
.top_features li {
  float: none !important;
  display: inline-block;
  width: 30%;
  margin: 1.66666666666667%;
  font-size: 12px;
  vertical-align: top;
}
.top_features li img {
  width: 100%;
}
.top_features li a {
  display: block;
  position: relative;
}
.top_features li span {
  display: block;
  font-size: 14px;
  font-weight: bold;
}
/*おすすめ商品、ランキング*/
.top_recommend_item li .sysItemName,
.top_ranking_item li .sysItemName {
  font-size: 16px;
  font-weight: 500;
  padding-top: 10px;
}
top_recommend_item .sysItemPrice,
top_ranking_item .sysItemPrice {
  font-size: 14px;
  color: #f00;
  font-weight: 600;
  padding-top: 5px;
}

/*おすすめ商品*/
.top_recommend_item {
  margin-bottom: 60px;
}
.top_recommend_item li {
  width: 100% !important;
  padding: 0 20px !important;
}
/*ランキング*/
.top_ranking_item ul {
  font-size: 0;
  text-align: left;
}
.top_ranking_item li {
  float: none !important;
  display: inline-block;
  width: 30% !important;
  margin: 0 1.5% 30px !important;
  padding: 10px;
  font-size: 12px;
  text-align: center;
  vertical-align: top;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box;
}
/*クロネコペイボタン装飾調整*/
div#kuronekoPayFlex {
  margin-right: 21px;
}
.sysCart #sysMain #kuronekoPayFlex button img {
  margin-top: -11px;
}
.sysCart #sysMain button#kmid-login-subwindow-launch,
.sysCart #sysMain button[onclick="Sys('#kmid-login-subwindow-launch').click()"] {
  padding: 10px 0px 0px 0px;
}
.sysConfirmButton input#open_dlg_edit_customer_info {
  display: inline-block;
  padding: 10px;
  width: auto;
  height: auto;
  color: #000;
  background: #fff;
  border-radius: none;
  border: 1px solid #999;
  text-overflow: ellipsis;
  overflow: hidden;
  white-space: nowrap;
}
/*ソーシャルギフト*/
.opcSocialGiftLetter_message_edit {
  height: 200px;
}
.opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit {
  width: 80%;
}
.opcSocialGiftLetter_letterImageAndTitleGroup_edit {
  width: 20%;
  float: left;
  margin-right: 10px;
}
.opcSocialGiftLetter_messageTitleAndMessageGroup_edit {
  clear: both;
}
input.opcSocialGiftLetter_letterImageId_edit.opcCommonInputRadio:checked ~ .opcSocialGiftLetter_imageUrlGroup_edit {
  border: 3px solid #c03d3d;
}
.opcSocialGiftLetter_letterImageId_edit,
.opcSocialGiftLetter_letterImageIdTitle_edit {
  display: none;
}
.sysSocialGiftReceiveUrlSendLineButton {
  background: #00b900 !important;
  color: #fff !important;
  border: none !important;
}
.sysSocialGiftReceiveGiftLetterArea {
  width: 70%;
  border: 1px solid #999;
  border-radius: 5px;
  margin: 0 auto;
}
.sysSocialGiftReceiveGiftLetterMessage {
  padding: 10px;
}
.opcSocialGiftLetter_messageTitleLabel {
  display: none;
}
.sysSocialGiftReceiveGiftLetterMessage {
  height: 200px;
}
.sysSocialGiftReceiveButton {
  font-weight: bold;
  width: 30% !important;
  font-size: 20px;
  width: 70% !important;
}
/*カレンダー調整*/
.sysNextCalendar {
  z-index: 0;
}
.sysPrevCalendar {
  z-index: 0;
}
/* title
============================================================ */
.detail-main-wrap .main-item-name {
  font-size: 32px;
  font-weight: bold;
  color: #5d0909;
  margin-bottom: 6px;
}
.detail-main-wrap .sub-item-name {
  font-size: 32px;
  font-weight: bold;
  color: #5d0909;
  line-height: 1.2;
}
.category-icon {
  margin-bottom: 10px;
}
/* free-area
============================================================ */
.free-area {
  margin-top: 30px;
}
/* detail-main-wrap
============================================================ */
.detail-main-wrap {
  padding: 40px 40px;
  box-sizing: border-box;
  background-color: #fff;
}
.item-detail-disc-table {
  margin: 40px 0 60px;
}
.item-detail-disc-table table th,
.item-detail-disc-table table td {
  vertical-align: top;
  padding: 18px 25px;
  box-sizing: border-box;
  text-align: left;
  border-bottom: solid 1px #dfd8c7;
  background-color: #f6f3ee;
}
.item-detail-disc-table table tr:last-child th,
.item-detail-disc-table table tr:last-child td {
  border-bottom: none;
}
.item-detail-disc-table table th {
  width: 130px;
  font-weight: bold;
}
.item-detail-disc-table table td {
  padding-left: 10px;
}
.item-main-detail {
  padding-bottom: 20px;
  border-bottom: solid 1px #ddd;
  margin-bottom: 60px;
}
/* detail disc
============================================================ */
.product-detail-sns li {
  margin-right: 10px;
}
.item-detail-img-area {
  width: 350px;
  float: left;
  overflow: hidden;
}
.detail-slider-section {
  margin: 0 0 20px 0;
/*opacity: 0;*/
}
.detail-slide-thumb {
  margin: 7.5px 0 0;
}
.detail-slide-thumb li {
  width: 110px;
  height: 110px;
  line-height: 90px;
  text-align: center;
  margin-right: 10px;
  border: solid 1px #ddd;
  box-sizing: border-box;
  padding: 10px;
}
.detail-slide-thumb li:last-child {
  margin-right: 0;
}
.detail-slide-thumb li .active img {
  opacity: 0.8;
}
#product.detail .detail-bxslider {
  background-color: #fff;
}
#product.detail .detail-bxslider>li {
  width: 350px;
  height: 350px;
  line-height: 320px;
  text-align: center;
  border: solid 1px #ddd;
  box-sizing: border-box;
  padding: 10px;
}
#product.detail .detail-bxslider>li span {
  text-align: center;
  vertical-align: middle !important;
}
.detail-slide-thumb li img,
.detail-bxslider img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  vertical-align: middle !important;
  margin: 0 auto;
}
.item-detail-disc-area .disc-wrap {
  border-bottom: solid 1px #dfd8c7;
  padding: 26px 0;
}
.item-detail-disc-area .disc-wrap .alert {
  font-size: 13px;
  font-weight: bold;
  text-align: center;
  color: #ce414c;
  padding: 12px 10px 12px;
  background-color: #f5d9db;
  margin-bottom: 15px;
  line-height: 1.8;
  height: auto;
  box-sizing: border-box;
}
.item-detail-disc-area .disc-wrap-last {
  padding: 26px 0;
}
.item-detail-disc-area .disc-wrap-last li {
  width: 160px;
  margin-right: 10px;
}
.item-detail-disc-area .disc-wrap-last li:nth-child(3n) {
  margin-right: 0;
}
.item-detail-disc-area .disc-wrap-last li a {
  display: table;
  text-align: center;
  padding: 0 0 0;
  width: 160px;
  height: 52px;
  background-color: #faf8f3;
  color: #000;
  font-size: 14px;
  line-height: 1.4;
}
.item-detail-disc-area .disc-wrap-last li a span {
  display: table-cell;
  height: 52px;
  vertical-align: middle;
}
.item-detail-disc-area .disc-wrap-last li a .star:before {
  content: "★";
  color: #ff9000;
}
.item-detail-disc-area .disc-wrap-last li a:hover {
  text-decoration: none;
}
.bn-wrap a {
  text-decoration: none;
}
.item-detail-disc-area .disc-wrap .inner-table-01 th {
  width: 70px;
  text-align: left;
  vertical-align: top;
}
.item-detail-disc-area .disc-wrap .inner-table-01 td {
  text-align: left;
}
.item-detail-disc-area .disc-wrap .inner-table-02>tbody>tr>th {
  width: 105px;
  text-align: left;
  vertical-align: top;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td {
  text-align: left;
  font-size: 14px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li {
  width: 50%;
  padding-left: 10px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li th {
  font-size: 13px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li td {
  text-align: right;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li td .rating span {
  margin-left: 0;
  position: relative;
  top: -4px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li td .rating span img {
  width: 14px;
  height: auto;
}
/* title
============================================================ */
.detail-main-wrap .main-item-name {
  font-size: 32px;
  font-weight: bold;
  color: #5d0909;
  margin-bottom: 6px;
}
.detail-main-wrap .sub-item-name {
  font-size: 32px;
  font-weight: bold;
  color: #5d0909;
  line-height: 1.2;
}
.category-icon {
  margin-bottom: 10px;
}
/* free-area
============================================================ */
.free-area {
  margin-top: 30px;
}
/* detail-main-wrap
============================================================ */
.detail-main-wrap {
  padding: 40px 40px;
  box-sizing: border-box;
  background-color: #fff;
}
.item-detail-disc-table {
  margin: 40px 0 60px;
}
.item-detail-disc-table table th,
.item-detail-disc-table table td {
  vertical-align: top;
  padding: 18px 25px;
  box-sizing: border-box;
  text-align: left;
  border-bottom: solid 1px #dfd8c7;
  background-color: #f6f3ee;
}
.item-detail-disc-table table tr:last-child th,
.item-detail-disc-table table tr:last-child td {
  border-bottom: none;
}
.item-detail-disc-table table th {
  width: 130px;
  font-weight: bold;
}
.item-detail-disc-table table td {
  padding-left: 10px;
}
.item-main-detail {
  padding-bottom: 20px;
  border-bottom: solid 1px #ddd;
  margin-bottom: 60px;
}
/* detail disc
============================================================ */
.product-detail-sns li {
  margin-right: 10px;
}
.item-detail-img-area {
  width: 350px;
  float: left;
  overflow: hidden;
}
.detail-slider-section {
  margin: 0 0 20px 0;
/*opacity: 0;*/
}
.detail-slide-thumb {
  margin: 7.5px 0 0;
}
.detail-slide-thumb li {
  width: 110px;
  height: 110px;
  line-height: 90px;
  text-align: center;
  margin-right: 10px;
  border: solid 1px #ddd;
  box-sizing: border-box;
  padding: 10px;
}
.detail-slide-thumb li:last-child {
  margin-right: 0;
}
.detail-slide-thumb li .active img {
  opacity: 0.8;
}
#product.detail .detail-bxslider {
  background-color: #fff;
}
#product.detail .detail-bxslider>li {
  width: 350px;
  height: 350px;
  line-height: 320px;
  text-align: center;
  border: solid 1px #ddd;
  box-sizing: border-box;
  padding: 10px;
}
#product.detail .detail-bxslider>li span {
  text-align: center;
  vertical-align: middle !important;
}
.detail-slide-thumb li img,
.detail-bxslider img {
  width: auto;
  height: auto;
  max-width: 100%;
  max-height: 100%;
  vertical-align: middle !important;
  margin: 0 auto;
}
.item-detail-disc-area .disc-wrap {
  border-bottom: solid 1px #dfd8c7;
  padding: 26px 0;
}
.item-detail-disc-area .disc-wrap .alert {
  font-size: 13px;
  font-weight: bold;
  text-align: center;
  color: #ce414c;
  padding: 12px 10px 12px;
  background-color: #f5d9db;
  margin-bottom: 15px;
  line-height: 1.8;
  height: auto;
  box-sizing: border-box;
}
.item-detail-disc-area .disc-wrap-last {
  padding: 26px 0;
}
.item-detail-disc-area .disc-wrap-last li {
  width: 160px;
  margin-right: 10px;
}
.item-detail-disc-area .disc-wrap-last li:nth-child(3n) {
  margin-right: 0;
}
.item-detail-disc-area .disc-wrap-last li a {
  display: table;
  text-align: center;
  padding: 0 0 0;
  width: 160px;
  height: 52px;
  background-color: #faf8f3;
  color: #000;
  font-size: 14px;
  line-height: 1.4;
}
.item-detail-disc-area .disc-wrap-last li a span {
  display: table-cell;
  height: 52px;
  vertical-align: middle;
}
.item-detail-disc-area .disc-wrap-last li a .star:before {
  content: "★";
  color: #ff9000;
}
.item-detail-disc-area .disc-wrap-last li a:hover {
  text-decoration: none;
}
.bn-wrap a {
  text-decoration: none;
}
.item-detail-disc-area .disc-wrap .inner-table-01 th {
  width: 70px;
  text-align: left;
  vertical-align: top;
}
.item-detail-disc-area .disc-wrap .inner-table-01 td {
  text-align: left;
}
.item-detail-disc-area .disc-wrap .inner-table-02>tbody>tr>th {
  width: 105px;
  text-align: left;
  vertical-align: top;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td {
  text-align: left;
  font-size: 14px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li {
  width: 50%;
  padding-left: 10px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li th {
  font-size: 13px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li td {
  text-align: right;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li td .rating span {
  margin-left: 0;
  position: relative;
  top: -4px;
}
.item-detail-disc-area .disc-wrap .inner-table-02 td li td .rating span img {
  width: 14px;
  height: auto;
}
@-moz-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-webkit-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@-o-keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

.sysMypage .sysKuronekoB2bService form input[value="取引先登録"] {
    width: 100%;
    padding: 16px;
    border: none;
    border-radius: 5px;
    color: #fff;
    background: #417c69;
}
.sysKuronekoB2bStatus{
margin-bottom: 15px;
}
.sysMypageNav > form input[value="クロネコ掛け払いサービス"]{
background: #417c69;
}
.sysMypageNav > form input[value="会員情報を編集する"]{
background: #FFD700;
color:#000000;
}
.sysOrderList form input[name="submit"]{
    padding:4px;
    border: none;
    border-radius: 4px;
    color: #fff;
    font-weight: 700;
    background: #ff8400;
    margin: 4px 0;
}
/*20260626rw*/
#sysMypageEditSave {
    margin-top: 100px;
}

body#sysMypageReminder .sysRemindForm input[type="submit"] {
    width: 300px;
    height: 65px;
    margin: 16px auto 0;
    padding: 0;
    border: none;
    border-radius: 40px;
    color: #fff;
    font-size: 18px;
    /* font-weight: 700; */
    background: #3c2609;
    margin: 0 auto;
    display: block;
}
/*20260626rw*/

.sysCallOrderHistoryDetail button{
    padding:4px;
    border: solid 0.5px;
    border-radius: 4px;
    font-weight: 700;
    background: #fff;
    margin: 4px 0;
}
.sysPrintDeliveryNote form button{
    padding:4px;
    border: none;
    border-radius: 4px;
    color: #fff;
    font-weight: 700;
    background: #00BFFF;
    margin: 4px 0;
}
.sysCallPrintReceipt form button{
    padding:4px;
    border: none;
    border-radius: 4px;
    color: #fff;
    font-weight: 700;
    background: #DC143C;
    margin: 4px 0;
}
.sysOrderList .sysOrder input[value="カートを見る"]{
    padding:4px;
    border: none;
    border-radius: 4px;
    color: #fff;
    font-weight: 700;
    background: #ba0402;
}

.top-raw .sysItemSuggestedPrice{
display:none;
}
body[data-member-login="true"] .top-raw .sysItemSuggestedPrice{
display:block;
}

.top-ranking .is-raw .sysItemSuggestedPrice{
display:none;
}
body[data-member-login="true"] .top-ranking .is-raw .sysItemSuggestedPrice{
display:block;
}

#sysMypageEditDelivery .sysDeliveryCardActions form input[value="編集"]{
background: 3c2609;
}

#sysMypageEditDelivery .sysDeliveryCardActions button{
    margin: 0 0 0 auto;
    padding: 12px 16px;
    border-radius: 4px;
    font-size: 18px;
    background: #fff;
    font-weight: 500;
    border: solid 0.5px;
}

.sysDeliveryFormActions form input[value="一覧に戻る"]{
    display: block;
    width: 130px;
    min-width: auto;
    height: 50px;
    line-height: 1;
    margin: 32px 0 0;
    border: 1px solid #583c32;
    border-radius: 4px;
    font-size: 12px;
    background: #fff;
    margin: auto 0;
}

@media screen and (max-width:750px){
@charset "UTF-8";
html {
  scroll-padding-top: 52px;
}
#sysFooter {
  padding: 40px 16px;
}
.footer-buynow {
  width: 80px;
  left: calc(100% - 80px);
  bottom: 56px;
  margin: 0 0 16px;
}
.footer-buynow-btn a {
  gap: 4px 0;
  height: 72px;
  font-size: 10px;
}
.footer-buynow-btn a:before {
  width: 16px;
  height: 16px;
}
.pagetop {
  width: 80px;
  left: calc(100% - 80px);
  bottom: 16px;
  margin: 0 0 16px;
}
.pagetop .footer-page-top {
  font-size: 10px;
}
.pagetop .footer-page-top:before {
  margin: 1px 8px 0 0;
}
.footer-ttl {
  margin: 0 0 24px;
  font-size: 18px;
}
.footer-ttl:before {
  margin-top: 3px;
}
.footer-item {
  display: block;
  margin: 0 0 24px;
}
.footer-item-label {
  width: auto;
  margin: 0 0 16px;
  padding: 8px;
}
.footer-item-txt {
  flex: 1;
}
.footer-item-txt small {
  display: inline-block;
  margin: 8px 0 0;
  font-size: 12px;
}
.footer-payment .footer-item-txt {
  display: block;
}
.footer-payment .footer-item-txt .footer-item-img {
  width: auto;
  margin: 0 0 16px;
  text-align: center;
}
.footer-btn {
  position: static;
}
.footer-btn a {
  justify-content: center;
  padding: 16px;
}
.footer-nav {
  margin: 40px auto 0;
  padding: 40px 0 0;
}
.footer-nav-inner {
  display: block;
}
.footer-nav-logo {
  margin: 0 0 24px;
  text-align: center;
}
.footer-nav-list {
  margin: 0 0 24px;
  padding: 0;
  border-left: none;
}
.footer-nav-list li + li {
  margin: 8px 0 0;
}
.footer-nav-bnr {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
  margin: 0 0 24px;
}
.footer-nav-bnr a {
  margin: 0;
}
.footer-nav-copyright {
  position: static;
  text-align: center;
}
.ai_chat_btn {
  left: calc(100% - 60px);
  bottom: 56px;
  width: 60px;
  height: 60px;
}
body:has(.footer-buynow) .ai_chat_btn {
  bottom: 144px;
}
.ai_chat_modal {
  top: 54%;
  width: 90%;
  height: 85%;
  min-width: unset;
}
.ai_chat_modal::after {
  width: 10.6666666667vw;
  height: 10.6666666667vw;
  top: -12.2666666667vw;
  right: 1.3333333333vw;
}
.ai_chat_modal .ai_chat_modal_inner iframe .relative {
  background-color: #333333;
}
.ai_chat_modal .ai_chat_modal_inner iframe .relative > .flex-col {
  background: #A76642 !important;
}
.ai_chat_modal .ai_chat_modal_inner iframe .relative > .flex-col .h-14 {
  background: #A76642 !important;
}
.ai_chat_modal .ai_chat_modal_inner iframe .group .w-full .rounded-2xl {
  background: #F7E6BB !important;
}
#sysHeader {
  display: flex;
  align-items: center;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  height: 52px;
  margin: 0;
  background: #f3f0ec;
  box-shadow: 0px 4px 10px 0px rgba(0,0,0,0.051);
  z-index: 1000;
}
#sysHeader .header_wrap {
  flex: 1;
}
.header {
  box-shadow: none;
}
.header-inner {
  height: auto;
  padding: 0 8px;
}
.header-logo {
  max-width: 150px;
}
.header-tel {
  display: none;
}
.header-nav {
  display: none;
}
.header.is-scroll {
  position: static;
}
.header.is-scroll .header-inner {
  height: auto;
}
.right-nav {
  flex-shrink: 0;
  position: static;
}
.right-nav-wrap {
  height: auto;
  border-left: none;
  background: none;
  box-shadow: none;
}
.right-nav-main {
  display: flex;
  margin: 0;
}
.right-nav-main li a,
.right-nav-main li span {
  width: 52px;
  height: 52px;
}
.right-nav-main-item-01 {
  display: none;
}
.right-nav-main-item-02 {
  order: 3;
}
.right-nav-main-item-02 img {
  width: 18px;
}
.right-nav-main-item-03 {
  border-bottom: none;
}
.right-nav-main-item-03 a {
  color: #3c2609;
  background: #fff;
}
.right-nav-main-item-03 a:before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  mask: url("/img/common/icon_login.svg") no-repeat 0 0/100% 100%;
  background: #3c2609;
}
.right-nav-main-item-03 a img {
  display: none;
}
.right-nav-main-item-04 {
  display: none;
}
.right-nav-main-item-05 {
  border-bottom: none;
  margin-left: 1px;
}
.right-nav-main-item-05 span {
  color: #3c2609;
  background: #fff;
}
.right-nav-main-item-05 span:before {
  content: "";
  display: block;
  width: 18px;
  height: 18px;
  mask: url("/img/common/icon_search.svg") no-repeat 0 0/100% 100%;
  background: #3c2609;
}
.right-nav-main-item-05 span img {
  display: none;
}
.right-nav-main .cart_in {
  top: 4px;
  right: 4px;
  width: 18px;
  height: 18px;
}
.right-nav-sub {
  display: none;
}
.right-nav-search {
  top: 52px;
  right: 0;
  width: 100vw;
  height: calc(100vh - 52px);
  overflow: auto;
  padding: 20px 20px 64px;
}
.right-nav-search.is-open {
  box-shadow: none;
}
.right-nav .side-search-ttl,
.right-nav .side-cat-ttl,
.right-nav .sysFuncItemCategory[class*="side_navi_"],
.right-nav .sysFuncText[class*="side_navi_"] {
  display: block;
}
.header-hbg {
  flex-shrink: 0;
  display: block;
}
.header-hbg-btn {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  gap: 4px 0;
  width: 52px;
  height: 52px;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  background: #3c2609;
}
.header-hbg-btn span {
  display: block;
  position: relative;
  width: 18px;
  height: 18px;
}
.header-hbg-btn span:before,
.header-hbg-btn span:after {
  content: "";
  position: absolute;
  width: 28px;
  height: 2px;
  left: 50%;
  border-radius: 2px;
  background: #fff;
  transform: translateX(-50%);
  transition: 0.3s;
}
.header-hbg-btn span:before {
  top: 4px;
}
.header-hbg-btn span:after {
  bottom: 4px;
}
.header-hbg-btn.is-open span:before,
.header-hbg-btn.is-open span:after {
  position: absolute;
  top: 50%;
  left: 50%;
  bottom: auto;
  width: 20px;
}
.header-hbg-btn.is-open span:before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.header-hbg-btn.is-open span:after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.header-hbg-nav {
  display: block;
  position: absolute;
  top: 52px;
  right: 0;
  width: 100vw;
  height: calc(100vh - 52px);
  overflow: auto;
  padding: 20px 20px 64px;
  background: #f3f0ec;
  transform: translateX(100%);
  transition: 0.3s;
}
.header-hbg-nav.is-open {
  transform: translateX(0);
}
.header-hbg-nav-list {
  overflow: hidden;
  margin: 0 0 20px;
  border: 1px solid #e4ded6;
  border-radius: 5px;
}
.header-hbg-nav-list li + li {
  border-top: 1px solid #e4ded6;
}
.header-hbg-nav-list li a {
  display: block;
  position: relative;
  padding: 16px;
  font-weight: 700;
  text-decoration: none;
  background: #fff;
}
.header-hbg-nav-list li a:after {
  content: "";
  position: absolute;
  top: 50%;
  right: 16px;
  width: 12px;
  height: 12px;
  mask: url("/img/common/icon_arrow_01.svg") no-repeat 0 0/100% 100%;
  background: #171717;
  transform: translateY(-50%);
}
.header-hbg-nav-list li.is-roasted a:after,
.header-hbg-nav-list li.is-green a:after {
  content: none;
}
.header-hbg-nav-list li.is-roasted a img,
.header-hbg-nav-list li.is-green a img {
  position: absolute;
  top: 50%;
  right: 16px;
  transform: translateY(-50%);
}
.header-hbg-nav-list li.is-roasted a {
  color: #8b540e;
}
.header-hbg-nav-list li.is-green a {
  color: #178242;
}
.header-hbg-nav-bnr li + li {
  margin: 10px 0 0;
}
.header-hbg-nav-bnr li a {
  display: block;
  overflow: hidden;
  border-radius: 5px;
  text-align: center;
}
.header-hbg-nav-close {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 8px;
  width: 123px;
  margin: 20px auto 0;
  padding: 11px 16px;
  border: 1px solid #171717;
  border-radius: 40px;
  font-size: 12px;
}
.header-hbg-nav-close i {
  display: block;
  position: relative;
  width: 14px;
  height: 14px;
}
.header-hbg-nav-close i:before,
.header-hbg-nav-close i:after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 16px;
  height: 2px;
  background: #3c2609;
  transition: 0.3s;
}
.header-hbg-nav-close i:before {
  transform: translate(-50%, -50%) rotate(45deg);
}
.header-hbg-nav-close i:after {
  transform: translate(-50%, -50%) rotate(-45deg);
}
#sysWrap {
  display: block;
  margin: 76px 16px 24px;
}
div#sysMain {
  width: auto;
  margin: 0 0 40px;
}
div#sysAside {
  width: auto;
  margin: 0 auto;
}
.side-type,
.side-search-ttl,
.side-cat-ttl,
.sysFuncItemCategory[class*="side_navi_"],
.sysFuncText[class*="side_navi_"],
.side-bnr {
  display: none;
}
body.sysCheckoutBody div#sysMain {
  margin: 76px 16px 40px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaTop .cart-notice {
  margin: 0 0 40px !important;
  padding: 24px 16px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaTop .cart-notice-ttl {
  margin: 0 0 24px !important;
  font-size: 16px;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaTop .cart-notice-subttl {
  margin: 0 0 16px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present {
  padding: 24px 16px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .ttl {
  margin: 0 auto 24px !important;
  font-size: 16px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img {
  gap: 0 24px !important;
  margin: 0 0 24px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img1 {
  width: 88px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img2 {
  flex-shrink: 0 !important;
  width: 136px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .img3 {
  flex-shrink: 0 !important;
  width: 96px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .btn a {
  font-size: inherit !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .applied {
  gap: 0 24px !important;
}
body.sysCheckoutBody div#sysMain #sysCheckout#sysCheckout#sysCheckout#sysCheckout .sysCheckoutPageFreeAreaBottom .cart-present .txt {
  font-size: 12px !important;
}
body.sysCheckoutBody #sysAside {
  margin: 0 0 40px;
}
body.sysCheckoutBody #sysAside .top-special {
  margin: 0 0 40px;
  padding: 24px 16px;
}
body.sysCheckoutBody #sysAside .top-special .sysHeadline {
  margin: 0 0 24px;
}
body.sysCheckoutBody #sysAside .top-special .sysHeadline:before {
  width: 40px;
  height: 40px;
}
body.sysCheckoutBody #sysAside .top-special .sysHeadline:after {
  font-size: 12px;
}
body.sysCheckoutBody #sysAside .cart-history {
  padding: 0 16px;
}
body.sysCheckoutBody #sysAside .cart-history .sysHeadline {
  margin: 0 0 24px;
  font-size: 18px;
}
body.sysCheckoutBody #sysAside .cart-history .sysHeadline:before {
  width: 40px;
  height: 40px;
}
body.sysCheckoutBody #sysAside .cart-history .sysHeadline span {
  font-size: 12px;
}
body.sysCheckoutBody #sysAside .cart-history .sysItemBlock .sysHorizontal {
  grid-template-columns: repeat(2, 1fr);
  gap: 24px 16px;
}
#sysItemDetail article .sysPr {
  margin: 0 0 8px;
}
#sysItemDetail article > .sysItemName {
  margin: 0 0 24px;
  font-size: 18px;
}
#sysItemDetail article > .sysExplanation {
  margin: 0 0 24px;
}
#sysItemDetail article > .sysExplanation .item-explanation {
  margin: 0 0 24px;
  padding: 16px;
}
#sysItemDetail article > .sysExplanation .item-explanation-img {
  display: grid;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 16px;
  margin: 24px 0 0;
  padding: 24px 0 0;
}
#sysItemDetail:has(.bean-type-roasted) .sysVariationOptions {
  margin: 0 0 32px;
}
#sysItemDetail:has(.bean-type-roasted) .sysVariationOptions span {
  font-size: 28px;
}
#sysItemDetail .sysBlock.orderArea {
  display: block;
}
#sysItemDetail .sysBlock.orderArea .sysItemImages {
  width: auto;
  margin: 0 0 24px;
}
#sysItemDetail .sysBlock.orderArea .sysBlock.orderArea .sysItemNameWrap {
  margin: 24px 0 0;
  padding: 24px 0 0;
}
#sysItemDetail .sysBlock.orderArea .sysBlock.orderArea .sysItemName {
  font-size: 18px;
}
#sysItemDetail .print-button {
  display: none;
}
#sysItemDetail .sysSpecifications {
  margin: 0 0 24px;
}
#sysItemDetail .sysSpecifications .sysSpecTable td {
  display: block;
}
#sysItemDetail .sysSpecifications .sysSpecTable td.sysSpecItemFieldName {
  width: auto;
  padding: 16px 0 4px 16px;
  border-bottom: none;
}
#sysItemDetail .sysSpecifications .sysSpecTable td.sysSpecItemFieldContent {
  padding: 0 0 16px;
}
#sysItemDetail .sysForm + .sysForm {
  margin: 24px 0 0;
  padding: 24px 0 0;
}
#sysItemDetail .label-purchase {
  margin: 0 0 16px;
  padding: 8px 16px;
  font-size: 16px;
}
#sysItemDetail .label-purchase span {
  font-size: 20px;
}
#sysItemDetail .label-purchase:before {
  width: 14px;
  height: 14px;
  margin: 0 8px 0 0;
}
#sysItemDetail .sysVariationCartBlock .sysCartButton {
  height: 64px;
  padding: 0 0 0 40px;
  font-size: 16px;
}
#sysItemDetail #sysNumber {
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 8px;
}
#sysItemDetail #sysNumber select[name="num"] {
  flex: 1;
  min-width: inherit;
}
#sysItemDetail #sysNumber .sysNumArea {
  width: 100%;
  gap: 0 8px;
}
#sysItemDetail #sysNumber .sysNumArea button {
  flex: 1;
}
#sysItemDetail #sysNumber .sysNumArea button.sysBtnPlus {
  width: auto;
}
#sysItemDetail #sysNumber .sysNumArea button.sysBtnMinus {
  width: auto;
}
#sysItemDetail .greenbean-jute-notice {
  margin: 0 0 24px;
}
#sysItemDetail .greenbean-10kg-notice {
  margin: 0 0 24px;
}
#sysItemDetail .greenbean-login-link a {
  padding: 16px 40px 16px 16px;
}
#sysItemDetail .greenbean-login-link a:after {
  right: 16px;
}
#sysItemDetail #sysSubtotal {
  margin: 0 0 32px;
}
#sysItemDetail #sysSubtotal .sysSubtotalPrice span {
  font-size: 28px;
}
#sysItemDetail #sysSubmit {
  margin: 0 0 24px;
}
#sysItemDetail #sysSubmit input[type=submit] {
  height: 64px;
  padding: 0 0 0 40px;
  font-size: 16px;
}
#sysItemDetail #sysWishlist {
  float: none;
  width: auto;
  margin: 0 0 16px;
}
#sysItemDetail .sysShowWishlistButton {
  width: 100%;
  margin: 16px auto;
}
#sysItemDetail .sysFreeForm {
  float: none;
  width: auto;
}
#sysItemDetail .sysFreeForm input[type="submit"] {
  padding: 0 0 0 32px;
  background-position: calc(50% - 72px) 50%;
}
#sysItemDetail .modaal-content-container {
  padding: 0;
}
#sysItemDetail .mdl-dialog__content {
  padding: 0;
  color: inherit;
}
#sysItemDetail .rating-coffee {
  margin: 24px 0 0;
  padding: 24px 0 0;
}
.rating-coffee-list {
  padding: 16px;
}
.rating-coffee-item {
  display: block;
}
.rating-coffee-item-num {
  margin: 8px 0 0 16px;
}
.detail-yamato {
  margin: 40px 0;
}
.detail-history {
  margin: 0 0 40px;
  padding: 40px 0 0;
}
.detail-history .sysHeadline {
  margin: 0 0 24px;
  font-size: 18px;
}
.detail-recommend .sysHeadline {
  margin: 0 0 24px;
  font-size: 18px;
}
.detail-commercial-baked,
.detail-commercial-green {
  margin: 0 0 40px;
}
.detail-commercial-baked .sysHeadline,
.detail-commercial-green .sysHeadline {
  margin: 0 0 24px;
  padding: 0 0 8px 32px;
  font-size: 18px;
}
.detail-commercial-baked .sysHeadline:before,
.detail-commercial-green .sysHeadline:before {
  top: 3px;
  width: 24px;
  height: 24px;
}
.commercial-subttl {
  padding: 8px 16px;
  font-size: 16px;
}
.commercial-lead {
  margin: 0 0 24px;
}
.commercial-feature {
  display: block;
}
.commercial-feature-img {
  width: auto;
  margin: 0 0 16px;
}
.commercial-feature-img img {
  width: 100%;
}
.commercial-feature-ttl {
  margin: 0 0 16px;
  font-size: 16px;
}
.commercial-feature-ttl span {
  padding: 2px 8px;
  font-size: 10px;
}
.inquiry-guide {
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.form-inquiry .sysForm,
.form-products .sysForm,
.form-original-drip .sysForm,
.sysMemberRegister .sysForm {
  margin: 24px 0 0;
}
.form-inquiry .sysFormItem,
.form-products .sysFormItem,
.form-original-drip .sysFormItem,
.sysMemberRegister .sysFormItem {
  margin: 0 0 24px;
}
.form-inquiry .sysFormField input[name="item[4][answer][0]"],
.form-products .sysFormField input[name="item[4][answer][0]"],
.form-original-drip .sysFormField input[name="item[4][answer][0]"],
.sysMemberRegister .sysFormField input[name="item[4][answer][0]"] {
  width: 120px;
}
.form-inquiry .sysNextSubmit,
.form-products .sysNextSubmit,
.form-original-drip .sysNextSubmit,
.sysMemberRegister .sysNextSubmit {
  width: 100%;
  height: 56px;
  font-size: inherit;
}
.form-inquiry .pp,
.form-products .pp,
.form-original-drip .pp,
.sysMemberRegister .pp {
  padding: 16px;
}
#sysFormConfirm #sysMain {
  padding-bottom: 72px;
}
#sysFormConfirm .sysButton {
  transform: translateY(128px);
}
.form-thanks-tel {
  margin: 40px auto;
}
.list-ttl {
  margin: 0 0 24px;
  font-size: 18px;
}
.list-search .sysItemSearchForm {
  gap: 8px 16px;
  padding: 16px;
}
.sysItemSearchFormWord {
  width: 100%;
}
.sysItemSearchFormWord input[type="search"] {
  padding: 12px;
}
.sysItemSearchFormCategory,
.sysItemSearchFormPrice {
  width: 100%;
}
.sysItemSearchFormCategory select,
.sysItemSearchFormPrice select {
  width: 100%;
}
.sysItemSearchFormItemCategoryGroups,
.sysItemSearchFormItemPrGroups {
  margin: 8px 0 16px;
}
.sysSearchButton {
  width: 200px;
  margin: 0 auto;
  background-position: calc(50% - 28px) 50%;
}
.sysItemSearchFormInput {
  gap: 8px 16px;
  padding: 16px;
}
.pd_wrap {
  width: 152px;
}
.pd_ttl {
  padding: 10px 32px;
}
.pd_ttl:before {
  left: 12px;
}
.sysItemBlock ul.sysHorizontal,
.sysItemList ul.sysList {
  grid-template-columns: repeat(2, 1fr);
  gap: 24px 16px;
}
.sysItemBlock ul.sysHorizontal li .sysItemName,
.sysItemList ul.sysList li .sysItemName {
  font-size: inherit;
}
.sysItemBlock ul.sysHorizontal li #sysDescriptionMobile,
.sysItemList ul.sysList li #sysDescriptionMobile {
  display: none;
}
.sysItemBlock ul.sysHorizontal li .sysItemPrice,
.sysItemList ul.sysList li .sysItemPrice,
.sysItemBlock ul.sysHorizontal li .sysRetailPrice,
.sysItemList ul.sysList li .sysRetailPrice {
  font-size: 18px;
}
.sysItemPr {
  padding: 2px 4px;
  font-size: 10px;
}
.sysPagination ul {
  gap: 0 8px;
}
.sysPagination ul li a {
  width: 32px;
  height: 32px;
  line-height: 32px;
}
.sysMemberRegister #sysMain {
  margin: 0 16px 40px;
}
.sysMemberRegister #sysMain > h2 {
  display: none;
}
.sysMemberRegister #sysMain .sysHeadline {
  margin: 76px 0 24px;
  font-size: 18px;
}
.sysMemberRegister #sysMain .sysHeadline span {
  font-size: 12px;
}
.sysMemberRegister #sysMain .sysForm {
  margin: 0 -16px;
  padding: 24px 16px;
  border-radius: 0;
}
.sysMemberRegister #sysMain .sysForm:has(input[value="戻る"]) {
  margin: 0;
  padding: 0;
}
.sysMemberRegister #sysMain .point-present {
  margin: 0 0 40px;
  font-size: 18px;
}
.sysMemberRegister #sysMain .regist-line {
  margin: 0 0 40px;
}
.sysMemberRegister #sysMain .regist-line-label {
  margin: 0 0 16px;
  font-size: 16px;
}
.sysMemberRegister #sysMain .regist-line-btn a {
  width: auto;
  padding: 16px;
  font-size: 16px;
}
.sysMemberRegister .sysZipcode .sysFormField {
  width: 120px;
}
.sysMemberRegister .sysFormField + .sysFormLabel {
  margin-top: 32px;
}
.sysMemberRegister .sysFormCaution {
  margin-top: 8px;
}
.sysMemberRegister .sysFormCaution li {
  list-style: none;
}
.sysMemberRegister .sysFormField + .sysFormLabel {
  margin-top: 24px;
}
.sysMemberRegister .sysBirthday .sysFormField input[type="text"][size="2"] {
  width: 56px;
}
.sysMemberRegister .sysGender ul {
  gap: 0 16px;
}
.sysMemberRegister .sysMemberAgreement {
  padding: 16px;
}
.sysMemberRegister input[value="戻る"] {
  display: block;
  width: 130px;
  min-width: auto;
  height: 50px;
  line-height: 1;
  margin: 32px 0 0;
  border: 1px solid #583c32;
  border-radius: 4px;
  font-size: 12px;
  background: #fff;
}
.sysCategoryPankuzu,
.sysItemCategoryPankuzu,
.staticPankuzu {
  margin: 0 0 24px;
}
#sysItemDetail .sysCategoryPankuzu {
  margin: 40px 0;
}
.sysCategoryPankuzu .sysPankuzuRow,
.sysItemCategoryPankuzu .sysPankuzuRow,
.staticPankuzu .sysPankuzuRow {
  margin: 0 0 8px;
}
.sysCategoryPankuzu .sysPankuzuUrl,
.sysItemCategoryPankuzu .sysPankuzuUrl,
.staticPankuzu .sysPankuzuUrl {
  font-size: 10px;
}
.sysCategoryPankuzu .sysPankuzuUrl.sysPankuzuHome img,
.sysItemCategoryPankuzu .sysPankuzuUrl.sysPankuzuHome img,
.staticPankuzu .sysPankuzuUrl.sysPankuzuHome img {
  width: 12px;
}
.sysCategoryPankuzu .sysPankuzuUrl + .sysPankuzuUrl:before,
.sysItemCategoryPankuzu .sysPankuzuUrl + .sysPankuzuUrl:before,
.staticPankuzu .sysPankuzuUrl + .sysPankuzuUrl:before {
  width: 6px;
  height: 6px;
  margin: 5px 8px 0;
  border-width: 1px;
}
.btn-01 {
  padding: 16px 24px 16px 32px;
}
.btn-back {
  padding: 16px 32px 16px 24px;
}
body.sysMypage div#sysMain {
  margin: 0 16px 40px;
}
body.sysMypage div#sysMain .sysHeadline {
  margin: 76px 0 24px;
  font-size: 18px;
}
body.sysMypage div#sysMain .sysHeadline span {
  font-size: 12px;
}
body.sysMypage .sysLoginForm {
  display: block;
  margin: 0 -16px;
  padding: 24px 16px;
  border-radius: 0;
}
body.sysMypage .sysLoginFormLogin {
  margin: 0 0 32px;
}
body.sysMypage .sysLoginFormLogin .sysLoginButton {
        /* width: auto; */
        height: 56px;
        font-size: inherit;
        display: block;
        margin: 5px auto;
        width: 100%;
}
body.sysMypage .sysLoginFormLogin input[value="パスワードをお忘れの方はこちら"] {
  font-size: inherit;
}
body.sysMypage .mypage-registration-btn1 a {
  width: auto;
  height: 56px;
  font-size: inherit;
}
body.sysMypage .mypage-registration-btn2 a {
  width: auto;
  height: 56px;
}
body.sysMypage .sysAmazonLogin {
  margin: 32px 0 0;
}
.mypage-wrap {
  margin: 0 -16px;
  padding: 24px 16px;
  border-radius: 0;
}
.mypage-wrap .sysMypageMinorHeadLine {
  font-size: 16px;
}
.mypage-wrap .sysOrderList {
  padding: 24px 16px;
}
.sysMypageNav {
  grid-template-columns: repeat(1, 1fr);
  gap: 16px 0;
}
.sysMypage .sysForm {
  margin: 0 -16px;
  padding: 24px 16px;
  border-radius: 0;
}
.sysMypage .sysFormItem {
  margin: 0 0 24px;
}
.sysMypage .sysZipcode input[name="zipcode"] {
  width: 120px;
}
.sysMypage .sysBirthday .sysFormField input[type="text"][size="2"] {
  width: 56px;
}
.sysMypage input[value="戻る"] {
  margin: 32px 0 0;
}
.sysMypage .sysNextSubmit {
  width: 100%;
  font-size: inherit;
}
.sysMypage .sysSelectAddress {
  margin: 0 0 16px;
}
.sysMypage .sysSelectAddress button {
  padding: 16px 40px 16px 16px;
}
.sysMypage .sysSelectAddress button:after {
  right: 16px;
}
.sysMypage input[value="お気に入りから削除する"] {
  padding: 14px 0;
  font-size: 12px;
}
.news_all ul {
  margin: 0 0 24px;
}
.news_all ul li a {
  display: block;
  padding: 16px 40px 16px 16px;
}
.news_all ul li a time {
  margin: 0 0 4px;
  padding: 0;
}
.news_all ul li a:after {
  right: 16px;
}
.page-nav ul {
  gap: 8px;
}
.page-nav ul li a {
  padding: 12px 16px;
}
.page-nav ul li a:after {
  width: 8px;
  height: 8px;
}
.static-page h1,
#sysInformation .topics-detail-ttl {
  margin: 0 0 24px;
  font-size: 18px;
}
.static-page h2,
.sysNewsDetail h2 {
  margin: 56px 0 24px;
  font-size: 16px;
}
.static-page h2:after,
.sysNewsDetail h2:after {
  margin: 24px 0 0;
}
.static-page h3,
.sysNewsDetail h3 {
  font-size: 16px;
}
.static-page .table-01 th,
.sysNewsDetail .table-01 th {
  display: block;
  width: auto;
  padding: 8px 0 8px 16px;
}
.static-page .table-01 td,
.sysNewsDetail .table-01 td {
  display: block;
  padding: 8px 0;
}
.static-page .table-02 th,
.sysNewsDetail .table-02 th {
  padding: 8px;
}
.static-page .table-02 th span,
.sysNewsDetail .table-02 th span {
  display: block;
  margin: 0;
}
.static-page .table-02 td,
.sysNewsDetail .table-02 td {
  padding: 8px;
}
.faq-item-q {
  padding: 16px 20px 16px 40px;
}
.faq-item-q:before {
  top: 11px;
}
.faq-item-q:after {
  top: 20px;
}
.faq-item[open] {
  padding: 0 0 16px;
}
.faq-item[open] .faq-item-q:after {
  top: 24px;
}
.faq-item-a {
  padding: 16px 16px 16px 56px;
}
.faq-item-a:before {
  top: 16px;
  left: 16px;
}
.sysFuncBanner.feature .sysContent ul {
  display: block;
  margin: 0 0 24px;
}
.sysFuncBanner.feature .sysContent ul li {
  margin: 0 0 24px;
}
.feature-product {
  display: block;
  margin: 24px 0 0;
}
.feature-product + .feature-product {
  margin: 40px 0 0;
  padding: 40px 0 0;
}
.feature-product-img {
  width: auto;
  max-width: 300px;
  margin: 0 auto 24px;
}
.feature-product-data .rating-coffee {
  margin: 24px 0 0;
}
.feature-product-name {
  font-size: 18px;
}
.feature-product-price {
  margin: 36px 0 0;
}
.feature-product-price span {
  font-size: 24px;
}
.feature-product-btn {
  margin: 24px 0 0;
}
.feature-product-btn .btn-01 {
  min-width: auto;
  padding: 16px 24px;
}
.decaffeinated-points {
  grid-template-columns: repeat(1, 1fr);
  margin: 0 0 40px;
  padding: 16px;
}
.decaffeinated-point {
  gap: 16px 0;
  padding: 16px;
}
.decaffeinated-point img {
  width: auto;
  height: 56px;
}
.decaffeinated-steps {
  margin: 0 0 40px;
  padding: 0 0 40px;
}
.decaffeinated-step {
  padding: 24px 16px;
}
.decaffeinated-step:before {
  content: none;
}
.decaffeinated-step:after {
  content: none;
}
.decaffeinated-step img {
  display: block;
  position: static;
  margin: 24px auto 0;
  transform: none;
}
.reason-kv {
  margin: 0 0 24px;
}
.reason-lead {
  margin: 0 0 40px;
  padding: 0 0 24px;
}
.reason-point {
  display: block;
}
.reason-point + .reason-point {
  margin: 40px 0 0;
}
.reason-point-img {
  width: auto;
  margin: 0 0 24px;
}
.reason-point-img img {
  width: 100%;
}
.reason-point-02 .reason-point-img,
.reason-point-04 .reason-point-img {
  border-radius: 0 5px 5px 5px;
}
.reason-point-02 .reason-point-num,
.reason-point-04 .reason-point-num {
  right: auto;
  left: 0;
  text-align: left;
  background-image: url("/img/reason/img_09.png");
}
.reason-point-quality {
  margin: 24px 0 0;
  padding: 16px;
}
.reason-point-quality-ttl {
  font-size: inherit;
}
.reason-point-quality-ttl:before {
  margin: 3px 8px 0 0;
}
.reason-point-quality-list {
  grid-template-columns: repeat(1, 1fr);
  gap: 16px;
}
.reason-point-quality-item img {
  width: 100%;
}
.original-kv {
  margin: 0 0 24px;
}
.original-lead {
  margin: 0 0 24px;
}
.original-features {
  grid-template-columns: repeat(1, 1fr);
  gap: 16px 0;
  margin: 0 0 40px;
  padding: 16px;
}
.original-features-item {
  padding: 16px;
}
.original-features-item img {
  margin: 0 auto 16px;
}
.original-dripbags {
  display: block;
  margin: 0 0 40px;
}
.original-dripbags-main {
  margin: 0 0 24px;
}
.original-dripbags-img {
  width: auto;
  margin: 0 0 24px;
  text-align: center;
}
.original-dripbags-point {
  padding: 0;
}
.original-dripbags-point-list {
  grid-template-columns: repeat(1, 1fr);
}
.original-dripbags-point-item {
  padding: 16px 0;
}
.original-dripbags-point-item + .original-dripbags-point-item {
  border-top: 1px dashed #cdcdcd;
  border-left: none;
}
.original-dripbags-point-up {
  margin: 0;
  border-radius: 0;
  font-size: 16px;
}
.original-flow {
  padding: 0;
}
.original-flow-item {
  display: block;
  margin: 0 0 16px;
  padding: 24px 16px;
}
.original-flow-item:before {
  content: none;
}
.original-flow-item:after {
  content: none;
}
.original-flow-item-main {
  margin: 0 0 16px;
}
.original-flow-item-img {
  margin: 0 auto;
}
.original-examples {
  margin: 0 0 49px;
  padding: 0 16px;
}
.original-examples-slides {
  padding: 24px 0;
}
.original-examples-item {
  padding: 16px 0;
}
.original-examples-item-label {
  position: static;
  width: fit-content;
  margin: 0 auto 16px;
  padding: 6px 12px;
  transform: none;
}
.original-examples-item-tbl {
  margin: 0 16px;
}
.original-examples-item-tbl th {
  text-align: center;
}
.original-examples .swiper-button-next,
.original-examples .swiper-button-prev {
  width: 40px;
  height: 40px;
}
.original-examples .swiper-button-next svg,
.original-examples .swiper-button-prev svg {
  width: 12px;
  height: 12px;
}
.original-examples .swiper-button-next {
  right: 8px;
}
.original-examples .swiper-button-prev {
  left: 8px;
}
.original-examples-btns {
  flex-direction: column;
  gap: 16px 0;
}
.original-examples-btns .btn-01 {
  flex: 1;
}
.original-formbtn {
  margin: 24px 0 40px;
  text-align: center;
}
.liquid-kv {
  margin: 0 0 24px;
}
.liquid-jas img {
  width: 64px;
  margin: 0 0 8px 24px;
}
.liquid-needs {
  margin: 0 0 40px;
}
h2.liquid-needs-ttl {
  margin: 0;
  font-size: inherit;
}
.liquid-needs-inner {
  display: block;
  padding: 24px 16px;
}
.liquid-needs-inner:before {
  content: none;
}
.liquid-needs-item:before {
  top: 2px;
}
.liquid-points:before {
  content: none;
}
h2.liquid-points-ttl {
  font-size: 16px;
}
h2.liquid-points-ttl span {
  font-size: 12px;
}
.liquid-points-list {
  grid-template-columns: repeat(1, 1fr);
  gap: 16px;
  padding: 16px;
}
.liquid-point {
  padding: 24px 16px;
}
.liquid-point:nth-child(1) {
  grid-column: auto;
  padding-right: 16px;
}
.liquid-point:nth-child(1) .liquid-point-figure {
  position: static;
}
.liquid-point:nth-child(5) .liquid-point-body {
  padding-right: 96px;
}
.liquid-point:nth-child(5) .liquid-point-figure {
  position: absolute;
  top: 50%;
  right: 0;
  z-index: -1;
  transform: translateY(-50%);
}
.liquid-point-head {
  padding: 6px 0 0 40px;
}
.liquid-point-no {
  font-size: 24px;
}
h3.liquid-point-ttl {
  font-size: 16px;
}
.liquid-point-dl {
  display: block;
}
.liquid-point-dl dt {
  width: auto;
  margin: 0 0 8px;
}
.gas-kv {
  margin: 0 0 24px;
}
.gas-lead {
  margin: 0 0 24px;
}
.gas-features {
  margin: 0 0 24px;
}
.gas-spec {
  display: block;
}
.gas-spec-img {
  width: auto;
  text-align: center;
}
.gas-secret img {
  margin: 0 0 0 32px;
}
.gas-exp {
  grid-template-columns: repeat(1, 1fr);
  gap: 16px;
  margin: 0 0 24px;
  padding: 16px;
}
.gas-exp-item {
  padding: 16px;
}
.gas-exp-notes {
  padding: 8px 16px;
}
.gas-flow-intro {
  display: block;
  margin: 0 0 24px;
}
.gas-flow-intro-img {
  width: auto;
  margin: 0 0 24px;
  text-align: center;
}
.gas-flow {
  margin: 0 0 24px;
  padding: 0;
}
.gas-flow-item {
  display: block;
  margin: 0 0 16px;
  padding: 24px 16px;
}
.gas-flow-item:before {
  content: none;
}
.gas-flow-item:after {
  content: none;
}
.drip-kv {
  margin: 0 0 24px;
}
.drip-point {
  margin: 40px 0;
  padding: 24px 16px;
}
.drip-point ul {
  margin: 0 0 16px;
}
.drip-point img {
  display: block;
  position: static;
  margin: 0 auto;
  transform: none;
}
.drip-example {
  margin: 0 0 40px;
  padding: 0 0 24px;
}
.drip-example .img {
  margin: 0 16px 24px;
}
.drip-example .txt {
  padding: 0 16px;
}
.drip-tel {
  margin: 0 0 24px;
  padding: 24px 16px;
}
.drip-tel .tel a {
  font-size: 28px;
}
.drip-tel .tel a:before {
  width: 20px;
  height: 20px;
  margin: 6px 8px 0 0;
}
.form-original-drip .sysFormItem {
  padding: 24px 0 0;
}
.form-original-drip .sysFormField:has(input[value="77188"]),
.form-original-drip .sysFormField:has(input[value="77184"]) {
  grid-template-columns: repeat(1, 1fr);
  gap: 16px;
  padding: 24px 16px;
}
.form-original-drip .sysFormField:has(input[value="77188"]) label,
.form-original-drip .sysFormField:has(input[value="77184"]) label {
  padding: 16px;
}
.form-original-drip .sysFormField:has(input[value="77188"]) label:has(input[type="radio"]):before,
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]):before {
  left: 118px;
}
.form-original-drip .sysFormField:has(input[value="77188"]) label:has(input[type="radio"]:checked):after,
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]:checked):after {
  left: 124px;
}
.form-original-drip .sysFormField:has(input[value="77188"]) label img,
.form-original-drip .sysFormField:has(input[value="77184"]) label img {
  width: 80px;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label {
  padding: 28px 16px 24px;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]):before {
  top: 28px;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label:has(input[type="radio"]:checked):after {
  top: 34px;
}
.form-original-drip .sysFormField:has(input[value="77184"]) label img {
  margin-top: 0;
}
.form-original-drip .sysFormField .type {
  transform: translateY(-40%);
}
.form-original-drip .sysFormField .num {
  top: 56px;
  left: 118px;
  font-size: 10px;
}
.form-original-drip .sysFormField:has(input[value="77190"]) {
  gap: 16px;
}
.form-original-drip .sysFormField br + textarea[name="item[4][answer][0]"],
.form-original-drip .sysFormField br + select[name="item[5][answer][0]"],
.form-original-drip .sysFormField br + input[name="item[12][answer][0]"] {
  margin-top: 16px;
}
.form-original-drip .sysFormField input[name="item[9][answer][0]"] {
  width: 120px;
}
.notfound .ttl-en {
  font-size: 20px;
}
.notfound .ttl-en span {
  font-size: 32px;
}
.notfound .ttl-ja {
  margin: 0 0 40px;
  font-size: 18px;
}
.notfound .txt {
  margin: 0 0 40px;
  font-size: inherit;
}
.yamato-free {
  top: 96px;
  width: 80px;
  height: 80px;
  font-size: 8px;
}
.yamato-free span {
  font-size: 16px;
}
.yamato-intro {
  margin: 0 0 24px;
  padding: 40px 16px 24px;
}
.yamato-intro-logo {
  display: none;
}
.yamato-merit {
  grid-template-columns: repeat(1, 1fr);
  gap: 16px;
  margin: 0 0 24px;
  padding: 24px 16px;
}
.yamato-merit-item {
  padding: 40px 0 16px;
}
.yamato-merit-item-label {
  top: -8px;
  left: 16px;
}
.yamato-merit-item-txt {
  font-size: inherit;
}
.yamato-img {
  margin: 24px 0;
}
.yamato-pay th {
  width: auto;
}
.yamato-flow {
  margin: 0 0 24px;
  padding: 0;
}
.yamato-flow-item {
  display: block;
  margin: 0 0 16px;
  padding: 24px 16px;
}
.yamato-flow-item:before {
  content: none;
}
.yamato-flow-item:after {
  content: none;
}
.yamato-contact th {
  width: 80px;
}
.yamato-bnr {
  margin: 40px 0 0;
}
.top-slide {
  height: auto;
}
.top-slide-inner:before {
  content: none;
}
.top-slide .swiper-slide {
  width: auto;
}
.top-slide .swiper-slide a:after {
  width: 32px;
  height: 32px;
}
.top-slide .swiper-slide a img {
  border-radius: 8px;
}
.top-slide .swiper-button-next,
.top-slide .swiper-button-prev {
  width: 40px;
  height: 40px;
}
.top-slide .swiper-button-next svg,
.top-slide .swiper-button-prev svg {
  width: 10px;
  height: 10px;
}
.top-slide .swiper-button-next {
  left: auto;
  right: -8px;
  transform: translateY(-50%);
}
.top-slide .swiper-button-prev {
  left: -8px;
  transform: translateY(-50%);
}
.top-slide .swiper-pagination {
  gap: 0 8px;
}
.top-type-inner {
  display: block;
}
.top-type-inner a {
  margin: 0 0 24px;
  border-radius: 8px;
}
.top-type-inner a img {
  width: 100%;
}
.top-pickup {
  display: block;
  margin: 0 0 40px;
  padding: 16px;
  border-radius: 8px;
}
.top-pickup .sysHeadline {
  margin: 0 0 8px;
  padding-top: 0;
}
.top-pickup .sysHeadline:before {
  top: -1px;
}
.top-pickup .sysContent {
  border-left: none;
}
.top-pickup .sysContent ul {
  padding: 0;
}
.top-pickup .sysContent li a {
  display: block;
}
.top-pickup .sysContent li a time {
  margin: 0 0 4px;
  padding: 0;
}
.top-baked {
  margin: 0 0 40px;
}
.top-baked .sysHeadline {
  margin: 0 0 24px;
  padding: 0 0 8px 32px;
  font-size: 18px;
}
.top-baked .sysHeadline:before {
  top: 3px;
  width: 24px;
  height: 24px;
}
.top-baked .sysContent ul {
  gap: 24px 16px;
}
.top-baked-img:after {
  width: 32px;
  height: 32px;
}
.top-baked-ttl {
  font-size: inherit;
}
.top-baked-txt {
  font-size: 12px;
}
.top-baked-featured {
  margin: 0 -16px 40px;
  padding: 40px 16px;
  background: #f3f0ec;
}
.top-baked-featured:before {
  content: none;
}
.top-baked-featured .sysHeadline {
  margin: 0 0 24px;
  font-size: 18px;
}
.top-baked-featured .sysItemBlock {
  margin: 0;
}
.top-raw {
  margin: 0 0 40px;
}
.top-raw .sysHeadline {
  margin: 0 0 24px;
  padding: 0 0 8px 32px;
  font-size: 18px;
}
.top-raw .sysHeadline:before {
  top: 3px;
  width: 24px;
  height: 24px;
}
.top-ranking {
  margin: 0 0 40px;
}
.top-ranking-tab {
  margin: 0 0 24px;
}
.top-ranking-tab-item {
  flex: 1;
  width: auto;
  padding: 8px 16px;
  font-size: 14px;
  text-align: center;
}
.top-ranking-tab-item:before {
  flex-shrink: 0;
}
.top-ranking-content .sysIconRank {
  margin: 0 0 8px;
}
.top-ranking-content .sysIconRank img {
  width: 32px;
}
.top-special {
  margin: 0 0 40px;
}
.top-special .sysHeadline {
  margin: 0 0 24px;
  padding: 0 0 8px 32px;
  font-size: 18px;
}
.top-special .sysHeadline:before {
  top: 3px;
  width: 24px;
  height: 24px;
}
.top-special .sysContent ul {
  display: block;
  margin: 0 0 24px;
}
.top-special .sysContent ul li {
  margin: 0 0 24px;
}
.top-special .sysContent ul li:nth-child(n+3) {
  display: none;
}
.top-tea {
  margin: 0 -16px 40px;
  padding: 40px 16px;
  background: #fff1f5;
}
.top-tea:before {
  content: none;
}
.top-tea .sysHeadline {
  margin: 0 0 24px;
  font-size: 18px;
}
.top-tea .sysItemBlock {
  margin: 0;
}
.top-tea-comment {
  margin: 0 0 8px;
  padding: 8px;
}
.top-tea-comment:after {
  bottom: -8px;
  left: 24px;
  height: 16px;
}
.top-news {
  padding: 32px 16px;
  border-radius: 8px;
}
.top-news .sysHeadline {
  margin: 0 0 24px;
  font-size: 18px;
}
.top-news .sysHeadline:before {
  margin-top: 3px;
}
.top-news ul {
  margin: 0 0 24px;
}
.top-news ul li a {
  display: block;
  padding: 16px 40px 16px 16px;
}
.top-news ul li a time {
  margin: 0 0 4px;
  padding: 0;
}
.top-news ul li a:after {
  right: 16px;
}
.sysDisplayMobileNone {
  display: none !important;
}
/* 10-0 Only Smartphone
 *----------------------------------------------------------------------*/
.sysFormField label {
  display: block;
}
#sysFormIndex .txtBlock {
  text-align: left;
}
.grid-col {
  float: none;
  width: 100% !important;
  margin-left: 0;
}
/*Header */
/* Category Pankuzu */
.sysItemCategoryPankuzu {
  font-size: xx-small;
}
/* Archive Thumbnail Item */
.sysItemList ul.sysThumbnail {
  font-size: small;
}
.sysItemList ul.sysThumbnail input {
  font-size: x-small;
}
/* Order Area */
.orderArea {
  letter-spacing: normal;
}
.orderArea > div {
  width: 100%;
  padding-right: 0;
  float: none;
}
/*header検索ボックス*/
.h_search {
  margin-top: 30px;
}
/***********************************
  商品詳細ページ
***********************************/
/*商品名*/
#sysItemDetail .sysForm select {
  height: 30px;
  text-align: center;
}
#sysItemDetail .sysSelectionDescription {
  margin: 5px 0 10px;
}
#sysItemDetail #sysNumber {
  text-align: right;
}
/*数量増減*/
#sysItemDetail .sysNumArea button {
  width: 35%;
}
/*PRアイコン(商品カテゴリーページ)*/
#sysItemCategory input[type=submit] {
  margin-top: 0px;
}
.sysAddSelection {
  font-size: 12px;
}
.sysSelectionDescription {
  font-size: 10px;
}
/*PRアイコン(商品詳細ページ)*/
#sysItemDetail .sysForm select {
  min-width: 300px;
  display: inline-block;
  float: right;
}
#sysItemDetail .sysNumber select {
  min-width: 100px;
}
#sysItemDetail {
  padding-bottom: 40px;
}
/*商品ページ用おすすめ商品*/
.itempage_recommend .sysItemBlock .sysHorizontal li {
  width: 50%;
  padding: 0 5px;
  margin-bottom: 20px;
}
.itempage_recommend .sysItemName {
  font-size: 12px;
}
.itempage_recommend .sysItemPrice {
  font-size: 11px;
}
/*for demo 2017/01/12*/
span.sp_newline {
  display: block;
}
/***********************************
  ヘッダー
***********************************/
/***********************************
  カート情報
***********************************/
#cartInfo {
  display: none;
}
/***********************************
  ナビゲーション
***********************************/
#headNavigation .pcnone {
  display: block;
}
#headNavigation .spnone {
  display: none;
}
#headNavigation li.active {
  background: #fff;
}
.h_navi {
  width: 100%;
  height: 40px;
}
#headNavigation li.tab1 {
  width: 25%;
  margin-top: 10px;
}
#headNavigation li.tab1 a {
  font-size: 12px;
  line-height: 15px;
  position: relative;
}
#headNavigation li.tab1:nth-of-type(5) {
  display: none;
}
/*ナビゲーショントグル*/
.toggleNav {
  display: none;
  width: 100%;
  position: absolute;
  height: 0px; /*heightはjs制御*/
  top: 39px;
  left: 0;
  z-index: 110;
  background: rgba(0,0,0,0);
  box-shadow: 0px 0px 0px 0px #ccc;
  -moz-box-shadow: 0px 0px 0px 0px #ccc;
  -webkit-box-shadow: 0px 0px 0px 0px #ccc;
}
.toggleNav:hover {
  overflow: visible !important;
}
#headNavigation ul.tab {
  position: relative;
}
.tabmenu .border:after {
  content: none;
}
.tabmenu li.tab1 {
  position: static;
  border-right: 1px solid #000;
}
.tabmenu li.tab1:nth-child(4) {
  border-right: none;
}
.tabmenu li.tab1 a {
  font-size: 14px;
}
.tabmenu ul:after {
  display: block;
  content: "";
  clear: both;
}
.tabmenu li.tab2 {
  width: 100%;
  height: auto;
  text-align: left;
  line-height: 1;
  font-size: 18px;
  border-bottom: 1px dotted #ddd;
  position: relative;
  background: #fff;
}
.tabmenu li.tab2 a {
  display: block;
  position: relative;
  padding: 5px 15px;
  font-size: 14px !important;
  line-height: 40px !important;
  font-weight: bold;
}
#headNavigation li.tab2 a:after {
  display: none;
}
.tabmenu li.tab2 a i {
  position: absolute;
  right: 10px;
  top: 50%;
  margin-top: -7px;
}
.h_spnavi {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 0px;
  left: 0;
  background: rgba(220,220,220,0.9);
  z-index: 150;
  color: #444;
  display: none;
  overflow: auto;
}
#spNaviWrap {
  position: absolute;
  width: 100%;
  height: 1550px;
  top: 0px;
  left: -100%;
  background: #e1e1e1;
  z-index: 200;
  padding: 30px 10px 0;
  overflow: scroll;
}
/***********************************
  ログイン情報
***********************************/
.h_login .sysHeadline,
.h_search .sysHeadline {
  text-align: center;
  font-size: 18px;
  margin-botom: 10px;
}
.h_login .sysContent {
  text-align: center;
}
.h_login .sysFormItem {
  margin-bottom: 10px;
}
.h_login .sysFormLabel {
  display: block;
  font-size: 12px;
  height: 20px;
  text-align: left;
  margin-bottom: 3px;
}
.h_login .sysLoginButton {
  width: 100%;
  margin: 10px 0%;
  border-radius: 5px;
  background: #000;
  font-size: 15px;
  height: 35px;
  line-height: 10px;
}
.h_login li {
  border: 1px solid #444;
  margin-bottom: 10px;
  font-size: 15px;
  height: 35px;
  line-height: 32px;
  text-align: center;
  border-radius: 5px;
}
.h_login li a {
  font-size: 12px;
  padding: 0px 5px 5px 0px;
}
/***********************************
  ナビゲーションメニュー
***********************************/
#closeMenu {
  position: absolute;
  top: 15px;
  left: 15px;
  font-size: 15px;
}
#closeMenu span {
  font-size: 12px;
  margin: 0 10px;
  display: inline-block;
  cursor: pointer;
}
#closeMenu2 {
  text-align: center;
  margin: 20px 0;
  border: 1px solid #444;
  height: 40px;
  line-height: 40px;
  font-size: 15px;
  border-radius: 5px;
  cursor: pointer;
}
#closeMenu2 span {
  display: inline-block;
  margin: 0 10px;
}
#spNavMenu .navTitle {
  text-align: center;
  font-size: 18px;
  font-weight: bold;
}
#spNavMenu {
  margin: 30px 0 0;
}
#spNavMenu .spMenuList {
  height: auto;
  line-height: 40px;
  font-size: 15px;
  position: relative;
  border-bottom: 1px solid #aaa;
}
#spNavMenu .spMenuList a {
  display: block;
  padding-left: 15px;
}
#spNavMenu .spToggleNav {
  height: 270px;
  overflow: hidden;
}
#spNavMenu .spToggleNav li {
  height: 45px;
  line-height: 45px;
  font-size: 12px;
  border-bottom: 1px dotted #aaa;
}
#spNavMenu .spToggleNav li {
  padding-left: 20px;
}
#spNavMenu .spToggleNav li:first-child {
  border-top: 1px solid #aaa;
}
#spNavMenu .spToggleNav li:last-child {
  border-bottom: 0;
}
/***********************************
  フッター
***********************************/
/***********************************
  サイド
***********************************/
.side_search {
  width: 95%;
  margin: 0 auto 30px;
}
.side_navi_item,
.side_navi {
  width: 95%;
  margin: 0 auto;
}
.side_navi ul li.sysText a {
  padding: 10px 5px !important;
}
.side_navi_item .sysHeadline,
.side_navi_item .sysContent {
  width: 100% !important;
  margin: 0 auto !important;
}
.side_navi_1 {
  border-top: 1px solid #000;
}
/***********************************
  共通パーツ
***********************************/
.sysTitle {
  width: 100%;
  margin: 30px auto !important;
  position: relative;
  text-align: center;
  font-size: 13px;
  letter-spacing: auto;
}
.sysTitle b {
  display: block;
  font-size: 12px;
  text-align: center;
  margin-top: 5px;
}
.sysTitle span {
  position: relative;
  z-index: 2;
  display: inline-block;
  margin: 0 2.5em;
  padding: 0 10px 0 20px;
  background-color: #fff;
  text-align: center;
  font-weight: bold;
}
.sysTitle::before {
  position: absolute;
  top: 50%;
  z-index: 1;
  content: '';
  display: block;
  width: 100%;
  height: 1px;
  background-color: #222;
}
/*.sysHeadline{
  width: 95%;
  margin: 30px auto!important;
  position: static;
  font-size: 20px;
  letter-spacing: 3px;
}
.sysHeadline b{
  width: 100%;
  display: block;
  font-size: 10px;
  text-align: center;
  border-top: 1px solid #222222;
  padding: 0 80px;
  margin-top: 3px;
  padding-top: 5px;
}*/
.sysTitle span {
  position: relative;
  z-index: 2;
  display: inline-block;
  margin: 0;
  padding: 0;
  background-color: #fff;
  text-align: center;
}
.sysTitle::before,
.sysHeadline::before {
  height: 0px;
}
.contentsWrap {
  width: 90%;
  margin: 0 auto;
}
/***********************************
  特商法テーブルレイアウト
***********************************/
.p-law .sysTitle {
  width: 90%;
}
#main_tradelaw,
.main_tradelaw {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto 30px;
  border: 0px solid #ddd;
}
#main_tradelaw dl,
.main_tradelaw d {
  width: 100%;
  background: #ededed;
  border-bottom: 0px dotted #bfbfbf;
  overflow: hidden;
}
#main_tradelaw dl:after,
.main_tradelaw dl:after {
  display: block;
  content: "";
  clear: both;
}
#main_tradelaw dt,
.main_tradelaw dt {
  width: 100%;
  padding: 15px 0 15px 20px;
  float: none;
  clear: both;
  font-weight: bolder;
}
#main_tradelaw dd,
.main_tradelaw dd {
  margin-left: 0px;
  padding: 15px;
  background: #fff;
}
.shipFee {
  max-width: 1100px;
  margin: 20px auto;
}
.shipFee .tableTitle {
  text-align: center;
  font-size: 12px;
}
table.shipFeeTable {
  width: 100%;
  margin: 0%;
  border-collapse: collapse;
  margin-bottom: 30px;
  text-align: left;
  line-height: 1.5;
}
.spThead {
  display: block;
}
.pcThead {
  display: none;
}
table.shipFeeTable thead th {
  font-size: 12px;
  padding: 10px;
  font-weight: bold;
  vertical-align: top;
  color: #fff;
  text-align: left;
}
table.shipFeeTable tbody th {
  font-size: 12px;
  display: block;
  width: 100%;
  border: 0px solid #ddd;
}
table.shipFeeTable tbody .sum {
  position: relative;
  padding: 25px 10px;
  text-align: center;
}
table.shipFeeTable tbody .sum i {
  position: absolute;
  color: #888;
  font-size: 35px;
  left: 0;
  right: 0px;
  margin: auto;
  bottom: -20px;
  z-index: 20;
}
table.shipFeeTable td {
  display: block;
  width: 100%;
  vertical-align: top;
  border: 0px;
}
table.shipFeeTable b {
  color: #d42e30;
  display: inline-block;
  padding: 0 3px;
  font-size: 1.2em;
}
/***********************************
  2カラムレイアウト
***********************************/
.col2Style h2.pattern03 {
  height: 35px;
  line-height: 35px;
  font-size: 18px;
  padding: 0 0px 3px 10px;
  margin: 0 0 15px;
  border-bottom: 1px solid #6843ac;
}
.col2Style .txtBlock li {
  margin: 10px 0;
}
.col2Style .imgWrap img {
  width: 80%;
  margin: 0px 10%;
}
.col2Style .floatWrap img {
  width: 80%;
  margin: 0px 10%;
  float: none;
}
.col2Style .floatWrap .txt {
  padding-top: 5px;
  margin-left: 0px;
}
.col2Style .floatImg .imgWrap {
  width: 100%;
  float: none;
}
.col2Style .floatImg .imgWrap img {
  width: 80%;
  margin: 20px 10%;
}
/***********************************
  お買物ガイド
***********************************/
.indexList li {
  padding: 3px 5px;
  font-size: 12px;
}
.guideBlock {
  padding-top: 0;
  maergin-top: 30px;
}
/***********************************
  ご利用ガイド
***********************************/
.f_guide {
  margin-top: 30px;
}
.f_guide .sysContent {
  width: 100%;
  margin: 0 auto;
  text-align: center;
}
.f_guide .Title {
  font-size: 20px;
  text-align: center;
  padding: 20px 0 0px;
}
.f_guide .guideBlock {
  width: 95%;
  margin: 50px 2.5%;
  display: block;
  padding: 30px 0px 5px;
  border: 1px solid #424242;
  border-radius: 10px;
  position: relative;
}
.f_guide .guide01 {
  padding-right: 0px;
}
.f_guide .guide02 {
  padding-left: 0px;
}
.f_guide .guideTitle {
  width: 200px;
  margin: auto;
  text-align: center;
  margin-bottom: 10px;
  position: absolute;
  top: -15px;
  left: 0;
  right: 0;
  background: #fff;
  font-size: 15px;
}
.f_guide p {
  font-size: 15px;
  line-height: 20px;
  margin: 5px 0 !important;
  text-align: left;
  padding: 0 10px 0 15px;
}
.f_guide img {
  width: 100%;
}
.f_guide .mt {
  margin-top: 10px;
}
.f_guide .smaller {
  font-size: 12px;
}
.f_guide a.f_guide_btn {
  margin: 20px auto;
  float: none;
}
.f_guide .freedial {
  font-size: 30px;
}
/* カート内商品数表示*/
button.itemCount2 {
  display: none;
  position: absolute;
  bottom: 0px;
  right: 0px;
  background: rgba(207,15,42,0.9);
  border: none;
  width: 18px;
  height: 18px;
  border-radius: 10px;
  text-align: center;
  line-height: 15px;
  font-size: 10px;
  color: #fff;
  font-weight: bold;
}
/*商品購入ステップ*/
.steps ul {
  width: 350px;
}
.steps li {
  float: left;
  padding: 0 6px;
  height: 150px;
}
.steps li a {
  height: 150px !important;
}
.steps li img {
  height: 150px;
}
@media screen and (max-width: 350px) {
  .steps ul {
    width: 275px;
  }
  .steps li {
    float: left;
    padding: 0 2px;
    height: 100px;
  }
  .steps li a {
    height: 100px !important;
  }
  .steps li img {
    height: 100px;
  }
}
/* 決済ページ*/
/***********************************
  マイページ
***********************************/
/***********************************
  新規会員登録
***********************************/
/***********************************
  カートページ
***********************************/
/*ドメイン*/
.sysAcceptDomainArea .sysAcceptDomain a {
  padding: 0;
  font-size: 10px;
}
/***********************************
  ボタンデザイン
***********************************/
.common_btn {
  margin: 20px auto 30px;
}
/***********************************
  TOPページ
***********************************/
/*.トップスライダー*/
#slideShow {
  height: 130px;
}
.top_slider {
  padding-top: 0;
  margin: 120px auto 0;
}
.owl-dots .owl-dot {
  top: 0;
}
.owl-dots .owl-dot span {
  width: 10px;
  height: 10px;
  margin: 5px 7px;
}
.owl-nav [class*=owl-] {
  margin-top: -25px;
  width: 15px !important;
  height: 28px !important;
}
.owl-nav .owl-prev {
  left: 20%;
  background: url("/img/common/controls.png") no-repeat 0 0;
  background-size: 30px !important;
}
.owl-nav .owl-next {
  right: 20%;
  background: url("/img/common/controls.png") no-repeat -15px 0;
  background-size: 30px !important;
}
.owl-nav .owl-prev:hover {
  background-position: 0 0;
}
.owl-nav .owl-next:hover {
  background-position: -15px 0;
}
/*新着アイテム*/
.top_newarrival li {
  width: 30% !important;
  margin: 0 1.5% 30px !important;
  padding: 0 !important;
}
.top_newarrival li .sysItemName {
  padding-top: 0;
}
.top_newarrival li .sysItemPrice {
  font-size: 12px;
}
/*特集一覧*/
.top_features {
  overflow: hidden;
}
.top_recommend_item ul {
  font-size: 0;
  text-align: left;
}
.top_features li {
  width: 46%;
  margin: 2%;
}
.top_features li:nth-child(1),
.top_features li:nth-child(2) {
  position: relative;
  z-index: 10;
  width: 96%;
}
.top_features li:nth-child(1) p,
.top_features li:nth-child(2) p {
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 15;
  margin: 0;
  padding: 10px;
  background: rgba(255,255,255,0.8) none repeat scroll 0 0;
}
/*おすすめ商品、ランキング*/
.top_ranking_item li {
  width: 30% !important;
  margin: 0 1.5% 30px !important;
  padding: 0 !important;
}
.top_recommend_item li .sysItemName,
.top_ranking_item li .sysItemName {
  padding-top: 0;
}
.top_recommend_item li .sysItemPrice,
.top_ranking_item li .sysItemPrice {
  font-size: 12px;
}
.top_recommend_item li .sysCartButton,
.top_ranking_item li .sysCartButton {
  width: 100%;
  font-size: 10px;
  letter-spacing: -1px;
}
/*おすすめ商品*/
.top_recommend_item li {
  padding: 5px !important;
}
/***********************************
  ワンページカート
***********************************/
/*情報入力ページ調整*/
.sysOpcBody .header_wrap {
  border-bottom: none;
}
.sysOpcBody img {
  max-width: 100%;
}
.opcBillingAddress_genderMaleAndLabelGroup_edit,
.opcBillingAddress_genderFemaleAndLabelGroup_edit {
  width: 30% !important;
}
.opcBillingAddress_prefState_edit {
  margin: 5px 0;
  width: 100% !important;
}
.opcBillingAddress .opcCommonReferenceLabel {
  width: 70px;
  display: inline-block;
  position: relative;
}
.opcBillingAddress .opcCommonReferenceLabel::after {
  position: absolute;
  right: 0;
}
.opcDeliveryMethod .opcCommonReferenceLabel {
  width: 123px;
  display: inline-block;
  position: relative;
}
.opcDeliveryMethod .opcCommonReferenceLabel::after {
  position: absolute;
  right: 0;
}
.opcBillingAddress_addressGroup {
  width: calc(100% - 80px) !important;
}
.opcRemarks_remark_edit {
  width: 100% !important;
}
.opcOrderSummary_totalPriceLabel {
  font-size: 14px !important;
}
/*完了ページ調整*/


#sysMypageKuronekoB2b #sysMain{
margin-top: 115px;
}

#sysMypageReminder {
    margin-top: 100px;
}

}
@media screen and (min-width:751px) and (max-width:1100px){
@charset "UTF-8";
.sysDisplayTabletNone {
  display: none !important;
}
/* 20-0 Only Tablet
 *----------------------------------------------------------------------*/
/* 決済ページ*/
/*header検索ボックス*/
/***********************************
  商品詳細ページ
***********************************/
/***********************************
  ヘッダー
***********************************/
/***********************************
  カート情報
***********************************/
/***********************************
  ナビゲーション
***********************************/
/*ナビゲーショントグル*/
/***********************************
  ログイン情報
***********************************/
/***********************************
  ナビゲーションメニュー
***********************************/
/***********************************
  フッター
***********************************/
/***********************************
  サイド
***********************************/
/***********************************
  共通パーツ
***********************************/
/***********************************
  商法テーブルレイアウト
***********************************/
/***********************************
   フッター部分のご利用ガイド
***********************************/
/***********************************
  カート内商品数表示
***********************************/
/***********************************
  商品購入ステップ
***********************************/
/***********************************
  TOPページ
***********************************/
/*.トップスライダー*/
/***********************************
  ワンページカート
***********************************/
/*情報入力ページ調整*/

}
@media screen and (min-width:1101px){
a[href*="tel:"] {
  pointer-events: none;
}

.sysDisplayPcNone{
  display:none !important;
}
}
/* #END_OF_RESOURCE_FILE */
