@charset "UTF-8";
:root {
  --header-bg: #fff;
  --main-menu-clr: #333;
  --bg-clr: #fff;
  --txt-clr: #333;
  --cart-btn-bg: #333;
  --cart-btn-clr: #fff;
  --nav-bg: #1a1a1a;
  --nav-clr: #fff;
  --clr-red: #c1272d;
}

html {
  font-size: 100%;
  font-size: 62.5%;
}

body {
  padding: 0;
  margin: 0;
  border: 0;
  letter-spacing: 0.075em;
  font-family: "Lato", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ", "メイリオ", sans-serif;
  font-feature-settings: "palt";
  color: var(--txt-clr);
  background: #fff;
}

a:link, a:active, a:hover, a:visited {
  color: var(--txt-clr);
}

ul, li, dt, dd, p, h1, h2, h3, h4, h5, h6 {
  list-style: none;
  margin: 0;
  padding: 0;
}

p {
  font-size: 14px;
  font-size: 1.4rem;
}

.red {
  color: var(--clr-red);
}

.breadcrumb {
  font-size: 12px;
  font-size: 1.2rem;
  margin: 1.666em;
}
.breadcrumb .breadcrumb__child {
  display: inline-block;
}
.breadcrumb .breadcrumb__child:not(:last-of-type)::after {
  font-size: 12px;
  font-size: 1.2rem;
  margin: 0 1.25em;
  content: "＞";
}
.breadcrumb .breadcrumb__child a {
  color: var(--txt-clr);
  text-decoration: none;
}

@media only screen and (min-width: 768px) {
  .breadcrumb {
    font-size: 12px;
    font-size: 1.2rem;
    margin: 1.666em;
  }
}
@media only screen and (min-width: 1024px) {
  .breadcrumb {
    font-size: 12px;
    font-size: 1.2rem;
    margin-left: 0;
    margin-bottom: 2.5em;
  }
}
.title {
  font-size: 24px;
  font-size: 2.4rem;
  margin-bottom: 1.25em;
  text-align: center;
}
.title::before {
  content: "";
  display: block;
  height: 0;
  width: 0;
  margin-top: calc((1 - 1.8) * 0.5em);
}
@media only screen and (min-width: 768px) {
  .title {
    font-size: 36px;
    font-size: 3.6rem;
    margin-bottom: 0.833em;
    font-weight: bold;
  }
}
@media only screen and (min-width: 1024px) {
  .title {
    text-align: left;
  }
}

.s_title {
  font-size: 18px;
  font-size: 1.8rem;
  margin-bottom: 1.666em;
  text-align: left;
  font-weight: bold;
}

.list-disc li {
  font-size: 13px;
  font-size: 1.3rem;
  position: relative;
  padding-left: 0.769em;
  margin-bottom: 0.769em;
}
.list-disc li::before {
  font-size: 13px;
  font-size: 1.3rem;
  display: block;
  position: absolute;
  top: 0.5em;
  left: 0;
  width: 0.384em;
  height: 0.384em;
  background: var(--txt-clr);
  border-radius: 5em;
  content: "";
}

main > p:first-child {
  display: none;
}

.right > section {
  font-size: 10px;
  font-size: 1rem;
}

#index .wrap {
  font-size: 10px;
  font-size: 1rem;
  margin-top: 6em;
}

@media only screen and (min-width: 768px) {
  .right > section {
    font-size: 10px;
    font-size: 1rem;
  }
  #index .wrap {
    font-size: 10px;
    font-size: 1rem;
    margin-top: 8em;
  }
}
@media only screen and (min-width: 1024px) {
  .wrap {
    font-size: 10px;
    font-size: 1rem;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    grid-template-columns: repeat(6, 16.6666666667%);
    gap: 0px 0px;
    margin-top: 10em;
  }
  aside {
    grid-area: 1/1/2/2;
  }
  .right {
    grid-area: 1/2/2/7;
  }
  .topics {
    display: grid;
    grid-auto-rows: 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    gap: 0px 0px;
  }
  .topics_area {
    grid-area: 1/2/2/6;
  }
}
.wide_wrap > section {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 2.142em;
  padding: 0 1.428em;
}

@media only screen and (min-width: 768px) {
  .wide_wrap {
    width: 100%;
    padding: 0 6.25%;
  }
}
@media only screen and (min-width: 1024px) {
  .wide_wrap {
    font-size: 14px;
    font-size: 1.4rem;
    width: 50%;
    margin: 2.857em auto 0 auto;
    padding: 0;
  }
  .wide_wrap > section {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 7.142em;
    padding: 0;
  }
  .right > section {
    font-size: 10px;
    font-size: 1rem;
  }
  .right > .new_item {
    font-size: 10px;
    font-size: 1rem;
  }
}
.ff-lato {
  /* font-family: 'Lato', 'Yu Gothic Medium', '游ゴシック Medium', 'YuGothic', '游ゴシック体', 'ヒラギノ角ゴ', 'メイリオ', sans-serif; */
  font-weight: 800;
  letter-spacing: 0.075em;
}

.ff-cor {
  font-family: "Cormorant", "Yu Mincho", "游明朝", "游明朝体", "ヒラギノ明朝", serif;
  letter-spacing: 0.075em;
}

.ff-pla {
  font-family: "Playball", "Yu Mincho", "游明朝", "游明朝体", "ヒラギノ明朝", serif;
  font-weight: 500;
}

.ff-osw {
  font-family: "Oswald", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ", "メイリオ", sans-serif;
  font-weight: 800;
}

.ff-jos {
  font-family: "Josefin Slab", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ", "メイリオ", sans-serif;
  font-weight: 500;
  letter-spacing: 0.075em;
}

.ff-mon {
  font-family: "Monoton", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ", "メイリオ", sans-serif;
  font-weight: 500;
}

.ff-default {
  font-family: "Noto Sans", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ", "メイリオ", sans-serif;
  font-weight: 500;
}

.slide_menu {
  font-size: 14px;
  font-size: 1.4rem;
  position: fixed;
  top: 0;
  left: -120%;
  width: 100%;
  height: 110vh;
  height: 110dvh;
  padding: 7.142em 5% 8.571em 5%;
  margin-top: -1.429em;
  background: var(--nav-bg);
  transition: 0.3s ease-out;
  z-index: 50;
  overflow: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
  transition: 0.3s ease-out;
}
.slide_menu.open {
  left: 0;
  transition: 0.3s ease-out;
}
.slide_menu::-webkit-scrollbar {
  display: none;
}

.search {
  margin-bottom: 1.5em;
  border: 1px solid var(--nav-clr);
  overflow: hidden;
}
.search form {
  display: flex;
  justify-content: space-between;
}
.search input,
.search input[type=text] {
  font-size: 16px;
  font-size: 1.6rem;
  height: 2.5em;
  width: calc(100% - 2.625em);
  padding: 0 0.312em !important;
  margin-bottom: 0;
  border-radius: 0;
  box-shadow: none;
  border: none;
}
.search input::-moz-placeholder {
  font-size: 16px;
  font-size: 1.6rem;
}
.search input::placeholder {
  font-size: 16px;
  font-size: 1.6rem;
}
.search button {
  font-size: 10px;
  font-size: 1rem;
  width: 4em;
  height: 4em;
  border: none;
  background: var(--nav-bg);
}
.search button img {
  font-size: 10px;
  font-size: 1rem;
  width: 1.5em;
  height: auto;
}

.close {
  font-size: 13px;
  font-size: 1.3rem;
  position: relative;
  float: right;
  color: var(--nav-clr);
  margin-top: 4.615em;
  padding-bottom: 3em;
  line-height: 2;
  cursor: pointer;
}
.close::after {
  position: absolute;
  bottom: 3em;
  left: -1em;
  width: calc(100% + 1em);
  height: 1px;
  background: var(--nav-clr);
  transition: all 1s;
  content: "";
}
.close:hover::after {
  width: 100%;
  left: 0;
}

li.mypage {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 2.142em;
}
li.mypage span {
  font-size: 14px;
  font-size: 1.4rem;
  display: inline-block;
  width: 1.142em;
  height: 1.142em;
  margin-right: 0.714em;
  background-color: var(--nav-clr);
  vertical-align: middle;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center;
          mask-position: center;
  -webkit-mask-size: contain;
          mask-size: contain;
  -webkit-mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M20.4652%2020.3703C20.593%2020.2371%2020.7177%2020.1007%2020.8391%2019.9614L20.8566%2019.9411C20.9742%2019.8056%2021.0885%2019.6676%2021.1998%2019.5267C21.2088%2019.5154%2021.2175%2019.5041%2021.2265%2019.4928C21.3334%2019.3562%2021.4374%2019.2171%2021.5383%2019.0756C21.5498%2019.0593%2021.5616%2019.0432%2021.5731%2019.0269C21.6697%2018.89%2021.7631%2018.7509%2021.8537%2018.6096C21.8679%2018.5876%2021.882%2018.5657%2021.896%2018.5434C21.982%2018.4072%2022.065%2018.269%2022.1455%2018.1289C22.1616%2018.1009%2022.1782%2018.0728%2022.1941%2018.0445C22.2702%2017.9095%2022.3431%2017.7727%2022.4137%2017.6344C22.4312%2017.6002%2022.4491%2017.5659%2022.4664%2017.5314C22.5329%2017.3982%2022.5959%2017.2632%2022.6573%2017.1273C22.6759%2017.0864%2022.6948%2017.0456%2022.713%2017.0042C22.7702%2016.8731%2022.824%2016.7404%2022.8765%2016.6068C22.8951%2016.5594%2022.9144%2016.5127%2022.9324%2016.4651C22.9811%2016.3361%2023.0262%2016.2055%2023.0704%2016.0741C23.0883%2016.0208%2023.1074%2015.9676%2023.1247%2015.914C23.1651%2015.7873%2023.2019%2015.659%2023.2383%2015.5304C23.2551%2015.4708%2023.273%2015.412%2023.2889%2015.3522C23.322%2015.227%2023.351%2015.1003%2023.38%2014.9733C23.3947%2014.9089%2023.4108%2014.8452%2023.4243%2014.7806C23.4506%2014.6555%2023.4726%2014.5288%2023.4947%2014.4023C23.5065%2014.3346%2023.5203%2014.2679%2023.5308%2014.2001C23.5508%2014.0724%2023.566%2013.9434%2023.5819%2013.8144C23.5902%2013.7465%2023.6008%2013.6791%2023.6077%2013.6108C23.6219%2013.4735%2023.6311%2013.3346%2023.6405%2013.1959C23.6447%2013.135%2023.6511%2013.0749%2023.6543%2013.0137C23.6647%2012.8136%2023.6702%2012.6124%2023.6702%2012.4098C23.67%206.05878%2018.5212%200.909996%2012.17%200.909996C5.81876%200.909996%200.669983%206.05878%200.669983%2012.41C0.669983%2012.6126%200.675503%2012.8139%200.685853%2013.014C0.689073%2013.0752%200.695513%2013.1352%200.699653%2013.1961C0.709083%2013.3348%200.718283%2013.4737%200.732543%2013.6111C0.739673%2013.6794%200.750023%2013.7465%200.758303%2013.8146C0.773943%2013.9436%200.789353%2014.0727%200.809363%2014.2003C0.819943%2014.2682%200.833743%2014.3351%200.845473%2014.4025C0.867553%2014.529%200.889633%2014.6557%200.915853%2014.7808C0.929423%2014.8455%200.945753%2014.9092%200.960243%2014.9736C0.989223%2015.1003%201.0182%2015.227%201.05132%2015.3524C1.06719%2015.4122%201.08513%2015.4711%201.10192%2015.5306C1.13803%2015.6592%201.17506%2015.7875%201.21554%2015.9143C1.23279%2015.9681%201.25165%2016.021%201.26982%2016.0744C1.31398%2016.2055%201.35906%2016.3361%201.40782%2016.4654C1.42576%2016.513%201.44508%2016.5599%201.46371%2016.607C1.51615%2016.7407%201.56997%2016.8734%201.62724%2017.0045C1.64518%2017.0459%201.66427%2017.0864%201.6829%2017.1275C1.74431%2017.2637%201.80733%2017.3985%201.8738%2017.5316C1.89105%2017.5661%201.90899%2017.6004%201.92647%2017.6347C1.99708%2017.7729%202.07022%2017.9098%202.14612%2018.0448C2.16199%2018.0731%202.17855%2018.1011%202.19465%2018.1292C2.27515%2018.2692%202.35818%2018.4075%202.4442%2018.5436C2.45823%2018.5657%202.47249%2018.5876%202.48652%2018.6096C2.57714%2018.7509%202.67052%2018.8898%202.76689%2019.0266C2.77839%2019.0432%202.79012%2019.0595%202.80185%2019.0759C2.90259%2019.2173%203.00655%2019.3565%203.1135%2019.4931C3.12224%2019.5043%203.13121%2019.5156%203.13995%2019.5269C3.25104%2019.6679%203.36558%2019.8059%203.48311%2019.9413L3.50082%2019.9616C3.62226%2020.1007%203.74692%2020.2371%203.87457%2020.3703L3.88331%2020.3795C4.01464%2020.5159%204.14896%2020.6491%204.28673%2020.7788C6.34546%2022.7191%209.11788%2023.91%2012.1698%2023.91C15.2216%2023.91%2017.9938%2022.7188%2020.0525%2020.779L20.053%2020.7785C20.1908%2020.6488%2020.3251%2020.5157%2020.4564%2020.3793L20.4649%2020.3705L20.4652%2020.3703ZM12.17%205.05C14.3295%205.05%2016.08%206.80053%2016.08%208.96C16.08%2011.1195%2014.3295%2012.87%2012.17%2012.87C10.0105%2012.87%208.25998%2011.1195%208.25998%208.96C8.25998%206.80053%2010.0105%205.05%2012.17%205.05ZM12.17%2022.76C9.30533%2022.76%206.70932%2021.5898%204.83344%2019.7026C6.42665%2016.949%209.11696%2015.1383%2012.17%2015.1383C15.223%2015.1383%2017.9133%2016.949%2019.5065%2019.7026C17.6306%2021.5895%2015.0346%2022.76%2012.17%2022.76Z%22%20fill%3D%22%23222222%22%2F%3E%3C%2Fsvg%3E");
          mask-image: url("data:image/svg+xml;charset=utf8,%3Csvg%20width%3D%2224%22%20height%3D%2224%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%3E%3Cpath%20d%3D%22M20.4652%2020.3703C20.593%2020.2371%2020.7177%2020.1007%2020.8391%2019.9614L20.8566%2019.9411C20.9742%2019.8056%2021.0885%2019.6676%2021.1998%2019.5267C21.2088%2019.5154%2021.2175%2019.5041%2021.2265%2019.4928C21.3334%2019.3562%2021.4374%2019.2171%2021.5383%2019.0756C21.5498%2019.0593%2021.5616%2019.0432%2021.5731%2019.0269C21.6697%2018.89%2021.7631%2018.7509%2021.8537%2018.6096C21.8679%2018.5876%2021.882%2018.5657%2021.896%2018.5434C21.982%2018.4072%2022.065%2018.269%2022.1455%2018.1289C22.1616%2018.1009%2022.1782%2018.0728%2022.1941%2018.0445C22.2702%2017.9095%2022.3431%2017.7727%2022.4137%2017.6344C22.4312%2017.6002%2022.4491%2017.5659%2022.4664%2017.5314C22.5329%2017.3982%2022.5959%2017.2632%2022.6573%2017.1273C22.6759%2017.0864%2022.6948%2017.0456%2022.713%2017.0042C22.7702%2016.8731%2022.824%2016.7404%2022.8765%2016.6068C22.8951%2016.5594%2022.9144%2016.5127%2022.9324%2016.4651C22.9811%2016.3361%2023.0262%2016.2055%2023.0704%2016.0741C23.0883%2016.0208%2023.1074%2015.9676%2023.1247%2015.914C23.1651%2015.7873%2023.2019%2015.659%2023.2383%2015.5304C23.2551%2015.4708%2023.273%2015.412%2023.2889%2015.3522C23.322%2015.227%2023.351%2015.1003%2023.38%2014.9733C23.3947%2014.9089%2023.4108%2014.8452%2023.4243%2014.7806C23.4506%2014.6555%2023.4726%2014.5288%2023.4947%2014.4023C23.5065%2014.3346%2023.5203%2014.2679%2023.5308%2014.2001C23.5508%2014.0724%2023.566%2013.9434%2023.5819%2013.8144C23.5902%2013.7465%2023.6008%2013.6791%2023.6077%2013.6108C23.6219%2013.4735%2023.6311%2013.3346%2023.6405%2013.1959C23.6447%2013.135%2023.6511%2013.0749%2023.6543%2013.0137C23.6647%2012.8136%2023.6702%2012.6124%2023.6702%2012.4098C23.67%206.05878%2018.5212%200.909996%2012.17%200.909996C5.81876%200.909996%200.669983%206.05878%200.669983%2012.41C0.669983%2012.6126%200.675503%2012.8139%200.685853%2013.014C0.689073%2013.0752%200.695513%2013.1352%200.699653%2013.1961C0.709083%2013.3348%200.718283%2013.4737%200.732543%2013.6111C0.739673%2013.6794%200.750023%2013.7465%200.758303%2013.8146C0.773943%2013.9436%200.789353%2014.0727%200.809363%2014.2003C0.819943%2014.2682%200.833743%2014.3351%200.845473%2014.4025C0.867553%2014.529%200.889633%2014.6557%200.915853%2014.7808C0.929423%2014.8455%200.945753%2014.9092%200.960243%2014.9736C0.989223%2015.1003%201.0182%2015.227%201.05132%2015.3524C1.06719%2015.4122%201.08513%2015.4711%201.10192%2015.5306C1.13803%2015.6592%201.17506%2015.7875%201.21554%2015.9143C1.23279%2015.9681%201.25165%2016.021%201.26982%2016.0744C1.31398%2016.2055%201.35906%2016.3361%201.40782%2016.4654C1.42576%2016.513%201.44508%2016.5599%201.46371%2016.607C1.51615%2016.7407%201.56997%2016.8734%201.62724%2017.0045C1.64518%2017.0459%201.66427%2017.0864%201.6829%2017.1275C1.74431%2017.2637%201.80733%2017.3985%201.8738%2017.5316C1.89105%2017.5661%201.90899%2017.6004%201.92647%2017.6347C1.99708%2017.7729%202.07022%2017.9098%202.14612%2018.0448C2.16199%2018.0731%202.17855%2018.1011%202.19465%2018.1292C2.27515%2018.2692%202.35818%2018.4075%202.4442%2018.5436C2.45823%2018.5657%202.47249%2018.5876%202.48652%2018.6096C2.57714%2018.7509%202.67052%2018.8898%202.76689%2019.0266C2.77839%2019.0432%202.79012%2019.0595%202.80185%2019.0759C2.90259%2019.2173%203.00655%2019.3565%203.1135%2019.4931C3.12224%2019.5043%203.13121%2019.5156%203.13995%2019.5269C3.25104%2019.6679%203.36558%2019.8059%203.48311%2019.9413L3.50082%2019.9616C3.62226%2020.1007%203.74692%2020.2371%203.87457%2020.3703L3.88331%2020.3795C4.01464%2020.5159%204.14896%2020.6491%204.28673%2020.7788C6.34546%2022.7191%209.11788%2023.91%2012.1698%2023.91C15.2216%2023.91%2017.9938%2022.7188%2020.0525%2020.779L20.053%2020.7785C20.1908%2020.6488%2020.3251%2020.5157%2020.4564%2020.3793L20.4649%2020.3705L20.4652%2020.3703ZM12.17%205.05C14.3295%205.05%2016.08%206.80053%2016.08%208.96C16.08%2011.1195%2014.3295%2012.87%2012.17%2012.87C10.0105%2012.87%208.25998%2011.1195%208.25998%208.96C8.25998%206.80053%2010.0105%205.05%2012.17%205.05ZM12.17%2022.76C9.30533%2022.76%206.70932%2021.5898%204.83344%2019.7026C6.42665%2016.949%209.11696%2015.1383%2012.17%2015.1383C15.223%2015.1383%2017.9133%2016.949%2019.5065%2019.7026C17.6306%2021.5895%2015.0346%2022.76%2012.17%2022.76Z%22%20fill%3D%22%23222222%22%2F%3E%3C%2Fsvg%3E");
}

