@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@700&display=swap");
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before, blockquote:after {
  content: "";
  content: none;
}

q:before, q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

main {
  display: block;
}

button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  appearance: none;
  color: var(--color-black);
}

input,
button,
select,
textarea {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: transparent;
  border: none;
  border-radius: 0;
  font: inherit;
  outline: none;
}

:root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}

*,
*::before,
*::after {
  margin: 0;
  padding: 0;
  box-sizing: inherit;
  letter-spacing: 0.04em;
}

html {
  font-size: 62.5%;
  font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
  font-weight: 500;
  box-sizing: border-box;
}
@media (max-width: 768px) {
  html {
    font-size: 1.33vw;
  }
}

body {
  color: var(--color-black);
  line-height: 1.5;
  font-smoothing: antialiased;
  text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  -webkit-text-size-adjust: 100%;
  -moz-font-smoothing: antialiased;
  -moz-text-size-adjust: 100%;
  -ms-font-smoothing: antialiased;
  -ms-text-size-adjust: 100%;
  -o-font-smoothing: antialiased;
  -o-text-size-adjust: 100%;
}

a {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
}

img {
  max-width: 100%;
  width: 100%;
  height: auto;
  line-height: 1;
  vertical-align: bottom;
}

input {
  outline: none;
}

textarea {
  outline: none;
  resize: none;
}

.wrap {
  position: relative;
}

.invalid-feedback {
  color: var(--color-red);
  font-size: 1.4rem;
  font-weight: bold;
}

.splide__container {
  box-sizing: border-box;
  position: relative;
}

.splide__list {
  backface-visibility: hidden;
  display: -ms-flexbox;
  display: flex;
  height: 100%;
  margin: 0 !important;
  padding: 0 !important;
}

.splide.is-initialized:not(.is-active) .splide__list {
  display: block;
}

.splide__pagination {
  -ms-flex-align: center;
  align-items: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0;
  pointer-events: none;
}

.splide__pagination li {
  display: inline-block;
  line-height: 1;
  list-style-type: none;
  margin: 0;
  pointer-events: auto;
}

.splide:not(.is-overflow) .splide__pagination {
  display: none;
}

.splide__progress__bar {
  width: 0;
}

.splide {
  position: relative;
  visibility: hidden;
}

.splide.is-initialized,
.splide.is-rendered {
  visibility: visible;
}

.splide__slide {
  backface-visibility: hidden;
  box-sizing: border-box;
  -ms-flex-negative: 0;
  flex-shrink: 0;
  list-style-type: none !important;
  margin: 0;
  position: relative;
}

.splide__slide img {
  vertical-align: bottom;
}

.splide__spinner {
  animation: splide-loading 1s linear infinite;
  border: 2px solid #999;
  border-left-color: transparent;
  border-radius: 50%;
  bottom: 0;
  contain: strict;
  display: inline-block;
  height: 20px;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  top: 0;
  width: 20px;
}

.splide__sr {
  clip: rect(0 0 0 0);
  border: 0;
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute;
  width: 1px;
}

.splide__toggle.is-active .splide__toggle__play,
.splide__toggle__pause {
  display: none;
}

.splide__toggle.is-active .splide__toggle__pause {
  display: inline;
}

.splide__track {
  overflow: hidden;
  position: relative;
  z-index: 0;
}

@keyframes splide-loading {
  0% {
    transform: rotate(0);
  }
  to {
    transform: rotate(1turn);
  }
}
.splide__track--draggable {
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
}

.splide__track--fade > .splide__list > .splide__slide {
  margin: 0 !important;
  opacity: 0;
  z-index: 0;
}

.splide__track--fade > .splide__list > .splide__slide.is-active {
  opacity: 1;
  z-index: 1;
}

.splide--rtl {
  direction: rtl;
}

.splide__track--ttb > .splide__list {
  display: block;
}

.splide__arrow {
  -ms-flex-align: center;
  align-items: center;
  background: #ccc;
  border: 0;
  border-radius: 50%;
  cursor: pointer;
  display: -ms-flexbox;
  display: flex;
  height: 2em;
  -ms-flex-pack: center;
  justify-content: center;
  opacity: 0.7;
  padding: 0;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 2em;
  z-index: 1;
}

.splide__arrow svg {
  fill: #000;
  height: 1.2em;
  width: 1.2em;
}

.splide__arrow:hover:not(:disabled) {
  opacity: 0.9;
}

.splide__arrow:disabled {
  opacity: 0.3;
}

.splide__arrow:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__arrow--prev {
  left: 1em;
}

.splide__arrow--prev svg {
  transform: scaleX(-1);
}

.splide__arrow--next {
  right: 1em;
}

.splide.is-focus-in .splide__arrow:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__pagination {
  bottom: 0.5em;
  left: 0;
  padding: 0 1em;
  position: absolute;
  right: 0;
  z-index: 1;
}

.splide__pagination__page {
  background: #ccc;
  border: 0;
  border-radius: 50%;
  display: inline-block;
  height: 8px;
  margin: 3px;
  opacity: 0.7;
  padding: 0;
  position: relative;
  transition: transform 0.2s linear;
  width: 8px;
}

.splide__pagination__page.is-active {
  background: #fff;
  transform: scale(1.4);
  z-index: 1;
}

.splide__pagination__page:hover {
  cursor: pointer;
  opacity: 0.9;
}

.splide__pagination__page:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__pagination__page:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__progress__bar {
  background: #ccc;
  height: 3px;
}

