/* utils
---------------------------------------------------*/
:root {
  --drop-shadow: drop-shadow(10px 10px 24px rgba(0, 0, 0, 0.1));
}

@media only screen and (max-width: 768px) {
  :root {
    --drop-shadow: drop-shadow(1.5625vw 1.5625vw 2.34375vw rgba(0, 0, 0, 0.1));
  }
}
/* body
---------------------------------------------------*/
body {
  background: #fff;
}

sup {
  top: -0.25em;
}

.josefin {
  font-family: "Josefin Sans", sans-serif;
  font-weight: 300;
}

/* wrap */
.wrap {
  width: 100%;
  color: #595757;
  font-family: "Noto Sans JP", sans-serif;
  overflow: hidden;
}
.wrap img {
  max-width: 100%;
  height: auto;
}

#Footer {
  margin-top: 0;
}

.btn_cart {
  border-color: #e5004f;
  background-color: #e5004f;
}

.btn_cart:hover a {
  color: #e5004f;
}

.btn_cart:hover a span:before {
  background-image: url(../img/icon_cart_on.png);
}

/* hero
---------------------------------------------------*/
#hero {
  position: relative;
  width: 100%;
  background: #F4F4F4;
  background: linear-gradient(0deg, rgb(244, 244, 244) 0%, rgb(229, 230, 230) 100%);
  margin: 0 auto;
  overflow: hidden;
}
#hero .inner {
  position: relative;
  width: 100%;
  aspect-ratio: 1300/640;
  margin: 0 auto;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  #hero .inner {
    aspect-ratio: 640/960;
  }
}
#hero .inner img {
  width: 100%;
  user-select: none;
  pointer-events: none;
}
#hero .inner .hero-icon {
  position: absolute;
  top: -0.78125%;
  left: -1.4615384615%;
  width: 15.3846153846%;
  z-index: 40;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-icon {
    top: -0.78125vw;
    left: -5.9375vw;
    width: 31.40625vw;
  }
}
#hero .inner .hero-title {
  position: absolute;
  top: 15.15625%;
  left: 44.3846153846%;
  width: 45.6153846154%;
  z-index: 30;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-title {
    top: 75.9375vw;
    left: 8.59375vw;
    width: 83.28125vw;
  }
}
#hero .inner .hero-model {
  position: absolute;
  top: -4.6875%;
  left: 0;
  width: 55.6923076923%;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-model {
    top: -3.59375vw;
    bottom: auto;
    width: 100%;
  }
}
#hero .inner .hero-pkg {
  position: absolute;
  top: 37.1875%;
  width: 3.1538461538%;
  filter: var(--drop-shadow);
  z-index: 20;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg {
    top: 95vw;
    width: 5.78125vw;
  }
}
#hero .inner .hero-pkg.pkg01 {
  left: 44.6153846154%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg.pkg01 {
    left: 8.75vw;
  }
}
#hero .inner .hero-pkg.pkg02 {
  left: 52.5384615385%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg.pkg02 {
    left: 23.28125vw;
  }
}
#hero .inner .hero-pkg.pkg03 {
  left: 60.4615384615%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg.pkg03 {
    left: 37.65625vw;
  }
}
#hero .inner .hero-pkg.pkg04 {
  left: 68.3076923077%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg.pkg04 {
    left: 52.03125vw;
  }
}
#hero .inner .hero-pkg.pkg05 {
  left: 76.2307692308%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg.pkg05 {
    left: 66.40625vw;
  }
}
#hero .inner .hero-pkg.pkg06 {
  left: 84.1538461538%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg.pkg06 {
    left: 80.9375vw;
  }
}
#hero .inner .hero-pkg-item {
  position: absolute;
  top: 45.3125%;
  width: 2.0769230769%;
  filter: var(--drop-shadow);
  z-index: 20;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg-item {
    top: 102.34375vw;
    width: 3.75vw;
  }
}
#hero .inner .hero-pkg-item.pkg-item01 {
  left: 48.4615384615%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg-item.pkg-item01 {
    left: 15.78125vw;
  }
}
#hero .inner .hero-pkg-item.pkg-item02 {
  left: 56.3846153846%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg-item.pkg-item02 {
    left: 30.3125vw;
  }
}
#hero .inner .hero-pkg-item.pkg-item03 {
  left: 64.2307692308%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg-item.pkg-item03 {
    left: 44.53125vw;
  }
}
#hero .inner .hero-pkg-item.pkg-item04 {
  left: 72.1538461538%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg-item.pkg-item04 {
    left: 59.0625vw;
  }
}
#hero .inner .hero-pkg-item.pkg-item05 {
  left: 80%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg-item.pkg-item05 {
    left: 73.28125vw;
  }
}
#hero .inner .hero-pkg-item.pkg-item06 {
  left: 87.9230769231%;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-pkg-item.pkg-item06 {
    left: 87.8125vw;
  }
}
#hero .inner .hero-bg {
  position: absolute;
  top: 3.125%;
  left: 0;
  width: 100%;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  #hero .inner .hero-bg {
    top: 5.46875vw;
    width: 100%;
  }
}