.item-category-midium {
  font-size: 24px;
  font-size: 2.4rem;
  position: relative;
  margin-bottom: 1.25em;
  color: var(--nav-clr);
  font-weight: bold;
}
.item-category-midium div {
  font-size: 24px;
  font-size: 2.4rem;
  padding-left: 1.458em;
}
.item-category-midium div a {
  color: var(--nav-clr);
  text-decoration: none;
}
.item-category-midium li.active::before {
  display: none;
  transition: all 0.5s;
}
.item-category-midium li {
  font-size: 24px;
  font-size: 2.4rem;
  margin-top: 1.25em;
}
.item-category-midium li div {
  transition: all 0.5s;
}
.item-category-midium li div:hover {
  opacity: 0.6;
  transition: all 1s;
}

.open > li:first-child::after, .open > li:first-child::before {
  font-size: 24px;
  font-size: 2.4rem;
  position: absolute;
  display: block;
  top: 0.75em;
  left: 0;
  width: 0.75em;
  height: 1px;
  background: var(--nav-clr);
  transition: all 0.5s;
  content: "";
}
.open > li:first-child::before {
  transform: rotate(90deg);
}

.open_icon > li:first-child::before {
  display: none;
}

.item-category-child {
  margin-bottom: 1.5em;
}
.item-category-child li {
  font-size: 13px;
  font-size: 1.3rem;
  line-height: 1.8;
  padding-left: 2.692em;
}
.item-category-child a {
  font-weight: normal;
  color: var(--nav-clr);
  transition: all 0.5s;
}
.item-category-child a:hover {
  opacity: 0.6;
  transition: all 1s;
}

.slide-main-menu li {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 1.071em;
}
.slide-main-menu li a {
  display: block;
  text-decoration: none;
  color: var(--nav-clr);
}

@media only screen and (min-width: 768px) {
  .slide_menu {
    font-size: 14px;
    font-size: 1.4rem;
    width: 25%;
    padding: 7.142em 2.7777777778%;
    margin-top: 0;
    transition: 0.5s ease-out;
  }
  .slide_menu.open {
    transition: 0.5s ease-out;
  }
}
@media only screen and (min-width: 1024px) {
  .slide_menu {
    font-size: 14px;
    font-size: 1.4rem;
    width: 16.6666666667%;
    right: -120%;
    left: auto;
    padding-bottom: 10.714em;
  }
  .slide_menu.open {
    left: auto;
    right: 0;
  }
  .item-category-midium:hover {
    cursor: pointer;
  }
  .search input,
.search input[type=text] {
    font-size: 14px;
    font-size: 1.4rem;
    height: 2.857em;
    width: calc(100% - 3em);
    padding: 0 0.357em !important;
  }
  .search input::-moz-placeholder {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .search input::placeholder {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
.category_nav {
  background: var(--nav-bg);
  position: relative;
  overflow: hidden;
}
.category_nav ul {
  text-align: center;
}
.category_nav ul li {
  font-size: 14px;
  font-size: 1.4rem;
  display: inline-block;
  padding: 1.071em 0.357em;
  text-align: center;
  min-width: calc(33.3333333333% - 0.357em * 2);
  color: var(--nav-clr);
  font-weight: bold;
}
.category_nav ul li a {
  color: var(--nav-clr);
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
}

.side_shopinfo {
  display: none;
}

@media only screen and (min-width: 768px) {
  .category_nav {
    font-size: 18px;
    font-size: 1.8rem;
    height: 3.333em;
    overflow: hidden;
  }
  .category_nav ul li {
    font-size: 18px;
    font-size: 1.8rem;
    transition: all 1s;
  }
  .category_nav ul li a {
    font-size: 18px;
    font-size: 1.8rem;
  }
  .category_nav ul li a:hover {
    opacity: 0.6;
  }
  .category_nav .next {
    right: -15%;
  }
  .category_nav.scroll > ul {
    width: 100%;
  }
}
.category_list {
  font-size: 18px;
  font-size: 1.8rem;
}
.category_list nav {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 4em;
}

.category_title {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 0.833em 1.111em;
  font-weight: bold;
}
.category_title a {
  text-decoration: none;
  color: var(--txt-clr);
}

.category_group,
.menu_group {
  position: relative;
  overflow: hidden;
}
.category_group::after, .category_group::before,
.menu_group::after,
.menu_group::before {
  position: absolute;
  display: block;
  width: 100%;
  height: 1px;
  background: var(--txt-clr);
  opacity: 0.3;
  content: "";
}
.category_group::before,
.menu_group::before {
  top: 0;
}
.category_group::after,
.menu_group::after {
  bottom: 0;
}
.category_group + p,
.menu_group + p {
  margin-top: 2em;
}
.category_group li,
.menu_group li {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  float: left;
  margin-bottom: -1px;
  height: 2.857em;
  width: calc(50% - 2px);
  text-align: center;
}
.category_group li::after,
.menu_group li::after {
  position: absolute;
  width: 100%;
  height: 1px;
  display: block;
  bottom: 0;
  background: var(--txt-clr);
  opacity: 0.3;
  content: "";
}
.category_group li a,
.menu_group li a {
  position: absolute;
  display: block;
  top: 50%;
  width: 96%;
  padding: 0 2%;
  color: var(--txt-clr);
  text-overflow: ellipsis;
  text-decoration: none;
  white-space: nowrap;
  transform: translateY(-50%);
  overflow: hidden;
}
.category_group li:nth-of-type(1),
.category_group li:nth-of-type(2),
.menu_group li:nth-of-type(1),
.menu_group li:nth-of-type(2) {
  border-top: 0;
}
.category_group li:nth-of-type(2n+1)::before,
.menu_group li:nth-of-type(2n+1)::before {
  position: absolute;
  width: 1px;
  height: 30px;
  top: 5px;
  right: 0;
  background: var(--txt-clr);
  opacity: 0.3;
  content: "";
}

@media only screen and (min-width: 768px) {
  .category_list {
    margin: 0;
  }
  .category_title {
    margin-left: 6.25%;
    margin-right: 6.25%;
  }
}
@media only screen and (min-width: 1024px) {
  .category_list {
    padding: 0;
    margin: 1em 20%;
  }
  .category_list .title {
    position: relative;
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 2.142em;
    font-weight: bold;
    font-family: "Lato", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ", "メイリオ", sans-serif;
  }
  .category_list .title span {
    position: absolute;
    display: inline-block;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: 100%;
    padding-right: 0.5em;
    background: var(--bg-clr);
    transform: translateY(-50%);
  }
  .category_list .title::before {
    position: absolute;
    display: block;
    width: 100%;
    height: 1px;
    top: 50%;
    margin-top: 0 !important;
    background: var(--txt-clr);
    content: "";
  }
  .category_list nav + .title {
    font-size: 14px;
    font-size: 1.4rem;
    margin-top: 4.285em;
  }
  .category_list .category_title {
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 0 1.111em 0;
    border: none;
    transition: all 0.5s;
  }
  .category_list .category_title:hover {
    opacity: 0.6;
    transition: all 1s;
  }
  .category_list .category_group {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 2.142em;
    border-top: 0;
    border-bottom: 0;
  }
  .category_list .category_group.side_shopinfo {
    display: block;
  }
  .category_list .category_group.side_shopinfo li {
    margin-left: 0;
  }
  .category_list .category_group li {
    font-size: 14px;
    font-size: 1.4rem;
    width: 100%;
    height: auto;
    margin: 0 0 1.071em -0.358em;
    text-align: left;
    border-top: 0;
    border-bottom: 0;
    transition: all 0.5s;
  }
  .category_list .category_group li:hover {
    opacity: 0.6;
    transition: all 0.5s;
  }
  .category_list .category_group li:last-child {
    margin-bottom: 0;
  }
  .category_list .category_group li a {
    position: initial;
    top: auto;
    text-overflow: initial;
    overflow: auto;
    white-space: initial;
    transform: none;
  }
  .category_list .category_group li::before {
    display: none;
  }
}
@media only screen and (min-width: 1024px) {
  .menu_group {
    border-top: none;
    border-bottom: none;
  }
  .menu_group li {
    text-align: left;
    border-top: 0;
    border-bottom: 0;
    transition: all 0.5s;
  }
  .menu_group li:hover {
    opacity: 0.6;
    transition: all 1s;
  }
  .menu_group li::before {
    display: none;
  }
}
.banner_wrap {
  overflow: hidden;
  font-size: 1px;
  padding: 40em 20em;
  margin-bottom: 40em;
  text-align: center;
}
.banner_wrap .banner {
  display: inline-block;
  width: calc(50% - 2px);
  margin: 0;
}
.banner_wrap img {
  width: 100%;
  height: auto;
}

@media only screen and (min-width: 1024px) {
  .banner_wrap {
    font-size: 14px;
    font-size: 1.4rem;
    width: 100%;
    padding: 2.857em 0;
    margin-bottom: 0;
  }
  .banner_wrap .banner {
    width: 100%;
    margin: 0 0 1px 0;
    transition: all 0.5s;
  }
  .banner_wrap .banner:hover {
    opacity: 0.6;
    transition: all 1s;
  }
}
@media only screen and (min-width: 1024px) {
  .category_list .category_group::before, .category_list .category_group::after,
.menu_group::before,
.menu_group::after {
    display: none;
  }
  .category_list .category_group li,
.menu_group li {
    border: none;
    margin-left: 0;
  }
  .category_list .category_group li::before, .category_list .category_group li::after,
.menu_group li::before,
.menu_group li::after {
    display: none;
  }
}
.bg_image::before {
  display: none !important;
}

.bg_image span {
  background: transparent !important;
}

.informationBanner {
  z-index: 150;
  color: #fff;
  text-decoration: none !important;
  width: 100%;
}
.informationBanner .informationBannerClose {
  font-size: 10px !important;
  font-size: 1em !important;
}
.informationBanner .informationBannerArrow {
  font-size: 15px !important;
  font-size: 1.5em !important;
}

.informationBanner {
  padding: 0 16px !important;
  min-height: 52px !important;
}

@media only screen and (min-width: 1024px) {
  .informationBanner {
    min-height: 44px !important;
  }
}
.header_wrapper {
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 150;
}

header {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  top: 0;
  height: 4.285em;
  background: var(--header-bg);
  z-index: 100;
}
header h1 {
  font-size: 26px;
  font-size: 2.6rem;
  position: absolute;
  display: block;
  top: 50%;
  left: 50%;
  width: calc(100% - 3.846em);
  text-align: center;
  line-height: 1;
  transform: translate(-50%, -50%);
  white-space: nowrap;
  overflow: hidden;
}
header h1 a {
  text-decoration: none;
}
header h1 .logoImage {
  font-size: 10px;
  font-size: 1rem;
  display: block;
  margin: 0 auto;
  max-width: 75%;
  max-height: 5.6em;
  vertical-align: middle;
}
header .cart {
  position: absolute;
  top: 0;
  right: 0;
}
header .mypage_icon {
  display: none;
}
@media only screen and (min-width: 1024px) {
  header .mypage_icon {
    display: block;
  }
  header .mypage_icon svg {
    fill: var(--main-menu-clr);
  }
}
header #baseMenu .base img,
header #baseMenu .cart img {
  font-size: 10px;
  font-size: 1rem;
  height: 2.4em;
  width: 2.4em;
}
header #baseMenu .cart {
  font-size: 10px;
  font-size: 1rem;
  position: absolute;
  top: 50%;
  right: 1em;
  transform: translateY(-50%);
}
@media only screen and (min-width: 1024px) {
  header #baseMenu .cart {
    font-size: 10px;
    font-size: 1rem;
    margin-right: 3em;
    cursor: pointer;
  }
}
header #baseMenu .cart img {
  display: none;
}
header #baseMenu #cart_icon {
  font-size: 10px;
  font-size: 1rem;
  width: 2.9em;
  margin-top: -3px;
  color: var(--main-menu-clr);
}
header #baseMenu .base {
  display: none;
}

.menu_btn {
  font-size: 10px;
  font-size: 1rem;
  position: absolute;
  top: 60%;
  left: 1em;
  transform: translateY(-60%);
}
.menu_btn img {
  font-size: 10px;
  font-size: 1rem;
  width: 3em;
  height: auto;
}
.menu_btn svg {
  font-size: 10px;
  font-size: 1rem;
  width: 3em;
  height: auto;
  margin-top: -0.7em;
  color: var(--main-menu-clr);
  fill: var(--main-menu-clr);
}

.fixed {
  position: fixed;
  width: 100%;
  z-index: 100;
  transition: all 5s;
}

@media only screen and (min-width: 768px) {
  header {
    font-size: 14px;
    font-size: 1.4rem;
    height: 5.714em;
  }
  header h1 {
    font-size: 36px;
    font-size: 3.6rem;
    transition: 1s;
  }
  header h1:hover {
    opacity: 0.6;
  }
  header h1 .logoImage {
    font-size: 14px;
    font-size: 1.4rem;
    max-height: 4.285em;
    max-width: 65%;
    padding: 0;
  }
  header h1 .logoImage img {
    -o-object-fit: contain;
       object-fit: contain;
  }
}
@media only screen and (min-width: 1024px) {
  header h1 {
    font-size: 36px;
    font-size: 3.6rem;
    display: -webkit-box;
    left: 2.7777777778%;
    max-width: 30%;
    text-align: left;
    transform: translate(0, -50%);
    white-space: initial;
    transition: 1s;
    overflow: hidden;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
  }
  header h1:hover {
    opacity: 0.6;
  }
  header h1 .logoImage {
    margin: 0;
    max-width: 100%;
  }
  .menu_btn {
    font-size: 24px;
    font-size: 2.4rem;
    right: 2.291em;
    left: auto;
  }
}
.main_menu {
  display: none;
}