.splide__slide {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

.splide__slide:focus {
  outline: 0;
}

@supports (outline-offset: -3px) {
  .splide__slide:focus-visible {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide__slide:focus-visible {
    border: 3px solid #0bf;
  }
}
@supports (outline-offset: -3px) {
  .splide.is-focus-in .splide__slide:focus {
    outline: 3px solid #0bf;
    outline-offset: -3px;
  }
}
@media screen and (-ms-high-contrast: none) {
  .splide.is-focus-in .splide__slide:focus {
    border: 3px solid #0bf;
  }
  .splide.is-focus-in .splide__track > .splide__list > .splide__slide:focus {
    border-color: #0bf;
  }
}
.splide__toggle {
  cursor: pointer;
}

.splide__toggle:focus-visible {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide.is-focus-in .splide__toggle:focus {
  outline: 3px solid #0bf;
  outline-offset: 3px;
}

.splide__track--nav > .splide__list > .splide__slide {
  border: 3px solid transparent;
  cursor: pointer;
}

.splide__track--nav > .splide__list > .splide__slide.is-active {
  border: 3px solid #000;
}

.splide__arrows--rtl .splide__arrow--prev {
  left: auto;
  right: 1em;
}

.splide__arrows--rtl .splide__arrow--prev svg {
  transform: scaleX(1);
}

.splide__arrows--rtl .splide__arrow--next {
  left: 1em;
  right: auto;
}

.splide__arrows--rtl .splide__arrow--next svg {
  transform: scaleX(-1);
}

.splide__arrows--ttb .splide__arrow {
  left: 50%;
  transform: translate(-50%);
}

.splide__arrows--ttb .splide__arrow--prev {
  top: 1em;
}

.splide__arrows--ttb .splide__arrow--prev svg {
  transform: rotate(-90deg);
}

.splide__arrows--ttb .splide__arrow--next {
  bottom: 1em;
  top: auto;
}

.splide__arrows--ttb .splide__arrow--next svg {
  transform: rotate(90deg);
}

.splide__pagination--ttb {
  bottom: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
  flex-direction: column;
  left: auto;
  padding: 1em 0;
  right: 0.5em;
  top: 0;
}

.container {
  width: 100%;
  max-width: 100%;
  padding: 0 3rem;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .container {
    padding: 0 7.2rem;
  }
}

.btn {
  position: relative;
  width: 100%;
  height: 5.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  border: 1px solid var(--color-black);
  border-radius: 10rem;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}
@media (max-width: 768px) {
  .btn {
    font-size: 1.6rem;
    height: 7rem;
  }
}
@media (hover: hover) {
  .btn:hover {
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.btn.-chevron::after {
  content: "";
  width: 0.8rem;
  height: 0.8rem;
  border-right: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  transform: rotate(-45deg);
  margin-left: 0.8rem;
}
@media (hover: hover) {
  .btn.-chevron:hover::after {
    border-color: var(--color-white);
  }
}
.btn.-reverse {
  background-color: var(--color-black);
  color: var(--color-white);
}
@media (hover: hover) {
  .btn.-reverse:hover {
    background-color: var(--color-white);
    color: var(--color-black);
  }
}
.btn.-profile::before {
  content: "";
  width: 3.3rem;
  height: 3.3rem;
  background-image: url("../img/icon-profile.png");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  margin-right: 1.2rem;
}
.btn.-cart {
  background-color: var(--color-black);
  height: 10rem;
  color: var(--color-white);
  font-size: 2rem;
}
.btn.-cart::before {
  content: "";
  display: block;
  width: 3.2rem;
  height: 3.4rem;
  background-image: url("../img/icon-cart-white.png"), url("../img/icon-cart.png");
  background-size: contain, 0;
  background-position: center center;
  background-repeat: no-repeat;
  margin-right: 1.6rem;
}
@media (hover: hover) {
  .btn.-cart:hover {
    background-color: var(--color-white);
    color: var(--color-black);
  }
  .btn.-cart:hover::before {
    background-size: 0, contain;
  }
}

.hamburger-menu {
  position: fixed;
  right: 0;
  top: 0;
  width: 100%;
  height: 100vh;
  background-color: var(--color-white);
  z-index: 100;
  overflow-y: auto;
  transform: translateY(-100%);
  transition: all 0.6s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.hamburger-menu__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 5rem;
  height: 14.8rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
.hamburger-menu__close-btn {
  position: relative;
  display: block;
  width: 3.3rem;
  height: 3.3rem;
  flex-shrink: 0;
  margin-right: 8rem;
}
.hamburger-menu__close-btn::before, .hamburger-menu__close-btn::after {
  content: "";
  height: 0.3rem;
  width: 100%;
  background-color: var(--color-black);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  border-radius: 1rem;
  transition: all 0.3s;
}
.hamburger-menu__close-btn::before {
  transform: rotate(45deg);
}
.hamburger-menu__close-btn::after {
  transform: rotate(-45deg);
}
.hamburger-menu__logo {
  width: 15.4rem;
}
.hamburger-menu__head-btns {
  display: flex;
}
.hamburger-menu__head-btn {
  width: 3.5rem;
  height: 3.5rem;
  display: flex;
  align-items: center;
  margin-left: 3rem;
  transition: opacity 0.3s;
}
.hamburger-menu__item {
  border-bottom: 1px solid var(--color-black);
}
.hamburger-menu__link {
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  height: 10rem;
  width: 100%;
}
.hamburger-menu__content {
  padding: 4.5rem 8rem;
}
.hamburger-menu__btn .btn {
  height: 10rem;
}
.hamburger-menu__btn:not(:first-child) {
  margin-top: 1.6rem;
}
.hamburger-menu__sub-list {
  margin-top: 4rem;
}
.hamburger-menu__sub-item {
  text-align: center;
}
.hamburger-menu__sub-item:not(:first-child) {
  margin-top: 3.2rem;
}
.hamburger-menu__sub-link {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}

.form__row:not(:first-child) {
  margin-top: 6rem;
}
@media (max-width: 768px) {
  .form__row:not(:first-child) {
    margin-top: 5.6rem;
  }
}
.form__label {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .form__label {
    font-size: 1.8rem;
  }
}
.form__label span {
  color: var(--color-red);
}
.form__col-wrap {
  width: 100%;
  display: flex;
  gap: 4rem;
  margin-top: 1rem;
}
@media (max-width: 768px) {
  .form__col-wrap {
    gap: 2.4rem;
  }
}
.form__col {
  flex-grow: 1;
}
.form__col input,
.form__col textarea,
.form__col select {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-gray-3);
  padding: 2.3rem 2.8rem;
  background-color: var(--color-white);
  color: var(--color-black);
}
@media (max-width: 768px) {
  .form__col input,
  .form__col textarea,
  .form__col select {
    font-size: 1.6rem;
  }
}
.form__col.-is-select {
  position: relative;
}
.form__col.-is-select::after {
  content: "";
  position: absolute;
  right: 3.2rem;
  top: 0;
  bottom: 0;
  margin: auto 0;
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  border-right: 2px solid var(--color-black);
  border-bottom: 2px solid var(--color-black);
  transform: rotate(45deg);
}
@media (max-width: 768px) {
  .form__col.-is-select::after {
    width: 1.2rem;
    height: 1.2rem;
  }
}
.form__col.-is-textarea {
  height: 45.6rem;
}
.form__col-wrap.-is-tel {
  gap: 0;
  align-items: center;
}
.form__col-wrap.-is-tel .form__col {
  position: relative;
  width: 13.5rem;
  flex-grow: 0;
}
@media (max-width: 768px) {
  .form__col-wrap.-is-tel .form__col {
    width: auto;
    flex-grow: 1;
  }
}
.form__col-wrap.-is-tel .form__col:nth-child(1) {
  width: 9.8rem;
}
@media (max-width: 768px) {
  .form__col-wrap.-is-tel .form__col:nth-child(1) {
    width: auto;
    flex-grow: 1;
  }
}
.form__col-wrap.-is-tel span {
  width: 1.2rem;
  height: 1px;
  background-color: var(--color-black);
  display: block;
  margin: 0 2.2rem;
}
@media (max-width: 768px) {
  .form__col-wrap.-is-tel span {
    margin: 0 1.8rem;
  }
}
.form__col-wrap.-is-zip {
  gap: 0;
  align-items: center;
}
.form__col-wrap.-is-zip .form__col {
  flex-grow: 0;
}
.form__col-wrap.-is-zip .form__col:nth-of-type(1) {
  width: 13.5rem;
}
.form__col-wrap.-is-zip .form__col:nth-of-type(2) {
  width: 16.5rem;
}
.form__col-wrap.-is-zip span {
  width: 1.2rem;
  height: 1px;
  background-color: var(--color-black);
  display: block;
  margin: 0 2.2rem;
}
@media (max-width: 768px) {
  .form__col-wrap.-is-zip span {
    margin: 0 1.8rem;
  }
}
.form__col-wrap.-is-birthday {
  gap: 0;
  align-items: center;
}
.form__col-wrap.-is-birthday .form__col {
  flex-grow: 0;
}
.form__col-wrap.-is-birthday .form__col:nth-child(1) {
  width: 15.8rem;
}
.form__col-wrap.-is-birthday .form__col:nth-of-type(2), .form__col-wrap.-is-birthday .form__col:nth-of-type(3) {
  width: 10.5rem;
}
.form__col-wrap.-is-birthday span {
  font-size: 1.8rem;
  font-weight: bold;
  margin: 0 2.4rem 0 1.6rem;
}
.form__col-wrap.-is-small {
  max-width: 48rem;
}
@media (max-width: 768px) {
  .form__col-wrap.-is-small {
    max-width: 100%;
  }
}
.form__error {
  width: 100%;
  color: var(--color-red);
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.2rem;
}
.form__btn {
  max-width: 60rem;
  width: 100%;
  height: 10rem;
  border-radius: 10rem;
  margin: 6.4rem auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-black);
  background-color: var(--color-black);
  color: var(--color-white);
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}
@media (hover: hover) {
  .form__btn:hover {
    background-color: var(--color-white);
    color: var(--color-black);
  }
}
.form__btn.-is-reverse {
  background-color: var(--color-white);
  color: var(--color-black);
}
@media (hover: hover) {
  .form__btn.-is-reverse:hover {
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.form__message {
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 2;
  text-align: center;
  letter-spacing: 0.2em;
  color: var(--color-gray-4);
  margin-top: 8rem;
}
@media (max-width: 768px) {
  .form__message {
    text-align: left;
    margin-top: 4.4rem;
    font-size: 1.6rem;
  }
}
.form__zip-btn {
  width: 16.6rem;
  height: 7rem;
  border: 1px solid var(--color-black);
  border-radius: 10rem;
  background-color: var(--color-white);
  font-size: 1.6rem;
  font-weight: bold;
  color: var(--color-black);
  letter-spacing: 0.2em;
  margin-left: 4rem;
  transition: all 0.3s;
}
@media (hover: hover) {
  .form__zip-btn:hover {
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.form__privacy {
  margin-top: 8.4rem;
}
@media (max-width: 768px) {
  .form__privacy {
    margin-top: 5.8rem;
  }
}
.form__privacy-head {
  text-align: center;
  font-weight: bold;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
}
.form__privacy-head a {
  color: var(--color-red);
  text-decoration: underline;
  letter-spacing: 0.2em;
}
.form__privacy-text {
  margin-top: 2.6rem;
  background-color: var(--color-gray-2);
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 2;
  letter-spacing: 0.2em;
  height: 29.8rem;
  overflow-y: auto;
  padding: 3.2rem 4rem;
}
.form__privacy-text > *:not(:first-child) {
  margin-top: 2em;
}

.pagination {
  display: flex;
  justify-content: center;
  align-items: center;
}
.pagination__page {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin: 0 2.4rem;
  color: var(--color-black-2);
}
@media (max-width: 768px) {
  .pagination__page {
    font-size: 2.2rem;
    margin: 0 2rem;
  }
}
.pagination__page.active {
  color: var(--color-gray-4);
}
.pagination__prev, .pagination__next {
  width: 0.9rem;
}
.pagination__prev {
  margin-right: 9.6rem;
}
@media (max-width: 768px) {
  .pagination__prev {
    margin-right: auto;
  }
}
.pagination__next {
  margin-left: 9.6rem;
}
@media (max-width: 768px) {
  .pagination__next {
    margin-left: auto;
  }
}

.mypage-menu__title {
  font-family: "Montserrat", sans-serif;
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.mypage-menu__list {
  max-width: 113rem;
  margin: 4rem auto 0;
}
.mypage-menu__item:not(:first-child) {
  margin-top: 1.5rem;
}
.mypage-menu__link {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10rem;
  width: 100%;
  height: 10rem;
  border: 1px solid var(--color-black);
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}
@media (hover: hover) {
  .mypage-menu__link:hover {
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.mypage-menu__link.-reverse {
  background-color: var(--color-black);
  color: var(--color-white);
}
@media (hover: hover) {
  .mypage-menu__link.-reverse:hover {
    background-color: var(--color-white);
    color: var(--color-black);
  }
}

.product-sort {
  position: relative;
}
.product-sort__toggle-btn {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 10rem;
  width: 22rem;
  margin-left: auto;
}
@media (max-width: 768px) {
  .product-sort__toggle-btn {
    font-size: 1.8rem;
    width: 100%;
  }
}
.product-sort__toggle-btn::before {
  content: "";
  width: 2.6rem;
  height: 2.6rem;
  background-image: url("../img/icon-sort.svg");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  margin-right: 1.2rem;
}
.product-sort__btns {
  position: absolute;
  z-index: 1;
  right: 3px;
  top: 10rem;
  width: 43.8rem;
  display: none;
}
@media (max-width: 1200px) {
  .product-sort__btns {
    right: 1px;
  }
}
@media (max-width: 768px) {
  .product-sort__btns {
    width: 100%;
    top: calc(10rem - 1px);
    border-bottom: 1px solid var(--color-black);
  }
}
.product-sort__btn {
  width: 100%;
  height: 10rem;
  border: 1px solid var(--color-black);
  color: var(--color-black);
  background-color: var(--color-white);
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: -1px;
}
@media (max-width: 768px) {
  .product-sort__btn {
    margin-top: 0;
    border-left: none;
    border-right: none;
    border-bottom: none;
  }
}

.product-search-modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100svh;
  height: 100%;
  padding: 8rem 16rem;
  overflow-y: auto;
  cursor: pointer;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.6s;
  z-index: 10;
  background-color: rgba(0, 0, 0, 0.6);
}
@media (max-width: 1200px) {
  .product-search-modal {
    padding: 8rem;
  }
}
@media (max-width: 768px) {
  .product-search-modal {
    padding: 6rem;
  }
}
.product-search-modal__content {
  position: relative;
  background-color: var(--color-white);
  max-width: 160rem;
  width: 100%;
  display: flex;
  align-items: center;
  flex-direction: column;
  padding: 7rem 13.6rem;
}
@media (max-width: 768px) {
  .product-search-modal__content {
    padding: 4.4rem 4.4rem 11.2rem;
  }
}
.product-search-modal__close-btn {
  width: 3rem;
  height: 3rem;
  position: absolute;
  top: 5.4rem;
  left: 5.4rem;
}
@media (max-width: 768px) {
  .product-search-modal__close-btn {
    top: 4rem;
    left: 4rem;
  }
}
.product-search-modal__close-btn::before, .product-search-modal__close-btn::after {
  content: "";
  width: 3rem;
  height: 2px;
  border-radius: 1rem;
  background-color: var(--color-black);
  display: block;
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  margin: auto;
}
@media (max-width: 768px) {
  .product-search-modal__close-btn::before, .product-search-modal__close-btn::after {
    height: 1px;
  }
}
.product-search-modal__close-btn::before {
  transform: rotate(45deg);
}
.product-search-modal__close-btn::after {
  transform: rotate(-45deg);
}
.product-search-modal__content-inner {
  max-width: 122rem;
  width: 100%;
  margin: 0 auto;
}
.product-search-modal__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .product-search-modal__title {
    font-size: 2.4rem;
  }
}
.product-search-modal__label {
  display: block;
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .product-search-modal__label {
    text-align: left;
    font-size: 1.8rem;
  }
}
.product-search-modal__price {
  margin-top: 5.6rem;
}
.product-search-modal__price-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.4rem;
  margin-top: 0.8rem;
}
@media (max-width: 768px) {
  .product-search-modal__price-row {
    justify-content: flex-start;
  }
}
.product-search-modal__price-row span {
  font-size: 1.8rem;
  font-weight: bold;
}
.product-search-modal__price-col {
  display: flex;
  align-items: center;
}
.product-search-modal__price-col input {
  width: 16rem;
  height: 7rem;
  border: 1px solid var(--color-gray-3);
  font-size: 1.6rem;
  font-weight: bold;
  padding: 2.8rem;
}
.product-search-modal__price-col span {
  font-size: 1.8rem;
  font-weight: bold;
  margin-left: 1.6rem;
}
.product-search-modal__category {
  margin-top: 4.8rem;
}
.product-search-modal__check-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 1rem;
  margin-top: 1rem;
}
@media (max-width: 768px) {
  .product-search-modal__check-list {
    justify-content: flex-start;
  }
}
.product-search-modal__check-label {
  cursor: pointer;
}
.product-search-modal__check-label input {
  display: none;
}
.product-search-modal__check-label span {
  display: block;
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-black);
  border-radius: 10rem;
  padding: 1.6rem 3.4rem;
  transition: all 0.3s;
}
.product-search-modal__check-label input:checked + span {
  background-color: var(--color-black);
  color: var(--color-white);
}
.product-search-modal__review {
  margin-top: 4.8rem;
}
.product-search-modal__detail {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 4rem;
  max-width: 106rem;
  width: 100%;
  margin: 4.4rem auto 0;
}
@media (max-width: 768px) {
  .product-search-modal__detail {
    grid-template-columns: 1fr;
  }
}
.product-search-modal__detail-label {
  display: block;
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.product-search-modal__detail-select {
  position: relative;
  margin-top: 1.2rem;
}
.product-search-modal__detail-select::after {
  content: "";
  position: absolute;
  right: 3.2rem;
  top: 0;
  bottom: 0;
  margin: auto 0;
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  border-right: 2px solid var(--color-black);
  border-bottom: 2px solid var(--color-black);
  transform: rotate(45deg);
}
@media (max-width: 768px) {
  .product-search-modal__detail-select::after {
    width: 1.2rem;
    height: 1.2rem;
  }
}
.product-search-modal__detail-select select {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-gray-3);
  padding: 2.3rem 2.8rem;
  background-color: var(--color-white);
  color: var(--color-black);
}
@media (max-width: 768px) {
  .product-search-modal__detail-select select {
    font-size: 1.6rem;
  }
}
.product-search-modal__btns {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2.4rem;
  margin-top: 9.2rem;
}
@media (max-width: 768px) {
  .product-search-modal__btns {
    margin-top: 5.6rem;
    gap: 1.6rem;
  }
}
.product-search-modal__clear-btn {
  border: 1px solid var(--color-black);
  height: 10rem;
  border-radius: 10rem;
  color: var(--color-black);
  font-weight: bold;
  font-size: 2rem;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}
@media (hover: hover) {
  .product-search-modal__clear-btn:hover {
    color: var(--color-white);
    background-color: var(--color-black);
  }
}
.product-search-modal__search-btn {
  border: 1px solid var(--color-black);
  height: 10rem;
  border-radius: 10rem;
  color: var(--color-white);
  background-color: var(--color-black);
  font-weight: bold;
  font-size: 2rem;
  letter-spacing: 0.2em;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}
.product-search-modal__search-btn::before {
  content: "";
  display: block;
  width: 2.8rem;
  height: 2.8rem;
  background-image: url("../img/icon-search-white.svg"), url("../img/icon-search.svg");
  background-size: contain, 0;
  background-position: center center;
  background-repeat: no-repeat;
  margin-right: 1rem;
}
@media (hover: hover) {
  .product-search-modal__search-btn:hover {
    background-color: var(--color-white);
    color: var(--color-black);
  }
  .product-search-modal__search-btn:hover::before {
    background-size: 0, contain;
  }
}

.img-slider .index__list {
  display: flex;
  gap: 0.8rem;
  position: absolute;
  width: 100%;
  bottom: 3.2rem;
  justify-content: center;
}
.img-slider .index__list .index__item {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background-color: white;
  cursor: pointer;
}
.img-slider .index__list .index__item.active {
  background-color: #b4b4b4;
}
.img-slider .arrow {
  width: 24px;
  height: 48px;
  position: absolute;
  top: 25rem;
  background-repeat: no-repeat;
  cursor: pointer;
}
.img-slider .arrow.arrow-left {
  left: 6rem;
  background-image: url("/assets/img/arrow-left.svg");
}
.img-slider .arrow.arrow-right {
  right: 6rem;
  background-image: url("/assets/img/arrow-right.svg");
}
.img-slider .img-wrap {
  width: 37.4rem;
  height: 49.6rem;
  position: relative;
}
@media (max-width: 768px) {
  .img-slider .img-wrap {
    width: 32rem;
  }
}
.img-slider img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  opacity: 0;
  transition: opacity 0.8s;
}
.img-slider img.active {
  opacity: 1;
}

.header {
  position: fixed;
  top: 0;
  left: 0;
  height: 11rem;
  width: 100%;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  background-color: var(--color-white);
  z-index: 10;
}
.header__container {
  max-width: 164rem;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
@media (max-width: 1050px) {
  .header__container {
    padding: 0 5rem;
  }
}
.header__hamburger-btn {
  display: none;
}
@media (max-width: 1050px) {
  .header__hamburger-btn {
    position: relative;
    display: block;
    width: 3.3rem;
    height: 3.3rem;
    flex-shrink: 0;
    margin-right: 8rem;
  }
  .header__hamburger-btn::before, .header__hamburger-btn::after {
    content: "";
  }
  .header__hamburger-btn::before, .header__hamburger-btn::after,
  .header__hamburger-btn span {
    height: 0.3rem;
    width: 100%;
    background-color: var(--color-black);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    border-radius: 1rem;
    transition: all 0.3s;
  }
  .header__hamburger-btn::before {
    transform: translateY(-1rem);
  }
  .header__hamburger-btn::after {
    transform: translateY(1rem);
  }
}
.header__main {
  display: flex;
}
.header__logo {
  display: flex;
  width: 17.2rem;
  margin-right: 10.5rem;
}
@media (max-width: 1050px) {
  .header__logo {
    margin-right: 0;
  }
}
@media (max-width: 1050px) {
  .header__nav {
    display: none;
  }
}
.header__nav-list {
  display: flex;
}
.header__nav-item:not(:first-child) {
  margin-left: 4.4rem;
}
@media (max-width: 1050px) {
  .header__nav-item:not(:first-child) {
    margin-left: 4rem;
  }
}
.header__nav-link {
  position: relative;
  font-family: "Montserrat", sans-serif;
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.header__nav-link::after {
  content: "";
  width: 100%;
  height: 2px;
  background-color: var(--color-black);
  display: block;
  position: absolute;
  left: 0;
  bottom: -0.4rem;
  transform: scaleX(0);
  transition: all 0.3s;
}
@media (hover: hover) {
  .header__nav-link:hover::after {
    transform: scaleX(1);
  }
}
.header__btns {
  display: flex;
}
.header__btn {
  width: 3.5rem;
  height: 3.5rem;
  display: flex;
  align-items: center;
  margin-left: 3rem;
  transition: opacity 0.3s;
}
@media (hover: hover) {
  .header__btn:hover {
    opacity: 0.7;
  }
}

.footer {
  padding-top: 11rem;
  padding-bottom: 9rem;
}
@media (max-width: 768px) {
  .footer {
    padding-top: 10rem;
    padding-bottom: 8rem;
  }
}
@media (max-width: 768px) {
  .footer__container {
    padding: 0;
  }
}
.footer__logo {
  width: 24rem;
  margin: 0 auto;
}
.footer__btn {
  margin: 4.6rem auto 0;
  width: 32rem;
}
@media (max-width: 768px) {
  .footer__btn {
    margin: 4rem auto 0;
    width: 40rem;
  }
}
.footer__nav-list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 2.4rem;
}
@media (max-width: 768px) {
  .footer__nav-list {
    position: relative;
    margin-top: 6rem;
    border-top: 1px solid var(--color-black);
  }
  .footer__nav-list::after {
    content: "";
    height: 100%;
    width: 1px;
    background-color: var(--color-black);
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    margin: 0 auto;
  }
}
.footer__nav-item {
  margin: 1.6rem 2.4rem 0;
}
@media (max-width: 768px) {
  .footer__nav-item {
    margin: 0;
    width: 50%;
    border-bottom: 1px solid var(--color-black);
  }
}
.footer__nav-link {
  display: inline-block;
  position: relative;
  font-size: 1.2rem;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .footer__nav-link {
    font-size: 1.6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    height: 10rem;
  }
}
.footer__nav-link::after {
  content: "";
  width: 100%;
  height: 1px;
  background-color: var(--color-black);
  display: block;
  position: absolute;
  left: 0;
  bottom: -0.4rem;
  transform: scaleX(0);
  transition: all 0.3s;
}
@media (hover: hover) {
  .footer__nav-link:hover::after {
    transform: scaleX(1);
  }
}
@media (hover: hover) and (max-width: 768px) {
  .footer__nav-link:hover::after {
    transform: scaleX(0);
  }
}
.footer__copy {
  font-size: 1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  margin-top: 14.8rem;
}
@media (max-width: 768px) {
  .footer__copy {
    font-size: 1.4rem;
    margin-top: 6.6rem;
  }
}

.home-page .header {
  position: absolute;
  top: calc(100svh - 14.8rem);
}
.home-page .mv {
  position: relative;
  height: calc(100svh - 10.8rem);
  min-height: 66rem;
  width: 100%;
}
.home-page .mv__img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: all 1s;
}
.home-page .mv__img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.home-page .mv__img {
  opacity: 0;
  transform: translateY(2.4rem);
}
.home-page .mv__img.is-animated {
  opacity: 1;
  transform: translateY(0);
}
.home-page .mv__overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: center bottom;
  transition: all 1s;
  transform: scaleY(0);
}
.home-page .mv__overlay.is-animated {
  transform: scaleY(1);
}
.home-page .mv__overlay.is-no-animation {
  transform: scaleY(1);
  transition: none;
}
.home-page .mv__logo {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 500px;
  aspect-ratio: 700/787;
}
@media (max-width: 768px) {
  .home-page .mv__logo {
    width: 80%;
  }
}
.home-page .mv__logo img {
  display: block;
  width: 100%;
  height: 100%;
}
.home-page .mv__logo__text {
  position: absolute;
  top: calc(50% + 144px);
  left: calc(50% + 18px);
  transform: translate(-50%, -50%);
  width: 323px;
  height: 38px;
  opacity: 0;
  transition: opacity 1.5s;
  transition-delay: 3s;
}
@media (max-width: 768px) {
  .home-page .mv__logo__text {
    width: 200px;
    top: calc(50% + 95px);
    left: calc(50% + 10px);
  }
}
.home-page .mv__logo__text.is-animated {
  opacity: 1;
}
.home-page .mv__logo__text.is-no-animation {
  opacity: 1;
  transition: none;
}
.home-page :root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}
.home-page .about {
  padding: 16rem 0 0;
}
.home-page .about__caution {
  max-width: 1280px;
  margin: 0 auto 15rem auto;
  text-align: center;
  padding: 38px 0;
}
.home-page .about__caution__text1 {
  font-size: 2.4rem;
}
.home-page .about__caution__text2 {
  font-size: 1.6rem;
}
.home-page .about__content {
  padding-bottom: 23.6rem;
}
@media (max-width: 768px) {
  .home-page .about__content {
    padding-bottom: 16rem;
  }
}
.home-page .about__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .home-page .about__title {
    font-size: 4.2rem;
  }
}
.home-page .about__sub-title {
  font-size: 3.6rem;
  font-weight: 500;
  letter-spacing: 0.35em;
  text-align: center;
  margin-top: 5.4rem;
}
.home-page .about__text {
  font-size: 1.4rem;
  line-height: 2;
  text-align: center;
  margin-top: 4.8rem;
}
@media (max-width: 768px) {
  .home-page .about__text {
    font-size: 1.6rem;
    line-height: 2.5;
  }
}
.home-page .about__text * {
  letter-spacing: 0.3em;
}
.home-page .about__text p:not(:first-child) {
  margin-top: 2em;
}
.home-page .about__text small {
  display: block;
  font-size: 1rem;
  line-height: 1.5;
  margin-top: 8.5rem;
}
@media (max-width: 768px) {
  .home-page .about__text small {
    font-size: 1.6rem;
    letter-spacing: 0.3em;
    line-height: 2.43;
    margin-top: 3.5rem;
  }
}
.home-page .about__img {
  width: 100%;
  display: flex;
}
.home-page .about__img .img-wrap {
  width: 25%;
  object-fit: cover;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  border-right: 1px solid var(--color-black);
}
.home-page .about__img .img-wrap:last-child {
  border-right: none;
}
.home-page .about__img img {
  width: 100%;
  height: 100%;
}
@media (max-width: 768px) {
  .home-page .about__img {
    flex-wrap: wrap;
  }
  .home-page .about__img .img-wrap {
    width: 50%;
    border-top: 1px solid var(--color-black);
    border-bottom: 1px solid var(--color-black);
    border-right: 1px solid var(--color-black);
  }
  .home-page .about__img .img-wrap:nth-child(even) {
    border-right: none;
  }
}
.home-page :root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}
.home-page .product__head {
  padding: 16.8rem 0 9.2rem;
  text-align: center;
}
@media (max-width: 768px) {
  .home-page .product__head {
    padding: 17.8rem 0 10.2rem;
  }
}
@media (max-width: 768px) {
  .home-page .product__container {
    padding: 0 2rem;
  }
}
.home-page .product__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .home-page .product__title {
    font-size: 4.2rem;
  }
}
.home-page .product__intro {
  font-size: 1rem;
  font-weight: bold;
  line-height: 2;
  letter-spacing: 0.31em;
  margin-top: 2.6rem;
}
@media (max-width: 768px) {
  .home-page .product__intro {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.3em;
    margin-top: 2.4rem;
  }
}
.home-page .product__row {
  display: flex;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .home-page .product__row {
    flex-wrap: wrap;
  }
}
.home-page .product__img {
  width: 50%;
  padding: 7rem 0;
  background-color: var(--color-gray-2);
  border-right: 1px solid var(--color-black);
  display: flex;
  justify-content: center;
  align-items: center;
}
@media (max-width: 768px) {
  .home-page .product__img {
    width: 100%;
    padding: 5rem 0 5.6rem;
    border-right: none;
    border-bottom: 1px solid var(--color-black);
  }
}
.home-page .product__img img {
  display: block;
  width: 58rem;
  height: auto;
}
.home-page .product__info {
  width: 50%;
  padding: 14.2rem 6.4rem 15.6rem;
}
@media (max-width: 1050px) {
  .home-page .product__info {
    padding: 8rem 4rem;
  }
}
@media (max-width: 768px) {
  .home-page .product__info {
    width: 100%;
    padding: 7.4rem 7.2rem 16.8rem;
  }
}
.home-page .product__name {
  font-size: 2.7rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .home-page .product__name {
    font-size: 3.2rem;
  }
}
.home-page .product__price {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 2rem;
}
@media (max-width: 768px) {
  .home-page .product__price {
    margin-top: 0.5rem;
  }
}
.home-page .product__text {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.183em;
  line-height: 1.71;
  margin-top: 3.6rem;
}
@media (max-width: 768px) {
  .home-page .product__text {
    font-size: 1.6rem;
    line-height: 1.75;
    margin-top: 1.6rem;
  }
}
.home-page .product__btns {
  max-width: 67.2rem;
  display: flex;
  justify-content: space-between;
  margin-top: 3rem;
}
@media (max-width: 1050px) {
  .home-page .product__btns {
    flex-wrap: wrap;
    max-width: 100%;
  }
}
@media (max-width: 768px) {
  .home-page .product__btns {
    margin-top: 7.4rem;
  }
}
.home-page .product__btn {
  width: calc(50% - 1.7rem);
}
@media (max-width: 1050px) {
  .home-page .product__btn {
    width: 100%;
  }
  .home-page .product__btn:not(:first-child) {
    margin-top: 1.8rem;
  }
}
.home-page :root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}
.home-page .user-voice {
  padding: 21.2rem 0 23.6rem;
}
@media (max-width: 768px) {
  .home-page .user-voice {
    padding: 16.2rem 0 17.6rem;
  }
}
.home-page .user-voice__container {
  max-width: 116rem;
}
@media (min-width: 1441px) {
  .home-page .user-voice__container {
    max-width: 165rem;
  }
}
.home-page .user-voice__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .home-page .user-voice__title {
    font-size: 4.2rem;
  }
}
.home-page .user-voice__list {
  border-bottom: 1px solid var(--color-black);
  margin-top: 7rem;
}
@media (max-width: 768px) {
  .home-page .user-voice__list {
    margin-top: 6rem;
  }
}
.home-page .user-voice__item {
  border-top: 1px solid var(--color-black);
  padding: 7rem 0;
}
@media (max-width: 768px) {
  .home-page .user-voice__item {
    padding: 5.6rem 0;
  }
}
.home-page .user-voice__item-title {
  font-size: 2.6rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .home-page .user-voice__item-title {
    font-size: 2.4rem;
    line-height: 2;
  }
}
.home-page .user-voice__item-text {
  font-size: 1.4rem;
  letter-spacing: 0.2rem;
  line-height: 2.2;
  margin-top: 1.2rem;
}
@media (max-width: 768px) {
  .home-page .user-voice__item-text {
    font-size: 1.6rem;
    margin-top: 1.8rem;
  }
}
.home-page .user-voice__tw-item {
  margin-top: 3rem;
  font-size: 2.1rem;
  font-weight: bold;
}
.home-page .user-voice__tw-item span {
  letter-spacing: 0.4rem;
  margin-right: 3.6rem;
}
.home-page .user-voice__tw-item a {
  font-size: 1.4rem;
}
@media (max-width: 768px) {
  .home-page .user-voice__tw-item a {
    margin-top: 1.8rem;
  }
}
.home-page .user-voice__tw-item a:after {
  content: "";
  display: inline-block;
  width: 0.5rem;
  height: 1rem;
  background-image: url("/assets/img/chobo-right.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  margin-left: 2.4rem;
}
@media (max-width: 768px) {
  .home-page .user-voice__tw-item a:after {
    margin-left: 1.2rem;
  }
}
.home-page :root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}
.home-page .news {
  padding: 21.2rem 0 20.6rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .home-page .news {
    padding: 19.8rem 0 15.4rem;
  }
}
.home-page .news__container {
  padding: 0;
}
@media (max-width: 768px) {
  .home-page .news__container {
    padding: 0 7.2rem;
  }
}
.home-page .news__title {
  font-family: "Montserrat", sans-serif;
  font-size: 4.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.home-page .news__slider {
  margin-top: 7.4rem;
}
@media (max-width: 768px) {
  .home-page .news__slider {
    margin-top: 6.2rem;
  }
}
.home-page .news__slide:not(:first-child) {
  margin-top: 7.8rem;
}
.home-page .news__slide-thumb {
  width: 100%;
}
.home-page .news__slide-time {
  display: block;
  font-size: 1.3rem;
  letter-spacing: 0.2em;
  margin-top: 4rem;
}
@media (max-width: 768px) {
  .home-page .news__slide-time {
    font-size: 1.8rem;
    margin-top: 2.8rem;
  }
}
.home-page .news__slide-title {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 0.4rem;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
}
@media (max-width: 768px) {
  .home-page .news__slide-title {
    font-size: 3.2rem;
    margin-top: 0.2rem;
    -webkit-line-clamp: unset;
  }
}
.home-page .news__slide-excerpt {
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  margin-top: 1.2rem;
  line-height: 2;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
@media (max-width: 768px) {
  .home-page .news__slide-excerpt {
    font-size: 1.6rem;
    -webkit-line-clamp: 3;
    margin-top: 0.8rem;
  }
}
.home-page .news__slide-link {
  display: inline-flex;
  align-items: center;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 4.2rem;
}
@media (max-width: 768px) {
  .home-page .news__slide-link {
    font-size: 1.6rem;
    margin-top: 3rem;
  }
}
.home-page .news__slide-link::after {
  content: "";
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  border-right: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  transform: rotate(-45deg);
  margin-left: 1rem;
}
.home-page .news__btn {
  width: 32rem;
  margin: 10.4rem auto 0;
}
@media (max-width: 768px) {
  .home-page .news__btn {
    width: 100%;
    margin-top: 9rem;
  }
}
.home-page :root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}
.home-page .dev-voice {
  padding: 19.2rem 0;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .home-page .dev-voice {
    padding: 17.2rem 0 20.2rem;
  }
}
.home-page .dev-voice__content__inner {
  display: flex;
  max-width: 1380px;
  margin: 8.4rem auto 0 auto;
}
.home-page .dev-voice__content__inner__text {
  margin-left: 7rem;
}
@media (max-width: 768px) {
  .home-page .dev-voice__content__inner {
    display: block;
  }
  .home-page .dev-voice__content__inner__text {
    margin-left: 0;
  }
}
.home-page .dev-voice__img {
  width: 34rem;
  height: 34rem;
}
@media (max-width: 768px) {
  .home-page .dev-voice__img {
    margin: 0 auto 5.6rem auto;
  }
}
.home-page .dev-voice__title {
  text-align: center;
}
.home-page .dev-voice__title span {
  display: block;
}
.home-page .dev-voice__title span:first-child {
  font-family: "Montserrat", sans-serif;
  font-size: 4.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.home-page .dev-voice__title span:last-child {
  font-size: 2rem;
  letter-spacing: 0.35em;
  margin-top: 2.4rem;
}
.home-page .dev-voice__sub-title {
  font-size: 3.2rem;
  letter-spacing: 0.28em;
}
@media (max-width: 768px) {
  .home-page .dev-voice__sub-title {
    font-size: 2.6rem;
    font-weight: bold;
    letter-spacing: 0.2em;
    line-height: 1.85;
    text-align: left;
  }
}
.home-page .dev-voice__text {
  font-size: 1.4rem;
  letter-spacing: 0.3em;
  line-height: 2.7;
  margin-top: 2rem;
}
@media (max-width: 768px) {
  .home-page .dev-voice__text {
    line-height: 2.43;
    text-align: left;
    margin-top: 2.8rem;
  }
}

.about-page :root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}
.about-page .mv {
  padding: 33.6rem 0 17.5rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .about-page .mv {
    padding: 23.2rem 2rem 15.4rem;
  }
}
.about-page .mv__title {
  font-family: "Montserrat", sans-serif;
  font-weight: bold;
  font-size: 5rem;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .about-page .mv__title {
    font-size: 3.2rem;
  }
}
.about-page .mv__logo {
  width: 50rem;
  aspect-ratio: 700/787;
  margin: -3rem auto;
}
@media (max-width: 768px) {
  .about-page .mv__logo {
    margin: -3rem auto 0;
  }
}
.about-page .mv__sub-title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.35em;
  text-align: center;
}
.about-page .mv__text {
  font-size: 1.4rem;
  line-height: 2.78;
  text-align: center;
  margin-top: 4rem;
}
@media (max-width: 768px) {
  .about-page .mv__text {
    margin-top: 3rem;
    font-size: 1.6rem;
  }
}
.about-page .mv__text p {
  letter-spacing: 0.3em;
}
.about-page .feature {
  padding-top: 20.8rem;
}
@media (max-width: 768px) {
  .about-page .feature {
    padding-top: 11.2rem;
  }
}
.about-page .feature__title {
  display: flex;
  justify-content: center;
  flex-direction: column;
  align-items: center;
}
.about-page .feature__title-logo {
  display: flex;
  width: 20.8rem;
}
.about-page .feature__title-text {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 3rem;
}
@media (max-width: 768px) {
  .about-page .feature__title-text {
    font-size: 2.4rem;
    margin-top: 2.4rem;
  }
}
.about-page .feature__list {
  border-top: 1px solid var(--color-black);
  margin-top: 11.2rem;
}
@media (max-width: 768px) {
  .about-page .feature__list {
    margin-top: 5.4rem;
  }
}
.about-page .feature__item {
  display: flex;
  height: 45.3rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .about-page .feature__item {
    flex-direction: column;
    height: auto;
  }
}
.about-page .feature__item:nth-child(even) {
  flex-direction: row-reverse;
}
@media (max-width: 768px) {
  .about-page .feature__item:nth-child(even) {
    flex-direction: column;
  }
}
.about-page .feature__item:nth-child(even) .feature__item-content {
  border-right: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .about-page .feature__item:nth-child(even) .feature__item-content {
    border-right: none;
  }
}
.about-page .feature__item-img {
  width: 50%;
  height: 100%;
  border-right: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .about-page .feature__item-img {
    width: 100%;
    height: 25rem;
    border-right: none;
  }
}
.about-page .feature__item-img img {
  height: 100%;
  object-fit: cover;
}
.about-page .feature__item-content {
  width: 50%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding: 0 3rem;
}
@media (max-width: 768px) {
  .about-page .feature__item-content {
    width: 100%;
    padding: 5.8rem 8rem 6.4rem;
    border-top: 1px solid var(--color-black);
  }
}
.about-page .feature__item-content-inner {
  max-width: 57rem;
  width: 100%;
}
@media (max-width: 768px) {
  .about-page .feature__item-content-inner {
    max-width: 100%;
  }
}
.about-page .feature__item-title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.about-page .feature__item-text {
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 2;
  margin-top: 1.6rem;
}
.about-page .feature__item-text p {
  letter-spacing: 0.183em;
}
.about-page :root {
  --color-black: #000;
  --color-black-2: #464445;
  --color-gray: #eeeeee;
  --color-gray-2: #e7e7e7;
  --color-gray-3: #b5b5b5;
  --color-gray-4: #989898;
  --color-white: #fff;
  --color-red: #aa272d;
}
.about-page .product__head {
  padding: 16.8rem 0 9.2rem;
  text-align: center;
}
@media (max-width: 768px) {
  .about-page .product__head {
    padding: 10rem 0 7rem;
  }
}
@media (max-width: 768px) {
  .about-page .product__container {
    padding: 0 2rem;
  }
}
.about-page .product__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .about-page .product__title {
    font-size: 4.2rem;
  }
}
.about-page .product__row {
  display: flex;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .about-page .product__row {
    flex-wrap: wrap;
  }
}
.about-page .product__img {
  width: 50%;
  padding: 7rem 0;
  background-color: #e7e7e7;
  border-right: 1px solid var(--color-black);
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
@media (max-width: 768px) {
  .about-page .product__img {
    width: 100%;
    padding: 5rem 0 5.6rem;
    border-right: none;
    border-bottom: 1px solid var(--color-black);
  }
}
.about-page .product__info {
  width: 50%;
  padding: 14.2rem 6.4rem 15.6rem;
}
@media (max-width: 1050px) {
  .about-page .product__info {
    padding: 8rem 4rem;
  }
}
@media (max-width: 768px) {
  .about-page .product__info {
    width: 100%;
    padding: 7.4rem 7.2rem 16.8rem;
  }
}
.about-page .product__name {
  font-size: 2.7rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .about-page .product__name {
    font-size: 3.2rem;
  }
}
.about-page .product__price {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 2rem;
}
@media (max-width: 768px) {
  .about-page .product__price {
    margin-top: 0.5rem;
  }
}
.about-page .product__text {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.183em;
  line-height: 1.71;
  margin-top: 3.6rem;
}
@media (max-width: 768px) {
  .about-page .product__text {
    font-size: 1.6rem;
    line-height: 1.75;
    margin-top: 1.6rem;
  }
}
.about-page .product__btns {
  max-width: 67.2rem;
  display: flex;
  justify-content: space-between;
  margin-top: 3rem;
}
@media (max-width: 1050px) {
  .about-page .product__btns {
    flex-wrap: wrap;
    max-width: 100%;
  }
}
@media (max-width: 768px) {
  .about-page .product__btns {
    margin-top: 7.4rem;
  }
}
.about-page .product__btn {
  width: calc(50% - 1.7rem);
}
@media (max-width: 1050px) {
  .about-page .product__btn {
    width: 100%;
  }
  .about-page .product__btn:not(:first-child) {
    margin-top: 1.8rem;
  }
}

.faq-page .faq {
  padding: 32.8rem 0 18rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .faq-page .faq {
    padding: 23.2rem 0 14.4rem;
  }
}
.faq-page .faq__container {
  max-width: 166rem;
}
@media (max-width: 768px) {
  .faq-page .faq__container {
    padding: 0;
  }
}
.faq-page .faq__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .faq-page .faq__title {
    font-size: 3.2rem;
  }
}
.faq-page .faq__list {
  margin-top: 8rem;
}
.faq-page .faq__item {
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  margin-top: -1px;
  padding: 5.6rem 6.8rem 7.2rem;
}
@media (max-width: 768px) {
  .faq-page .faq__item {
    padding: 7rem 7.2rem;
  }
}
.faq-page .faq__item:nth-child(odd) {
  background-color: var(--color-gray-2);
}
.faq-page .faq__question {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.75;
}
@media (max-width: 768px) {
  .faq-page .faq__question {
    font-size: 2.1rem;
    line-height: 1.71;
  }
}
.faq-page .faq__answer {
  font-size: 1.8rem;
  font-weight: bold;
  line-height: 1.56;
  letter-spacing: 0.183em;
  margin-top: 1.8rem;
}

