* {
  font-family: "IwaUDRGoPro-Md", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
}
html {
  scroll-behavior: smooth;
}
@font-face {
  font-family: "hiragino-sans-gb-w3";
  src: url(../font/hiragino-sans-gb-w3.otf);
}
#cart-num {
  position: absolute; 
  border-radius: 0.8em; 
  background-color: #444433; 
  color: white; 
  font-size: 0.4em; 
  padding: 0 0.45em; 
  top:-0.7em; 
  right:-0.9em;
}
#cart-num-sp {
  position: absolute; 
  border-radius: 0.8em; 
  background-color: #444433; 
  color: white; 
  font-size: 0.4em; 
  padding: 0.1em 0.5em; 
  top:-0.4em; 
  right:-0.3em;
}
#cartModal #cart-support {
  width: 8em !important;
}
.container.footer-inner.row {
  padding-bottom: 0 !important;
}
.outline-none, .outline-none:focus, .outline-none:active {
  outline: none !important;
}
.font-family-1 {
  font-family: "hiragino-sans-gb-w3";
}
.font-14 {
  font-size: 14px !important;
}
.header {
  display: block;
}
.header-sp {
  display: none;
}
.main {
  margin-top: 190px;
  min-height: calc(100vh - 440px);
}
.footer-social-group-sp {
  display: none;
}
a {
  color: #444433;
}
a:hover {
  text-decoration: none;
  color: #888888;
}
a:hover #cart-num {
  background-color: #888888;
}
button.close:focus {
  outline: none;
}
.header {
  position: fixed;
  top: 0;
  width: 100%;
  background-color: white;
  z-index: 1000;
}
.header-sp {
  position: relative;
  z-index: 1000;
}
.header-top {
  padding: 20px 30px 10px;
}
.header-top-left {
  text-align: center;
}
.header-logo {
  width: 300px;
  transition: 0.4s;
}
.header-logo:hover {
  opacity: 0.7;
}
.header-top-right {
  display: none;
}
nav {
  border-bottom-style: solid;
  border-bottom-color: #ef6d15;
}
nav ul {
  list-style: none;
  display: flex;
  padding: 0px;
  justify-content: center;
  margin-bottom: 5px;
}
li {
  display: flex;
  height: 42px;
}
.li-1 {
  background-color: #ef6d15;
  border-radius: 6px;
  margin-right: 40px;
  padding-left: 20px;
  padding-right: 20px;
}
.li-1 a {
  color: white;
  margin: auto;
  font-size: 23px;

}
.li-2 a {
  font-size: 18px;
  height: 30px;
  margin: auto;
  padding-left: 20px;
  padding-right: 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  border-left-style: solid;
  border-left-width: 1px;
  border-left-color: #666666;
}
.li-3 {
  padding-left: 30px;
}
.li-3 a span {
  font-size: 18px;
}
.header-button-group {
  margin-left: 50px;
}
.li-3 a {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 30px;
  margin: auto;
}
.btn-custom-mypage {
  position: absolute; 
  font-size: 14px;
  padding: 6px 12px;
  width: 100px;
  bottom: -44px; 
  right: 12px; 
  z-index: 1000;
  color: #ffc107;
  background-color: white;
  border-color: #ffc107;
}
.btn-custom-mypage:hover {
  color: white;
  background-color: #ffc107;
}
.footer {
  margin-top: 20px;
  border-top-style: solid;
  border-top-color: #ef6d15;
  background-color: #fddac2;
}
.footer-inner {
  margin: auto;
  padding: 50px 20px 50px;
}
.footer-subtitle {
  font-size: 16px;
  margin-bottom: 10px;
}
.footer-item {
  font-size: 14px;
  font-family: Lato, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, メイリオ;
  font-weight: 600;
  padding-top: 12px;
  display: block;
  color: #444433;
}
.footer-social-group {
  padding-top: 20px;
}
.footer-social-item {
  font-size: 24px;
  margin-right: 1em;
}
.footer-input {
  font-size: 14px;
}
.footer-submit {
  margin-top: 8px;
}
.modal.right .modal-dialog {
  position: fixed !important;
  right: 0 !important;
  margin: auto !important;
  width: 360px !important;
  max-width: 80%;
  height: 100% !important;
}
.modal.right .modal-content {
  height: 100% !important;
  overflow-y: auto !important;
}
.modal-open .header {
  padding-right: 17px;
}
.btn-custom {
  margin-top: 8px;
  width: 106px;
  color: white;
  background-color: #ffc107;
  border-color: #ffc107;
}
.btn-custom:hover {
  color: white;
  background-color: #ffc107aa;
}
.btn-outline-custom {
  margin-top: 8px;
  width: 106px;
  color: #ffc107;
  background-color: white;
  border-color: #ffc107;
}
.btn-outline-custom:hover {
  color: white;
  background-color: #ffc107;
}
.btn-white {
  border: none;
  background-color: white;
}
.btn-white:focus {
  outline: none;
}
.btn-white:hover {
  color: #555555;
}
#cartModal {
  overflow-y: auto;
}
@media (max-width: 1199.98px) and (min-width: 992px) {
  .main {
    margin-top: 170px;
  }
  .header-logo {
    width: 250px;
  }
  .li-1 {
    margin-right: 30px;
  }
  .li-1 a {
    font-size: 18px !important;
  }
  .li-2 a {
    font-size: 16px !important;
  }
  .li-3 {
    padding-left: 15px !important;
  }
  .li-3 a {
    font-size: 26px;
  }
  .header-button-group {
    margin-left: 10px;
  }
  .li-3 a span {
    font-size: 16px;
  }
}