@media only screen and (min-width: 1024px) {
  .main_menu {
    font-size: 14px;
    font-size: 1.4rem;
    position: relative;
    display: flex;
    float: right;
    max-width: 50%;
    justify-content: flex-end;
    flex-wrap: wrap;
    top: 50%;
    transform: translateY(-50%);
  }
  .main_menu li {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 0.142em 0 0.142em 2.142em;
    font-weight: bold;
    justify-content: flex-end;
    white-space: nowrap;
    overflow: hidden;
  }
  .main_menu li a {
    display: block;
    height: 100%;
    text-decoration: none;
    color: var(--main-menu-clr);
    overflow: hidden;
    transition: all 0.25s;
  }
  .main_menu li a:hover {
    opacity: 0.6;
    transition: all 0.5s;
  }
  .menu_icon_wrap {
    font-size: 14px;
    font-size: 1.4rem;
    display: flex;
    gap: 0 30px;
    align-items: center;
    float: right;
    margin: 1.571em 2.7777777778% 0 2.142em;
  }
  .menu_icon_wrap .menu_icon,
.menu_icon_wrap #baseMenu {
    display: inline-block;
    vertical-align: middle;
  }
  .menu_icon_wrap #baseMenu + .menu_icon > div {
    font-size: 14px;
    font-size: 1.4rem;
  }
  header #baseMenu .cart {
    position: initial;
    margin: 0;
    transform: none;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
  }
  .menu_btn {
    position: initial;
    margin: 0;
    transform: none;
    top: auto;
    left: auto;
    right: auto;
    bottom: auto;
  }
}
/*アイコン出し分け*/
.menu_icon > div:not(.icon_full) {
  display: none;
}

.menu_icon > .icon_cat:only-of-type,
.menu_icon > .icon_cat + .icon_search,
.menu_icon > .icon_cat + .icon_cat {
  display: block;
}

.icon_full + .icon_cat + .icon_search {
  display: none;
}

@media only screen and (min-width: 1024px) {
  .menu_icon > .icon_cat:only-of-type {
    display: none;
  }
}
/*カートバッジ*/
.cart-badge {
  display: block !important;
  position: relative;
}

.cart-qty {
  position: absolute;
  top: -4px;
  right: -5px;
  padding: 0 1px;
  min-width: 14px;
  background: var(--cart-btn-bg);
  border-radius: 50%;
  color: var(--cart-btn-clr);
  font-size: 10px;
  font-weight: 700;
  line-height: 16px;
  text-align: center;
}

.footer {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  padding: 5em 0 0.714em 0;
  overflow: hidden;
}
.footer::before {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.1;
  background: var(--txt-clr);
  content: "";
}
.footer .footer_logo a {
  font-size: 26px;
  font-size: 2.6rem;
  display: block;
  margin: 0 5% 2.692em 5%;
  color: var(--txt-clr);
  text-decoration: none;
  transition: all 1s;
}
.footer .footer_logo a:hover {
  opacity: 0.6;
  transition: all 0.5s;
}
.footer .footer_logo a .logoImage {
  font-size: 42px;
  font-size: 4.2rem;
  display: block;
  max-width: 65%;
}
@media only screen and (min-width: 768px) {
  .footer .footer_logo a .logoImage {
    max-width: 100%;
  }
}
.footer .footer_logo .logo_wrap .logoText {
  color: var(--txt-clr) !important;
}
.footer .magazine,
.footer .footer_pay {
  font-size: 13px;
  font-size: 1.3rem;
  margin-top: 2.307em;
  margin-bottom: 4.615em;
  padding: 0 5%;
}
.footer .magazine .s_title,
.footer .footer_pay .s_title {
  font-size: 18px;
  font-size: 1.8rem;
  margin-bottom: 1.111em;
}
.footer .footer_menu {
  font-size: 13px;
  font-size: 1.3rem;
  margin-bottom: 1.538em;
}
.footer .footer_menu > .s_title {
  padding: 0 5%;
}
.footer .footer_menu a {
  text-decoration: none;
  color: var(--txt-clr);
}

#footer {
  position: relative;
}
#footer .copyright {
  font-size: 13px;
  font-size: 1.3rem;
  position: absolute;
  left: 1.538em;
  bottom: 6.153em;
}

.mailMagazineSubscribe_form {
  margin-top: 2em;
  overflow: hidden;
  border: 1px solid var(--bg-clr);
}
.mailMagazineSubscribe_form input,
.mailMagazineSubscribe_form input[type=text],
.mailMagazineSubscribe_form input[type=email] {
  font-size: 16px;
  font-size: 1.6rem;
  float: left;
  height: 2.5em;
  width: calc(100% - 5.062em);
  border: none;
  padding: 0 0 0 0.312em;
  margin: 0;
  border-radius: 0 !important;
  box-shadow: none;
  background: #fff;
  color: #222;
}
.mailMagazineSubscribe_form button {
  font-size: 14px;
  font-size: 1.4rem;
  float: right;
  width: 5.714em;
  height: 2.857em;
  border: none;
  border-left: 1px solid var(--bg-clr);
  color: var(--bg-clr);
  background: var(--txt-clr);
}

@media only screen and (min-width: 1024px) {
  .mailMagazineSubscribe_form input,
.mailMagazineSubscribe_form input[type=text],
.mailMagazineSubscribe_form input[type=email] {
    font-size: 14px;
    font-size: 1.4rem;
    height: 2.857em;
    width: calc(100% - 5.785em);
  }
}
.footer_bottom {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  padding: 2.857em 1.428em 5.714em 1.428em;
}
.footer_bottom li {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
}
.footer_bottom li a {
  text-decoration: none;
  color: var(--txt-clr);
}
.footer_bottom small {
  font-size: 14px;
  font-size: 1.4rem;
  position: absolute;
  display: block;
  left: 0;
  bottom: 2.857em;
  padding: 0 1.428em;
  margin-top: 1.428em;
  color: var(--txt-clr);
}

.footer_select {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  width: 100%;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin-left: 1.428em;
  margin-bottom: 7.142em;
  overflow: hidden;
}
.footer_select + p {
  font-size: 14px;
  font-size: 1.4rem;
  opacity: 0.6;
}
.footer_select #i18 {
  font-size: 14px;
  font-size: 1.4rem;
  float: left;
  margin: 0 1.428em 0 0;
}
.footer_select #i18 .lang,
.footer_select #i18 .currency {
  position: relative;
  display: inline-block;
}
.footer_select #i18 .lang::after,
.footer_select #i18 .currency::after {
  font-size: 14px;
  font-size: 1.4rem;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: 0.75em;
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0.285em 0.25em 0 0.25em;
  border-color: var(--bg-clr) transparent transparent transparent;
  content: "";
}
.footer_select #i18 .lang select,
.footer_select #i18 .currency select {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  display: inline-block;
  margin: 0.25em;
  padding: 0.5em 2em 0.5em 0.75em;
  min-width: auto;
  color: var(--bg-clr);
  background: var(--txt-clr);
  border: 1px solid var(--bg-clr);
  border-radius: 0;
}
.footer_select #i18 .lang select option,
.footer_select #i18 .currency select option {
  background: var(--txt-clr);
}
.footer_select #baseMenu {
  font-size: 14px;
  font-size: 1.4rem;
  float: left;
  margin-top: 0.285em;
}
.footer_select #baseMenu .cart {
  display: none;
}

@media only screen and (min-width: 768px) {
  .footer {
    width: 100%;
    padding: 0 6.25%;
  }
  .footer_bottom {
    width: 100%;
    padding: 2em 6.25% 4em 6.25%;
  }
  .footer_select {
    font-size: 14px;
    font-size: 1.4rem;
    margin-left: 6.25%;
    margin-bottom: 1.428em;
  }
  #footer .copyright {
    font-size: 14px;
    font-size: 1.4rem;
    bottom: 4.285em;
    left: 6.25%;
  }
  .footer {
    font-size: 10px;
    font-size: 1rem;
    padding-top: 7em;
    padding-bottom: 7em;
  }
  .footer .footer_menu > .s_title,
.footer .magazine,
.footer .footer_pay,
.footer .footer_logo a {
    padding: 0;
  }
  .footer .footer_logo a {
    font-size: 36px;
    font-size: 3.6rem;
    margin: 0 0 1.944em 0;
  }
  .footer .footer_pay {
    margin-bottom: 0;
  }
  .footer .menu_group {
    margin: 0 -6.25%;
  }
}
@media only screen and (min-width: 1024px) {
  #footer {
    position: relative;
  }
  .footer {
    font-size: 10px;
    font-size: 1rem;
    display: grid;
    padding: 6em 0;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    gap: 0px 0px;
    grid-auto-flow: row;
  }
  .footer .footer_logo {
    grid-area: 1/1/2/3;
  }
  .footer .footer_menu {
    grid-area: 1/3/2/4;
  }
  .footer .footer_pay {
    grid-area: 1/5/2/6;
  }
  .logo_wrap {
    font-size: 36px;
    font-size: 3.6rem;
    padding: 0 8.3333333333%;
  }
  .footer .footer_logo .size_small a .logoImage {
    font-size: 10px;
    font-size: 1rem;
    max-height: 6em;
  }
  .footer .magazine,
.footer .footer_pay,
.footer .footer_menu > .s_title {
    font-size: 18px;
    font-size: 1.8rem;
    padding: 0;
    margin-bottom: 1.111em;
    margin-top: 0;
  }
  .footer .menu_group {
    margin: 0;
  }
  .footer_bottom {
    font-size: 14px;
    font-size: 1.4rem;
    position: relative;
    padding: 2.857em 2.7777777778% 7.857em 2.7777777778%;
  }
  .footer_bottom li {
    display: inline-block;
    font-size: 14px;
    font-size: 1.4rem;
    margin-right: 2.142em;
    transition: all 0.5s;
  }
  .footer_bottom li:hover {
    opacity: 0.6;
    transition: all 1s;
  }
  .footer_bottom small {
    display: block;
    position: initial;
    padding: 0;
  }
  .footer_select {
    font-size: 14px;
    font-size: 1.4rem;
    position: absolute;
    bottom: 5.357em;
    right: 2.7777777778%;
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    overflow: initial;
  }
  .footer_select #i18 {
    font-size: 14px;
    font-size: 1.4rem;
    float: right;
    margin: 0 0 0 1.428em;
  }
  .footer_select #baseMenu {
    float: right;
  }
  #footer .copyright {
    font-size: 14px;
    font-size: 1.4rem;
    bottom: 4.285em;
    left: 2.7777777778%;
    padding: 0;
  }
}
.creditcard {
  font-size: 10px;
  font-size: 1rem;
  margin-top: 0.5em;
  overflow: hidden;
}
.creditcard li {
  font-size: 10px;
  font-size: 1rem;
  display: inline-block;
  width: 3em;
  height: 3em;
  margin-right: 0.2em;
}
.creditcard li img {
  width: 100%;
  height: auto;
}

/*SNS*/
.shop_sns {
  font-size: 10px;
  font-size: 1rem;
  margin: 5em 0;
}

.sns_txt {
  font-size: 12px;
  font-size: 1.2rem;
  margin: 1.666em 0 0 0;
  text-align: center;
}
.sns_txt > li {
  display: inline-block;
}
.sns_txt > li:not(:last-child)::after {
  font-size: 10px;
  font-size: 1rem;
  margin-left: 0.5em;
  content: "／";
}

.sns_icon {
  text-align: center;
}
.sns_icon > li {
  display: inline-block;
}

#twitter_icon,
#facebook_icon,
#instagram_icon {
  font-size: 12px;
  font-size: 1.2rem;
  margin: 0 0.833em;
  width: 1.666em;
  height: 1.666em;
  fill: var(--txt-clr);
}

@media only screen and (min-width: 1024px) {
  /*SNS*/
  .shop_sns {
    font-size: 10px;
    font-size: 1rem;
    margin: 3em 0 4.5em 0;
  }
  .sns_txt,
.sns_icon {
    text-align: left;
  }
  .sns_txt {
    font-size: 14px;
    font-size: 1.4rem;
    margin: 1.071em 0 0 0;
  }
  #twitter_icon,
#facebook_icon,
#instagram_icon {
    font-size: 12px;
    font-size: 1.2rem;
    margin: 0 1.25em 0 0;
    width: 2.5em;
    height: 2.5em;
  }
  .sns_icon li a,
.sns_txt li a {
    transition: all 1s;
  }
  .sns_icon li a:hover,
.sns_txt li a:hover {
    opacity: 0.6;
    transition: all 0.5s;
  }
}
.i-gray {
  filter: brightness(100%);
}

.i-white {
  filter: brightness(300%);
}

.i-black {
  filter: brightness(-300%);
}

input, select {
  -webkit-appearance: none;
  -moz-appearance: none;
       appearance: none;
  line-height: 1 !important;
}

.bnr-float {
  font-size: 10px;
  font-size: 1rem;
  position: fixed;
  right: 50%;
  bottom: 8em;
  transform: translateX(50%);
  z-index: 49;
  display: none;
}
.bnr-float img {
  width: auto;
  height: auto;
  max-width: 20em;
  max-height: 20em;
}
.bnr-float .bnr-float-close {
  display: block;
  position: absolute;
  right: -1.5em;
  top: -1.5em;
  width: 3.5em;
  height: 3.5em;
  background: url('data:image/svg+xml;charset=utf8,%3Csvg id="a" xmlns="http%3A//www.w3.org/2000/svg" viewBox="0 0 35 35"%3E%3Ccircle cx="17.5" cy="17.5" r="12.5" style="fill%3A%23444; stroke-width%3A0px;"/%3E%3Cpath d="m18.914,17.5l4.293-4.293c.391-.391.391-1.023,0-1.414s-1.023-.391-1.414,0l-4.293,4.293-4.293-4.293c-.391-.391-1.023-.391-1.414,0s-.391,1.023,0,1.414l4.293,4.293-4.293,4.293c-.391.391-.391,1.023,0,1.414.195.195.451.293.707.293s.512-.098.707-.293l4.293-4.293,4.293,4.293c.195.195.451.293.707.293s.512-.098.707-.293c.391-.391.391-1.023,0-1.414l-4.293-4.293Z" style="fill%3A%23fff; stroke-width%3A0px;"/%3E%3C/svg%3E') center center no-repeat;
  transition: opacity 0.5s;
  opacity: 1;
}
.bnr-float .bnr-float-close:hover {
  cursor: pointer;
  transition: opacity 0.5s;
  opacity: 0.75;
}
@media only screen and (min-width: 768px) {
  .bnr-float {
    bottom: 10em;
    right: 3em;
    transform: translateX(0);
  }
  .bnr-float img {
    max-width: 30em;
    max-height: 30em;
  }
}

.pickup {
  font-size: 10px;
  font-size: 1rem;
  padding-top: 4em;
}
.pickup .item {
  position: relative;
}
.pickup .item .item_img {
  width: 100%;
  height: auto;
}
.pickup .item img {
  font-size: 10px;
  font-size: 1rem;
  width: 100%;
  height: 37.5em;
  -o-object-fit: cover;
     object-fit: cover;
}

@media only screen and (min-width: 768px) {
  .pickup {
    font-size: 10px;
    font-size: 1rem;
    position: relative;
    font-weight: bold;
  }
  .pickup .item_img {
    aspect-ratio: 1/1;
    overflow: hidden;
  }
  .pickup .item_img img {
    height: 100%;
  }
  .pickup_wrap {
    display: flex;
    justify-content: center;
  }
  .pickup_wrap .item {
    position: relative;
    width: 33.3333333333%;
    overflow: hidden;
    background: rgba(0, 0, 0, 0.05);
  }
  .pickup_wrap .item img {
    transition: all 0.25s;
  }
  .pickup_wrap .item:hover .item_img img {
    filter: brightness(1.25);
    transform: scale(1.1);
    transition: all 1s;
  }
  .pickup_wrap .item .item_data {
    font-size: 10px;
    font-size: 1rem;
    position: absolute;
    left: 3em;
    bottom: 0;
    padding: 0 0 3em 0;
    color: #fff;
    text-shadow: 0 0 5px rgba(0, 0, 0, 0.3);
  }
  .pickup_wrap .item .item_name {
    font-size: 18px;
    font-size: 1.8rem;
    font-weight: bold;
  }
  .pickup_wrap .item .item_price {
    font-size: 14px;
    font-size: 1.4rem;
    color: #fff;
  }
}
@media only screen and (min-width: 1024px) {
  .pickup {
    font-size: 10px;
    font-size: 1rem;
    padding-top: 11.5em;
  }
  .pickup .title {
    position: absolute;
    width: 83.3333333333%;
    margin: 0 0 0 16.6666666667%;
    transform: translateY(-50%);
    z-index: 10;
  }
}
.main_slider {
  width: 100%;
}