.news-archive-page .news {
  padding: 33rem 0 18.8rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .news-archive-page .news {
    padding: 23.2rem 0 14.4rem;
  }
}
.news-archive-page .news__container {
  max-width: 166rem;
}
.news-archive-page .news__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .news-archive-page .news__title {
    font-size: 3.2rem;
  }
}
.news-archive-page .news__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 13rem 7.2rem;
  margin-top: 10rem;
}
@media (max-width: 768px) {
  .news-archive-page .news__list {
    grid-template-columns: 1fr;
    margin-top: 5.6rem;
    gap: 9rem;
  }
}
.news-archive-page .news__item-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 764/406;
}
.news-archive-page .news__item-thumb img {
  height: 100%;
  object-fit: cover;
}
.news-archive-page .news__item-time {
  display: block;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  margin-top: 2.4rem;
}
@media (max-width: 768px) {
  .news-archive-page .news__item-time {
    font-size: 1.8rem;
    margin-top: 2.8rem;
  }
}
.news-archive-page .news__item-title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.6rem;
}
@media (max-width: 768px) {
  .news-archive-page .news__item-title {
    font-size: 3.2rem;
    margin-top: 1.2rem;
  }
}
.news-archive-page .news__item-text {
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
  margin-top: 1.6rem;
}
@media (max-width: 768px) {
  .news-archive-page .news__item-text {
    font-size: 1.6rem;
    -webkit-line-clamp: 3;
    line-height: 2.125;
  }
}
.news-archive-page .news__item-btn {
  margin-top: 5.6rem;
  height: 10rem;
  font-size: 2.1rem;
}
@media (max-width: 768px) {
  .news-archive-page .news__item-btn {
    margin-top: 2.4rem;
    font-size: 1.4rem;
    height: 7rem;
  }
}
.news-archive-page .news__item-btn::after {
  margin-left: 2.4rem;
}
.news-archive-page .news__pagination {
  margin-top: 11.6rem;
}