/* feature
---------------------------------------------------*/
#feature {
  position: relative;
  width: 100%;
  padding: 90px 0 110px;
}
@media only screen and (max-width: 768px) {
  #feature {
    padding: 10.9375vw 0 12.5vw;
  }
}
#feature .head {
  line-height: 1.56em;
  font-size: 32px;
  letter-spacing: 0.025em;
  text-align: center;
  margin-bottom: 46px;
}
@media only screen and (max-width: 768px) {
  #feature .head {
    line-height: 1.38em;
    font-size: 6.25vw;
    margin-bottom: 7.8125vw;
  }
}
#feature .head span {
  color: #e85298;
}
#feature ul.item-list {
  width: 568px;
  margin: 0 auto 40px;
}
@media only screen and (max-width: 768px) {
  #feature ul.item-list {
    width: 93.75vw;
    margin-bottom: 4.6875vw;
  }
}
#feature ul.item-list li:not(:first-child) {
  margin-top: 3.125vw;
}
#feature ul.item-list li.note {
  text-align: right;
  line-height: 1.6em;
  font-size: 11px;
  letter-spacing: 0.025em;
}
@media only screen and (max-width: 768px) {
  #feature ul.item-list li.note {
    font-size: 2.1875vw;
  }
}
#feature ul.item-list li img {
  width: 100%;
  filter: var(--drop-shadow);
}
#feature .name {
  text-align: center;
  line-height: 1.5em;
  font-size: 16px;
  letter-spacing: 0.025em;
  margin-bottom: 8px;
}
@media only screen and (max-width: 768px) {
  #feature .name {
    font-size: 2.8125vw;
    margin-bottom: 1.5625vw;
  }
}
#feature .price {
  text-align: center;
  line-height: 1.5em;
  font-size: 16px;
  letter-spacing: 0.025em;
  margin-bottom: 25px;
}
@media only screen and (max-width: 768px) {
  #feature .price {
    font-size: 2.8125vw;
    margin-bottom: 3.90625vw;
  }
}
#feature > .note {
  text-align: center;
  line-height: 1.5em;
  font-size: 11px;
  letter-spacing: 0.025em;
}
@media only screen and (max-width: 768px) {
  #feature > .note {
    font-size: 2.1875vw;
  }
}

/* detail
---------------------------------------------------*/
#detail {
  background-color: #f1efed;
  padding: 100px 0;
}
@media only screen and (max-width: 768px) {
  #detail {
    padding: 15.625vw 0;
  }
}