.swiper-wrapper {
  position: relative;
  margin: 0;
  padding: 0;
}
.swiper-wrapper img {
  width: 100%;
  height: auto;
}
.swiper-wrapper .txt {
  position: absolute;
  width: 80%;
  margin: 10%;
  background: rgba(255, 255, 255, 0.5);
}
.swiper-wrapper .txt p {
  text-align: center;
}

.swiper-button-prev,
.swiper-button-next {
  color: #fff !important;
}
.swiper-button-prev::after,
.swiper-button-next::after {
  font-size: 25px !important;
  font-size: 2.5em !important;
}

.slick-slide img {
  width: 100%;
}

.slick-prev,
.slick-next,
.slick-item-prev,
.slick-item-next {
  position: absolute;
  z-index: 3;
  top: 50%;
  cursor: pointer;
  outline: none;
  border-top: 2px solid #fff !important;
  border-right: 2px solid #fff !important;
  height: 25px;
  width: 25px;
}
.slick-prev::before,
.slick-next::before,
.slick-item-prev::before,
.slick-item-next::before {
  display: none;
}

.slick-prev,
.slick-item-prev {
  left: 25px !important;
  transform: rotate(-135deg) !important;
}

.slick-next,
.slick-item-next {
  right: 25px !important;
  transform: rotate(45deg) !important;
}

.notshop p:first-of-type {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  padding: 2.142em;
  margin: 2.857em;
  text-align: center;
}
.notshop p:first-of-type::before {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 5%;
  content: "";
  background: var(--txt-clr);
}

.topics {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 2.857em 5% 0 5%;
}
.main_slider + .topics {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 5em;
}
.topics dt {
  font-size: 14px;
  font-size: 1.4rem;
  width: 100%;
  margin-bottom: 1.071em;
  opacity: 0.6;
}
.topics dd {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 2.142em;
}

@media only screen and (min-width: 768px) {
  .topics {
    font-size: 10px;
    font-size: 1rem;
    margin-top: 7em;
  }
}
@media only screen and (min-width: 1024px) {
  .topics {
    font-size: 10px;
    font-size: 1rem;
    margin: 10em 0 0 0;
  }
  .main_slider + .topics {
    font-size: 10px;
    font-size: 1rem;
    margin-top: 9.5em;
  }
  .topics dt {
    font-size: 14px;
    font-size: 1.4rem;
    float: left;
    width: 8.571em;
    margin: 0;
  }
  .topics dd {
    font-size: 14px;
    font-size: 1.4rem;
    margin: 0 0 2.142em 8.571em;
  }
}
.result_message {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 1.111em 1.666em 1.111em;
}

@media only screen and (min-width: 1024px) {
  .result_message {
    margin-left: 0;
  }
}
.new_item {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 8em;
}
.new_item:blank {
  margin-bottom: 0;
}

.new_item_wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.new_item_wrap .item {
  position: relative;
  width: calc(50% - 1px);
  flex-direction: column;
}
.new_item_wrap .item:not(:last-child) {
  margin-right: 1px;
}
.new_item_wrap .item .label_image {
  font-size: 10px;
  font-size: 1rem;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
  width: 6em;
  height: 6em;
}
.new_item_wrap .item .item_img {
  position: relative;
}
.new_item_wrap .item .item_img img {
  font-size: 10px;
  font-size: 1rem;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  vertical-align: bottom;
}

.img-pt-screen .item:not(#moreItems) .item_img {
  aspect-ratio: 1/1.33;
}

.img-sq .item:not(#moreItems) .item_img {
  aspect-ratio: 1/1;
}

.img-la-gold .item:not(#moreItems) .item_img {
  aspect-ratio: 1.618/1;
}

.img-la-screen .item:not(#moreItems) .item_img {
  aspect-ratio: 4/3;
}

.img-pt-gold .item:not(#moreItems) .item_img {
  aspect-ratio: 1/1.618;
}

.item a {
  text-decoration: none;
  color: var(--txt-clr);
}

@media only screen and (min-width: 768px) {
  .new_item_wrap .item {
    width: calc(25% - 1px);
    overflow: hidden;
  }
  .new_item_wrap .item_img {
    width: 100%;
    height: auto;
    overflow: hidden;
  }
  .new_item_wrap .item_img img {
    height: auto;
    transition: all 0.25s;
  }
}
@media only screen and (min-width: 1024px) {
  .new_item_wrap .item {
    width: calc(20% - 1px);
  }
  .new_item_wrap .item:hover .item_img img {
    transition: all 1s;
    filter: brightness(1.25);
    transform: scale(1.1);
  }
  .new_item_wrap .item .item_data {
    font-size: 10px;
    font-size: 1rem;
    padding: 2em 2em 4em 0;
  }
}
.item_data {
  font-size: 10px;
  font-size: 1rem;
  padding: 2em 5% 3em 5%;
}
.item_data .itemPrice,
.item_data .discountPrice__calcPrice {
  font-size: 14px;
  font-size: 1.4rem;
  color: var(--txt-clr);
}
.item_data .discountPrice__calcPrice {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 1.071em;
}
.item_data .discountPrice__calcPrice > span {
  display: inline-block;
  margin-right: 1em;
}
.item_data .discountPrice__default {
  color: var(--txt-clr);
  text-decoration: line-through;
  margin-right: 0.5em;
}
.item_data .discountPrice__calcPrice {
  color: var(--clr-red);
}
.item_data .item_name,
.item_data .item_price {
  font-size: 14px;
  font-size: 1.4rem;
}
.item_data .item_price,
.item_data .discount {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 1.071em;
}
.item_data .item_price {
  opacity: 0.6;
}
.item_data .discountPrice {
  color: var(--clr-red);
}

.status {
  position: absolute;
  bottom: 0;
  left: 0;
  font-size: 0;
  width: 100%;
  overflow: hidden;
}
.status > div {
  display: inline-block;
}

p.soldout_cover, p.coming_soon, p.preOrder, p.community, p.takeout, p.discountPrice, p.lottery {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  text-align: center;
  padding: 0 0.833em;
  min-width: calc(33.3333333333% - 0.5em);
  height: 1.666em;
  line-height: 1.666em;
  color: #fff;
}
p.soldout_cover {
  background: #808080;
}
p.coming_soon, p.preOrder {
  background: #a2b937;
}
p.takeout, p.lottery {
  background: #5aa9c8;
}
p.community {
  background: #ffaa00;
}
p.discountPrice {
  background: #c1272d;
}

.item {
  position: relative;
}
.item .loader {
  position: absolute;
  top: -50%;
  left: 48%;
}

@media only screen and (min-width: 768px) {
  .item .loader {
    top: -30%;
    margin: 0;
  }
}
@media only screen and (min-width: 1024px) {
  .item {
    position: relative;
  }
  .item .loader {
    position: absolute;
    top: 0;
    left: 50%;
    transform: translate(-50%, 0);
    margin: 50% 0 0 0;
  }
}
#moreItems {
  font-size: 12px;
  font-size: 1.2rem;
  width: 100%;
  margin: 3.333em 1.666em 0 1.666em;
}
#moreItems .item_img {
  font-size: 12px;
  font-size: 1.2rem;
  display: block !important;
  margin: 0 1.666em;
  height: 2.5em;
  text-align: center;
  line-height: 2.5em;
  background: var(--txt-clr);
  border-radius: 3px;
}
#moreItems .item_img a {
  display: block;
  width: 100%;
  height: 100%;
  color: var(--bg-clr);
}

.more_no {
  display: none;
}

@media only screen and (min-width: 768px) {
  #moreItems {
    width: 25%;
    margin: 0 auto;
  }
  #moreItems .item_img {
    font-size: 14px;
    font-size: 1.4rem;
    margin: 0 auto;
    height: 2.857em;
    line-height: 2.857em;
  }
}
@media only screen and (min-width: 1024px) {
  #moreItems {
    position: relative;
    width: calc(20% - 1px);
  }
  #moreItems .item_img {
    background: var(--txt-clr);
    display: block;
    width: 100%;
    height: auto;
    margin: 0;
    aspect-ratio: 1/1.33;
    border-radius: 0;
  }
  #moreItems .item_img a {
    text-align: center;
    color: var(--bg-clr);
  }
  #moreItems .item_img a span {
    display: block;
    position: absolute;
    top: 50%;
    left: 50%;
    white-space: nowrap;
    transform: translate(-50%, -50%);
  }
  #moreItems .item_img a span::after {
    position: absolute;
    bottom: 0.5em;
    left: -1em;
    width: calc(100% + 1em);
    height: 1px;
    background: var(--bg-clr);
    transition: all 1s;
    content: "";
  }
  #moreItems .item_img a:hover span::after {
    width: 100%;
    left: 0;
  }
  .img-pt-screen #moreItems .item_img {
    aspect-ratio: 1/1.33;
  }
  .img-sq #moreItems .item_img {
    aspect-ratio: 1/1;
  }
  .img-la-gold #moreItems .item_img {
    aspect-ratio: 1.618/1;
  }
  .img-la-screen #moreItems .item_img {
    aspect-ratio: 4/3;
  }
  .img-pt-gold #moreItems .item_img {
    aspect-ratio: 1/1.618;
  }
  .more_no {
    display: block;
  }
  .more_no .item_img {
    position: relative;
    background: var(--txt-clr);
    color: var(--bg-clr);
    display: block;
    width: 100%;
    height: auto;
    aspect-ratio: 1/1.33;
  }
  .more_no .item_img span {
    display: block;
    position: absolute;
    top: 50%;
    width: 100%;
    text-align: center;
    color: var(--bg-clr) !important;
    transform: translateY(-50%);
  }
  .more_no .message .logoText {
    font-size: 14px;
    font-size: 1.4rem;
  }
  .more_no .message span + span {
    font-size: 18px;
    font-size: 1.8rem;
  }
  .more_no .message .logoImage,
.more_no .message .logoText + span {
    display: none;
  }
}
.loader,
.loader:before,
.loader::after {
  border-radius: 50%;
  width: 1em;
  height: 1em;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation: load7 1.8s infinite ease-in-out;
  animation: load7 1.8s infinite ease-in-out;
  content: "";
  position: absolute;
  top: 0;
}

.loader {
  color: var(--bg-clr);
  font-size: 10px;
  position: relative;
  text-indent: -9999em;
  transform: translateZ(0);
  -webkit-animation-delay: -0.16s;
  animation-delay: -0.16s;
}
.loader::before {
  left: -2.5em;
  -webkit-animation-delay: -0.32s;
  animation-delay: -0.32s;
}
.loader::after {
  left: 2.5em;
}

@media only screen and (min-width: 768px) {
  .loader,
.loader:before,
.loader::after {
    border-radius: 50%;
    width: 1.5em;
    height: 1.5em;
  }
}
@media only screen and (min-width: 1024px) {
  .loader,
.loader:before,
.loader::after {
    border-radius: 50%;
    width: 2.5em;
    height: 2.5em;
  }
  .loader {
    font-size: 10px;
  }
  .loader::before {
    left: -3.5em;
    -webkit-animation-delay: -0.32s;
    animation-delay: -0.32s;
  }
  .loader::after {
    left: 3.5em;
  }
}
@-webkit-keyframes load7 {
  0%, 80%, 100% {
    box-shadow: 0 2.5em 0 -1.3em;
  }
  40% {
    box-shadow: 0 2.5em 0 0;
  }
}
@keyframes load7 {
  0%, 80%, 100% {
    box-shadow: 0 2.5em 0 -1.3em;
  }
  40% {
    box-shadow: 0 2.5em 0 0;
  }
}
section.blog {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 7.142em;
  overflow: hidden;
}

.entry a {
  text-decoration: none;
  color: var(--txt-clr);
}
.entry .entry_detail {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 1.428em 5%;
}
.entry .entry_date {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 1.071em;
  opacity: 0.6;
}

.entry_img img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

@media only screen and (min-width: 768px) {
  #entry-wrap {
    display: flex;
  }
  #entry-wrap .entry {
    width: calc(25% - 1px);
    margin-right: 1px;
    overflow: hidden;
  }
  #entry-wrap .entry .entry_detail {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 1.428em 5% 0 5%;
  }
  #entry-wrap .entry:hover .entry_img img {
    transition: all 1s;
    filter: brightness(1.25);
    transform: scale(1.1);
  }
  #entry-wrap .entry .entry_img {
    width: 100%;
    aspect-ratio: 1/0.75;
    overflow: hidden;
  }
  #entry-wrap .entry .entry_img img {
    transition: all 0.25s;
    aspect-ratio: 1/0.75;
    -o-object-fit: cover;
       object-fit: cover;
  }
  #entry-wrap .entry .entry_detail {
    margin: 0;
  }
}
.blog_all {
  font-size: 10px;
  font-size: 1rem;
  display: block;
  margin: 4em 2em 0 2em;
  height: 3em;
  text-align: center;
  line-height: 3em;
  border-radius: 3px;
  background: var(--txt-clr);
}
.blog_all a, .blog_all a:link, .blog_all a:hover, .blog_all a:active {
  font-size: 12px;
  font-size: 1.2rem;
  width: 100%;
  height: 100%;
  display: block;
  color: var(--bg-clr);
  text-decoration: none;
}

@media only screen and (min-width: 768px) {
  .blog_all {
    font-size: 10px;
    font-size: 1rem;
    width: 25%;
    margin: 4em auto 0 auto;
    height: 4em;
    line-height: 4em;
  }
  .blog_all a, .blog_all a:link, .blog_all a:hover, .blog_all a:active {
    font-size: 14px;
    font-size: 1.4rem;
  }
}
@media only screen and (min-width: 1024px) {
  .blog_all,
.blog_all a {
    display: none;
  }
}
@media only screen and (min-width: 1024px) {
  #entry-wrap {
    float: left;
    width: 80%;
    overflow: hidden;
  }
  #entry-wrap .entry {
    float: left;
    width: 25%;
  }
  #entry-wrap .entry .entry_detail {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 1.428em 5% 0 0;
  }
  .blog_all {
    position: relative;
    float: left;
    width: 20%;
    height: auto;
    margin: 0;
    aspect-ratio: 1/0.75;
    background: var(--txt-clr);
    border-radius: 0;
    text-align: center;
  }
  .blog_all a {
    display: block;
    top: 50%;
    width: 100%;
    height: 100%;
    color: var(--bg-clr);
    text-decoration: none;
    transform: translateY(50%);
  }
  .blog_all span {
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    line-height: initial;
    color: var(--bg-clr);
    transform: translate(-50%, -50%);
  }
  .blog_all span::after {
    position: absolute;
    bottom: -0.25em;
    left: -1em;
    width: calc(100% + 1em);
    height: 1px;
    background: var(--bg-clr);
    transition: all 1s;
    content: "";
  }
  .blog_all:hover span::after {
    width: 100%;
    left: 0;
  }
}
.insta {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 6.428em;
  overflow: hidden;
}

.categoryTitle01 {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 2.222em 0 1.666em 0;
  text-align: center;
}

.childCategoryList01 {
  font-size: 1px;
  font-size: 0.1rem;
  margin-bottom: 30em;
  padding: 0 20em;
}
.childCategoryList01 li.childCategoryList01_child {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  margin: 0 0.333em 0.833em 0;
  color: var(--bg-clr);
  background: var(--txt-clr);
}
.childCategoryList01 li.childCategoryList01_child a {
  font-size: 12px;
  font-size: 1.2rem;
  width: 100%;
  height: 1.666em;
  padding: 0 0.833em;
  line-height: 1.666em;
  color: var(--bg-clr);
  text-decoration: none;
}

@media only screen and (min-width: 1024px) {
  .categoryTitle01 {
    text-align: left;
  }
  .childCategoryList01 {
    padding: 0;
  }
  #itempage .wrap,
#indexcategory .wrap,
#indexsearch .wrap {
    font-size: 12px;
    font-size: 1.2rem;
    margin-top: 2.5em;
  }
  #itempage .wrap .category_list,
#indexcategory .wrap .category_list,
#indexsearch .wrap .category_list {
    margin-top: 1.5em;
  }
}
#indexcategory .top_page,
#indexsearch .top_page {
  display: none;
}