.news-single-page .news-single {
  padding: 32.2rem 0 23.6rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .news-single-page .news-single {
    padding: 23.2rem 0 15.8rem;
  }
}
.news-single-page .news-single__container {
  max-width: 166rem;
}
@media (max-width: 768px) {
  .news-single-page .news-single__container {
    padding: 0 7.8rem;
  }
}
.news-single-page .news-single__head {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .news-single-page .news-single__head {
    font-size: 3.2rem;
  }
}
.news-single-page .news-single__thumb {
  width: 100%;
  margin-top: 10rem;
}
@media (max-width: 768px) {
  .news-single-page .news-single__thumb {
    margin-top: 7.6rem;
  }
}
.news-single-page .news-single__time {
  display: block;
  font-size: 1.4rem;
  letter-spacing: 0.2em;
  margin-top: 4.6rem;
}
@media (max-width: 768px) {
  .news-single-page .news-single__time {
    margin-top: 3.2rem;
  }
}
.news-single-page .news-single__title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.4rem;
}
@media (max-width: 768px) {
  .news-single-page .news-single__title {
    font-size: 3.2rem;
  }
}
.news-single-page .news-single__user-content {
  margin-top: 1.6rem;
  font-size: 1.4rem;
  line-height: 1.5;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .news-single-page .news-single__user-content {
    margin-top: 3.2rem;
  }
}
.news-single-page .news-single__user-content > *:not(:first-child) {
  margin-top: 1.5em;
}
.news-single-page .news-single__user-content strong {
  font-weight: bold;
}
.news-single-page .news-single__user-content em {
  font-style: italic;
}
.news-single-page .news-single__user-content a {
  color: var(--color-black);
  text-decoration: underline;
}
.news-single-page .news-single__btn {
  margin: 17.2rem auto 0;
  max-width: 75.8rem;
}
@media (max-width: 768px) {
  .news-single-page .news-single__btn {
    margin-top: 7rem;
  }
}
.news-single-page .news-single__btn .btn {
  height: 10rem;
  font-size: 2.1rem;
}
@media (max-width: 768px) {
  .news-single-page .news-single__btn .btn {
    font-size: 1.6rem;
  }
}