/* Color Lineup
---------------------------------------------------*/
#lineup {
  position: relative;
  width: 100%;
  margin-bottom: 100px;
}
@media only screen and (max-width: 768px) {
  #lineup {
    margin-bottom: 15.625vw;
  }
}
#lineup .lineup-title {
  text-align: center;
  font-size: 70px;
  font-weight: 300;
}
@media only screen and (max-width: 768px) {
  #lineup .lineup-title {
    font-size: 10.9375vw;
  }
}
#lineup .caption {
  text-align: center;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.025em;
  margin-top: 15px;
}
@media only screen and (max-width: 768px) {
  #lineup .caption {
    font-size: 3.4375vw;
    margin-top: 2.34375vw;
  }
}
#lineup .item-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  row-gap: 50px;
  width: 910px;
  margin: 58px auto 0;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list {
    flex-direction: column;
    width: 68.125vw;
    margin-top: 9.0625vw;
    column-gap: 4.6875vw;
  }
}
#lineup .item-list .item {
  position: relative;
  width: 405px;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item {
    width: 100%;
  }
}
#lineup .item-list .item .color-wrap {
  display: flex;
  align-items: center;
}
#lineup .item-list .item .eye {
  width: 160px;
  margin-right: 23px;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .eye {
    width: 25vw;
    margin-right: 3.59375vw;
  }
}
#lineup .item-list .item .txt-wrap {
  width: calc(100% - 183px);
  white-space: nowrap;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .txt-wrap {
    width: calc(100% - 28.59375vw);
  }
}
#lineup .item-list .item .color {
  font-size: 36px;
  font-weight: 400;
  margin-bottom: 4px;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .color {
    font-size: 5.625vw;
    margin-bottom: 0.625vw;
  }
}
#lineup .item-list .item .color-ja {
  font-size: 12px;
  letter-spacing: 0.025em;
  margin-bottom: 14px;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .color-ja {
    font-size: 1.875vw;
    margin-bottom: 2.1875vw;
  }
}
#lineup .item-list .item .txt {
  line-height: 1.56em;
  font-size: 16px;
  letter-spacing: 0.025em;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .txt {
    font-size: 2.5vw;
  }
}
#lineup .item-list .item .refill {
  text-align: right;
  margin-top: 17px;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .refill {
    margin-top: 2.65625vw;
  }
}
#lineup .item-list .item .refill img {
  width: 395px;
  filter: var(--drop-shadow);
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .refill img {
    width: 61.71875vw;
  }
}
#lineup .item-list .item .line {
  position: absolute;
  top: 130px;
  left: -16px;
  width: 130px;
  z-index: 10;
}
@media only screen and (max-width: 768px) {
  #lineup .item-list .item .line {
    top: 20.3125vw;
    left: -2.5vw;
    width: 20.3125vw;
  }
}
#lineup .item-list .item img {
  width: 100%;
}
#lineup .item-list .item.bk {
  color: #101010;
}
#lineup .item-list .item.dbr {
  color: #4c2b23;
}
#lineup .item-list .item.br {
  color: #78472e;
}
#lineup .item-list .item.mlb {
  color: #b1825b;
}
#lineup .item-list .item.mgr {
  color: #8b7970;
}
#lineup .item-list .item.rzb {
  color: #943c46;
}

/* spec-type-block
---------------------------------------------------*/
.spec-type-block {
  position: relative;
  width: 96%;
  max-width: 1180px;
  background-color: #fff;
  border-radius: 20px;
  filter: var(--drop-shadow);
  padding: 14px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .spec-type-block {
    width: 93.75vw;
    border-radius: 3.125vw;
    padding: 2.1875vw;
    margin-top: 7.03125vw;
  }
}
.spec-type-block-border {
  width: 100%;
  border: 3px solid #ededed;
  border-radius: 10px;
  padding: 50px 32px 24px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block-border {
    border-radius: 1.5625vw;
    padding: 7.8125vw 3.125vw 6.25vw;
  }
}
.spec-type-block-border > .note {
  text-align: center;
  color: #615d78;
  font-size: 12px;
  letter-spacing: 0.1em;
  margin-top: 24px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block-border > .note {
    font-size: 2.1875vw;
    margin-top: 7.34375vw;
  }
}
.spec-type-block-inner {
  position: relative;
  margin-bottom: 30px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block-inner {
    margin-bottom: 6.5625vw;
  }
}
.spec-type-block-inner .title {
  text-align: center;
  color: #615d78;
  font-size: 36px;
  font-weight: 400;
  letter-spacing: 0.1em;
  margin-bottom: 40px;
  font-feature-settings: "palt";
}
@media only screen and (max-width: 768px) {
  .spec-type-block-inner .title {
    line-height: 1.25em;
    font-size: 6.25vw;
    margin-bottom: 4.21875vw;
  }
}
.spec-type-block-inner .title span {
  color: #e85298;
}
.spec-type-block-inner .img {
  position: relative;
  width: 100%;
  max-width: 1080px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  .spec-type-block-inner .img {
    width: 149.0625vw;
    max-width: none;
  }
}
.spec-type-block-inner .img img {
  width: 100%;
}
.spec-type-block .function {
  text-align: center;
}
.spec-type-block .function img {
  max-width: 1003px;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .function img {
    width: 75.9375vw;
  }
}
.spec-type-block .cover {
  position: relative;
  overflow: hidden;
}
.spec-type-block .cover:after {
  position: absolute;
  content: "";
  bottom: 0;
  left: 0;
  width: 100%;
  height: 30px;
  background-color: transparent;
  z-index: 99;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .cover:after {
    height: 4.6875vw;
  }
}
.spec-type-block .scrollable {
  overflow: hidden;
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch;
  -webkit-appearance: none;
  padding-bottom: 0;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .scrollable {
    padding-bottom: 4.6875vw;
  }
}
.spec-type-block .scrollable::-webkit-scrollbar {
  display: none;
  -webkit-appearance: none;
}
.spec-type-block .scrollbar {
  display: none;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .scrollbar {
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 2px;
    background-color: #ddd;
  }
}
.spec-type-block .scrollbar-thumb {
  position: absolute;
  top: 50%;
  left: 0;
  transform: translate(0, -50%);
  width: 30px;
  aspect-ratio: 1/1;
  background-color: #ddd;
  border-radius: 50%;
  -webkit-border-radius: 50%;
}
@media only screen and (max-width: 768px) {
  .spec-type-block .scrollbar-thumb {
    width: 4.6875vw;
  }
}