@media only screen and (min-width: 768px) {
  .item_wrapper {
    padding: 0 6.25%;
    overflow: hidden;
  }
  .item_wrapper .item_img_wrap {
    width: 50%;
    margin: 0;
    float: left;
  }
  .item_wrapper .item_detail {
    width: 50%;
    padding: 0 0 0 6.25%;
    margin: 0;
    float: left;
  }
  .item_wrapper .sns_wrap {
    margin: 0;
    width: 50%;
    float: right;
    padding: 0 0 0 6.25%;
  }
  .item_wrapper .sns_wrap .shareButtons {
    padding: 0;
  }
  .item_wrapper .sns_wrap .sns_widget_wrap {
    padding: 0;
  }
}
@media only screen and (min-width: 1024px) {
  .item_wrapper {
    padding: 0;
  }
  .item_wrapper .item_img_wrap {
    width: 40%;
  }
  .item_wrapper .item_detail {
    width: 40%;
    padding: 0 0 0 2.7777777778%;
  }
  .item_wrapper .sns_wrap {
    width: 20%;
    padding: 0 3.3333333333%;
  }
}
.item_img_wrap {
  position: relative;
}
.item_img_wrap .slideImg {
  width: 100%;
}
.item_img_wrap .slideImg img:not(.label_image) {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}
.item_img_wrap .label_image {
  font-size: 10px;
  font-size: 1rem;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
  width: 6em;
  height: 6em;
}

.mCSB_container,
#slideImgPager,
.item_thumb {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 1.428em 0 0 1.428em;
  display: flex;
  top: 0 !important;
}
.mCSB_container li,
#slideImgPager li,
.item_thumb li {
  width: 16.6666666667% !important;
  min-width: 16.6666666667% !important;
  height: auto;
  margin: 0 1px 1px 0;
  background: rgba(0, 0, 0, 0.005);
}
.mCSB_container li img,
#slideImgPager li img,
.item_thumb li img {
  width: 100%;
  aspect-ratio: 1/1;
  -o-object-fit: cover;
     object-fit: cover;
}

.slider-thumbnail,
.item_thumb {
  overflow-x: scroll;
  -webkit-overflow-scrolling: touch;
}
.slider-thumbnail::-webkit-scrollbar,
.item_thumb::-webkit-scrollbar {
  display: none;
}

.swiper-pointer-events {
  width: 100%;
  height: 100%;
  touch-action: pan-x !important;
}

@media only screen and (min-width: 768px) {
  .mCSB_container,
#slideImgPager,
.item_thumb {
    margin-left: 0;
    overflow-x: initial;
    flex-wrap: wrap;
  }
  .mCSB_container li,
#slideImgPager li,
.item_thumb li {
    min-width: auto;
    width: calc(10% - 1px) !important;
    min-width: auto !important;
  }
}
.item_detail {
  margin: 0 2em;
}

.itemDescription {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 3.571em;
}

.hidden {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  overflow: hidden;
  cursor: pointer;
}

.custom_morebtn {
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
  position: relative;
  margin: 2.857em auto;
  width: 10em;
  height: 2.142em;
  line-height: 2.142em;
  padding: 0 0 0 1.071em;
  border-radius: 10em;
  border: 1px solid var(--txt-clr);
}
.custom_morebtn::after {
  font-size: 25px;
  font-size: 2.5rem;
  position: absolute;
  font-family: "Material Symbols Outlined";
  right: 0.2em;
  top: 0.04em;
  color: var(--txt-clr);
  content: "\e5cf";
}

.purchaseButton {
  font-size: 14px;
  font-size: 1.4rem;
}
.purchaseButton button,
.purchaseButton .purchaseButton__btn {
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
  width: 100%;
  height: 4.285em;
  text-align: center;
  line-height: 4.285em;
  color: var(--cart-btn-clr);
  margin: 2.142em 0;
  background: var(--cart-btn-bg);
  border: none;
  border-radius: 0.25em;
}
.purchaseButton button.purchaseButton__btn--notApplying, .purchaseButton button.purchaseButton__btn--soldOut, .purchaseButton button.purchaseButton__btn--endOfSale,
.purchaseButton .purchaseButton__btn.purchaseButton__btn--notApplying,
.purchaseButton .purchaseButton__btn.purchaseButton__btn--soldOut,
.purchaseButton .purchaseButton__btn.purchaseButton__btn--endOfSale {
  background: #808080;
  cursor: initial !important;
}

#item_page {
  overflow: inherit;
}
#item_page .itemTitle {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 2.222em 0 1.666em 0;
  font-weight: bold;
}
#item_page .itemTitle .filename {
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
  font-weight: normal;
  margin-top: 1.428em;
  opacity: 0.6;
}
#item_page .itemPrice {
  font-size: 24px;
  font-size: 2.4rem;
  line-height: 1;
  margin-bottom: 1.25em;
}
#item_page .itemPrice.itemPrice_soldout {
  font-size: 12px;
  font-size: 1.2rem;
  background: #808080;
  display: inline-block;
  text-align: center;
  padding: 0 0.5em;
  height: 1.666em;
  line-height: 1.666em;
  color: #fff;
}

@media only screen and (min-width: 768px) {
  #item_page .itemTitle {
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 0 1.666em 0;
  }
  #item_page .itemPrice {
    font-size: 24px;
    font-size: 2.4rem;
    line-height: 1;
    margin-bottom: 1.666em;
  }
}
.regular-delivery > p.initial,
.regular-delivery > p.repeat {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 0 0 1.071em 0;
}
.regular-delivery .item_discountPrice {
  display: flex;
  font-size: 12px;
  font-size: 1.2rem;
  margin-bottom: 0.833em;
}
.regular-delivery .item_discountPrice p.initial,
.regular-delivery .item_discountPrice p.repeat {
  align-items: center;
  display: flex;
}
.regular-delivery .item_discountPrice p.initial > span:first-of-type,
.regular-delivery .item_discountPrice p.repeat > span:first-of-type {
  font-size: 14px;
  font-size: 1.4rem;
  color: #c1272d;
  margin-right: 0.714em;
}

.easyOverseasSales {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 2.5em 0;
  row-gap: 0 !important;
  padding: 0 !important;
  align-items: flex-start !important;
}
.easyOverseasSales .easyOverseasSales__label {
  color: inherit !important;
}

div#itemSelect > div {
  margin-bottom: 1em;
}

.purchaseElement label,
.itemOptionElement label {
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
  margin-bottom: 0.357em;
}
.purchaseElement select,
.itemOptionElement select {
  font-size: 16px;
  font-size: 1.6rem;
  min-width: calc(8.75em - 1em);
  height: 1.875em;
  padding: 0.5em;
  border-radius: 2px;
  background: #fff;
}
.purchaseElement input[type=text],
.itemOptionElement input[type=text] {
  font-size: 16px;
  font-size: 1.6rem;
  width: 100%;
  height: 1.875em;
  border-radius: 2px;
  background: #fff;
}

.itemOption__caption {
  font-size: 14px;
  font-size: 1.4rem;
  display: block;
  margin-top: 1em;
  margin-bottom: 0.357em;
  vertical-align: top;
}

#itemSelect select,
#itemSelect input[type=text],
#itemSelect textarea {
  border: solid 1px #CCC;
  border-radius: 3px;
}

#itemAttention {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
  margin: 0 0 3.571em 0;
}

.shareButtons {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0 1.428em;
}
.shareButtons .share_wrap {
  display: flex;
  justify-content: space-between;
}
.shareButtons .twitter,
.shareButtons .facebook {
  font-size: 14px;
  font-size: 1.4rem;
  border-radius: 3px;
  height: 2.142em;
  line-height: 2.142em;
  color: #fff;
  width: 49.5%;
}
.shareButtons .twitter a,
.shareButtons .facebook a {
  display: block;
  width: 100%;
  height: 100%;
  color: #fff;
  text-align: center;
}
.shareButtons .twitter {
  font-size: 14px;
  font-size: 1.4rem;
  background: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22UTF-8%22%3F%3E%3Csvg%20id%3D%22_%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%20242.54%20248%22%3E%3Cdefs%3E%3Cstyle%3E.cls-1%7Bfill%3A%23fff%3Bstroke-width%3A0px%3B%7D%3C%2Fstyle%3E%3C%2Fdefs%3E%3Cpath%20class%3D%22cls-1%22%20d%3D%22m143.23%2C110.49L219.51%2C21.82h-18.08l-66.23%2C76.99L82.3%2C21.82H21.29l80%2C116.42L21.29%2C231.23h18.08l69.94-81.3%2C55.87%2C81.3h61.01l-82.96-120.74h0Zm-24.76%2C28.78l-8.11-11.59L45.88%2C35.43h27.77l52.05%2C74.45%2C8.11%2C11.59%2C67.65%2C96.77h-27.77l-55.21-78.96h0Z%22%2F%3E%3C%2Fsvg%3E") no-repeat #000;
  background-size: 1.2em;
  background-position: 10% 50%;
}
.shareButtons .facebook {
  font-size: 14px;
  font-size: 1.4rem;
  background: url("data:image/svg+xml;charset=utf8,%3C%3Fxml%20version%3D%221.0%22%20encoding%3D%22utf-8%22%3F%3E%3Csvg%20version%3D%221.1%22%20id%3D%22%E3%83%AC%E3%82%A4%E3%83%A4%E3%83%BC_1%22%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20x%3D%220px%22%20y%3D%220px%22%20viewBox%3D%220%200%20100%20100%22%20style%3D%22enable-background%3Anew%200%200%20100%20100%3B%22%20xml%3Aspace%3D%22preserve%22%3E%3Cstyle%20type%3D%22text%2Fcss%22%3E%20.st0%7Bfill%3A%23FFFFFF%3B%7D%3C%2Fstyle%3E%3Cpath%20class%3D%22st0%22%20d%3D%22M50%2C6C25.7%2C6%2C6%2C25.7%2C6%2C50c0%2C22.1%2C16.2%2C40.3%2C37.4%2C43.5V61.7H32.5V50.1h10.9v-7.7c0-12.7%2C6.2-18.3%2C16.8-18.3%20c5.1%2C0%2C7.8%2C0.4%2C9%2C0.5v10.1H62c-4.5%2C0-6.1%2C4.3-6.1%2C9.1v6.3h13.2l-1.8%2C11.6H56v31.9C77.4%2C90.6%2C94%2C72.3%2C94%2C50C94%2C25.7%2C74.3%2C6%2C50%2C6z%22%2F%3E%3C%2Fsvg%3E") no-repeat #476cf0;
  background-size: 1.3em;
  background-position: 9.5% 50%;
}

.sns_widget_wrap {
  font-size: 14px;
  font-size: 1.4rem;
  overflow: hidden;
  margin-top: 1.428em;
  padding: 0 1.428em;
  overflow: hidden;
}
.sns_widget_wrap #reportBtn,
.sns_widget_wrap .pinterest {
  float: left;
  margin-right: 1em;
}
.sns_widget_wrap #openIllegalReport {
  font-size: 14px;
  font-size: 1.4rem;
  text-decoration: underline;
}
.sns_widget_wrap #openIllegalReport:hover {
  text-decoration: none;
}

.bottom {
  font-size: 14px;
  font-size: 1.4rem;
  clear: both;
  padding-top: 4.285em;
}

.review01__title {
  padding-top: 0 !important;
}

.review01 {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 0 1.428em 5em 1.428em !important;
}

.review01__tab > li:first-of-type label {
  line-height: 1.6;
  display: inline;
}

@media only screen and (max-width: 828px) {
  .review01__tabWrap {
    padding: 0 30px 0 0 !important;
  }
}
@media only screen and (min-width: 1024px) {
  button.purchaseButton__btn:hover {
    cursor: pointer;
  }
  .shareButtons {
    padding: 0;
  }
  .shareButtons .share_wrap {
    display: block;
  }
  .shareButtons .share_wrap .twitter,
.shareButtons .share_wrap .facebook {
    font-size: 14px;
    font-size: 1.4rem;
    width: 100%;
    margin-bottom: 1.071em;
  }
  .sns_widget_wrap {
    padding: 0;
  }
  .bottom {
    font-size: 14px;
    font-size: 1.4rem;
    padding-top: 2.142em;
  }
}
.related_wrap {
  font-size: 14px;
  font-size: 1.4rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin-bottom: 2.142em;
}
.related_wrap .item {
  width: calc(50% - 0.5px);
  flex-direction: column;
}
.related_wrap .item:nth-of-type(odd) {
  margin-right: 1px;
}
.related_wrap .item .item_img {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
  aspect-ratio: 1/1.33;
}
.related_wrap .item .item_img img {
  width: 100%;
  height: auto;
  aspect-ratio: 1/1.33;
  -o-object-fit: cover;
     object-fit: cover;
}
.related_wrap.img-pt-screen .item_img {
  aspect-ratio: 1/1.33;
}
.related_wrap.img-sq .item_img {
  aspect-ratio: 1/1;
}
.related_wrap.img-la-gold .item_img {
  aspect-ratio: 1.618/1;
}
.related_wrap.img-la-screen .item_img {
  aspect-ratio: 4/3;
}
.related_wrap.img-pt-gold .item_img {
  aspect-ratio: 1/1.618;
}

@media only screen and (min-width: 768px) {
  .bottom .title {
    font-size: 36px;
    font-size: 3.6rem;
    margin-top: 0.833em;
  }
  .review01 {
    font-size: 14px;
    font-size: 1.4rem;
    width: 100%;
    margin-bottom: 7.142em !important;
    margin-left: 0 !important;
  }
  .related_wrap {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 4.285em;
  }
  .related_wrap .item,
.related_wrap .item:nth-of-type(odd) {
    font-size: 14px;
    font-size: 1.4rem;
    width: calc(25% - 1px);
    margin-right: 1px;
  }
}
@media only screen and (min-width: 1024px) {
  .bottom .title {
    font-size: 36px;
    font-size: 3.6rem;
  }
  .review01 {
    width: 80%;
  }
  .related_wrap {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 5.714em;
  }
  .related_wrap .item,
.related_wrap .item:nth-of-type(odd) {
    font-size: 14px;
    font-size: 1.4rem;
    width: calc(20% - 1px);
  }
  .related_wrap .item .item_img img,
.related_wrap .item:nth-of-type(odd) .item_img img {
    transition: all 0.25s;
  }
  .related_wrap .item .item_img img:hover,
.related_wrap .item:nth-of-type(odd) .item_img img:hover {
    transition: all 1s;
    filter: brightness(1.25);
    transform: scale(1.1);
  }
  .related_wrap .item .item_data,
.related_wrap .item:nth-of-type(odd) .item_data {
    font-size: 10px;
    font-size: 1rem;
    padding: 2em 2em 4em 0;
  }
}
.item_detail .item_discountPrice {
  font-size: 12px;
  font-size: 1.2rem;
  margin: 0 0 1.25em 0;
}
.item_detail .discountPrice__ratio {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  background: #c1272d;
  padding: 0 0.5em;
  height: 1.666em;
  line-height: 1.666em;
  margin: 0 0.416em 0 0;
  color: #fff;
}
.item_detail #text {
  opacity: 0.7;
}
.item_detail .discountPrice__default {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  opacity: 0.6;
}
.item_detail .discountPrice__default span {
  text-decoration: line-through;
}
.item_detail .discountPrice__calcPrice {
  font-size: 24px;
  font-size: 2.4rem;
  color: #c1272d;
  margin-bottom: 1.25em;
}
.item_detail .comingSoon {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  padding: 0 0.833em;
  background: #a2b937;
  color: #fff;
  height: 1.666em;
  line-height: 1.666em;
}
.item_detail #itemAttention {
  font-size: 10px;
  font-size: 1rem;
}
.item_detail #itemAttention .preOrder {
  font-size: 12px;
  font-size: 1.2rem;
  margin: 1.666em 0;
}
.item_detail #itemAttention .preOrder .preOrder__data {
  font-size: 14px;
  font-size: 1.4rem;
}
.item_detail #itemAttention .preOrder__label {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  padding: 0 0.75em;
  background: #a2b937;
  color: #fff;
  height: 1.666em;
  line-height: 1.666em;
}
.item_detail #itemAttention .attention {
  font-size: 12px;
  font-size: 1.2rem;
}
.item_detail #itemAttention .attention.salesPeriod--term {
  font-size: 14px;
  font-size: 1.4rem;
}
.item_detail #itemAttention .attention.salesPeriod--text {
  font-size: 12px;
  font-size: 1.2rem;
  margin-bottom: 1.666em;
}
.item_detail #itemAttention .lottery .lottery__data {
  color: var(--clr-red);
  font-size: 14px;
  font-size: 1.4rem;
}
.item_detail #itemAttention .lottery .lottery__label {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  padding: 0 0.75em;
  background: var(--clr-red);
  color: #fff;
  height: 1.666em;
  line-height: 1.666em;
  margin-top: 1.666em;
}
.item_detail #itemAttention .communityLabel {
  font-size: 12px;
  font-size: 1.2rem;
  background: transparent;
  padding: 0;
  margin: 1.666em 0;
  font-weight: normal;
}
.item_detail #itemAttention .communityLabel .communityLabel__title {
  font-size: 12px !important;
  font-size: 1.2rem !important;
  display: inline-block;
  padding: 0 0.75em;
  background: #ffaa00;
  color: #fff;
  font-weight: normal;
  height: 1.666em;
  line-height: 1.666em;
  margin: 0;
  opacity: 1;
}
.item_detail #itemAttention .communityLabel .communityLabel__note {
  color: var(--txt-clr);
  opacity: 1;
}
.item_detail #itemAttention .takeout__label {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  padding: 0 0.75em;
  background: #5ba9c9;
  color: #fff;
  height: 1.666em;
  line-height: 1.666em;
  margin-top: 1.666em;
}
.item_detail #itemAttention .takeout__data {
  font-size: 14px;
  font-size: 1.4rem;
}