.product-archive-page .product {
  padding: 32.8rem 0 14.8rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .product-archive-page .product {
    padding: 23.2rem 0 10rem;
  }
}
@media (max-width: 768px) {
  .product-archive-page .product__container {
    padding: 0;
  }
}
.product-archive-page .product__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .product-archive-page .product__title {
    font-size: 3.2rem;
  }
}
.product-archive-page .product__search {
  max-width: 123rem;
  width: 100%;
  margin: 5.6rem auto 0;
  display: grid;
  gap: 2.8rem;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 768px) {
  .product-archive-page .product__search {
    padding: 0 7.4rem;
    margin-top: 8rem;
    gap: 2rem;
  }
}
.product-archive-page .product__search-input {
  position: relative;
  border: 1px solid var(--color-black);
  border-radius: 10rem;
  height: 10rem;
  width: 100%;
}
@media (max-width: 768px) {
  .product-archive-page .product__search-input {
    height: 7rem;
  }
}
.product-archive-page .product__search-input::before {
  content: "";
  width: 2.8rem;
  height: 2.8rem;
  background-image: url("../img/icon-search.svg");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 3.6rem;
  margin: auto 0;
}
.product-archive-page .product__search-input input {
  width: 100%;
  height: 100%;
  padding: 0 8rem 0 4.8rem;
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .product-archive-page .product__search-input input {
    padding: 0 8.8rem 0 3.6rem;
  }
}
.product-archive-page .product__search-btn {
  border: 1px solid var(--color-black);
  border-radius: 10rem;
  height: 10rem;
  width: 100%;
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}
@media (max-width: 768px) {
  .product-archive-page .product__search-btn {
    height: 7rem;
    font-size: 1.6rem;
  }
}
@media (hover: hover) {
  .product-archive-page .product__search-btn:hover {
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.product-archive-page .product__sort {
  margin-top: 4rem;
}
.product-archive-page .product__list {
  display: flex;
  flex-wrap: wrap;
}
.product-archive-page .product__item {
  position: relative;
  background-color: var(--color-white);
  width: 25%;
  border: 1px solid var(--color-black);
  margin: -1px -1px 0 0;
  display: flex;
  flex-direction: column;
}
@media (max-width: 1200px) {
  .product-archive-page .product__item {
    width: 50%;
  }
}
@media (max-width: 768px) {
  .product-archive-page .product__item:nth-child(odd) {
    border-left: none;
  }
  .product-archive-page .product__item:nth-child(even) {
    border-right: none;
  }
}
.product-archive-page .product__item-thumb {
  border-bottom: 1px solid var(--color-black);
  background-color: var(--color-gray-2);
  height: 26rem;
  padding: 2rem;
}
@media (max-width: 768px) {
  .product-archive-page .product__item-thumb {
    height: 23.6rem;
  }
}
.product-archive-page .product__item-thumb img {
  height: 100%;
  object-fit: contain;
}
.product-archive-page .product__item-body {
  padding: 4rem 4rem 5.6rem;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.product-archive-page .product__item-title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.product-archive-page .product__item-price {
  font-size: 1.9rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 2.4rem;
}
@media (max-width: 768px) {
  .product-archive-page .product__item-price {
    font-size: 1.8rem;
  }
}
.product-archive-page .product__item-price span {
  letter-spacing: 0.2em;
}
.product-archive-page .product__item-btn {
  font-size: 1.7rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-black);
  border-radius: 10rem;
  width: 100%;
  height: 8.3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: auto;
  transition: all 0.3s;
}
@media (max-width: 768px) {
  .product-archive-page .product__item-btn {
    font-size: 1.6rem;
    margin-top: auto;
  }
}
@media (hover: hover) {
  .product-archive-page .product__item-btn:hover {
    color: var(--color-white);
    background-color: var(--color-black);
  }
}
.product-archive-page .product__pagination {
  margin-top: 7.8rem;
}
@media (max-width: 768px) {
  .product-archive-page .product__pagination {
    padding: 0 5.8rem;
  }
}

.product-single-page .product-single {
  padding: 33.2rem 0 10rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .product-single-page .product-single {
    padding: 23.2rem 0 12rem;
  }
}
.product-single-page .product-single__head {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.product-single-page .product-single__main-row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  margin-top: 9.6rem;
}
@media (max-width: 768px) {
  .product-single-page .product-single__main-row {
    grid-template-columns: 1fr;
  }
}
.product-single-page .product-single__main-thumb {
  background-color: var(--color-gray-2);
  height: 100%;
  padding: 4rem;
  border-right: 1px solid var(--color-black);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}
@media (max-width: 768px) {
  .product-single-page .product-single__main-thumb {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--color-black);
    padding: 5.6rem;
  }
}
.product-single-page .product-single__main-thumb img {
  height: 100%;
  max-height: 47rem;
  width: auto;
  object-fit: contain;
}
@media (max-width: 768px) {
  .product-single-page .product-single__main-thumb img {
    max-height: 39.8rem;
  }
}
.product-single-page .product-single__main-col {
  padding: 10rem 9.5rem;
  flex-grow: 1;
}
@media (max-width: 1200px) {
  .product-single-page .product-single__main-col {
    padding: 10rem 3rem;
  }
}
@media (max-width: 768px) {
  .product-single-page .product-single__main-col {
    width: 100%;
    padding: 6.4rem 10rem;
  }
}
.product-single-page .product-single__main-title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.product-single-page .product-single__main-price {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.6rem;
}
@media (max-width: 768px) {
  .product-single-page .product-single__main-price {
    font-size: 1.8rem;
  }
}
.product-single-page .product-single__main-price span {
  color: var(--color-red);
  letter-spacing: 0.2em;
}
.product-single-page .product-single__main-terms {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.6rem;
  color: var(--color-red);
  text-decoration: underline;
}
@media (max-width: 768px) {
  .product-single-page .product-single__main-terms {
    font-size: 1.8rem;
  }
}
.product-single-page .product-single__main-terms span {
  color: var(--color-red);
  letter-spacing: 0.2em;
}
.product-single-page .product-single__main-terms:hover {
  opacity: 0.8;
}
.product-single-page .product-single__count {
  margin-top: 7rem;
}
@media (max-width: 768px) {
  .product-single-page .product-single__count {
    margin-top: 5.4rem;
  }
}
.product-single-page .product-single__count-wrap {
  display: flex;
  align-items: center;
}
.product-single-page .product-single__count-label {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-right: 2.4rem;
}
.product-single-page .product-single__count-select {
  position: relative;
  width: 14rem;
}
.product-single-page .product-single__count-select::after {
  content: "";
  position: absolute;
  right: 3.2rem;
  top: 0;
  bottom: 0;
  margin: auto 0;
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  border-right: 2px solid var(--color-black);
  border-bottom: 2px solid var(--color-black);
  transform: rotate(45deg);
}
@media (max-width: 768px) {
  .product-single-page .product-single__count-select::after {
    width: 1.2rem;
    height: 1.2rem;
  }
}
.product-single-page .product-single__count-select select {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-gray-3);
  padding: 2.3rem 2.8rem;
  background-color: var(--color-white);
  color: var(--color-black);
}
@media (max-width: 768px) {
  .product-single-page .product-single__count-select select {
    font-size: 1.6rem;
  }
}
.product-single-page .product-single__count-btn {
  width: 100%;
  max-width: 60rem;
  margin-top: 4.4rem;
}
.product-single-page .product-single__container {
  max-width: 166rem;
}
.product-single-page .product-single__section {
  padding-top: 8rem;
}
@media (max-width: 768px) {
  .product-single-page .product-single__section {
    padding-top: 7rem;
  }
}
.product-single-page .product-single__section-title {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .product-single-page .product-single__section-title {
    text-align: left;
  }
}
.product-single-page .product-single__section-text {
  text-align: center;
  margin-top: 2rem;
}
@media (max-width: 768px) {
  .product-single-page .product-single__section-text {
    text-align: left;
  }
}
.product-single-page .product-single__section-text p {
  font-size: 1.4rem;
  letter-spacing: 0.183em;
  font-weight: bold;
  line-height: 2;
  white-space: pre-line;
}
@media (max-width: 768px) {
  .product-single-page .product-single__section-text p {
    font-size: 1.6rem;
  }
}
.product-single-page .product-single__section-text p:not(:first-child) {
  margin-top: 2em;
}
.product-single-page .product-single__section-text span {
  color: var(--color-red);
  letter-spacing: 0.183em;
}
.product-single-page .product-single__section-text table {
  border: 1px solid var(--color-black);
  max-width: 60rem;
  width: 100%;
  margin: 3.2rem auto 0;
  font-size: 1.4rem;
  font-weight: bold;
  text-align: left;
}
@media (max-width: 768px) {
  .product-single-page .product-single__section-text table {
    font-size: 1.6rem;
  }
}
.product-single-page .product-single__section-text table th {
  letter-spacing: 0.183em;
  padding: 2rem 0 2.4rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .product-single-page .product-single__section-text table th:nth-child(2) {
    white-space: nowrap;
    padding-right: 7rem;
  }
}
@media (max-width: 768px) {
  .product-single-page .product-single__section-text table th:nth-child(3) {
    padding-right: 2rem;
  }
}
.product-single-page .product-single__section-text table td {
  letter-spacing: 0.183em;
}
.product-single-page .product-single__section-text table tr td:first-child {
  padding: 1rem 3.2rem;
}
@media (max-width: 768px) {
  .product-single-page .product-single__section-text table tr td:first-child {
    white-space: nowrap;
  }
}
.product-single-page .product-single__section-text table tr:first-child td {
  padding-top: 3rem;
}
.product-single-page .product-single__section-text table tr:last-child td {
  padding-bottom: 3rem;
}