@media (max-width: 991.98px) and (min-width: 768px) {
  .main {
    margin-top: 150px;
  }
  .header-logo {
    width: 230px;
  }
  .li-1 {
    margin-right: 15px;
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  .li-1 a {
    font-size: 16px !important;
  }
  .li-2 a {
    font-size: 15px !important;
    padding-left: 10px;
    padding-right: 10px;
  }
  .li-3 {
    padding-left: 10px !important;
  }
  .li-3 a {
    font-size: 20px;
  }
  .header-button-group {
    margin-left: 0px;
  }
  .li-3 a span {
    font-size: 15px;
  }
  .footer-inner {
    margin: auto;
    padding: 50px 20px 50px;
  }
  .footer-subtitle {
    font-size: 16px;
    margin-bottom: 10px;
  }
  .footer-item {
    font-size: 14px;
    font-family: Lato, "Noto Sans JP", "Hiragino Kaku Gothic ProN", Meiryo, メイリオ;
    font-weight: 600;
    padding-top: 12px;
    display: block;
    color: #444433;
  }
  .footer-social-group {
    padding-top: 20px;
  }
  .footer-social-item {
    font-size: 24px;
    margin-right: 1em;
  }
  .footer-input {
    font-size: 14px;
  }
  .footer-submit {
    margin-top: 8px;
  }
}

@media (max-width: 767.98px) {
  .main {
    margin-top: 10px;
  }
  .header {
    display: none;
  }
  .header-sp {
    display: block;
    border-bottom-style: solid;
    border-bottom-color: #ef6d15;
  }
  .header-top-sp {
    padding: 10px 10px;
    display: flex;
    align-items: flex-end;
  }
  .header-button-group-sp {
    width: 100%;
    text-align: right;
    margin-bottom: 4px;
  }
  .header-button-sp {
    font-size: 24px;
    padding-right: 6px;
  }
  .header-logo-sp {
    width: 200px;
  }
  ul {
    padding: 0;
    margin: 0px;
    background-color: #ef6d15;
  }
  ul li {
    justify-content: center;
    border-bottom-style: solid;
    border-bottom-color: white;
    border-bottom-width: 1px;
  }
  .li-sp {
    display: flex;
  }
  .li-sp a {
    vertical-align: baseline;
    align-self: center;
    color: white;
  }
  .footer-social-group {
    display: none;
  }
  .footer-newsletter {
    padding-top: 30px;
  }
  .footer-social-group-sp {
    display: block;
    margin: 30px auto 20px;
  }
  .btn-custom-mypage {
    font-size: 12px;
    padding: 4px 6px;
    width: 74px;
    bottom: -40px; 
    right: 12px; 
  }
}

@media (max-width: 575.98px) {
  .header-logo-sp {
    width: 200px !important;
  }
  .header-button-group-sp {
    margin-bottom: 0px !important;
  }
  .header-button-sp {
    font-size: 20px !important;
  }
  .footer-inner {
    max-width: 350px;
  }
  .footer-block-2 {
    padding-top: 20px;
  }
  .footer-subtitle {
    text-decoration: underline;
  }
  .footer-item {
    padding-top: 6px;
  }
}