.irContainer {
  top: 0 !important;
}

.item .swiper-button-next, .item .swiper-button-prev {
  top: 50% !important;
}

.takeout__text {
  font-weight: bold;
  text-decoration: underline !important;
}

.itemOption__caption--error {
  background: #c1272d;
  color: #fff;
  padding: 0 2px;
  line-height: 2;
  border-radius: 2px;
}

.communityBox,
.purchaseButtonModal__inputArea,
.communityTerms a,
.communityLinkMore a,
.communityModal .communityModalTextNotice,
.communityModalTable,
.purchaseButtonModal__error,
.purchaseButtonModal__ageVerificationWarningText,
.si-information:before {
  color: #3d3d3d !important;
}

.centeringFixForPostageInfo {
  position: fixed !important;
  top: 0% !important;
  left: 50% !important;
  right: auto;
  bottom: auto;
  transform: translate(-50%, 0%);
  margin-top: auto !important;
  margin-left: auto !important;
}

@media only screen and (min-width: 768px) {
  .centeringFixForPostageInfo {
    top: 50% !important;
    transform: translate(-50%, -50%);
  }
}
.communityModal {
  width: initial;
  max-height: 90%;
  overflow: auto;
}

.communityOverview {
  overflow: auto;
}

#communityPurchase .communitySignin {
  border-color: var(--txt-clr);
  color: var(--txt-clr);
}
#communityPurchase .communitySignin p {
  font-size: 12px;
  font-size: 1.2rem;
  margin-bottom: 1em !important;
}

.membershipPoint__attentionLink {
  text-decoration: underline !important;
}

#postageOpen {
  font-size: 12px;
  font-size: 1.2rem;
  display: inline-block;
  margin: 0.416em 0.833em;
  max-width: -webkit-fit-content;
  max-width: -moz-fit-content;
  max-width: fit-content;
  text-decoration: underline;
  color: var(--cart-btn-bg);
}
#postageOpen svg {
  font-size: 12px;
  font-size: 1.2rem;
  fill: var(--cart-btn-bg);
  width: 1.5em;
  margin: -0.167em 0.666em 0 0;
}

.wide_wrap .about {
  font-size: 10px;
  font-size: 1rem;
  padding: 0 2em 4em 2em;
}
.wide_wrap .sub_img {
  text-align: center;
}
.wide_wrap .sub_img img {
  max-width: 100%;
  height: auto;
}
.wide_wrap .concept,
.wide_wrap .information,
.wide_wrap .faq {
  font-size: 10px;
  font-size: 1rem;
  position: relative;
  padding: 2em;
}
.wide_wrap .concept::before,
.wide_wrap .information::before,
.wide_wrap .faq::before {
  font-size: 10px;
  font-size: 1rem;
  position: absolute;
  display: block;
  top: -2em;
  left: 50%;
  height: 1px;
  width: 2em;
  background: rgba(0, 0, 0, 0.3);
  transform: translateX(-50%);
  content: "";
}

@media only screen and (min-width: 768px) {
  .wide_wrap .about,
.wide_wrap .concept,
.wide_wrap .information,
.wide_wrap .faq {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 6.071em;
    padding: 0;
  }
  .wide_wrap .about::before,
.wide_wrap .concept::before,
.wide_wrap .information::before,
.wide_wrap .faq::before {
    display: none;
  }
}
.concept_box {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 3em;
  overflow: hidden;
}
.concept_box p:not(.img) {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
}
.concept_box .img {
  font-size: 10px;
  font-size: 1rem;
  width: 100%;
  margin-bottom: 3em;
}
.concept_box .img img {
  width: 100%;
  height: auto;
}
.concept_box .s_title {
  font-size: 18px;
  font-size: 1.8rem;
}

@media only screen and (min-width: 768px) {
  .concept_box {
    display: block;
  }
  .concept_box .img {
    width: 44.4444444444%;
    height: auto;
  }
  .concept_box:nth-child(odd) .img {
    float: left;
    margin-right: 5.5555555556%;
  }
  .concept_box:nth-child(even) .img {
    float: right;
    margin-left: 5.5555555556%;
  }
  .concept_box .txt {
    display: block;
  }
}
.sub_img {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 4em;
  width: 100%;
}
.sub_img img {
  width: 100%;
  height: auto;
}

.shop_data {
  font-size: 10px;
  font-size: 1rem;
  margin: 2em 0 4em 0;
}
.shop_data dt {
  font-size: 14px;
  font-size: 1.4rem;
  float: left;
  width: 5.714em;
  margin-bottom: 1.428em;
  color: var(--txt-clr);
  opacity: 0.5;
}
.shop_data dd {
  font-size: 14px;
  font-size: 1.4rem;
  padding-left: 6.428em;
  margin-bottom: 1.428em;
}

.shop_name {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
  overflow: hidden;
}

@media only screen and (min-width: 1024px) {
  .sub_img {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 7.142em;
  }
  .wide_wrap .about,
.wide_wrap .concept,
.wide_wrap .information,
.wide_wrap .faq {
    font-size: 14px;
    font-size: 1.4rem;
    margin-bottom: 6.071em;
  }
  .shop_data {
    font-size: 14px;
    font-size: 1.4rem;
    margin: 2.142em 0 0 0;
  }
  .shop_wrap {
    overflow: hidden;
  }
  .shop_list {
    float: left;
    width: 47.2222222222%;
  }
  .shop_list:first-child {
    margin-right: 5.5555555556%;
  }
}
.faq_data {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 4em;
}
.faq_data dt, .faq_data dd {
  position: relative;
}
.faq_data dt {
  font-size: 18px;
  font-size: 1.8rem;
  margin-bottom: 1.111em;
  padding-left: 2.222em;
  font-weight: bold;
  counter-increment: q_num;
}
.faq_data dd {
  font-size: 14px;
  font-size: 1.4rem;
  padding-left: 2.857em;
  padding-top: 0.142em;
  margin-bottom: 2.857em;
  counter-increment: a_num;
}
.faq_data dt::before,
.faq_data dd::before {
  position: absolute;
  top: 0;
  left: 0;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: bold;
  opacity: 0.5;
  color: var(--txt-clr);
}
.faq_data dt::before {
  font-size: 17px;
  font-size: 1.7rem;
  content: "Q" counter(q_num);
}
.faq_data dd::before {
  font-size: 17px;
  font-size: 1.7rem;
  content: "A" counter(a_num);
}

.sns-icon {
  filter: grayscale(100%);
}

.currency select, .currency option,
.lang select,
.lang option {
  border: none;
  background: #ccc;
}

.blog_body pre {
  background: transparent;
}

.wide_wrap > .blog_page {
  padding: 0;
}

.blog_title,
.blog_publish {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0 1.428em;
}

.blog_head_image {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 1.428em;
}

.blog_page .iframe {
  display: block;
  margin: 1.5em auto;
}

@media only screen and (min-width: 768px) {
  .blog_page {
    font-size: 14px;
    font-size: 1.4rem;
    margin-top: 4.285em;
  }
  .blog_page .blogListMain {
    display: flex;
    flex-wrap: wrap;
  }
  .blog_page .blogListMain .blog_inner {
    width: 50%;
    border-bottom: none;
  }
}
.blogListMain .blog_inner {
  display: flex;
  flex-direction: column;
}
.blogListMain .blog_inner .blog_title {
  order: 2;
}
.blogListMain .blog_inner .blog_publish {
  order: 3;
}
.blogListMain .blog_inner .blog_head_image {
  order: 1;
}
.blogListMain .blog_inner .blog_contents,
.blogListMain .blog_inner .read_more {
  display: none;
}

.blog_title h2 a {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 1.428em;
  text-decoration: none;
  color: var(--txt-clr);
  font-weight: normal;
}

@media only screen and (min-width: 768px) {
  .blog_title,
.blog_publish {
    padding: 0;
  }
}
.blog_head_image {
  font-size: 14px;
  font-size: 1.4rem;
  aspect-ratio: 1/0.75;
  overflow: hidden;
  height: 20.714em;
}
.blog_head_image img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

.main #about > .blog_inner {
  font-size: 14px;
  font-size: 1.4rem;
  border-bottom: none !important;
  padding: 0 0 4.285em 0 !important;
}
.main #about > .blog_inner .blog_publish {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 1.071em 0 0 0 !important;
}

.main #about.blogListMain .blog_publish .publish_date {
  font-size: 14px !important;
  font-size: 1.4rem !important;
}

.main #about.blogDetail .blog_title h2 a {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
}

.blog_body {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 0 1.428em;
}
.blog_body > * {
  color: var(--txt-clr) !important;
  background: transparent !important;
}
.blog_publish + .blog_body {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 2.142em;
}

@media only screen and (min-width: 768px) {
  .blog_title {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 0;
  }
  .blog_body {
    margin: 0;
  }
}
.text iframe.youtube,
div iframe.youtube {
  aspect-ratio: 16/9;
  width: 100%;
  height: auto;
  margin-bottom: 1em;
}

@media only screen and (min-width: 1024px) {
  .blog_head_image img {
    transition: all 0.25s;
  }
  .blog_head_image img:hover {
    transition: all 1s;
    filter: brightness(1.25);
    transform: scale(1.1);
  }
}
.paginate-wrp {
  width: 100%;
}
.paginate-wrp::before, .paginate-wrp::after {
  content: "";
  display: table;
  clear: both;
  overflow: hidden;
}

.paginate {
  padding: 0;
  display: block !important;
  text-align: center;
  font-size: 0;
  letter-spacing: -1em;
}
.paginate li {
  position: relative;
  margin: 0 0 0 1px !important;
  display: inline-block;
  font-size: 12px;
  font-size: 1.2rem;
  border: 0 !important;
  background: none !important;
  padding: 1px;
}
.paginate li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: var(--txt-clr);
  opacity: 0.2;
  z-index: -1;
  transition: 0.5s;
}
.paginate li:hover:before {
  opacity: 1;
  transition: 0.5s;
}
.paginate li.current::before {
  opacity: 1;
}
.paginate li.current a {
  background: none;
  background: var(--txt-clr);
  color: var(--bg-clr);
}
.paginate li a {
  display: block;
  line-height: 3.333em;
  line-height: 3.3333em !important;
  text-decoration: none;
  padding: 0 0.833em;
  padding: 0 0.71428em !important;
  min-width: 3.333em;
  font-size: 12px !important;
  font-size: 1.2rem !important;
  text-align: center;
}
.paginate li a:link, .paginate li a:visited {
  background: var(--bg-clr);
  color: var(--txt-clr);
  transition: 0.5s;
}
.paginate li a:hover {
  background: var(--txt-clr) !important;
  color: var(--bg-clr) !important;
  transition: 0.5s;
}
.paginate .prev a,
.paginate .next a {
  min-width: 5em;
}

.communityData .communityMain {
  font-size: 24px;
  font-size: 2.4rem;
  padding: 1.666em 0.833em;
  width: auto;
}
.communityData .communityMain .communityTitle {
  font-size: 24px;
  font-size: 2.4rem;
}
.communityData .communityMain .communityContent {
  border: none;
  padding: 0;
  flex-direction: column;
}
.communityData .communityMain .communityContent .communityOverview {
  width: auto;
  white-space: initial !important;
}
.communityData .communityMain .communityNav {
  width: auto;
  margin-left: 0;
}
.communityData .communityMain .communityPrice {
  font-size: 18px;
  font-size: 1.8rem;
  text-align: center;
  margin: 2.222em 0;
}
.communityData .communityMain .communityPrice p {
  margin: 0;
}
.communityData .communityMain .communityRegister {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 0.714em 0 2.142em 0;
}
.communityData .communityMain .communityRegister .communitySignin {
  position: relative;
  border: none;
}
.communityData .communityMain .communityRegister .communitySignin::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  border: 1px solid var(--txt-clr);
  height: 100%;
  z-index: -1;
  opacity: 0.3;
}
.communityData .communityMain .communityRegister .communityTerm {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 1.428em;
}
.communityData .communityMain .communityRegister .communityTerm a {
  color: var(--txt-clr);
}
.communityData .communityMain .communityRegister .communitySignin {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 2.142em 0;
}
.communityData .communityMain .communityRegister .communitySignin p {
  font-size: 14px;
  font-size: 1.4rem;
}
.communityData .communityMain #limitedItem {
  font-size: 14px;
  font-size: 1.4rem;
  margin-top: 4.285em;
  width: auto;
  margin: 0 -5%;
}
.communityData .communityMain .communityItemHeader {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 1.666em 1.111em;
}
.communityData .communityMain #limitedUrl {
  width: auto;
}
.communityData .communityMain #productsLimitedUrl .urlBox,
.communityData .communityMain #productsLimitedUrl .urlBox:nth-child(2n) {
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  width: 100%;
  background: transparent;
  border: none;
  margin-bottom: 1.428em;
  margin-left: 0;
}
.communityData .communityMain #productsLimitedUrl .urlBox::after,
.communityData .communityMain #productsLimitedUrl .urlBox:nth-child(2n)::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  background: var(--txt-clr);
  height: 100%;
  border-radius: 4px;
  z-index: -1;
  opacity: 5%;
}
.communityData .communityMain #productsLimitedUrl .urlBox .title,
.communityData .communityMain #productsLimitedUrl .urlBox:nth-child(2n) .title {
  text-align: left;
  margin: 0;
}

@media only screen and (min-width: 768px) {
  .communityData .communityMain {
    font-size: 10px;
    font-size: 1rem;
    padding: 0 0 12em 0;
  }
  .communityData .communityMain .communityTitle {
    font-size: 36px;
    font-size: 3.6rem;
    text-align: left;
    margin-bottom: 1.666em;
  }
  .communityData .communityMain .communityRegister .communityButton {
    font-size: 14px;
    font-size: 1.4rem;
    width: 66.6666666667%;
    margin-left: auto;
    margin-right: auto;
    text-decoration: none;
  }
  .communityData .communityMain .communityRegister .communityTerm,
.communityData .communityMain .communityRegister .communityTextNotice {
    width: 66.6666666667%;
    margin-right: auto;
    margin-left: auto;
  }
  .communityData .communityMain .communityRegister .communitySignin {
    font-size: 14px;
    font-size: 1.4rem;
    width: 66.6666666667%;
    padding: 1.428em 12.3%;
    margin: 2.142em auto 0 auto;
  }
  .communityData .communityMain .communityRegister .communitySignin > a {
    width: 100%;
  }
  .communityData .communityMain .openLeaveModal {
    color: var(--txt-clr) !important;
  }
  .communityData .communityMain #limitedItem {
    font-size: 10px;
    font-size: 1rem;
    margin: 8em 0 0 0;
  }
  .communityData .communityMain #limitedItem .communityItemHeader {
    font-size: 18px;
    font-size: 1.8rem;
    margin: 0 0 1.666em 0;
  }
  .communityData .communityMain .communityItems .communityItem {
    width: 33.3333333333%;
  }
  .communityData .communityMain #productsLimitedUrl {
    display: flex;
    justify-content: space-between;
  }
  .communityData .communityMain #productsLimitedUrl .urlBox,