.company-page .company {
  padding: 30rem 0 32.2rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .company-page .company {
    padding: 22rem 0 16.8rem;
  }
}
.company-page .company__container {
  max-width: 119rem;
}
@media (max-width: 768px) {
  .company-page .company__container {
    padding: 0 7.5rem;
  }
}
.company-page .company__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.company-page .company__list {
  margin-top: 13.4rem;
}
@media (max-width: 768px) {
  .company-page .company__list {
    margin-top: 9.6rem;
  }
}
.company-page .company__item {
  display: flex;
  align-items: center;
  height: 15rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  margin-top: -1px;
}
@media (max-width: 768px) {
  .company-page .company__item {
    flex-direction: column;
    justify-content: center;
  }
}
.company-page .company__dt {
  width: 30.8rem;
  flex-shrink: 0;
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  padding-left: 6.2rem;
}
@media (max-width: 768px) {
  .company-page .company__dt {
    width: 100%;
    padding-left: 0;
    text-align: center;
  }
}
.company-page .company__dd {
  flex-grow: 1;
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 2;
  letter-spacing: 0.183em;
}
@media (max-width: 768px) {
  .company-page .company__dd {
    flex-grow: 0;
    margin-top: 1.2rem;
  }
}
.company-page .company__section {
  padding: 3rem 6.2rem;
}
.company-page .company__section h3 {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.company-page .company__section p {
  margin-top: 1.2rem;
  font-size: 1.4rem;
}

.privacy-page .privacy {
  padding: 29.6rem 0 20rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .privacy-page .privacy {
    padding: 22.2rem 0 15.2rem;
  }
}
.privacy-page .privacy__container {
  max-width: 166rem;
}
.privacy-page .privacy__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.privacy-page .privacy__content {
  margin-top: 17.8rem;
}
@media (max-width: 768px) {
  .privacy-page .privacy__content {
    margin-top: 8.8rem;
  }
}
.privacy-page .privacy__content > *:first-child {
  margin-top: 0;
}
.privacy-page .privacy__content h2 {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.75;
  margin-top: 9.6rem;
}
@media (max-width: 768px) {
  .privacy-page .privacy__content h2 {
    margin-top: 7.6rem;
  }
}
.privacy-page .privacy__content h3 {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.75;
  margin-top: 9.6rem;
}
@media (max-width: 768px) {
  .privacy-page .privacy__content h3 {
    margin-top: 6.4rem;
  }
}
.privacy-page .privacy__content p {
  font-size: 1.6rem;
  font-weight: bold;
  letter-spacing: 0.15em;
  line-height: 1.75;
  margin-top: 1.75em;
}
.privacy-page .privacy__content a {
  text-decoration: underline;
  letter-spacing: 0.15em;
}

.contact-page .contact {
  padding: 34rem 0 21.2rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .contact-page .contact {
    padding: 23.2rem 0 12rem;
  }
}
.contact-page .contact__container {
  max-width: 119rem;
}
.contact-page .contact__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .contact-page .contact__title {
    font-size: 3.2rem;
  }
}
.contact-page .contact__intro {
  font-size: 1.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.17em;
  line-height: 2;
  color: var(--color-black-2);
  margin-top: 4rem;
}
@media (max-width: 768px) {
  .contact-page .contact__intro {
    font-size: 1.8rem;
    line-height: 1.75;
    margin-top: 6.4rem;
  }
}
.contact-page .contact__required {
  font-size: 1.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.17em;
  line-height: 2;
  margin-top: 4rem;
}
@media (max-width: 768px) {
  .contact-page .contact__required {
    font-size: 1.8rem;
    margin-top: 3.6rem;
  }
}
.contact-page .contact__required span {
  color: var(--color-red);
}
.contact-page .contact__form {
  margin-top: 14rem;
}
@media (max-width: 768px) {
  .contact-page .contact__form {
    margin-top: 6.4rem;
  }
}

.contact-page.contact-confirm-page .form__col {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}

.register-page .register__container {
  max-width: 119rem;
}
@media (max-width: 768px) {
  .register-page .register__container {
    padding: 0 7.5rem;
  }
}
.register-page .register__code {
  background-color: var(--color-gray-2);
  padding: 20.2rem 0 8.8rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .register-page .register__code {
    padding: 20.4rem 7.5rem 8.4rem;
  }
}
.register-page .register__code-label {
  display: block;
  font-size: 2.1rem;
  font-weight: bold;
  text-align: center;
}
@media (max-width: 768px) {
  .register-page .register__code-label {
    font-size: 1.8rem;
  }
}
.register-page .register__code-label span {
  color: var(--color-red);
}
.register-page .register__code-input {
  max-width: 100rem;
  width: 100%;
  margin: 1.4rem auto 0;
}
.register-page .register__code-input input, .register-page .register__code-input p {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-gray-3);
  padding: 2.3rem 2.8rem;
  background-color: var(--color-white);
  text-align: center;
}
@media (max-width: 768px) {
  .register-page .register__code-input input, .register-page .register__code-input p {
    font-size: 1.6rem;
  }
}
.register-page .register__body {
  padding: 6.4rem 0 21.4rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .register-page .register__body {
    padding-bottom: 16rem;
  }
}
.register-page .register__required {
  font-size: 1.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.17em;
  line-height: 2;
}
@media (max-width: 768px) {
  .register-page .register__required {
    font-size: 1.8rem;
  }
}
.register-page .register__required span {
  color: var(--color-red);
}
.register-page .form__col p {
  width: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  padding: 2.3rem 0;
  background-color: var(--color-white);
  color: var(--color-black);
}