/* howto
---------------------------------------------------*/
#howto {
  padding: 82px 0 100px;
}
@media only screen and (max-width: 768px) {
  #howto {
    padding: 12.8125vw 0 15.625vw;
  }
}
#howto .howto-title {
  text-align: center;
  font-size: 70px;
  font-weight: 300;
}
@media only screen and (max-width: 768px) {
  #howto .howto-title {
    font-size: 10.9375vw;
  }
}
#howto .caption {
  text-align: center;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.025em;
  margin-top: 10px;
}
@media only screen and (max-width: 768px) {
  #howto .caption {
    font-size: 3.4375vw;
    margin-top: 1.5625vw;
  }
}
#howto .howto-list {
  width: 820px;
  border-top: 1px solid #595757;
  margin: 62px auto 0;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list {
    width: 93.75vw;
    margin-top: 9.6875vw;
  }
}
#howto .howto-list li {
  border-bottom: 1px solid #595757;
  padding: 48px 0 40px;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list li {
    padding: 7.5vw 0 6.25vw;
  }
}
#howto .howto-list li .howto-wrap {
  position: relative;
}
#howto .howto-list li .num {
  position: absolute;
  top: -10px;
  left: 0;
  font-size: 80px;
  font-weight: 300;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list li .num {
    position: static;
    text-align: center;
    font-size: 12.5vw;
    margin-bottom: 1.5625vw;
  }
}
#howto .howto-list li .fig {
  text-align: center;
  margin-bottom: 30px;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list li .fig {
    margin-bottom: 4.6875vw;
  }
}
#howto .howto-list li .txt {
  text-align: center;
  line-height: 1.75em;
  font-size: 16px;
  letter-spacing: 0.025em;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list li .txt {
    text-align: left;
    font-size: 3.125vw;
    padding: 0 0.5em;
    letter-spacing: 0;
  }
}
#howto .howto-list li.howto01 .fig img {
  width: 629px;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list li.howto01 .fig img {
    width: 98.28125vw;
  }
}
#howto .howto-list li.howto02 .fig img {
  width: 614px;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list li.howto02 .fig img {
    width: 95.9375vw;
  }
}
#howto .howto-list li.howto03 .fig img {
  width: 407px;
}
@media only screen and (max-width: 768px) {
  #howto .howto-list li.howto03 .fig img {
    width: 63.59375vw;
  }
}
#howto .note {
  text-align: center;
  line-height: 1.6em;
  font-size: 11px;
  letter-spacing: 0.025em;
  margin-top: 50px;
}
@media only screen and (max-width: 768px) {
  #howto .note {
    font-size: 2.1875vw;
  }
}