.communityData .communityMain #productsLimitedUrl .urlBox:nth-child(2n) {
    font-size: 10px;
    font-size: 1rem;
    width: 47%;
    padding: 2em;
    margin-bottom: 2em;
  }
  .communityData .communityMain #limitedUrl {
    font-size: 10px;
    font-size: 1rem;
    margin-top: 6em;
  }
}
.communityMain .communityItems .communityItem {
  position: relative;
  width: 50%;
  flex-direction: column;
  margin: 0 !important;
}
.communityMain .communityItems .communityItem .communityLabelImage {
  top: 0 !important;
  left: 0 !important;
}
.communityMain .communityItems .communityItem .communityItemPrice.soldOut {
  text-decoration: none !important;
}
.communityMain .communityItems .communityItem .communityItemPrice.discount {
  opacity: 1;
}
.communityMain .communityItems .communityItem .communityImageContainer {
  position: relative;
  display: block;
  width: 100% !important;
  height: auto !important;
  overflow: hidden;
}
.communityMain .communityItems .communityItem .communityImageContainer .communityImageResize {
  max-width: initial !important;
  max-height: initial !important;
}
.communityMain .communityItems .communityItem .communityImageContainer img {
  font-size: 10px;
  font-size: 1rem;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  vertical-align: bottom;
}
.communityMain .communityItems .communityItem .communityItemMeta {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 1.428em 1.428em 0.214em 1.428em;
}
.communityMain .communityItems .communityItem .communityItemMetaSub {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0 1.428em 1.428em 1.428em;
  margin: 0 !important;
}
.communityMain .communityItems .communityItem .communityItemMetaSub > div,
.communityMain .communityItems .communityItem .communityItemLabel,
.communityMain .communityItems .communityItem .communityItemPrice > .discount {
  font-size: 12px;
  font-size: 1.2rem;
  border-radius: 0;
  display: inline-block;
  padding: 0 0.75em !important;
  height: 1.666em;
  line-height: 1.666em;
  margin-left: 0 !important;
  margin-right: 0.666em;
  margin-bottom: 0.416em;
  font-weight: normal !important;
  border: 0 !important;
  color: #fff !important;
}
.communityMain .communityItems .communityItem .soldOutText {
  background: #808080;
}
.communityMain .communityItems .communityItem .community {
  background: #ffaa00;
}
.communityMain .communityItems .communityItem .preOrder,
.communityMain .communityItems .communityItem .comingSoon {
  background: #a2b937;
}
.communityMain .communityItems .communityItem .communityItemPrice > .discount {
  background: #c1272d !important;
}
.communityMain .communityItems .communityItem .takeout,
.communityMain .communityItems .communityItem .lottery {
  background: #5aa9c8;
}
.communityMain .communityItems .communityItem .communityItemLabel {
  font-size: 12px;
  font-size: 1.2rem;
  margin-top: 0.416em;
}
.communityMain .communityItems .communityItem .communityItemTitle {
  width: auto !important;
  margin: 0 !important;
}
.communityMain .communityItems .communityItem .communityItemPrice {
  font-size: 14px;
  font-size: 1.4rem;
  opacity: 0.6;
  margin-top: 1.071em;
}

.img-pt-screen .communityImageContainer {
  aspect-ratio: 1/1.33;
}

.img-sq .communityImageContainer {
  aspect-ratio: 1/1;
}

.img-la-gold .communityImageContainer {
  aspect-ratio: 1.618/1;
}

.img-la-screen .communityImageContainer {
  aspect-ratio: 4/3;
}

.img-pt-gold .communityImageContainer {
  aspect-ratio: 1/1.618;
}

@media only screen and (min-width: 768px) {
  .communityMain .communityItems .communityItem .communityItemMeta {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 1.428em 2.142em 0 0;
  }
  .communityMain .communityItems .communityItem .communityItemMetaSub {
    font-size: 14px;
    font-size: 1.4rem;
    padding: 0 2.142em 0 0;
  }
}
@media only screen and (min-width: 1024px) {
  .communityImageContainer {
    overflow: hidden;
  }
  .communityImageResize {
    transition: all 0.25s;
  }
  .communityImageResize:hover {
    transition: all 1s;
    filter: brightness(1.25);
    transform: scale(1.1);
  }
}
.flashMessage {
  margin: 2em 0;
}

/*ユーザーカスタマイズで変わる要素*/
.inquirySection form::after {
  background: var(--txt-clr);
}
.inquirySection input[type=submit] {
  color: var(--bg-clr);
  border: solid 1px var(--bg-clr);
  background: var(--txt-clr);
}

#inquiryCompleteSection p::after {
  background: var(--txt-clr);
}
#inquiryCompleteSection p + a {
  background: var(--txt-clr);
  color: var(--bg-clr);
}

/*ユーザーカスタマイズで変わる要素・ここまで*/
.inquirySection textarea, .inquirySection input[type=text] {
  position: relative;
  width: 100%;
  padding: 0.437em 0.625em;
  font-size: 16px;
  font-size: 1.6rem;
  border: solid 1px #CCC;
  border-radius: 0.187em;
}

#inquiryCompleteSection p + a, .inquirySection input[type=submit] {
  display: block;
  width: 100%;
  padding: 0.5em 0.714em;
  margin-top: 0.714em;
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  border-radius: 0.214em;
}
#inquiryCompleteSection p + a:hover, .inquirySection input[type=submit]:hover {
  cursor: pointer;
}

.inquirySection {
  padding: 0 2em 4em 2em;
}
.inquirySection h1 {
  display: none !important;
}
.inquirySection form {
  position: relative;
  display: block;
  padding: 2em 2em 4em 2em;
}
.inquirySection form::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 5%;
}
.inquirySection dt {
  margin-top: 1.428em;
  font-size: 14px;
  font-size: 1.4rem;
}
.inquirySection dt:first-child {
  margin-top: 0.357em;
}
.inquirySection dt span {
  display: inline-block;
  padding-left: 0.05em;
  font-size: 12px;
  font-size: 1.2rem;
  vertical-align: 0.05em;
  color: var(--clr-red);
}
.inquirySection dd {
  margin-top: 0.357em;
  font-size: 14px;
  font-size: 1.4rem;
}
.inquirySection .error {
  color: var(--clr-red);
  font-size: 12px;
  font-size: 1.2rem;
  line-height: 1.4;
}
.inquirySection input[type=text],
.inquirySection textarea,
.inquirySection input[type=submit] {
  letter-spacing: 0.075em;
  font-family: "Lato", "Yu Gothic Medium", "游ゴシック Medium", "YuGothic", "游ゴシック体", "ヒラギノ角ゴ", "メイリオ", sans-serif;
  font-feature-settings: "palt";
}
.inquirySection input[type=text] {
  line-height: 1;
}
.inquirySection textarea {
  height: 10em;
  line-height: 1.4;
}
#inquiryCompleteSection p {
  position: relative;
  display: block;
  padding: 1.428em 1.428em;
  margin-bottom: 1.071em;
}
#inquiryCompleteSection p::after {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 5%;
}
#inquiryCompleteSection p + a {
  text-decoration: none;
}

@media only screen and (min-width: 768px) {
  .inquirySection dl::before, .inquirySection dl::after {
    content: "";
    display: table;
    clear: both;
    overflow: hidden;
  }
  .inquirySection dt,
.inquirySection dt:first-child {
    clear: both;
    float: left;
    width: 11.428em;
    margin: 0;
    padding-top: 1.071em;
    text-align: right;
  }
  .inquirySection dt + dd {
    width: 100%;
    float: right;
    padding: 1.071em 0.714em 0.714em 12.857em;
    margin: 0 0 0 -11.429em;
  }
  .inquirySection .error {
    padding-left: 15em;
  }
  .inquirySection input[type=text],
.inquirySection textarea {
    margin-top: -0.313em;
  }
  .inquirySection input[type=submit] {
    width: 12.857em;
    padding: 0.857em 0 0.857em 0.357em;
    margin: 0.714em auto 0 auto;
  }
  #inquiryCompleteSection p {
    padding: 2.857em 1.428em;
    text-align: center;
  }
  #inquiryCompleteSection p + a {
    width: 12.857em;
    padding: 0.857em 0 0.857em 0.357em;
    margin: 0.714em auto 0 auto;
  }
}
@media only screen and (min-width: 1024px) {
  #inquiryCompleteSection p + a, .inquirySection textarea, .inquirySection input[type=text] {
    margin-top: -0.358em;
    padding: 0.5em 0.714em;
    font-size: 14px;
    font-size: 1.4rem;
    border-radius: 0.214em;
  }
  .inquirySection {
    padding: 0 0 12em 0;
  }
  .inquirySection form {
    padding: 2em 2.7777777778vw 4em 2.7777777778vw;
  }
  #inquiryCompleteSection p {
    padding: 2.857em 2.7777777778vw;
    margin-bottom: 2.142em;
  }
  #inquiryCompleteSection p + a {
    padding: 0.857em 0;
  }
}
#law,
#privacy {
  padding: 0 2em 4em 2em;
}
#law h2,
#privacy h2 {
  margin: 2.222em 0 1.666em 0;
  font-size: 18px;
  font-size: 1.8rem;
  text-align: center;
  line-height: 1.4;
}
#law h3,
#privacy h3 {
  margin: 1.428em 0 0.714em 0;
  font-size: 14px;
  font-size: 1.4rem;
}
#law p,
#privacy p {
  line-height: 1.8;
}
#law .atobaraiTerm__body,
#privacy .atobaraiTerm__body {
  padding-left: 2em;
  margin-top: 0.5em;
  border-left: dotted 1px #CCC;
}

#privacy dl {
  display: block;
}
#privacy dt, #privacy dd {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
}
#privacy dt {
  font-weight: bold;
  margin: 1.428em 0 0.714em 0;
}

@media only screen and (min-width: 1024px) {
  #law,
#privacy {
    padding: 0 0 12em 0;
  }
  #law h2,
#privacy h2 {
    margin: 1.666em 0 2.222em 0;
    text-align: left;
  }
}
.telnumValid__txt {
  color: #000 !important;
}

#membership {
  font-size: 10px;
  font-size: 1rem;
  padding: 0 !important;
  width: auto !important;
}

.membership .mypage .img-wrapper img.img {
  max-height: none !important;
}
@media (max-width: 768px) {
  .membership .mypage .img-wrapper img.img {
    max-height: none !important;
  }
}

.membership .flash-message {
  margin: 0 1.428em;
  background: none;
  position: relative;
}
.membership .flash-message::before {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.1;
  background: var(--txt-clr);
  border-radius: 3px;
  content: "";
}
.membership .flash-message p {
  color: var(--txt-clr);
}
.membership .guide .content {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0 !important;
  margin: 0 1.428em 2.142em 1.428em;
}
.membership .mypage .content,
.membership .login .content,
.membership .guide .mypage-link {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0 !important;
  margin: 0 1.428em 1.428em 1.428em;
}
.membership .guide .register {
  font-size: 10px;
  font-size: 1rem;
  padding: 4em 2em !important;
  margin: 0 2em 2em 2em;
}
.membership .guide .link-wrapper button.link {
  display: inline-block;
  padding: 0.5em 0.714em;
  margin-top: 0.714em auto 0 auto;
  text-align: center;
  font-size: 14px;
  font-size: 1.4rem;
  font-size: 14px !important;
  font-size: 1.4rem !important;
  color: var(--bg-clr);
  background: var(--txt-clr) !important;
  border-radius: 0.214em;
  max-width: 100%;
}
.membership .guide .link-wrapper button.link:hover {
  cursor: pointer;
}
.membership .guide .description {
  margin: 0 !important;
}
.membership .guide .description li {
  position: relative;
  font-size: 14px;
  font-size: 1.4rem;
  padding-left: 0.714em;
  margin-bottom: 0.357em;
}
.membership .guide .description li::before {
  display: block;
  position: absolute;
  font-size: 14px;
  font-size: 1.4rem;
  top: 0.5em;
  left: 0;
  width: 0.357em;
  height: 0.357em;
  border: solid 1px var(--txt-clr);
  border-radius: 5em;
  content: "";
}
.membership .guide .about-point {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 3.571em 1.428em 0 1.428em;
}
@media only screen and (min-width: 768px) {
  .membership .guide .about-point {
    margin-left: 0;
    margin-right: 0;
  }
}
.membership .guide .about-point .heading-point {
  position: relative;
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1.4;
  padding: 0;
  text-align: left;
}
.membership .guide .about-point .heading-point::after {
  top: auto;
  bottom: 0;
  opacity: 0.15;
}
.membership .guide .about-point .heading-point::before {
  content: "？";
  display: inline-block;
  height: 1.5em;
  width: 1.5em;
  padding: 0 0 0.166em 0.083em;
  margin-right: 0.416em;
  vertical-align: 0.166em;
  font-size: 12px;
  font-size: 1.2rem;
  text-align: center;
  line-height: 1.5em;
  border: solid 1px var(--txt-clr);
  border-radius: 50%;
}
.membership .guide {
  font-size: 14px;
  font-size: 1.4rem;
  padding-bottom: 2.142em !important;
}
.membership .guide .content .heading {
  font-size: auto;
  line-height: auto;
}
.membership .guide .login {
  padding: 0 !important;
}
.membership .guide .mypage-link .link {
  font-size: 14px !important;
  font-size: 1.4rem !important;
  font-weight: normal !important;
  background: transparent !important;
  color: var(--txt-clr) !important;
  border: solid 1px var(--txt-clr) !important;
  border-radius: 3px !important;
}
.membership .guide .register {
  position: relative;
  background: transparent !important;
}
.membership .guide .register::before {
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  z-index: -1;
  opacity: 0.1;
  background: var(--txt-clr);
  content: "";
}
.membership .guide .register .description-link,
.membership .guide .register .login-link {
  color: var(--txt-clr) !important;
}
.membership .guide .register .box {
  background: transparent !important;
  color: var(--txt-clr) !important;
  border: 1px solid var(--txt-clr) !important;
  margin: 20px auto 30px auto !important;
}
.membership .guide .register .box::before {
  background: var(--txt-clr) !important;
}
.membership .guide .register .heading {
  font-size: 18px;
  font-size: 1.8rem;
  font-size: 18px !important;
  font-size: 1.8rem !important;
  margin-bottom: 1.666em;
}
.membership .guide .register .description,
.membership .guide .register .login {
  font-size: 14px !important;
  font-size: 1.4rem !important;
}
.membership .guide .register .link {
  font-size: 14px !important;
  font-size: 1.4rem !important;
  font-weight: normal !important;
  background: #000435 !important;
}
.membership .guide .register .mail-magazine .mail-magazine-wrapper .checkbox {
  box-shadow: 0 0 0 24px transparent inset !important;
  border-color: var(--cart-btn-bg);
  border: 1px solid var(--cart-btn-bg) !important;
  color: var(--txt-clr) !important;
  background-color: transparent !important;
}
.membership .guide .register .mail-magazine .mail-magazine-wrapper .checkbox:checked {
  border: 1px solid var(--cart-btn-bg);
  box-shadow: 0 0 0 24px var(--cart-btn-bg) inset !important;
}
.membership .guide .register .mail-magazine .mail-magazine-wrapper .label {
  color: var(--txt-clr) !important;
}
.membership .mypage {
  font-size: 14px;
  font-size: 1.4rem;
  padding-bottom: 2.142em !important;
  display: flex;
  flex-direction: column;
  margin: 0;
}
.membership .mypage .heading-wrapper {
  margin-bottom: 3rem !important;
}
.membership .mypage .title {
  margin: 0 !important;
}
.membership .mypage form {
  -webkit-margin-after: 0;
          margin-block-end: 0;
}
.membership .mypage .logout-wrapper {
  font-size: 10px;
  font-size: 1rem;
  position: relative;
  z-index: 1;
  opacity: 1;
  transition: 0.5s opacity;
}
.membership .mypage .logout-wrapper:hover {
  opacity: 0.5;
  transition: 0.5s opacity;
}
.membership .mypage .logout-wrapper::before {
  content: "";
  position: absolute;
  width: 100%;
  height: 100%;
  font-size: 10px;
  font-size: 1rem;
  background: none;
  border: solid 1px var(--txt-clr);
  border-radius: 1.7em;
  opacity: 0.25;
  z-index: -1;
}
.membership .mypage .logout-wrapper button.logout {
  padding: 0.833em 1.666em;
  font-size: 12px;
  font-size: 1.2rem;
  text-decoration: none;
  line-height: 1;
  color: var(--txt-clr);
  background: none;
}
.membership .mypage .logout-wrapper button.logout:hover {
  cursor: pointer;
}
.membership .mypage .img-wrapper {
  order: -1;
  font-size: 10px;
  font-size: 1rem;
  margin: 0 !important;
}
.membership .mypage .info {
  font-size: 10px;
  font-size: 1rem;
  padding: 0 2em;
}
.membership .mypage .info .card {
  position: relative;
  max-width: none;
  background: none;
  border: none;
  margin-bottom: 1.428em;
}
.membership .mypage .info .card::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  background: var(--txt-clr);
  border-radius: 0.214em;
  opacity: 0.1;
}
.membership .mypage .info .card span {
  background: none;
  width: auto;
  margin-bottom: 0.5em;
}
.membership .mypage .heading-wrapper {
  font-size: 10px;
  font-size: 1rem;
  padding: 0 2em;
  width: 100%;
}
.membership .mypage .logout,
.membership .mypage .leave-wrapper .leave {
  background: transparent !important;
  color: var(--txt-clr) !important;
  opacity: 1;
  transition: opacity 0.5s;
}
.membership .mypage .logout:hover,
.membership .mypage .leave-wrapper .leave:hover {
  opacity: 0.5;
  transition: opacity 0.5s;
}
.membership .mypage .content {
  margin: 0;
}
.membership .mypage .content .customer-info {
  font-size: 18px;
  font-size: 1.8rem;
  padding: 0;
  margin: 0;
}
.membership .mypage .content .bar {
  display: none;
}
.membership .mypage .content .point-history {
  padding: 0 !important;
}
.membership .mypage .content .definition-list {
  border-radius: 0.3em;
  font-size: 10px;
  font-size: 1rem;
}
.membership .mypage .content .definition-list:has(.point-amount) {
  padding: 4em 2em;
  font-size: 10px;
  font-size: 1rem;
  border: solid 1px var(--txt-clr);
}
.membership .mypage .content .definition-list:has(.point-amount) .definition-term {
  background: none;
  color: var(--txt-clr);
  font-size: 16px;
  font-size: 1.6rem;
  line-height: 1;
  text-align: center;
  margin: 0;
  letter-spacing: 0.05em;
}
.membership .mypage .content .definition-list:has(.point-amount) .definition-description {
  z-index: 0;
  display: block;
  font-size: 10px;
  font-size: 1rem;
  background: none;
  position: relative;
  margin: 0;
  padding: 0;
}
.membership .mypage .content .definition-list:has(.point-amount) .definition-description .point-amount {
  margin-top: 0.285em;
  font-size: 28px;
  font-size: 2.8rem;
  color: var(--txt-clr);
}
.membership .mypage .content .definition-list:has(.point-amount) .definition-description .point-expiry-date {
  font-size: 13px;
  font-size: 1.3rem;
  margin-top: 0.769em;
  color: var(--txt-clr);
}
.membership .mypage .content .definition-list:has(.point-amount) .point-history, .membership .mypage .content .definition-list:has(.point-amount) + .about-wrapper {
  font-size: 14px;
  font-size: 1.4rem;
  display: block !important;
  line-height: 2;
}
.membership .mypage .content .definition-list:has(.point-amount) .point-history a, .membership .mypage .content .definition-list:has(.point-amount) + .about-wrapper a {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0;
  position: relative;
  color: var(--txt-clr);
  opacity: 1;
  transition: opacity 0.5s;
}
.membership .mypage .content .definition-list:has(.point-amount) .point-history a:hover, .membership .mypage .content .definition-list:has(.point-amount) + .about-wrapper a:hover {
  opacity: 0.5;
  transition: opacity 0.5s;
}
.membership .mypage .content .definition-list:has(.mail-address) {
  display: grid;
  grid-template-columns: 1fr;
  grid-column-gap: 2em;
  grid-row-gap: 0.5em;
  margin: 0;
  font-size: 10px;
  font-size: 1rem;
}
.membership .mypage .content .definition-list:has(.mail-address) .definition-term {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: medium;
  line-height: 2;
}
.membership .mypage .content .definition-list:has(.mail-address) .definition-term::after {
  content: "：";
}
.membership .mypage .content .definition-list:has(.mail-address) .definition-description {
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 2;
  padding: 0;
  margin: 0;
  position: relative;
  background: none;
}
.membership .mypage .content .definition-list:has(.mail-address) .mail-address {
  padding: 0 !important;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  text-align: left;
  font-weight: normal;
  line-height: 2;
  background: none;
}
.membership .mypage .leave-wrapper {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 4em;
}
.membership > .login {
  font-size: 14px;
  font-size: 1.4rem;
  padding: 0 1.428em 2.857em 1.428em;
}
.membership > .login .heading {
  font-size: 18px;
  font-size: 1.8rem;
  font-size: 18px !important;
  font-size: 1.8rem !important;
  margin-bottom: 1.666em;
}
.membership > .login .link {
  font-size: 14px !important;
  font-size: 1.4rem !important;
  font-weight: normal !important;
  background: #000435 !important;
}
.membership > .login .register-description {
  font-size: 14px;
  font-size: 1.4rem;
  font-size: 14px !important;
  font-size: 1.4rem !important;
}
.membership > .login .register-link {
  color: var(--txt-clr) !important;
}
.membership .mypage .img-wrapper .img,
.membership .guide .img-wrapper .img {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 4em;
  height: auto !important;
}
.membership .draft .leave-wrapper {
  font-size: 14px;
  font-size: 1.4rem;
  margin-bottom: 2.857em;
}
.membership .draft .leave-wrapper .leave {
  background: transparent !important;
  color: var(--txt-clr) !important;
}
.membership .draft .logout-wrapper .logout {
  background: transparent !important;
  color: var(--txt-clr) !important;
}
.membership .draft .content .message {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 1.666em 0 !important;
}
.membership .draft .content .definition-description .point-amount {
  font-size: 18px;
  font-size: 1.8rem;
  background-color: transparent !important;
  font-weight: bold;
  position: relative;
}
.membership .draft .content .definition-description .point-amount::before {
  content: "";
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: var(--txt-clr);
  border-radius: 0.166em;
  opacity: 0.1;
}