.cart-page .cart {
  padding: 33.2rem 0 24rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .cart-page .cart {
    padding: 23.2rem 0 14rem;
  }
}
.cart-page .cart__container {
  max-width: 166rem;
}
.cart-page .cart__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .cart-page .cart__title {
    font-size: 3.2rem;
  }
}
.cart-page .cart__content {
  margin-top: 8.4rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  padding: 5rem 5rem 6rem;
}
@media (max-width: 768px) {
  .cart-page .cart__content {
    padding-left: 0;
    padding-right: 0;
  }
}
.cart-page .cart__empty-text {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  margin: 6.5rem 0 7.4rem;
}
.cart-page .cart__data-item {
  display: flex;
  justify-content: space-between;
}
.cart-page .cart__data-item:last-child {
  margin-top: 7rem;
}
.cart-page .cart__data-item:last-child .cart__data-title {
  font-size: 2.4rem;
}
.cart-page .cart__data-item:last-child .cart__data-desc {
  font-size: 2.4rem;
}
.cart-page .cart__data-title {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.78;
  color: --color-black-2;
}
.cart-page .cart__data-desc {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.78;
  color: --color-black-2;
}
.cart-page .cart__policy {
  padding-top: 7rem;
}
@media (max-width: 768px) {
  .cart-page .cart__policy {
    padding-top: 9rem;
  }
}
.cart-page .cart__policy-title {
  font-size: 2.1rem;
  font-weight: bold;
  text-align: center;
  text-decoration: underline;
}
.cart-page .cart__policy-text {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  margin-top: 2rem;
  line-height: 2.28;
}
.cart-page .cart__policy-text a {
  text-decoration: underline;
}
.cart-page .cart__policy-btn {
  max-width: 60rem;
  margin: 3.6rem auto 0;
}
@media (max-width: 768px) {
  .cart-page .cart__policy-btn {
    margin-top: 5.4rem;
  }
}

.login-page .login {
  padding: 33rem 0 20.4rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .login-page .login {
    padding: 23.2rem 0 15rem;
  }
}
.login-page .login__nologin__register-text {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  margin-top: 60px;
}
.login-page .login__container {
  max-width: 119rem;
}
@media (max-width: 768px) {
  .login-page .login__container {
    padding: 0;
  }
}
.login-page .login__title {
  font-family: "Montserrat", sans-serif;
  font-size: 5rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
@media (max-width: 768px) {
  .login-page .login__title {
    font-size: 3.2rem;
  }
}
.login-page .login__form {
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  background-color: var(--color-gray-2);
  padding: 8rem 3rem 12rem;
  margin-top: 7.4rem;
}
@media (max-width: 768px) {
  .login-page .login__form {
    margin-top: 9.5rem;
    padding: 8rem 7.5rem 12rem;
  }
}
.login-page .login__form-inner {
  max-width: 60rem;
  width: 100%;
  margin: 0 auto;
}
.login-page .login__form-inner .form__row {
  margin-top: 4rem;
}
.login-page .login__form-title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  display: flex;
  justify-content: center;
  align-items: center;
}
.login-page .login__form-title::before {
  content: "";
  width: 3.4rem;
  height: 3.4rem;
  background-image: url("../img/icon-profile.png");
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  margin-right: 1.4rem;
}
.login-page .login__form-link {
  text-align: center;
  margin-top: 4rem;
}
.login-page .login__form-link a {
  text-decoration: underline;
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.login-page .login__register {
  margin-top: 8.8rem;
}
.login-page .login__register-text {
  font-size: 1.8rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
}
.login-page .login__register-btn {
  max-width: 60rem;
  width: 100%;
  height: 10rem;
  border-radius: 10rem;
  margin: 1.6rem auto 0;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-black);
  background-color: var(--color-black);
  color: var(--color-white);
  font-size: 2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}
@media (hover: hover) {
  .login-page .login__register-btn:hover {
    background-color: var(--color-white);
    color: var(--color-black);
  }
}

.address-page .address {
  padding: 29.4rem 0 23.2rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .address-page .address {
    padding: 21.8rem 0 15.8rem;
  }
}
.address-page .address__container {
  max-width: 166rem;
}
.address-page .address__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.address-page .address .address-info__row {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 3.6rem;
  margin-top: 15.4rem;
  margin-bottom: 18rem;
}
@media (max-width: 768px) {
  .address-page .address .address-info__row {
    grid-template-columns: 1fr;
    gap: 7rem;
    margin-top: 9rem;
    margin-bottom: 10rem;
  }
}
.address-page .address .address-info__col {
  display: flex;
  flex-direction: column;
}
.address-page .address .address-info__col-title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  margin-bottom: -2.4rem;
}
.address-page .address .address-info__content {
  padding: 3.2rem 5rem 4rem;
  background-color: var(--color-gray-2);
  margin-top: 4.8rem;
  flex-grow: 1;
}
.address-page .address .address-info__head {
  color: var(--color-gray-4);
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.address-page .address .address-info__name {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 0.8rem;
}
.address-page .address .address-info__address {
  font-size: 1.8rem;
  font-weight: bold;
  margin-top: 0.8rem;
  letter-spacing: 0.2em;
}
.address-page .address .address-info__tel {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1rem;
}
.address-page .address .address-info__card-num {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 0.8rem;
}
.address-page .address .address-info__card-name {
  font-size: 1.8rem;
  font-weight: bold;
  margin-top: 0.8rem;
  letter-spacing: 0.2em;
}
.address-page .address .address-info__card-date {
  color: var(--color-gray-4);
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.4rem;
}
.address-page .address .address-info__btn {
  max-width: 60rem;
  width: 100%;
  height: 10rem;
  font-size: 2rem;
  margin: 4.8rem auto 0;
}
.address-page .address .address-payment {
  padding: 5rem 2.4rem 5.4rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .address-page .address .address-payment {
    padding: 4.5rem 0 6rem;
  }
}
.address-page .address .address-payment__item {
  display: flex;
  justify-content: space-between;
}
.address-page .address .address-payment__item:last-child {
  margin-top: 7.2rem;
}
.address-page .address .address-payment__item:last-child .address-payment__title,
.address-page .address .address-payment__item:last-child .address-payment__desc {
  font-size: 2.4rem;
}
.address-page .address .address-payment__title {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.71;
}
.address-page .address .address-payment__desc {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.71;
}
.address-page .address .address-form__row {
  display: flex;
  justify-content: center;
  margin-top: 12.4rem;
  margin-bottom: 11.2rem;
}
@media (max-width: 768px) {
  .address-page .address .address-form__row {
    gap: 9.6rem;
    grid-template-columns: 1fr;
    margin-top: 7.6rem;
    margin-bottom: 13.5rem;
  }
}
.address-page .address .address-form__col {
  min-width: 50%;
}
@media (max-width: 768px) {
  .address-page .address .address-form__col {
    min-width: 100%;
  }
}
.address-page .address .address-form__col-title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.address-page .address .address-form__group:not(:first-child) {
  margin-top: 4.6rem;
}
@media (max-width: 768px) {
  .address-page .address .address-form__group:not(:first-child) {
    margin-top: 3.2rem;
  }
}
.address-page .address .address-form__label {
  display: block;
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.address-page .address .address-form__input {
  margin-top: 0.8rem;
}
.address-page .address .address-form__input input, .address-page .address .address-form__input #card {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-gray-3);
  padding: 2.3rem 2.8rem;
  background-color: var(--color-white);
  color: var(--color-black);
}
@media (max-width: 768px) {
  .address-page .address .address-form__input input, .address-page .address .address-form__input #card {
    font-size: 1.6rem;
  }
}
.address-page .address .address-form__select {
  position: relative;
  margin-top: 0.8rem;
}
@media (max-width: 768px) {
  .address-page .address .address-form__select {
    font-size: 1.6rem;
  }
}
.address-page .address .address-form__select select {
  width: 100%;
  height: 100%;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-gray-3);
  padding: 2.3rem 2.8rem;
  background-color: var(--color-white);
  color: var(--color-black);
}
.address-page .address .address-form__select::after {
  content: "";
  position: absolute;
  right: 3.2rem;
  top: 0;
  bottom: 0;
  margin: auto 0;
  display: block;
  width: 0.8rem;
  height: 0.8rem;
  border-right: 2px solid var(--color-black);
  border-bottom: 2px solid var(--color-black);
  transform: rotate(45deg);
}
@media (max-width: 768px) {
  .address-page .address .address-form__select::after {
    width: 1.2rem;
    height: 1.2rem;
  }
}
.address-page .address .address-form__confirm {
  font-size: 1.4rem;
}
.address-page .address .address-form__btn {
  max-width: 60rem;
  margin: 3.2rem auto 0;
}
.address-page .address .address-policy {
  padding-top: 5.6rem;
}
.address-page .address .address-policy__title {
  text-align: center;
  font-size: 2.1rem;
  text-decoration: underline;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.address-page .address .address-policy__text {
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 1.78;
  letter-spacing: 0.2em;
  text-align: center;
  margin-top: 2rem;
}
.address-page .address .address-policy__text a {
  text-decoration: underline;
  letter-spacing: 0.2em;
}
.address-page .form-check {
  display: flex;
  margin: 8px 0;
  align-items: center;
}
.address-page .form-check .form-check-input {
  width: 15px;
  height: 15px;
  border: 1px solid var(--color-gray-3);
}
.address-page .form-check .form-check-input:checked {
  background-color: black;
}
.address-page .form-check label {
  margin-left: 8px;
}
.address-page .saved-card-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 10px 0;
}
.address-page .saved-card-box .form-check {
  margin-top: 0;
}
.address-page .btn.btn-small {
  display: inline-flex;
  width: auto;
  height: 30px;
  font-size: 1.2rem;
  padding: 0 10px;
}
.address-page .ec-orderCoupon .column {
  letter-spacing: 0.4em;
  margin-bottom: 4px;
  color: var(--color-red);
}
.address-page .ec-orderCoupon .column p {
  margin-top: 6px;
  color: var(--color-black);
}

.address-edit-page .address-edit {
  padding: 29.8rem 0 27.6rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .address-edit-page .address-edit {
    padding: 22.4rem 0 16.8rem;
  }
}
.address-edit-page .address-edit__container {
  max-width: 119rem;
}
.address-edit-page .address-edit__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.address-edit-page .address-edit__required {
  font-size: 1.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  margin-top: 5.4rem;
}
@media (max-width: 768px) {
  .address-edit-page .address-edit__required {
    margin-top: 2.8rem;
  }
}
.address-edit-page .address-edit__required span {
  color: var(--color-red);
}
.address-edit-page .address-edit__form {
  margin-top: 13.6rem;
}
@media (max-width: 768px) {
  .address-edit-page .address-edit__form {
    margin-top: 8rem;
  }
}

.address-select-page .address .ec-addressRole__actions {
  margin: 100px 0;
}
.address-select-page .address .ec-addressList__item {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 20px;
  padding: 20px;
  border: 1px solid #ccc;
  border-radius: 5px;
}
.address-select-page .address .ec-addressList__item .ec-addressList__remove input {
  width: 20px;
  height: 20px;
  border: 1px solid #ccc;
  border-radius: 50%;
}
.address-select-page .address .ec-addressList__item .ec-addressList__remove input:checked {
  background-color: #000;
}
.address-select-page .address .ec-addressList__item .ec-addressList__item__name {
  font-weight: bold;
}
.address-select-page .address .ec-addressList__item .ec-addressList__address {
  font-size: 1.6rem;
}
.address-select-page .address .ec-addressList__item .ec-addressList__item__actions {
  margin-top: 10px;
  text-align: right;
}
.address-select-page .address .ec-addressList__item .ec-addressList__item__actions .ec-btn {
  margin-left: 10px;
}
.address-select-page .ec-off4Grid__cell {
  display: flex;
  gap: 20px;
  margin-top: 100px;
}