/* sustainability
---------------------------------------------------*/
#sustainability {
  background-color: #fdf6ef;
  padding: 86px 0 0;
}
@media only screen and (max-width: 768px) {
  #sustainability {
    padding: 13.4375vw 0 0;
  }
}
#sustainability .sustainability-title {
  text-align: center;
  font-size: 70px;
  font-weight: 300;
}
@media only screen and (max-width: 768px) {
  #sustainability .sustainability-title {
    font-size: 10.9375vw;
  }
}
#sustainability .caption {
  text-align: center;
  line-height: 1.6em;
  font-size: 22px;
  font-weight: 500;
  letter-spacing: 0.025em;
  margin-top: 14px;
  margin-bottom: 42px;
}
@media only screen and (max-width: 768px) {
  #sustainability .caption {
    font-size: 3.4375vw;
    margin-top: 2.1875vw;
    margin-bottom: 6.5625vw;
  }
}
#sustainability .explain {
  margin-bottom: 34px;
}
@media only screen and (max-width: 768px) {
  #sustainability .explain {
    margin-bottom: 5.3125vw;
  }
}
#sustainability .explain p {
  text-align: center;
  line-height: 1.75em;
  font-size: 16px;
  font-weight: 500;
  letter-spacing: 0.025em;
}
@media only screen and (max-width: 768px) {
  #sustainability .explain p {
    text-align: left;
    font-size: 3.125vw;
    margin: 0 6.25vw;
  }
}
#sustainability .fig-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  column-gap: 45px;
}
@media only screen and (max-width: 768px) {
  #sustainability .fig-wrap {
    flex-direction: column;
    row-gap: 6.5625vw;
  }
}
#sustainability .fig-wrap .fig {
  width: 400px;
}
@media only screen and (max-width: 768px) {
  #sustainability .fig-wrap .fig {
    width: 62.5vw;
  }
}
#sustainability .fig-wrap .fig img {
  width: 100%;
}
#sustainability .fig-wrap .dots {
  position: relative;
  width: 30px;
  aspect-ratio: 1/1;
  background-color: #fff;
  border-radius: 50%;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  #sustainability .fig-wrap .dots {
    width: 4.6875vw;
  }
}
#sustainability .fig-wrap .dots::before, #sustainability .fig-wrap .dots::after {
  content: "";
  position: absolute;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: #fff;
  border-radius: 50%;
  z-index: -1;
}
#sustainability .fig-wrap .dots::before {
  left: -58px;
}
@media only screen and (max-width: 768px) {
  #sustainability .fig-wrap .dots::before {
    left: 0;
    top: -9.0625vw;
  }
}
#sustainability .fig-wrap .dots::after {
  right: -58px;
}
@media only screen and (max-width: 768px) {
  #sustainability .fig-wrap .dots::after {
    right: 0;
    top: 9.0625vw;
  }
}
#sustainability .note {
  text-align: center;
  line-height: 1.75em;
  font-size: 11px;
  letter-spacing: 0.025em;
  margin-top: 38px;
}
@media only screen and (max-width: 768px) {
  #sustainability .note {
    text-align: left;
    font-size: 2.5vw;
    margin: 7.8125vw 6.25vw 0;
  }
}
#sustainability .sdgs-block {
  background: #E0D8CA;
  background: linear-gradient(90deg, rgb(224, 216, 202) 0%, rgb(224, 216, 202) 50%, rgb(228, 237, 223) 50%, rgb(228, 237, 223) 100%);
  margin-top: 80px;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block {
    background: #E0D8CA;
    margin-top: 12.5vw;
  }
}
#sustainability .sdgs-block .sdgs-wrap {
  display: flex;
  justify-content: center;
  width: 100%;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap {
    flex-direction: column;
  }
}
#sustainability .sdgs-block .sdgs-wrap .sdgs {
  width: 50%;
  padding-bottom: 67px;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap .sdgs {
    width: 100%;
    padding-bottom: 7.8125vw;
  }
}
#sustainability .sdgs-block .sdgs-wrap .sdgs .title {
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 80px;
  text-align: center;
  line-height: 1.2em;
  color: #fff;
  font-size: 22px;
  letter-spacing: 0.025em;
  z-index: 1;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap .sdgs .title {
    height: 12.5vw;
    font-size: 3.75vw;
  }
}
#sustainability .sdgs-block .sdgs-wrap .sdgs .title::before {
  content: "";
  position: absolute;
  top: 0;
  width: 50vw;
  height: 100%;
  z-index: -1;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap .sdgs .title::before {
    display: none;
  }
}
#sustainability .sdgs-block .sdgs-wrap .sdgs .fig {
  text-align: center;
  margin: 75px auto 40px;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap .sdgs .fig {
    margin: 11.25vw auto 7.5vw;
  }
}
#sustainability .sdgs-block .sdgs-wrap .sdgs .fig img {
  width: 100%;
}
#sustainability .sdgs-block .sdgs-wrap .sdgs p {
  width: 82.8%;
  max-width: 540px;
  line-height: 1.75em;
  font-size: 16px;
  margin: 0 auto;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap .sdgs p {
    max-width: none;
    font-size: 2.8125vw;
  }
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-12 {
  background-color: #e0d8ca;
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-12 .title {
  background-color: #8a5300;
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-12 .title::before {
  right: 0;
  background-color: #8a5300;
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-12 .fig {
  width: 150px;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-12 .fig {
    width: 23.4375vw;
  }
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-15 {
  background-color: #e4eddf;
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-15 .title {
  background-color: #3a8a00;
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-15 .title::before {
  left: 0;
  background-color: #3a8a00;
}
#sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-15 .fig {
  width: 375px;
}
@media only screen and (max-width: 768px) {
  #sustainability .sdgs-block .sdgs-wrap .sdgs.sdgs-15 .fig {
    width: 58.59375vw;
  }
}

/* products
---------------------------------------------------*/
#products {
  background-color: #f1efed;
  padding: 90px 0 100px;
}
@media only screen and (max-width: 768px) {
  #products {
    padding: 15.625vw 0;
  }
}
#products .products-title {
  text-align: center;
  font-size: 70px;
  font-weight: 300;
}
@media only screen and (max-width: 768px) {
  #products .products-title {
    font-size: 10.9375vw;
  }
}
#products .caption {
  text-align: center;
  font-size: 20px;
  font-weight: 500;
  letter-spacing: 0.025em;
  margin-top: 8px;
  margin-bottom: 42px;
}
@media only screen and (max-width: 768px) {
  #products .caption {
    font-size: 3.4375vw;
    margin-top: 1.25vw;
    margin-bottom: 6.5625vw;
  }
}
#products ul.products-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  max-width: 820px;
  margin: 0 auto 36px;
}
@media only screen and (max-width: 768px) {
  #products ul.products-list {
    row-gap: 6.25vw;
    width: 93.75vw;
    margin-bottom: 9.375vw;
  }
}
@media only screen and (max-width: 768px) {
  #products ul.products-list li {
    width: 33.3333333333%;
    text-align: center;
  }
}
#products ul.products-list li img {
  width: 83px;
  filter: var(--drop-shadow);
}
@media only screen and (max-width: 768px) {
  #products ul.products-list li img {
    width: 12.96875vw;
  }
}
#products ul.products-list li p {
  text-align: center;
  font-size: 14px;
  letter-spacing: 0.025em;
  margin-top: 2em;
}
@media only screen and (max-width: 768px) {
  #products ul.products-list li p {
    font-size: 2.8125vw;
    margin-top: 1em;
  }
}
#products ul.products-list li.bk p {
  color: #221815;
}
#products ul.products-list li.dbr p {
  color: #4c2b23;
}
#products ul.products-list li.br p {
  color: #78472e;
}
#products ul.products-list li.mlb p {
  color: #b1825b;
}
#products ul.products-list li.mgr p {
  color: #8b7970;
}
#products ul.products-list li.rzb p {
  color: #943c46;
}
#products .name {
  text-align: center;
  line-height: 1.5em;
  font-size: 16px;
  letter-spacing: 0.025em;
  margin-bottom: 8px;
}
@media only screen and (max-width: 768px) {
  #products .name {
    font-size: 2.8125vw;
    margin-bottom: 1.5625vw;
  }
}
#products .price {
  text-align: center;
  line-height: 1.5em;
  font-size: 16px;
  letter-spacing: 0.025em;
  margin-bottom: 12px;
}
@media only screen and (max-width: 768px) {
  #products .price {
    font-size: 2.8125vw;
    margin-bottom: 3.90625vw;
  }
}
#products .link {
  text-align: center;
}
#products .link a {
  color: #595757;
  font-size: 11px;
  letter-spacing: 0.025em;
  text-decoration: underline;
  text-underline-offset: 0.3em;
}
@media only screen and (max-width: 768px) {
  #products .link a {
    font-size: 2.1875vw;
  }
}
#products .link a:hover {
  text-decoration: none;
}
#products .btn_cart {
  margin-top: 38px;
}
@media only screen and (max-width: 768px) {
  #products .btn_cart {
    margin-top: 5.9375vw;
  }
}

/*# sourceMappingURL=main.css.map */