@media only screen and (min-width: 768px) {
  .membership {
    font-size: 10px;
    font-size: 1rem;
  }
  .membership .guide .content,
.membership .mypage .content,
.membership .login .content,
.membership .mypage .heading-wrapper {
    margin: 0 auto !important;
  }
  .membership .guide .content {
    margin: 0 auto;
  }
  .membership .guide .mypage-link {
    margin: 0 auto 4.285em auto;
  }
  .membership .register {
    font-size: 10px;
    font-size: 1rem;
    padding: 4em;
    margin: 4em auto 8em auto !important;
  }
  .membership > .guide,
.membership > .mypage,
.membership > .login > .draft {
    font-size: 14px;
    font-size: 1.4rem;
    padding-bottom: 2.857em;
  }
  .membership .mypage .heading-wrapper {
    padding: 0 !important;
    margin-bottom: 2rem !important;
  }
  .membership .mypage .info {
    padding: 1em 0 0 0;
    display: flex !important;
    align-items: flex-start !important;
  }
  .membership .mypage .content .customer-info {
    padding: 0 0 0.555em 0 !important;
  }
  .membership .mypage .content .definition-list:has(.point-amount) {
    padding: 2em 2em;
  }
  .membership .mypage .content .definition-list:has(.point-amount) .definition-description .point-amount {
    margin-top: 0.5em;
  }
  .membership .mypage .content .definition-list:has(.point-amount) .definition-description .point-expiry-date {
    margin-top: 0.7em;
  }
  .membership .mypage .content .edit-wrapper a.edit {
    color: var(--txt-clr) !important;
    opacity: 1;
    transition: opacity 0.5s;
  }
  .membership .mypage .content .edit-wrapper a.edit:hover {
    opacity: 0.5;
    transition: opacity 0.5s;
  }
}
@media only screen and (min-width: 1024px) {
  .membership .mypage .img-wrapper .img,
.membership .guide .img-wrapper .img {
    margin-bottom: 7.2em;
  }
}
#membership .howto {
  background: none;
  position: relative;
  z-index: 1;
}
#membership .howto::before {
  content: "";
  position: absolute;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--txt-clr);
  opacity: 0.1;
  z-index: -1;
}
#membership #howto-caption .text {
  font-weight: normal;
  color: var(--txt-clr);
}
#membership #howto-caption #howto-icon svg {
  fill: var(--txt-clr);
}
#membership #howto-description {
  font-size: 10px;
  font-size: 1rem;
  position: relative;
  padding: 2em 2em 0 2em;
}
#membership #howto-description::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 1px;
  background: var(--txt-clr);
  opacity: 0.25;
}
#membership #howto-description .text {
  color: var(--txt-clr);
}
#membership .reward-list {
  position: relative;
  margin: 3em 0;
  padding: 1.5em;
  font-size: 10px;
  font-size: 1rem;
}
#membership .reward-list::before {
  background: none;
  border: solid 1px var(--txt-clrr);
  opacity: 0.15;
}
#membership .reward-list .title {
  font-size: 18px;
  font-size: 1.8rem;
  margin: 0 0 1.666em 0;
  line-height: 1;
  text-align: left;
}
#membership .reward-list .bar {
  display: none;
}
#membership .reward-list .description {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
  margin: 0.357em 0 1.714em 0;
}
#membership .reward-list .reward-card-list {
  font-size: 10px;
  font-size: 1rem;
  margin: 3em -1.5em 0 -1.5em;
  display: grid;
  grid-column-gap: 1px;
  grid-row-gap: 2em;
  grid-template-columns: repeat(2, 1fr);
}
#membership .reward-list .reward-image {
  max-width: 100%;
  height: auto;
  -o-object-fit: cover;
     object-fit: cover;
  aspect-ratio: 1/1.33;
}
#membership .reward-list .reward-detail-wrapper {
  margin: 0;
  font-size: 10px;
  font-size: 1rem;
  padding: 2em 2em 0 2em;
}
#membership .reward-list .reward-detail-wrapper .title {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 0;
  font-weight: normal;
  line-height: 1.5;
}
#membership .reward-list .reward-detail-wrapper .exchange-point-wrapper {
  position: relative;
  margin: 1em 0 0 0;
  padding: 0 0 0 2em;
  font-size: 10px;
  font-size: 1rem;
  color: var(--clr-red);
}
#membership .reward-list .reward-detail-wrapper .exchange-point-wrapper svg {
  display: none;
}
#membership .reward-list .reward-detail-wrapper .exchange-point-wrapper::before {
  content: "P";
  display: grid;
  place-items: center;
  position: absolute;
  left: 0;
  top: 0.4em;
  width: 1.4em;
  height: 1.4em;
  padding: 0.2em 0 0.2em 0.1em;
  font-size: 10px;
  font-size: 1rem;
  font-weight: normal;
  line-height: 0.75;
  border: solid 1px var(--clr-red);
  border-radius: 50%;
}
#membership .reward-list .reward-detail-wrapper .exchange-point-wrapper .exchange-point {
  font-size: 14px;
  font-size: 1.4rem;
  margin: 0;
}
#membership .reward-list .reward-detail-wrapper .description {
  font-size: 12px;
  font-size: 1.2rem;
  margin-top: 1.25em;
}
@media only screen and (min-width: 768px) {
  #membership #howto-description {
    padding: 4em 4em 0 4em;
  }
  #membership #howto-description .text {
    margin-bottom: 2.857em;
  }
  #membership .reward-list {
    margin: 3em 0;
    padding: 0;
    overflow: hidden;
  }
  #membership .reward-list .title {
    margin: 1.666em 0 1.666em 0 !important;
  }
  #membership .reward-list .reward-card-list {
    font-size: 10px;
    font-size: 1rem;
    margin: 3em 0 0 0;
    display: grid;
    grid-column-gap: 1px;
    grid-row-gap: 2em;
    grid-template-columns: repeat(3, 1fr);
  }
  #membership .reward-list .reward-image {
    filter: brightness(1);
    transition: all 0.25s;
  }
  #membership .reward-list .reward-image:hover {
    filter: brightness(1.25);
    transition: all 1s;
  }
  #membership .reward-list .reward-detail-wrapper {
    padding: 2.5em 2em 0 0;
  }
  #membership .reward-list .reward-detail-wrapper .title {
    margin: 0 !important;
  }
}

#membership .point-history {
  font-size: 10px;
  font-size: 1rem;
  padding: 0 1.5em 4em 1.5em;
}
#membership .point-history .content .point-history-summary {
  font-size: 10px;
  font-size: 1rem;
  margin-bottom: 4em;
}
#membership .point-history .content .point-name {
  font-size: 18px;
  font-size: 1.8rem;
  font-weight: bold;
  text-align: left;
  margin-bottom: 1.111em;
  color: var(--txt-clr);
}
#membership .point-history .content .description {
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1.8;
  color: var(--txt-clr);
}
#membership .point-history .content .point-history-empty-text {
  border: 0;
  padding: 1.428em;
  font-size: 14px;
  font-size: 1.4rem;
  position: relative;
  color: var(--txt-clr);
}
#membership .point-history .content .point-history-empty-text::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: var(--txt-clr);
  opacity: 0.1;
}
#membership .point-history .content .point-history-list {
  position: relative;
  padding: 2em;
  font-size: 10px;
  font-size: 1rem;
  border: 0;
}
#membership .point-history .content .point-history-list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: none;
  border: solid 1px var(--txt-clr);
  opacity: 0.5;
}
#membership .point-history .content .card {
  font-size: 10px;
  font-size: 1rem;
  border: 0;
  padding: 1em 0 0 0;
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: repeat(3, auto);
  grid-column-gap: 1em;
}
#membership .point-history .content .card:first-child {
  padding-top: 0;
}
#membership .point-history .content .card + .card {
  margin-top: 1.8em;
  position: relative;
}
#membership .point-history .content .card + .card::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 1px;
  background: var(--txt-clr);
  opacity: 0.1;
}
#membership .point-history .content .card .caption {
  margin: 0;
  grid-area: 1/1/4/2;
  font-size: 14px;
  font-size: 1.4rem;
  line-height: 1;
  display: flex;
  align-items: center;
  color: var(--txt-clr);
}
#membership .point-history .content .card .caption .action-type {
  display: inline-block;
  font-size: 11px;
  font-size: 1.1rem;
  background: #999;
  color: #FFF;
  padding: 0.181em 0.545em 0.272em 0.545em;
  border-radius: 0.181em;
}
#membership .point-history .content .card .point {
  margin: 0;
  grid-area: 1/2/2/3;
  font-size: 21px;
  font-size: 2.1rem;
  line-height: 1.4;
  text-align: right;
  color: var(--txt-clr);
}
#membership .point-history .content .card .order-header-unique-key {
  margin: 0;
  grid-area: 2/2/3/3;
  font-size: 11px;
  font-size: 1.1rem;
  line-height: 1.4;
  text-align: right;
  color: var(--txt-clr);
}
#membership .point-history .content .card .reward-name {
  grid-area: 3/2/4/3;
  font-size: 11px;
  font-size: 1.1rem;
  line-height: 1.4;
  text-align: right;
  color: var(--txt-clr);
}
#membership .point-history .content .card.is-get .caption .action-type {
  background: var(--clr-red);
}
#membership .point-history .content .card.is-get .point {
  color: var(--clr-red);
}
#membership .point-history .content .card.is-return .caption .action-type {
  background: #3762b2;
}
#membership .point-history .content .card.is-return .point {
  color: #3762b2;
}
#membership .point-history .pagination {
  font-size: 10px;
  font-size: 1rem;
  margin: 4em 0;
}
#membership .point-history .pagination .page-block {
  margin: 0;
}
#membership .point-history .pagination .page-block a.page-link,
#membership .point-history .pagination .page-block span.current {
  position: relative;
  margin: 0 0.071em;
  padding: 0.714em;
  min-width: 2.857em;
  font-size: 14px;
  font-size: 1.4rem;
  font-weight: normal;
  line-height: 1.25;
  background: none;
  border: 0;
  z-index: 1;
}
#membership .point-history .pagination .page-block a.page-link::before,
#membership .point-history .pagination .page-block span.current::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}
#membership .point-history .pagination .page-block span.current {
  color: var(--bg-clr);
}
#membership .point-history .pagination .page-block span.current::before {
  opacity: 1;
  background: var(--txt-clr);
}
#membership .point-history .pagination .page-block a.page-link {
  color: var(--txt-clr);
  transition: all 0.5s;
  background: var(--bg-clr);
}
#membership .point-history .pagination .page-block a.page-link::before {
  background: none;
  border: solid 1px var(--txt-clr);
  opacity: 0.5;
  transition: all 0.5s;
}
#membership .point-history .pagination .page-block a.page-link:hover {
  color: var(--bg-clr);
  opacity: 1;
  transition: all 0.5s;
}
#membership .point-history .pagination .page-block a.page-link:hover::before {
  opacity: 1;
  background: var(--txt-clr);
  transition: all 0.5s;
}
#membership .point-history .pagination .ellipses {
  color: var(--txt-clr);
  opacity: 0.5;
  margin: 0 10px;
}
@media only screen and (min-width: 768px) {
  #membership .point-history {
    padding: 0 0 4em 0;
  }
  #membership .point-history .content .point-history-empty-text {
    padding: 2.142em;
  }
  #membership .point-history .content .point-history-list {
    padding: 3em;
  }
  #membership .point-history .content .card {
    padding: 1.5em 0 0 0;
  }
  #membership .point-history .content .card + .card {
    margin-top: 1.7em;
  }
  #membership .point-history .content .card .order-header-unique-key {
    font-size: 12px;
    font-size: 1.2rem;
  }
  #membership .point-history .content .card .reward-name {
    font-size: 12px;
    font-size: 1.2rem;
  }
}
@media only screen and (min-width: 1024px) {
  #membership .point-history {
    padding: 0 0 6em 0;
  }
}

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