.complete-page .complete {
  padding-top: 14.8rem;
}
.complete-page .complete__content {
  padding: 12.2rem 0 23rem;
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .complete-page .complete__content {
    padding: 7rem 0 16rem;
  }
}
.complete-page .complete__container {
  max-width: 166rem;
}
.complete-page .complete__title {
  font-size: 3.2rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
}
.complete-page .complete__id {
  text-align: center;
  background-color: var(--color-gray-2);
  padding: 5.4rem 3rem 6rem;
  margin-top: 3.8rem;
}
@media (max-width: 768px) {
  .complete-page .complete__id {
    padding: 4.2rem 3rem 4.8rem;
  }
}
.complete-page .complete__id-title {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  color: var(--color-gray-4);
}
.complete-page .complete__id-num {
  display: block;
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.4rem;
}
.complete-page .complete__id-text {
  font-size: 1.4rem;
  font-weight: bold;
  line-height: 2.21;
  margin-top: 1.4rem;
}
.complete-page .complete__referral {
  text-align: center;
  max-width: 100rem;
  width: 100%;
  margin: 7.6rem auto 0;
}
@media (max-width: 768px) {
  .complete-page .complete__referral {
    margin-top: 6.5rem;
  }
}
.complete-page .complete__referral-title {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
}
.complete-page .complete__referral-text {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.183em;
  margin-top: 2.4rem;
}
@media (max-width: 768px) {
  .complete-page .complete__referral-text {
    margin-top: 3.2rem;
  }
}
.complete-page .complete__btn {
  margin: 10rem auto 0;
  max-width: 60rem;
}
@media (max-width: 768px) {
  .complete-page .complete__btn {
    margin-top: 7.6rem;
  }
}
.complete-page .complete__btn .btn {
  height: 10rem;
  font-size: 2rem;
}

.mypage .mypage-top {
  padding: 28rem 0 18.4rem;
  border-bottom: 1px solid var(--color-black);
}
.mypage .mypage-top .flash-message {
  text-align: center;
  margin: 20px 0;
  font-size: 20px;
}
.mypage .mypage-top__pic {
  width: 10.6rem;
  height: 10.6rem;
  border-radius: 50%;
  overflow: hidden;
  margin: 0 auto;
}
.mypage .mypage-top__title {
  font-size: 3.2rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  margin-top: 3.6rem;
}
.mypage .mypage-top__menu {
  margin-top: 7rem;
}
.mypage .mypage-history__empty {
  text-align: center;
  margin-top: 10rem;
  font-size: 20px;
}

.mypage .mypage-edit {
  padding: 29.8rem 0 0;
}
@media (max-width: 768px) {
  .mypage .mypage-edit {
    padding: 22.4rem 0 0;
  }
}
.mypage .mypage-edit__container {
  max-width: 119rem;
}
.mypage .mypage-edit__content {
  padding-bottom: 20.8rem;
}
@media (max-width: 768px) {
  .mypage .mypage-edit__content {
    padding-bottom: 16rem;
  }
}
.mypage .mypage-edit__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.mypage .mypage-edit__required {
  font-size: 1.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
  margin-top: 5.4rem;
}
@media (max-width: 768px) {
  .mypage .mypage-edit__required {
    margin-top: 2.8rem;
  }
}
.mypage .mypage-edit__required span {
  color: var(--color-red);
}
.mypage .mypage-edit__form {
  margin-top: 13.6rem;
}
@media (max-width: 768px) {
  .mypage .mypage-edit__form {
    margin-top: 8rem;
  }
}
.mypage .mypage-edit__menu {
  padding: 12.2rem 0 16rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .mypage .mypage-edit__menu {
    padding: 10.4rem 7.5rem 13.6rem;
  }
}

.mypage .mypage-history__container {
  max-width: 137rem;
}
.mypage .mypage-history__body {
  padding: 29.8rem 0 22.8rem;
}
@media (max-width: 768px) {
  .mypage .mypage-history__body {
    padding: 22rem 0 16rem;
  }
}
.mypage .mypage-history__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.mypage .mypage-history__list {
  margin-top: 6.4rem;
}
.mypage .mypage-history__item:not(:first-child) {
  margin-top: 3.2rem;
}
@media (max-width: 768px) {
  .mypage .mypage-history__item:not(:first-child) {
    margin-top: 4.6rem;
  }
}
.mypage .mypage-history__menu {
  padding: 12.2rem 0 16rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .mypage .mypage-history__menu {
    padding: 10.4rem 7.5rem 13.6rem;
  }
}
.mypage .mypage-history__pagination {
  margin-top: 10rem;
}
.mypage .history-card {
  background-color: var(--color-gray-2);
  padding: 4rem 4.4rem;
}
.mypage .history-card__time {
  font-size: 1.8rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  color: var(--color-gray-4);
}
.mypage .history-card__delivery {
  display: flex;
  align-items: center;
  margin-top: 3rem;
}
@media (max-width: 768px) {
  .mypage .history-card__delivery {
    flex-wrap: wrap;
    margin-top: 1.6rem;
  }
}
.mypage .history-card__delivery-status {
  display: block;
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-right: 2rem;
}
.mypage .history-card__delivery-status.-is-shipped {
  color: var(--color-red);
}
.mypage .history-card__delivery-btn {
  max-width: 25.8rem;
  background-color: var(--color-white);
  font-size: 1.6rem;
  margin-right: 2.8rem;
}
@media (max-width: 768px) {
  .mypage .history-card__delivery-btn {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
    margin-top: 2rem;
  }
}
@media (hover: hover) {
  .mypage .history-card__delivery-btn:hover {
    background-color: var(--color-black);
    color: var(--color-white);
  }
}
.mypage .history-card__delivery-text {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .mypage .history-card__delivery-text {
    margin-top: 2.4rem;
  }
}
.mypage .history-card__item {
  display: flex;
  margin-top: 4.8rem;
}
@media (max-width: 768px) {
  .mypage .history-card__item {
    margin-top: 2rem;
  }
}
.mypage .history-card__item-img {
  width: 13.2rem;
  height: 13.2rem;
}
.mypage .history-card__item-img img {
  height: 100%;
  object-fit: contain;
}
.mypage .history-card__item-info {
  padding-top: 1.4rem;
  margin-left: 2.6rem;
}
.mypage .history-card__item-name {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.mypage .history-card__item-price {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
@media (max-width: 768px) {
  .mypage .history-card__item-price {
    margin-top: 0.6rem;
  }
}
.mypage .history-card__data {
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  padding: 2rem 0;
  margin-top: 3rem;
}
.mypage .history-card__data-item {
  display: flex;
}
@media (max-width: 768px) {
  .mypage .history-card__data-item {
    justify-content: space-between;
  }
}
.mypage .history-card__data-title, .mypage .history-card__data-desc {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 2.21;
}
.mypage .history-card__data-title {
  width: 13.6rem;
  flex-shrink: 0;
}
.mypage .history-card__address {
  margin-top: 2.8rem;
}
.mypage .history-card__address-title {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.mypage .history-card__address-text {
  margin-top: 1.4rem;
}
.mypage .history-card__address-text p {
  font-size: 1.3rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  line-height: 1.92;
}

.mypage .mypage-referral__container {
  max-width: 166rem;
}
.mypage .mypage-referral__body {
  padding: 29.8rem 0 18.8rem;
}
@media (max-width: 768px) {
  .mypage .mypage-referral__body {
    padding: 22.2rem 0 9.5rem;
  }
}
.mypage .mypage-referral__title {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.mypage .mypage-referral__sub-title {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  margin-top: 8.8rem;
}
@media (max-width: 768px) {
  .mypage .mypage-referral__sub-title {
    margin-top: 6.4rem;
  }
}
.mypage .mypage-referral__text {
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
  margin-top: 1.4rem;
}
.mypage .mypage-referral__list {
  display: grid;
  gap: 3.4rem;
  grid-template-columns: repeat(2, 1fr);
  max-width: 98.5rem;
  width: 100%;
  margin: 2.4rem auto 3.2rem;
}
@media (max-width: 768px) {
  .mypage .mypage-referral__list {
    gap: 2rem;
  }
}
.mypage .mypage-referral__item {
  text-align: center;
  background-color: var(--color-gray-2);
  padding: 3.2rem;
}
.mypage .mypage-referral__item-text {
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
}
.mypage .mypage-referral__item-num {
  font-size: 3.2rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  margin-top: 1.4rem;
}
.mypage .mypage-referral__code-container {
  padding-bottom: 18.8rem;
}
@media (max-width: 768px) {
  .mypage .mypage-referral__code-container {
    padding: 0;
  }
}
.mypage .mypage-referral__code {
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
  background-color: var(--color-gray-2);
  padding: 6.4rem 3.2rem 9.6rem;
}
@media (max-width: 768px) {
  .mypage .mypage-referral__code {
    border-bottom: none;
    padding: 6.4rem 7.5rem 8rem;
  }
}
.mypage .mypage-referral__code-title {
  font-size: 2.4rem;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.2em;
}
.mypage .mypage-referral__code-input {
  max-width: 100rem;
  width: 100%;
  height: 10rem;
  font-size: 2.1rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  border: 1px solid var(--color-gray-3);
  padding: 2.3rem 2.8rem;
  background-color: var(--color-white);
  text-align: center;
  display: block;
  margin: 1.6rem auto 0;
}
@media (max-width: 768px) {
  .mypage .mypage-referral__code-input {
    height: 9rem;
    margin-top: 2rem;
  }
}
.mypage .mypage-referral__code-btn {
  max-width: 60rem;
  height: 10rem;
  font-size: 2rem;
  margin: 2.4rem auto 0;
}
@media (max-width: 768px) {
  .mypage .mypage-referral__code-btn {
    margin-top: 3rem;
  }
}
.mypage .mypage-referral__menu {
  padding: 12.2rem 0 16rem;
  border-top: 1px solid var(--color-black);
  border-bottom: 1px solid var(--color-black);
}
@media (max-width: 768px) {
  .mypage .mypage-referral__menu {
    padding: 10.4rem 7.5rem 13.6rem;
  }
}

.ec-orderCoupon {
  margin: 12.4rem auto;
  width: 50%;
}
.ec-orderCoupon .ec-rectHeading {
  margin-bottom: 2.4rem;
  display: flex;
  justify-content: center;
}
.ec-orderCoupon .ec-rectHeading h2 {
  font-size: 2.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  text-align: center;
}
.ec-orderCoupon .column {
  display: block;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  min-width: 50%;
}
.ec-orderCoupon .column p {
  position: relative;
  width: 100%;
  height: 5.8rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--color-white);
  border: 1px solid var(--color-black);
  border-radius: 10rem;
  font-size: 1.4rem;
  font-weight: bold;
  letter-spacing: 0.2em;
  transition: all 0.3s;
}

.sp {
  display: none;
}
@media (max-width: 768px) {
  .sp {
    display: block;
  }
}

@media (max-width: 768px) {
  .pc {
    display: none;
  }
}

.pc-sp-none {
  display: block;
}
@media (max-width: 1050px) {
  .pc-sp-none {
    display: none;
  }
}

.is-hamburger-menu-open {
  overflow: hidden;
}
.is-hamburger-menu-open .header__hamburger-btn::before {
  transform: rotate(45deg);
}
.is-hamburger-menu-open .header__hamburger-btn::after {
  transform: rotate(-45deg);
}
.is-hamburger-menu-open .header__hamburger-btn span {
  transform: translateX(-2rem);
  opacity: 0;
}
.is-hamburger-menu-open .hamburger-menu {
  pointer-events: auto;
  transform: translateY(0);
}

.is-product-search-modal-open {
  overflow: hidden;
}
.is-product-search-modal-open .product-search-modal {
  opacity: 1;
  pointer-events: auto;
  visibility: visible;
}

.inview {
  transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1);
  transform: translateY(3rem);
  opacity: 0;
}
.inview.inview-is-visible {
  transform: translateY(0);
  opacity: 1;
}

.inview-custom {
  transition: 1s cubic-bezier(0.165, 0.84, 0.44, 1);
  opacity: 0;
}
.inview-custom.inview-is-visible {
  opacity: 1;
}

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