@charset "UTF-8";
/*========================================
フォント
========================================*/
input[type="text"], input[type="email"], textarea {
  -webkit-appearance: none;
  appearance: none; }

::placeholder {
  color: #afafaf; }

@keyframes fadeIn {
  100% {
    opacity: 1;
    display: block; } }
@keyframes fadeOut {
  100% {
    background: none; } }
.fadeIn {
  filter: alpha(opacity=0);
  -ms-filter: "alpha(opacity=0)";
  -moz-opacity: 0;
  -khtml-opacity: 0;
  opacity: 0;
  zoom: 1;
  transition: 1s; }

.fadeIn.inview {
  filter: alpha(opacity=1);
  -ms-filter: "alpha(opacity=100)";
  -moz-opacity: 1;
  -khtml-opacity: 1;
  opacity: 1;
  z-index: 1;
  transition-delay: 0.2s; }

/******************************************************************************
 * RESET
*******************************************************************************/
h1, h2, h3, h4, h5, h6,
a, abbr, acronym, address, applet, article, aside, audio,
b, big, blockquote, body, caption, canvas, center, cite, code,
dd, del, details, dfn, dialog, div, dl, dt, em, embed,
fieldset, figcaption, figure, form, footer,
header, hgroup, h1, h2, h3, h4, h5, h6, html,
i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav,
object, ol, output, p, pre, q, ruby,
s, samp, section, main, small, span, strike, strong, sub, summary, sup,
tt, table, tbody, textarea, tfoot, thead, time, tr, th, td,
u, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-weight: initial;
  font: inherit;
  vertical-align: baseline;
  background: transparent; }

*:focus {
  outline: none; }

html {
  font-size: 62.5%;
  font-family: var(--basefont); }
  html figure {
    margin: 0; }

@media screen and (min-width: 1024px) and (max-width: 1280px) {
  html {
    font-size: calc(10 * (100vw / 1280)); } }
@media screen and (min-width: 561px) and (max-width: 768px) {
  html {
    font-size: calc(10 * (100vw / 768)); } }
@media screen and (max-width: 375px) {
  html {
    font-size: calc(10 * (100vw / 375)); } }
body {
  width: 100%;
  font-size: 1rem;
  position: relative;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  /* Webkit系 (Chrome, Safari) */
  -moz-osx-font-smoothing: grayscale;
  /* macOS Firefox */
  text-rendering: optimizeLegibility;
  /* 可読性を向上 */ }
  body b {
    font-weight: bold; }

article, aside, details, figcaption, figure, footer, header, hgroup,
menu, nav, section, main {
  display: block; }

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

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

img {
  vertical-align: bottom;
  max-width: 100%;
  height: auto;
  border: none;
  image-rendering: -webkit-optimize-contrast; }

a {
  display: inline;
  color: #1E1E1E;
  text-decoration: none;
  transition: 0.3s ease-in-out; }

a:hover {
  text-decoration: none;
  opacity: .75; }

li {
  list-style: none; }

.anchor-txt {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  z-index: 1; }

.inner {
  max-width: 123rem;
  width: 90vw;
  padding-left: 1.5rem;
  padding-right: 1.5rem;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  z-index: 1;
  box-sizing: border-box; }
  @media (max-width: 768px) {
    .inner {
      max-width: none;
      width: auto;
      padding-left: 2rem;
      padding-right: 2rem; } }

input, button, select, textarea {
  font-family: var(--basefont) !important; }

button {
  color: inherit;
  -webkit-appearance: none;
  appearance: none; }

body #privacy, body #law {
  font-family: var(--basefont) !important;
  font-size: 16px;
  color: #1E1E1E;
  max-width: 90rem;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 10rem; }
  body #privacy h2, body #law h2 {
    font-family: var(--enfont);
    font-weight: 400;
    font-size: max(2.4rem, 22px);
    line-height: 1;
    letter-spacing: .1em;
    text-align: center;
    margin: 0 auto 6rem; }
    @media (max-width: 768px) {
      body #privacy h2, body #law h2 {
        font-size: 2.4rem; } }
  body #privacy .privacy_intro, body #law .privacy_intro {
    margin-bottom: 4rem; }
  body #privacy dd, body #law dd {
    margin-bottom: 4rem; }

body#contact .inquirySection p {
  font-size: max(1.4rem, 16px);
  margin-bottom: 2rem;
  line-height: 1.8; }
  @media (max-width: 768px) {
    body#contact .inquirySection p {
      font-size: 1.2rem; } }
body#contact .inquirySection form {
  margin-bottom: 10rem;
  font-family: var(--basefont) !important; }
  body#contact .inquirySection form dl dt {
    font-size: max(1.4rem, 16px);
    font-weight: 500; }
    @media (max-width: 768px) {
      body#contact .inquirySection form dl dt {
        font-size: 1.2rem; } }
    body#contact .inquirySection form dl dt b {
      font-weight: 500; }
  body#contact .inquirySection form dl dd {
    font-size: max(1.4rem, 16px); }
    body#contact .inquirySection form dl dd input, body#contact .inquirySection form dl dd textarea {
      font-size: max(1.4rem, 16px); }
      @media (max-width: 768px) {
        body#contact .inquirySection form dl dd input, body#contact .inquirySection form dl dd textarea {
          font-size: 1.2rem; } }
  body#contact .inquirySection form input[type="submit"] {
    font-size: max(1.4rem, 16px);
    border: 1px solid #1E1E1E;
    background: #fff !important;
    color: #1E1E1E !important; }
    body#contact .inquirySection form input[type="submit"]:hover {
      background: #1E1E1E !important;
      color: #fff !important; }
    @media (max-width: 768px) {
      body#contact .inquirySection form input[type="submit"] {
        font-size: 1.2rem; } }
body#contact .inquirySection#inquiryConfirmSection form dl dd {
  margin-bottom: 2rem;
  padding-bottom: 2rem;
  border-bottom: 1px solid #ccc; }
body#contact .inquirySection#inquiryConfirmSection form .control-panel {
  margin-top: 4rem; }
body#contact .inquirySection#inquiryCompleteSection {
  margin-bottom: 10rem; }
  body#contact .inquirySection#inquiryCompleteSection a {
    font-size: max(1.4rem, 16px) !important;
    background: none !important;
    color: #1E1E1E !important;
    text-decoration: underline; }

/******************************************************************************
common
*******************************************************************************/
:root {
  --basefont:"Zen Kaku Gothic New", sans-serif;
  --enfont:"Roboto", sans-serif;
  --fontbold:700;
  --fontnomal:400;
  --fontnomal500:500;
  --maincolor:#0053B7;
  --browncolor:#A96626;
  --bgcolor:#F2F2F2; }

/******************************************************************************
.newstextbox
*******************************************************************************/
.newstextbox {
  height: 4rem;
  background-color: #F7F8F8;
  width: 100%;
  text-align: center;
  font-weight: 400;
  font-size: max(1.2rem, 14px);
  line-height: 1;
  letter-spacing: .1em;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative; }
  @media (max-width: 768px) {
    .newstextbox {
      height: 3rem;
      font-size: 1rem; } }
  .newstextbox:after {
    content: "";
    position: absolute;
    width: 1.1rem;
    height: 1.1rem;
    display: block;
    border-top: #1E1E1E 1px solid;
    border-right: 1px solid #1E1E1E;
    right: 2.2rem;
    top: 50%;
    transform: translateY(-50%) rotate(45deg); }
    @media (max-width: 768px) {
      .newstextbox:after {
        width: 0.7rem;
        height: 0.7rem;
        right: 0.8rem; } }
  .newstextbox .close {
    position: absolute;
    cursor: pointer;
    left: 2.1rem;
    top: 50%;
    transform: translateY(-50%);
    z-index: 104; }
    @media (max-width: 768px) {
      .newstextbox .close {
        left: 1rem; } }

/******************************************************************************
#headerbox
*******************************************************************************/
#headerbox {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 8.2rem;
  box-sizing: border-box;
  padding: 0 3.8rem 0 5rem;
  position: sticky;
  top: 0;
  z-index: 100;
  background-color: white; }
  @media (max-width: 768px) {
    #headerbox {
      height: 7rem;
      padding: 0 2rem;
      border-bottom: 1px solid #E6E5E5; }
      #headerbox .headlogo {
        width: 9rem; } }
  #headerbox .logoImage {
    width: 10.5rem; }

/******************************************************************************
.navibox
*******************************************************************************/
.navibox {
  display: flex;
  align-items: center;
  gap: 2rem; }
  @media (max-width: 768px) {
    .navibox {
      gap: 1.8rem; } }
  .navibox ul {
    display: flex;
    align-items: center;
    gap: 2rem; }
    @media (max-width: 768px) {
      .navibox ul {
        gap: 1.8rem; }
        .navibox ul li:first-child {
          display: none; } }

/******************************************************************************
#glovalnav
*******************************************************************************/
#glovalnav {
  position: fixed;
  right: -38.5rem;
  top: 0;
  width: 38.5rem;
  background-color: white;
  height: 100vh;
  z-index: 1000;
  box-sizing: border-box;
  padding: 4rem 4rem 3rem;
  overflow-y: scroll;
  transition: .5s; }
  @media (max-width: 768px) {
    #glovalnav {
      right: -85%;
      width: 85%; } }
  #glovalnav .search-form {
    display: flex;
    align-items: center;
    border: 1px solid #1E1E1E;
    border-radius: 0.6rem;
    padding: 1.2rem 1.7rem;
    max-width: 30.5rem;
    margin: auto;
    box-sizing: border-box;
    margin-bottom: 4rem; }
    #glovalnav .search-form input[type="text"] {
      flex: 1;
      border: none;
      font-size: max(1.4rem, 16px);
      outline: none;
      color: #1E1E1E;
      margin-bottom: 0;
      box-shadow: none; }
      #glovalnav .search-form input[type="text"]::placeholder {
        color: #999999; }
      @media (max-width: 768px) {
        #glovalnav .search-form input[type="text"] {
          width: 90%; } }
    #glovalnav .search-form button {
      background: none;
      border: none;
      cursor: pointer;
      padding: 0;
      line-height: 1; }
      #glovalnav .search-form button img {
        width: 1.5rem; }
      @media (max-width: 768px) {
        #glovalnav .search-form button {
          width: 10%; } }
  #glovalnav .menutitle {
    font-family: var(--enfont);
    font-weight: 500;
    font-size: max(1.8rem, 20px);
    line-height: 1;
    letter-spacing: .1em; }
    #glovalnav .menutitle--item span {
      position: relative;
      padding-right: 2rem;
      cursor: pointer; }
      #glovalnav .menutitle--item span:after {
        content: "";
        position: absolute;
        right: 0;
        top: 50%;
        transform: translateY(-50%);
        width: 1.2rem;
        height: 0.7rem;
        background: url(../images/common/icon-arrow-bottom.svg) no-repeat center center/contain;
        transition: .5s; }
    #glovalnav .menutitle--item.active span:after {
      transform: translateY(-50%) rotate(-180deg); }
  #glovalnav .logo {
    width: 17rem;
    margin: 0 auto 5rem; }
  #glovalnav .instagram {
    text-align: center; }
  #glovalnav .menu {
    margin-bottom: 5rem; }
  #glovalnav .minlist {
    margin-bottom: 10.3rem;
    font-family: var(--enfont);
    font-weight: 500;
    font-size: max(1.4rem, 16px);
    line-height: 1;
    letter-spacing: .1em; }
    #glovalnav .minlist li:not(:last-child) {
      margin-bottom: 2rem; }
  #glovalnav .box:not(:last-of-type) {
    margin-bottom: 2.3rem; }
  #glovalnav .togglebox {
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.5s ease; }
    #glovalnav .togglebox.open {
      max-height: 100rem; }
    #glovalnav .togglebox .minbox:first-of-type {
      padding-top: 3rem; }
    #glovalnav .togglebox .minbox:not(:last-of-type) {
      margin-bottom: 3.3rem; }
    #glovalnav .togglebox .minbox .title {
      font-family: var(--enfont);
      font-weight: 500;
      font-size: max(1.4rem, 16px);
      line-height: 1;
      letter-spacing: .1em;
      margin-bottom: 2rem; }
    #glovalnav .togglebox .minbox ul {
      font-family: var(--enfont);
      font-weight: 400;
      font-size: max(1.2rem, 14px);
      line-height: 1;
      letter-spacing: .1em; }
      #glovalnav .togglebox .minbox ul li {
        position: relative; }
        #glovalnav .togglebox .minbox ul li:before {
          content: "・"; }
        #glovalnav .togglebox .minbox ul li:not(:last-child) {
          margin-bottom: 2rem; }
    #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child:first-of-type {
      padding-top: 3rem; }
    #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child:not(:nth-last-child(2)) {
      margin-bottom: 3.3rem; }
    #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child:last-of-type {
      display: none; }
    #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child > a {
      font-family: var(--enfont);
      font-weight: 500;
      font-size: max(1.4rem, 16px);
      line-height: 1;
      letter-spacing: .1em;
      margin-bottom: 2rem;
      display: block; }
      #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child > a.mainHeaderNavColor {
        pointer-events: none; }
    #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child ul.appsItemCategoryTag_lowerchild {
      font-family: var(--enfont);
      font-weight: 400;
      font-size: max(1.2rem, 14px);
      line-height: 1;
      letter-spacing: .1em; }
      #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child ul.appsItemCategoryTag_lowerchild li {
        position: relative; }
        #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child ul.appsItemCategoryTag_lowerchild li:before {
          content: "・"; }
        #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child ul.appsItemCategoryTag_lowerchild li:not(:last-child) {
          margin-bottom: 2rem; }
        #glovalnav .togglebox #appsItemCategoryTag .appsItemCategoryTag_child ul.appsItemCategoryTag_lowerchild li a.appsItemCategoryTag_lowerLink {
          font-size: max(1.2rem, 14px); }

body.active {
  overflow: hidden;
  height: 100vh;
  /*position: fixed;*/
  width: 100%; }
  body.active #gbtn span {
    opacity: 0; }
  body.active #gbtn:before {
    transform: rotate(45deg);
    top: 0.8rem; }
  body.active #gbtn:after {
    transform: rotate(-45deg);
    bottom: 0.6rem; }
  body.active #glovalnav {
    right: 0;
    position: fixed; }
  body.active #wrapper {
    transform: translateX(-38.5rem); }
    @media (max-width: 768px) {
      body.active #wrapper {
        transform: translateX(-85%); } }
    body.active #wrapper:after {
      opacity: 1;
      visibility: initial; }

#wrapper {
  transition: .5s; }
  #wrapper:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    opacity: 0;
    transition: all 0.5s;
    visibility: hidden;
    z-index: 1001; }

/******************************************************************************
.gnavi
*******************************************************************************/
.gnavi {
  border: none;
  background: none;
  width: 1.6rem;
  height: 1.5rem;
  position: relative;
  padding: 0;
  margin: 0;
  cursor: pointer; }
  .gnavi:before, .gnavi:after {
    content: "";
    position: absolute;
    left: 0;
    width: 100%;
    height: 0.1rem;
    background-color: #1E1E1E;
    transition: all .5s; }
  .gnavi span {
    position: absolute;
    width: 100%;
    height: 0.1rem;
    background-color: #1E1E1E;
    left: 0;
    top: 0.7rem;
    transition: all .5s; }
  .gnavi:before {
    top: 0; }
  .gnavi:after {
    bottom: 0; }

/******************************************************************************
.topbanner
*******************************************************************************/
.topbanner {
  position: relative;
  margin-bottom: 0.2rem; }
  .topbanner .box {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 2; }
    .topbanner .box .logo {
      width: 100%;
      max-width: 20rem;
      margin: 0 auto 4.5rem; }
      @media (max-width: 1023px) {
        .topbanner .box .logo {
          max-width: 14rem;
          margin-bottom: 3rem; } }
    .topbanner .box .lead {
      font-family: var(--enfont);
      font-weight: 500;
      font-size: max(3.6rem, 34px);
      line-height: 100%;
      letter-spacing: .1em;
      text-align: center;
      color: white;
      white-space: nowrap; }
      @media (max-width: 1023px) {
        .topbanner .box .lead {
          font-size: 2rem;
          line-height: 1; } }

/******************************************************************************
.contents
*******************************************************************************/
.loopslide {
  width: 100%;
  overflow: hidden;
  position: relative;
  margin-bottom: 10rem; }
  @media (max-width: 1023px) {
    .loopslide {
      margin-bottom: 8.5rem; } }
  .loopslide .slidewrap {
    width: calc(426px * 16);
    display: flex;
    animation: slideLoop 60s linear infinite;
    gap: 0.2rem; }
    @media (max-width: 1023px) {
      .loopslide .slidewrap {
        width: calc(134px * 16); } }
    .loopslide .slidewrap .cap {
      flex: none;
      width: 42.6rem; }
      @media (max-width: 1023px) {
        .loopslide .slidewrap .cap {
          width: 13.4rem; } }
      .loopslide .slidewrap .cap img {
        width: 100%;
        aspect-ratio: 426 / 638;
        object-fit: cover; }
        @media (max-width: 1023px) {
          .loopslide .slidewrap .cap img {
            aspect-ratio: 134/200; } }

@keyframes slideLoop {
  0% {
    transform: translateX(0%); }
  100% {
    transform: translateX(-50%); } }
/******************************************************************************
.contents
*******************************************************************************/
.contents--title {
  font-family: var(--enfont);
  font-weight: 400;
  font-size: max(3.6rem, 34px);
  line-height: 1;
  letter-spacing: .1em;
  text-align: center; }
  @media (max-width: 768px) {
    .contents--title {
      font-size: 2.4rem; } }

/******************************************************************************
.brand
*******************************************************************************/
.linktxt {
  position: relative;
  padding-left: 1.8rem; }
  .linktxt:before {
    content: "";
    width: 1.2rem;
    height: 0.8rem;
    background: url(../images/common/icon-arrow.svg) no-repeat center center/contain;
    display: inline-block;
    top: 50%;
    transform: translateY(-50%);
    margin-top: 0.2rem;
    left: 0;
    position: absolute; }

.brand--index {
  padding: 20rem 0; }
  @media (max-width: 768px) {
    .brand--index {
      padding: 10rem 0; } }
  .brand--index .title {
    margin-bottom: 6.8rem; }
    @media (max-width: 768px) {
      .brand--index .title {
        margin-bottom: 4rem; } }
  .brand--index ul {
    display: flex;
    gap: 1.5rem;
    justify-content: space-between; }
    @media (max-width: 1023px) {
      .brand--index ul {
        gap: 0.1rem;
        flex-wrap: wrap;
        gap: 3rem 0;
        flex-wrap: wrap;
        margin: 0 2rem; } }
    .brand--index ul li {
      position: relative;
      width: 100%;
      min-width: calc(100% / 4 - 1.5rem);
      text-align: center;
      font-family: var(--enfont);
      font-weight: 400;
      font-size: max(1.6rem, 14px);
      line-height: 100%;
      letter-spacing: .1em; }
      @media (max-width: 1023px) {
        .brand--index ul li {
          min-width: inherit;
          max-width: calc((100% - 1.5rem) / 2);
          font-size: 1.4rem; }
          .brand--index ul li .text {
            left: 0;
            width: 100%;
            text-align: center;
            color: #1e1e1e;
            margin: 1rem auto 0; } }
      .brand--index ul li .cap {
        padding-bottom: 1.5rem; }
        @media (max-width: 1023px) {
          .brand--index ul li .cap {
            padding-bottom: 0; } }
.brand--page h2.title {
  margin-bottom: 11.7rem; }
  @media (max-width: 768px) {
    .brand--page h2.title {
      margin-bottom: 6rem; } }
.brand--list {
  margin-left: 8.3333333333vw;
  margin-right: 8.3333333333vw;
  font-weight: 400;
  font-size: max(1.6rem, 14px);
  line-height: 2.4;
  letter-spacing: .1em;
  text-align: justify;
  position: relative; }
  @media (max-width: 768px) {
    .brand--list {
      margin-left: 0;
      margin-right: 0;
      font-size: 1.2rem;
      padding-top: 7rem;
      margin-top: -7rem; } }
  .brand--list:last-of-type {
    margin-bottom: 20rem; }
    @media (max-width: 768px) {
      .brand--list:last-of-type {
        margin-bottom: 7rem; } }
  .brand--list:not(:last-of-type) {
    margin-bottom: 10rem; }
  .brand--list .box {
    width: calc(100% - 32.9861111111vw - 6.9444444444vw);
    position: absolute;
    right: 0;
    height: 100%;
    top: 0;
    display: flex;
    align-items: center;
    justify-content: center; }
    @media (max-width: 768px) {
      .brand--list .box {
        width: auto;
        position: initial;
        right: auto;
        height: auto;
        top: auto; }
        .brand--list .box .logo {
          display: none; }
        .brand--list .box .itembox {
          padding: 0 2rem; } }
    .brand--list .box p.text {
      margin-bottom: 6rem; }
      @media (max-width: 768px) {
        .brand--list .box p.text {
          margin-bottom: 4rem; } }
    .brand--list .box .linktext {
      text-align: center;
      font-family: var(--enfont);
      font-weight: 400;
      font-size: max(1.4rem, 16px);
      line-height: 1;
      letter-spacing: .1em; }
  .brand--list .logo {
    text-align: center;
    margin-bottom: 6rem; }
    @media (max-width: 768px) {
      .brand--list .logo {
        margin-bottom: 0;
        width: calc(100% -  15.1rem);
        display: flex;
        align-items: center;
        justify-content: center; } }
  .brand--list .title {
    text-align: center;
    margin-bottom: 9.9rem; }
    @media (max-width: 768px) {
      .brand--list .title {
        margin-bottom: 3rem; } }
    .brand--list .title .text, .brand--list .title .mintxt {
      display: block; }
    .brand--list .title .text {
      font-weight: 500;
      font-size: max(3.4rem, 36px);
      line-height: 1;
      letter-spacing: .1em;
      margin-bottom: 3.6rem; }
      @media (max-width: 768px) {
        .brand--list .title .text {
          font-size: 2rem;
          margin-bottom: 2rem; } }
    .brand--list .title .mintxt {
      font-weight: 500;
      font-style: Medium;
      font-size: max(1.4rem, 16px);
      line-height: 2;
      letter-spacing: .1em;
      position: relative;
      padding-bottom: 3.9rem; }
      @media (max-width: 768px) {
        .brand--list .title .mintxt {
          font-size: 1.2rem;
          padding-bottom: 3.2rem; } }
      .brand--list .title .mintxt:after {
        content: "";
        position: absolute;
        left: 50%;
        transform: translateX(-50%);
        width: 5rem;
        height: 1px;
        background-color: #1E1E1E;
        display: block;
        bottom: 0; }
  .brand--list .capbox {
    display: flex;
    align-items: center;
    justify-content: space-between; }
    @media (max-width: 768px) {
      .brand--list .capbox {
        justify-content: flex-start;
        margin-bottom: 6rem; } }
    .brand--list .capbox .cap {
      width: 100%;
      max-width: 32.9861111111vw; }
      @media (max-width: 768px) {
        .brand--list .capbox .cap {
          max-width: 15.1rem; } }
      .brand--list .capbox .cap img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        aspect-ratio: 475 / 750; }
        @media (max-width: 768px) {
          .brand--list .capbox .cap img {
            aspect-ratio: 151/240; } }

/******************************************************************************
.archivenavbox
*******************************************************************************/
.archivenavbox {
  margin-bottom: 20rem; }
  @media (max-width: 768px) {
    .archivenavbox {
      margin-bottom: 20rem; } }
  .archivenavbox ul.list {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7rem;
    font-family: var(--enfont);
    font-weight: 500;
    font-size: max(1.5rem, 17px);
    line-height: 1;
    letter-spacing: .1em; }
    @media (max-width: 768px) {
      .archivenavbox ul.list {
        display: grid;
        grid-template-columns: repeat(3, 1fr);
        gap: 3rem;
        font-size: 1.5rem; } }
    .archivenavbox ul.list > li {
      white-space: nowrap; }
      .archivenavbox ul.list > li a {
        position: relative;
        padding-bottom: 0;
        transition: .5s; }
        .archivenavbox ul.list > li a:after {
          content: "";
          width: 100%;
          height: 0.2rem;
          background-color: black;
          position: absolute;
          left: 0;
          bottom: 0;
          opacity: 0;
          transition: .5s; }
        .archivenavbox ul.list > li a:hover {
          /* padding-bottom: rem(10); */ }
          .archivenavbox ul.list > li a:hover:after {
            opacity: 1;
            bottom: -1rem; }
      .archivenavbox ul.list > li.itemlist {
        position: relative; }
        .archivenavbox ul.list > li.itemlist .item {
          position: relative;
          padding-bottom: 0;
          transition: .5s; }
          .archivenavbox ul.list > li.itemlist .item:after {
            content: "";
            width: 100%;
            height: 0.2rem;
            background-color: black;
            position: absolute;
            left: 0;
            bottom: 0;
            opacity: 0;
            transition: .5s; }
        .archivenavbox ul.list > li.itemlist:hover .item {
          position: relative;
          padding-bottom: 0;
          transition: .5s; }
          .archivenavbox ul.list > li.itemlist:hover .item:after {
            opacity: 1;
            bottom: -1rem; }
        .archivenavbox ul.list > li.itemlist .item {
          position: relative;
          z-index: 105; }
        .archivenavbox ul.list > li.itemlist .subbox {
          position: absolute;
          left: 0;
          top: 0;
          /* min-width: rem(150); */
          z-index: 104; }
          .archivenavbox ul.list > li.itemlist .subbox ul {
            /*max-height: 0;*/
            overflow: hidden;
            font-family: var(--enfont);
            font-weight: 400;
            font-size: max(1.2rem, 14px);
            line-height: 1;
            letter-spacing: .1em;
            text-align: left;
            transition: .5s;
            opacity: 0; }
            @media (max-width: 768px) {
              .archivenavbox ul.list > li.itemlist .subbox ul {
                background: none; } }
            .archivenavbox ul.list > li.itemlist .subbox ul li:not(:last-child) {
              margin-bottom: 1rem; }
            .archivenavbox ul.list > li.itemlist .subbox ul li a:after {
              display: none; }
        .archivenavbox ul.list > li.itemlist:hover .subbox ul {
          overflow: initial;
          min-height: 12.4rem;
          margin-top: 4rem;
          opacity: 1; }

/******************************************************************************
.about
*******************************************************************************/
.about--index {
  padding: 12rem 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 11.2rem;
  font-weight: 400;
  font-size: max(1.6rem, 14px);
  line-height: 2.4;
  letter-spacing: .1em;
  margin-bottom: 10rem; }
  @media (max-width: 1023px) {
    .about--index {
      display: block;
      font-size: 1.2rem; }
      .about--index .textbox {
        padding: 0 4rem;
        display: flex;
        justify-content: center; } }
  @media (max-width: 768px) {
    .about--index {
      padding: 10rem 0;
      margin-bottom: 10rem; } }
  .about--index .cap {
    width: 100%;
    max-width: 27.4rem; }
    @media (max-width: 1023px) {
      .about--index .cap {
        max-width: 12rem;
        margin: 0 auto 6rem; } }
.about .title {
  font-weight: 500;
  font-size: max(3rem, 28px);
  line-height: 2;
  letter-spacing: .1em;
  margin-bottom: 4.6rem; }
  @media (max-width: 1023px) {
    .about .title {
      font-size: 1.8rem;
      margin-bottom: 4rem; } }

/******************************************************************************
.collection
*******************************************************************************/
.collection--index {
  padding: 0 0 10rem;
  padding-left: 8.3333333333vw;
  padding-right: 8.3333333333vw; }
  @media (max-width: 1023px) {
    .collection--index {
      padding-left: 2rem;
      padding-right: 2rem; } }
  @media (max-width: 768px) {
    .collection--index {
      padding: 0 0 10rem; } }
  .collection--index .title {
    margin-bottom: 6rem; }
  .collection--index .list {
    display: flex;
    flex-wrap: wrap;
    gap: 2.4rem; }
    @media (max-width: 1023px) {
      .collection--index .list {
        gap: 2.5rem 1.5rem;
        justify-content: space-between; } }
    @media (max-width: 768px) {
      .collection--index .list {
        padding: 0 2rem; } }
    .collection--index .list.archive {
      gap: 6rem 5.3rem; }
      @media (max-width: 768px) {
        .collection--index .list.archive {
          gap: 2.2rem 1.2rem; } }
  .collection--index .subtitle {
    font-family: var(--enfont);
    font-weight: 400;
    font-size: max(2.2rem, 24px);
    line-height: 100%;
    letter-spacing: .1em;
    text-align: center;
    margin-bottom: 6rem; }
    @media (max-width: 768px) {
      .collection--index .subtitle {
        font-size: 1.8rem;
        margin-bottom: 4rem; } }
.collection--page {
  padding-top: 0;
  padding-bottom: 20rem; }
.collection--box {
  text-align: center; }
  .collection--box:not(:last-of-type) {
    margin-bottom: 12.4rem; }
    @media (max-width: 768px) {
      .collection--box:not(:last-of-type) {
        margin-bottom: 8.2rem; } }
.collection .linktxt, .collection button.linktxt {
  display: inline-block;
  text-align: center;
  margin-top: 6rem;
  font-family: var(--enfont) !important;
  font-weight: 400;
  font-size: max(1.4rem, 16px);
  position: relative;
  border: none;
  background: none;
  cursor: pointer;
  white-space: nowrap; }
  @media (max-width: 768px) {
    .collection .linktxt, .collection button.linktxt {
      margin-top: 4rem;
      font-size: 1.4rem;
      color: #1E1E1E !important; } }
  .collection .linktxt.single, .collection button.linktxt.single {
    position: relative;
    /* padding-left: rem(18); */ }
    .collection .linktxt.single:after, .collection button.linktxt.single:after {
      content: "";
      position: absolute;
      left: 50%;
      top: auto;
      transform: translateX(-50%);
      bottom: -2.5rem;
      width: 1.6rem;
      height: 0.9rem;
      background: url(../images/common/icon-arrow-bottom.svg) no-repeat center center/contain;
      transition: .5s; }
      @media (max-width: 768px) {
        .collection .linktxt.single:after, .collection button.linktxt.single:after {
          bottom: -2rem; } }
  .collection .linktxt.back:after, .collection button.linktxt.back:after {
    transform: translateY(-50%) rotate(180deg); }
.collection--list {
  position: relative;
  width: 100%;
  max-width: calc((100% - 2.4rem *4) / 5);
  overflow: hidden; }
  @media (max-width: 1023px) {
    .collection--list {
      max-width: calc((100% - 1.5rem) / 2); } }
  .collection--list:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
    opacity: 0;
    transition: opacity .5s ease; }
    @media (max-width: 1023px) {
      .collection--list:after {
        content: none; } }
  .collection--list .leadtxt {
    font-weight: 500;
    font-size: max(1.1rem, 13px);
    line-height: 1.6;
    letter-spacing: .1em;
    position: absolute;
    z-index: 2;
    width: calc(100%  - 2rem);
    bottom: 1.5rem;
    left: 50%;
    transform: translateX(-50%) translateY(1.5rem);
    color: white;
    opacity: 0;
    transition: .5s;
    text-align: left; }
    @media (max-width: 768px) {
      .collection--list .leadtxt {
        position: inherit;
        left: auto;
        transform: none;
        bottom: auto;
        opacity: 1;
        color: #1E1E1E; } }
  .collection--list .cap {
    overflow: hidden;
    position: relative; }
    .collection--list .cap:after {
      content: "";
      position: absolute;
      left: 0;
      bottom: 0;
      width: 100%;
      height: 100%;
      background: rgba(0, 0, 0, 0.5);
      opacity: 0;
      transition: opacity .5s ease; }
    @media (max-width: 768px) {
      .collection--list .cap {
        margin-bottom: 1.2rem; } }
    .collection--list .cap img {
      width: 100%;
      height: 100%;
      aspect-ratio: 1;
      object-fit: cover;
      transition: .5s; }
  .collection--list:hover:after {
    opacity: 1; }
  .collection--list:hover .cap img {
    transform: scale(1.2); }
  @media (max-width: 1023px) {
    .collection--list:hover .cap:after {
      opacity: 1; } }
  .collection--list:hover .leadtxt {
    opacity: 1;
    transform: translateX(-50%) translateY(0); }
    @media (max-width: 768px) {
      .collection--list:hover .leadtxt {
        transform: translateX(0) translateY(0); } }
  .collection--list.archive {
    max-width: calc((100% - 5.3rem *3) / 4); }
    @media (max-width: 768px) {
      .collection--list.archive {
        max-width: calc((100% - 1.2rem) / 2); } }
    .collection--list.archive .leadtxt {
      position: initial;
      opacity: 1;
      transform: translate(0);
      color: #1E1E1E;
      font-size: max(1.4rem, 16px);
      padding: 2rem 0; }
      @media (max-width: 768px) {
        .collection--list.archive .leadtxt {
          padding: 0;
          font-size: 1.2rem;
          margin-bottom: 0.5rem; } }
    .collection--list.archive .price, .collection--list.archive .sale {
      text-align: left;
      font-family: var(--enfont);
      font-weight: 400;
      font-size: max(1.2rem, 14px);
      color: #999999; }
      @media (max-width: 768px) {
        .collection--list.archive .price, .collection--list.archive .sale {
          font-size: 1.2rem; } }
    .collection--list.archive .sale, .collection--list.archive .discount {
      color: #e74c3c;
      text-align: left; }
    .collection--list.archive .discount {
      font-size: max(1.1rem, 13px);
      padding-left: 1rem; }
      @media (max-width: 768px) {
        .collection--list.archive .discount {
          font-size: 90%; } }
    .collection--list.archive:after {
      content: none; }
    .collection--list.archive:hover .cap:after {
      opacity: 1; }
.collection--single {
  padding-bottom: 20rem; }
  @media (max-width: 768px) {
    .collection--single {
      padding-bottom: 10rem; } }
  .collection--single .title {
    text-align: left;
    font-size: max(2.2rem, 24px); }
    @media (max-width: 1023px) {
      .collection--single .title {
        padding: 0 2rem;
        font-size: 1.8rem;
        margin-bottom: 4rem; } }

/******************************************************************************
.mailbox
*******************************************************************************/
.mailbox {
  margin-left: 8.3333333333vw;
  margin-right: 8.3333333333vw;
  background-color: #F7F8F8;
  box-sizing: border-box;
  padding: 6rem;
  display: flex;
  align-items: center;
  justify-content: space-between; }
  @media (max-width: 1023px) {
    .mailbox {
      margin-left: 2rem;
      margin-right: 2rem;
      justify-content: space-between;
      padding: 6rem 3rem; } }
  @media (max-width: 768px) {
    .mailbox {
      display: block;
      padding: 3rem 2rem; } }
  .mailbox .textbox {
    font-weight: 500;
    font-size: max(1.6rem, 14px);
    line-height: 2.2;
    letter-spacing: .1em; }
    @media (max-width: 1023px) {
      .mailbox .textbox {
        display: flex;
        justify-content: center;
        flex-wrap: wrap; } }
    @media (max-width: 768px) {
      .mailbox .textbox {
        font-size: 1.2rem;
        margin-bottom: 2rem; } }
    .mailbox .textbox h3 {
      font-family: var(--enfont);
      font-weight: 500;
      font-size: max(2.4rem, 22px);
      line-height: 1;
      letter-spacing: .1em;
      margin-bottom: 3.4rem;
      width: 100%; }
      @media (max-width: 768px) {
        .mailbox .textbox h3 {
          text-align: center;
          font-size: 1.8rem;
          margin-bottom: 1rem; } }
  .mailbox .mail-magazine__form {
    display: flex;
    flex: 1 1 20.8333333333vw;
    max-width: 29.1666666667vw; }
    @media (max-width: 1023px) {
      .mailbox .mail-magazine__form {
        max-width: 42rem;
        flex: 1 1 30rem;
        margin-left: auto;
        margin-right: auto; } }
    .mailbox .mail-magazine__form input[type="email"] {
      flex: 1;
      padding: 1rem 1.6rem;
      border: none;
      font-size: max(1.4rem, 12px);
      background-color: #fff;
      color: #333;
      border-radius: 0;
      width: auto;
      max-width: none; }
    .mailbox .mail-magazine__form button {
      padding: 1rem 2.4rem;
      background-color: #c3c9ce;
      color: #fff;
      border: none;
      font-size: max(1.5rem, 13px);
      cursor: pointer;
      letter-spacing: .1em;
      white-space: nowrap;
      border-radius: 0; }
      @media (max-width: 768px) {
        .mailbox .mail-magazine__form button {
          padding: 0.9rem 2.4rem; } }
  .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe {
    max-width: 29.1666666667vw;
    width: 100%; }
    .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_field.mailMagazineSubscribe_field {
      display: flex;
      flex: 1 1 20.8333333333vw; }
      @media (max-width: 1023px) {
        .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_field.mailMagazineSubscribe_field {
          max-width: 42rem;
          flex: 1 1 30rem;
          margin-left: auto;
          margin-right: auto; } }
      @media (max-width: 768px) {
        .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_field.mailMagazineSubscribe_field {
          max-width: 100%;
          width: 100%;
          margin-left: 0;
          margin-right: 0; } }
      .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_field.mailMagazineSubscribe_field .mailMagazineSubscribe_input {
        flex: 1;
        padding: 1rem 1.6rem;
        border: none;
        font-size: max(1.4rem, 12px);
        background-color: #fff;
        color: #333;
        border-radius: 0;
        width: auto;
        max-width: none;
        margin-bottom: 0 !important; }
        @media (max-width: 768px) {
          .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_field.mailMagazineSubscribe_field .mailMagazineSubscribe_input {
            width: 80%; } }
      .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_field.mailMagazineSubscribe_field .mailMagazineSubscribe_submit {
        padding: 1rem 2.4rem;
        background-color: #c3c9ce;
        color: #fff;
        border: none;
        font-size: max(1.5rem, 13px);
        cursor: pointer;
        letter-spacing: .1em;
        white-space: nowrap;
        border-radius: 0; }
        @media (max-width: 768px) {
          .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_field.mailMagazineSubscribe_field .mailMagazineSubscribe_submit {
            padding: 0;
            width: 20%; } }
    .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_confirm.mailMagazineSubscribe_confirm {
      font-size: max(1.4rem, 12px);
      color: #1E1E1E !important; }
      @media (max-width: 768px) {
        .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe .x_mailMagazineSubscribe_confirm.mailMagazineSubscribe_confirm {
          font-size: 1.2rem; } }
    @media (max-width: 768px) {
      .mailbox .x_mailMagazineSubscribe.mailMagazineSubscribe {
        max-width: 100%; } }

/******************************************************************************
.pagenavi
*******************************************************************************/
.pagenavi {
  padding: 2rem 8.3333333333vw 8.5rem; }
  @media (max-width: 768px) {
    .pagenavi {
      padding: 1rem 2rem 4.3rem; } }
  .pagenavi ul {
    font-family: var(--enfont);
    font-weight: 400;
    font-size: max(1.2rem, 12px);
    line-height: 1;
    letter-spacing: .1em;
    flex-wrap: wrap; }
    @media (max-width: 768px) {
      .pagenavi ul {
        font-size: 1rem; } }
    .pagenavi ul .txt {
      text-decoration: underline; }
    .pagenavi ul li {
      display: inline;
      line-height: 1.8; }
      .pagenavi ul li:not(:last-child) {
        position: relative;
        padding-right: 1.2rem;
        margin-right: 1.2rem; }
        @media (max-width: 768px) {
          .pagenavi ul li:not(:last-child) {
            padding-right: 0.8rem;
            margin-right: 0.8rem; } }
        .pagenavi ul li:not(:last-child):after {
          content: "";
          width: 0.5rem;
          height: 0.5rem;
          border-top: 1px solid #E6E5E5;
          border-right: 1px solid #E6E5E5;
          top: 50%;
          transform: translateY(-50%) rotate(45deg);
          right: 0;
          position: absolute; }

/******************************************************************************
#footerbox
*******************************************************************************/
#footerbox {
  padding: 12rem 0 4rem; }
  @media (max-width: 768px) {
    #footerbox {
      padding-top: 10rem; } }
  #footerbox .instagram {
    margin-bottom: 4.2rem; }
  #footerbox .box {
    text-align: center;
    margin-bottom: 4rem; }
    @media (max-width: 768px) {
      #footerbox .box {
        margin-bottom: 4rem; } }
  #footerbox .logo {
    position: relative;
    display: inline-block;
    text-align: center;
    margin-bottom: 8rem; }
    #footerbox .logo .icon, #footerbox .logo .item {
      display: block;
      margin-left: auto;
      margin-right: auto; }
    @media (max-width: 768px) {
      #footerbox .logo .item {
        max-width: 12rem; } }
    #footerbox .logo .icon {
      margin-bottom: 4rem; }
      @media (max-width: 768px) {
        #footerbox .logo .icon {
          width: 2.9rem;
          margin-bottom: 2.4rem; } }
  #footerbox .copy {
    display: block;
    text-align: center;
    font-family: var(--enfont);
    font-weight: 400;
    font-size: max(1rem, 12px);
    color: #1E1E1E; }
    @media (max-width: 768px) {
      #footerbox .copy {
        font-size: 1.1rem; } }
  #footerbox .othernav {
    padding-right: 4rem; }
    @media (max-width: 768px) {
      #footerbox .othernav {
        padding-right: 0; } }
    #footerbox .othernav ul {
      justify-content: flex-end; }
      @media (max-width: 768px) {
        #footerbox .othernav ul {
          justify-content: center; } }
    #footerbox .othernav a {
      color: #1E1E1E; }

.othernav ul {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 400;
  font-size: max(1.1rem, 12px);
  line-height: 1;
  gap: 4rem; }
  @media (max-width: 768px) {
    .othernav ul {
      font-size: 1.1rem; } }
  .othernav ul li {
    position: relative; }
    .othernav ul li:nth-child(1):before {
      position: absolute;
      right: -2rem;
      width: 1px;
      height: 0.8rem;
      background-color: #1E1E1E;
      top: 50%;
      transform: translateY(-50%);
      content: ""; }

/******************************************************************************
.singlepage
*******************************************************************************/
.singlepage {
  padding: 0 8.3333333333vw;
  font-weight: 400;
  font-size: max(1.4rem, 16px);
  line-height: 2.4;
  letter-spacing: .1em;
  /*.price{
  	font-size: max(1.6rem, 18px);
  	margin:rem(40) 0 0;
  }*/ }
  @media (max-width: 1023px) {
    .singlepage {
      padding: 0;
      margin-bottom: 6rem;
      font-size: 1.2rem; } }
  .singlepage--contents {
    white-space: normal;
    word-break: break-word;
    overflow-wrap: break-word; }
    @media (max-width: 1023px) {
      .singlepage--contents {
        padding: 0 2rem; } }
  .singlepage .readmore-target, .singlepage .appsItemDetailCustomTag_description:first-of-type {
    max-height: 0;
    overflow: hidden;
    position: relative;
    transition: max-height 0.5s ease;
    padding-top: 0; }
  .singlepage .readmore {
    cursor: pointer;
    font-weight: 400;
    font-size: max(1.3rem, 15px);
    line-height: 1;
    letter-spacing: 1;
    text-align: right; }
    @media (max-width: 768px) {
      .singlepage .readmore {
        font-size: 1.2rem; } }
    .singlepage .readmore .txt {
      position: relative;
      padding-right: 1.5rem; }
      .singlepage .readmore .txt:after {
        content: "";
        display: inline-block;
        width: 1rem;
        height: 1rem;
        border-right: 1px solid #1E1E1E;
        border-top: 1px solid #1E1E1E;
        transform: translateY(-50%) rotate(135deg);
        position: absolute;
        right: 0;
        top: 50%; }
        @media (max-width: 768px) {
          .singlepage .readmore .txt:after {
            width: 0.6rem;
            height: 0.6rem; } }
    .singlepage .readmore.active .txt:after {
      transform: translateY(-50%) rotate(-45deg);
      margin-top: 0.5rem; }
  .singlepage .readmore-target.open, .singlepage .appsItemDetailCustomTag_description:first-of-type.open {
    max-height: 999.9rem;
    padding-top: 4rem; }
  .singlepage--title {
    font-family: var(--enfont);
    font-weight: 400;
    font-size: max(3.4rem, 36px);
    line-height: 1.8;
    letter-spacing: .1em;
    margin-bottom: 6rem; }
    .singlepage--title .category {
      display: block;
      font-weight: 400;
      font-size: max(1.8rem, 20px);
      line-height: 1;
      letter-spacing: .1em;
      margin-bottom: 4rem; }
      @media (max-width: 768px) {
        .singlepage--title .category {
          margin-bottom: 2rem; } }
    @media (max-width: 1023px) {
      .singlepage--title {
        font-size: 2.4rem;
        line-height: 1.6;
        margin-bottom: 4rem; } }
  @media (max-width: 1023px) {
    .singlepage .notelist {
      padding: 0 2rem; } }
  .singlepage .notelist li {
    position: relative; }
    .singlepage .notelist li:before {
      content: "※"; }
  .singlepage .appsItemDetailCustomTag_heading {
    display: none; }
  .singlepage .appsItemDetailCustomTag_description {
    margin-top: 2rem; }

.slider-wrap {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  gap: 8.6805555556vw;
  margin-bottom: 10rem; }
  @media (max-width: 1023px) {
    .slider-wrap {
      display: block;
      margin-bottom: 4rem; } }

.slider-for {
  width: 100%;
  max-width: 55.5555555556vw; }
  @media (max-width: 1023px) {
    .slider-for {
      margin-bottom: 2rem;
      max-width: none; } }
  .slider-for img {
    width: 100%;
    height: 100%;
    aspect-ratio: 1;
    object-fit: cover; }

.slider-nav {
  width: 10.4166666667vw; }
  @media (max-width: 1023px) {
    .slider-nav {
      width: auto;
      display: flex;
      padding: 0 1.5rem;
      align-items: center;
      gap: 1rem; } }
  .slider-nav .slick-prev, .slider-nav .slick-next {
    position: initial;
    margin-left: auto;
    margin-right: auto; }
    .slider-nav .slick-prev:before, .slider-nav .slick-next:before {
      content: "";
      width: 1rem;
      height: 1rem;
      border-right: 1px solid #1E1E1E;
      border-bottom: 1px solid #1E1E1E;
      display: block; }
  .slider-nav .slick-prev {
    transform: rotate(-135deg);
    margin-bottom: 1rem; }
    @media (max-width: 1023px) {
      .slider-nav .slick-prev {
        margin: 0;
        transform: rotate(135deg); } }
  .slider-nav .slick-next {
    transform: rotate(45deg);
    margin-top: 1rem; }
    @media (max-width: 1023px) {
      .slider-nav .slick-next {
        margin: 0;
        transform: rotate(-45deg); } }
  .slider-nav div.slick-slide {
    width: 15rem;
    cursor: pointer;
    border: none;
    position: relative; }
    .slider-nav div.slick-slide:after {
      content: "";
      position: absolute;
      width: 100%;
      height: 100%;
      left: 0;
      top: 0;
      transition: all .5s;
      opacity: 0; }
    .slider-nav div.slick-slide.slick-current:after {
      background: rgba(255, 255, 255, 0.5);
      opacity: 1; }
    .slider-nav div.slick-slide img {
      width: 100%;
      height: 100%;
      aspect-ratio: 1;
      object-fit: cover; }

/******************************************************************************
.cart
*******************************************************************************/
.cart {
  padding: 6rem 0 10rem;
  font-weight: 400;
  font-size: max(1.6rem, 18px);
  line-height: 2.4;
  letter-spacing: .1em; }
  @media (max-width: 1023px) {
    .cart {
      padding: 4rem 2rem 6rem;
      font-size: 1.8rem; } }
  .cart--price {
    margin-bottom: 4rem; }
    @media (max-width: 768px) {
      .cart--price {
        margin-bottom: 2rem; } }
  .cart--box, .cart button.purchaseButton__btn, .cart a.purchaseButton__btn {
    background-color: white;
    width: 100%;
    max-width: 42rem;
    height: 6rem;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid #1E1E1E;
    font-size: max(1.4rem, 16px);
    cursor: pointer;
    color: #1E1E1E;
    transition: 0.3s ease-in-out; }
    @media (max-width: 768px) {
      .cart--box, .cart button.purchaseButton__btn, .cart a.purchaseButton__btn {
        font-size: 1.2rem; } }
    .cart--box:hover, .cart button.purchaseButton__btn:hover, .cart a.purchaseButton__btn:hover {
      color: white;
      background-color: #1E1E1E; }
  .cart a.purchaseButton__btn--soldOut {
    pointer-events: none;
    color: #f00 !important; }
  .cart--list {
    margin-bottom: 6rem; }
    @media (max-width: 1023px) {
      .cart--list {
        margin-bottom: 4rem; } }
    .cart--list li {
      font-size: max(1.4rem, 16px);
      display: flex;
      align-items: center;
      gap: 1rem; }
      @media (max-width: 1023px) {
        .cart--list li {
          font-size: 1.2rem; } }
      .cart--list li .title {
        width: 12rem; }
      .cart--list li .text:before {
        content: ":";
        display: inline-block;
        padding-right: 1rem; }
  .cart--select, .cart #itemSelect {
    margin-bottom: 3rem;
    display: flex;
    align-items: flex-start;
    gap: 2rem; }
    @media (max-width: 1023px) {
      .cart--select, .cart #itemSelect {
        display: block; }
        .cart--select .box:not(:last-of-type), .cart #itemSelect .box:not(:last-of-type) {
          margin-bottom: 2rem; } }
    .cart--select .txt, .cart--select label[for="valiationSelect"], .cart--select label[for="amountSelect"], .cart #itemSelect .txt, .cart #itemSelect label[for="valiationSelect"], .cart #itemSelect label[for="amountSelect"] {
      font-size: max(1.2rem, 14px);
      display: block; }
      @media (max-width: 768px) {
        .cart--select .txt, .cart--select label[for="valiationSelect"], .cart--select label[for="amountSelect"], .cart #itemSelect .txt, .cart #itemSelect label[for="valiationSelect"], .cart #itemSelect label[for="amountSelect"] {
          font-size: 1.2rem; } }
    .cart--select select, .cart #itemSelect select {
      width: 100%;
      padding: 1.5rem 6.7rem 1.5rem 2rem;
      font-size: max(1.3rem, 15px);
      border: 1px solid #ddd;
      background: #fff;
      appearance: none;
      -webkit-appearance: none;
      -moz-appearance: none;
      cursor: pointer;
      box-sizing: border-box;
      background-position: right 1em center; }
      @media (max-width: 1023px) {
        .cart--select select, .cart #itemSelect select {
          padding-right: 0;
          font-size: 1.2rem; } }
    .cart--select .selectbox, .cart #itemSelect .selectbox {
      width: 100%;
      max-width: 30rem;
      position: relative;
      color: #1E1E1E; }
      .cart--select .selectbox::after, .cart #itemSelect .selectbox::after {
        content: "";
        width: 1rem;
        height: 1rem;
        border-right: 1px solid #1E1E1E;
        border-bottom: 1px solid #1E1E1E;
        position: absolute;
        right: 2rem;
        top: 50%;
        transform: translateY(-50%) rotate(45deg);
        pointer-events: none;
        color: #333;
        margin-top: -0.3rem; }
      .cart--select .selectbox select, .cart #itemSelect .selectbox select {
        width: 100%;
        padding: 1.5rem 6.7rem 1.5rem 2rem;
        font-size: max(1.3rem, 15px);
        border: 1px solid #ddd;
        background: #fff;
        appearance: none;
        -webkit-appearance: none;
        -moz-appearance: none;
        cursor: pointer;
        box-sizing: border-box; }
        @media (max-width: 1023px) {
          .cart--select .selectbox select, .cart #itemSelect .selectbox select {
            padding-right: 0;
            font-size: 1.2rem; } }
      .cart--select .selectbox--min, .cart #itemSelect .selectbox--min {
        max-width: 10rem; }

/******************************************************************************
.otherlist
*******************************************************************************/
.otherlist {
  border-top: 1px solid #E6E5E5;
  border-bottom: 1px solid #E6E5E5;
  padding: 4rem 0; }
  @media (max-width: 1023px) {
    .otherlist {
      margin-left: 2rem;
      margin-right: 2rem; } }

#search {
  bottom: 0; }

#baseMenu {
  display: none; }

#search.searchbox {
  max-width: 40rem;
  background: none;
  display: none;
  transition: all 0.3s ease;
  position: absolute;
  top: 60px !important;
  right: 0;
  height: 100px !important;
  padding: 0 !important; }
  #search.searchbox.is-open {
    display: block !important; }
  #search.searchbox input[type="text"] {
    max-width: 20rem; }
  #search.searchbox .itemSearch__btn {
    cursor: pointer; }

body .appsItemDetailCustom_rwtW4uzk #appsItemDetailCustomTag .appsItemDetailCustomTag_description,
body .appsItemDetailCustom_rwtW4uzk #appsItemDetailCustomTag .appsItemDetailCustomTag_heading,
.singlepage .price {
  font-weight: 400;
  font-size: max(1.4rem, 16px);
  line-height: 2.4;
  letter-spacing: .1em;
  margin: 2rem 0; }
  @media (max-width: 1023px) {
    body .appsItemDetailCustom_rwtW4uzk #appsItemDetailCustomTag .appsItemDetailCustomTag_description,
    body .appsItemDetailCustom_rwtW4uzk #appsItemDetailCustomTag .appsItemDetailCustomTag_heading,
    .singlepage .price {
      padding: 0;
      margin-bottom: 1rem;
      font-size: 1.2rem; } }

.singlepage .price {
  margin-top: 0; }
  @media (max-width: 768px) {
    .singlepage .price {
      padding: 0 2rem; } }
  .singlepage .price .discount {
    color: #e74c3c;
    font-size: 90%;
    padding-left: 1rem; }
.singlepage .endOfSale {
  color: #e74c3c;
  font-size: max(1.4rem, 16px); }
  @media (max-width: 768px) {
    .singlepage .endOfSale {
      padding: 0 2rem; } }

body .appsItemDetailCustom_rwtW4uzk #appsItemDetailCustomTag .appsItemDetailCustomTag_description:last-of-type {
  margin-bottom: 0; }

body .appsItemDetailCustom_rwtW4uzk #appsItemDetailCustomTag .appsItemDetailCustomTag_heading {
  font-size: max(1.6rem, 18px);
  margin: 2rem 0 4rem; }

.modal-btn {
  cursor: pointer;
  transition: 0.3s ease-in-out; }
  .modal-btn:hover {
    opacity: .75; }

.modal {
  position: fixed;
  inset: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 1000;
  pointer-events: none;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease; }

.modal-inner {
  background: #fff;
  padding: 4rem;
  max-width: 80rem;
  max-height: 80%;
  overflow-y: auto;
  border-radius: 8px;
  transform: translateY(30px);
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.3s ease;
  position: relative;
  z-index: 1;
  pointer-events: auto; }
  @media (max-width: 768px) {
    .modal-inner {
      max-width: 90%;
      max-height: 70%;
      padding: 5%; } }
  .modal-inner h3 {
    font-size: max(1.4rem, 16px);
    margin-bottom: 1rem; }
    @media (max-width: 768px) {
      .modal-inner h3 {
        font-size: 1.4rem; } }
  .modal-inner p {
    font-size: max(1.2rem, 14px); }
    @media (max-width: 768px) {
      .modal-inner p {
        font-size: 1.2rem; } }
  .modal-inner ul li {
    font-size: max(1.2rem, 14px);
    margin-bottom: 1rem;
    line-height: 1.8;
    list-style: disc outside;
    margin-left: 2.2rem; }
    @media (max-width: 768px) {
      .modal-inner ul li {
        font-size: 1.2rem; } }
  .modal-inner .notelist {
    /* border-top: 1px solid #E6E5E5;
    padding-top: rem(20);
    margin-top: rem(20);*/ }
    .modal-inner .notelist ul li {
      list-style: none;
      margin-left: 0; }

.modal-overlay {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.6);
  cursor: pointer; }

.modal-close {
  position: absolute;
  top: 2rem;
  right: 2rem;
  font-size: 24px;
  cursor: pointer;
  line-height: 1; }

/* チェック時に表示状態へ（開くアニメーション） */
.modal-toggle:checked + .modal {
  opacity: 1;
  visibility: visible;
  pointer-events: auto; }

.modal-toggle:checked + .modal .modal-inner {
  opacity: 1;
  transform: translateY(0); }

.report {
  display: none; }

input[type="email"] {
  margin-bottom: 0; }

p.noitemtxt {
  font-size: max(1.6rem, 18px);
  text-align: center;
  margin: 10rem auto; }

.related {
  margin-top: 10rem; }
  @media (max-width: 768px) {
    .related {
      margin-top: 5rem; } }

.collection--index.top {
  padding-top: 10rem; }
  @media (max-width: 768px) {
    .collection--index.top {
      padding-top: 0; } }
  .collection--index.top .archivenavbox {
    margin-bottom: 20rem; }
    @media (max-width: 768px) {
      .collection--index.top .archivenavbox {
        margin-bottom: 20rem; } }

body .main #about > .blog_inner {
  padding-top: 5%; }
body .main #about .blog_body h3 {
  text-align: left;
  font-family: var(--basefont) !important;
  font-weight: 500 !important; }
  @media (max-width: 768px) {
    body .main #about .blog_body h3 {
      font-size: 1.6rem; } }
body .main #about .blog_inner .social, body .main #about.blogDetail .blog_publish {
  display: none !important; }
body .main #about.blogDetail .blog_title h2 {
  line-height: 1.8;
  font-family: var(--enfont);
  font-weight: 400;
  font-size: max(3.6rem, 34px);
  letter-spacing: .1em;
  text-align: center; }
  @media (max-width: 768px) {
    body .main #about.blogDetail .blog_title h2 {
      font-size: 2.4rem; } }
  body .main #about.blogDetail .blog_title h2 a {
    pointer-events: none; }

.stockists {
  width: 100%;
  max-width: 98.2rem;
  margin: auto;
  font-family: var(--basefont) !important;
  font-size: max(1.4rem, 16px) !important; }
  @media (max-width: 768px) {
    .stockists {
      max-width: none;
      padding-left: 0;
      padding-right: 0;
      width: auto;
      font-size: max(1rem, 12px) !important; } }
  @media (max-width: 768px) {
    .stockists .stockists--title {
      font-size: max(1rem, 12px) !important; } }
  .stockists--list {
    border-bottom: 1px solid #E6E5E5;
    padding-bottom: 2rem; }
    .stockists--list:not(:last-child) {
      margin-bottom: 2rem; }
  .stockists--title {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: space-between;
    box-sizing: border-box;
    padding: 0rem 2rem 0;
    font-weight: 500;
    font-size: max(1.4rem, 16px);
    letter-spacing: .1em; }
    @media (max-width: 768px) {
      .stockists--title {
        padding-left: 1.5rem;
        padding-right: 1.5rem;
        padding-bottom: 0;
        font-size: 1.2rem; } }
    .stockists--title .iconarrow {
      display: block;
      width: 1rem;
      height: 1rem;
      border-top: 1px solid #1E1E1E;
      border-right: 1px solid #1E1E1E;
      transform: rotate(135deg);
      transition: transform 0.3s ease; }
      @media (max-width: 768px) {
        .stockists--title .iconarrow {
          width: 0.7rem;
          height: 0.7rem;
          margin-top: -0.4rem; } }
    .stockists--title.is-active .iconarrow {
      transform: rotate(-45deg); }
    .stockists--title .text {
      padding-right: 2rem; }
  .stockists--subbox--list {
    width: 100%;
    max-width: calc(100% / 2 - 1.5rem); }
    @media (max-width: 768px) {
      .stockists--subbox--list {
        max-width: none; } }
    .stockists--subbox--list .txt {
      display: flex;
      align-items: center;
      gap: 2rem; }
      @media (max-width: 768px) {
        .stockists--subbox--list .txt {
          font-size: 1.2rem; } }
      .stockists--subbox--list .txt img {
        vertical-align: middle; }
  .stockists .subbox {
    padding: 0 4rem 0;
    max-height: 0;
    overflow: hidden;
    transition: max-height 0.4s ease;
    font-weight: 400;
    font-size: max(1.4rem, 16px);
    line-height: 2.4;
    letter-spacing: .1em; }
    @media (max-width: 768px) {
      .stockists .subbox {
        padding: 0 1.5rem 0;
        font-size: 1.2rem; } }
    .stockists .subbox a {
      text-decoration: underline; }
    .stockists .subbox ul {
      display: flex;
      align-items: flex-start;
      justify-content: flex-start;
      flex-wrap: wrap;
      gap: 1.5rem;
      margin-top: 2rem; }
      @media (max-width: 768px) {
        .stockists .subbox ul {
          display: block; }
          .stockists .subbox ul li:not(:last-child) {
            margin-bottom: 1rem; }
          .stockists .subbox ul img {
            width: 2rem; } }
    .stockists .subbox p {
      white-space: normal;
      word-break: break-word;
      overflow-wrap: break-word;
      margin-top: 2rem;
      line-height: 2; }
      .stockists .subbox p:not(:last-of-type) {
        margin-bottom: 3rem; }
      @media (max-width: 768px) {
        .stockists .subbox p font, .stockists .subbox p span {
          font-size: max(1rem, 12px) !important; } }

.main #about .blog_body p.text {
  font-size: 16px;
  line-height: 2.4; }
  @media (max-width: 768px) {
    .main #about .blog_body p.text {
      font-size: 1.2rem; } }

.main #about > .blog_inner {
  margin-bottom: 10rem; }
  @media (max-width: 768px) {
    .main #about > .blog_inner {
      margin-bottom: 5rem; } }

/* 罫線ありテスト */
#wrapper .brand--index, #wrapper .about--index {
  border-bottom: 1px solid #E6E5E5; }
@media (max-width: 768px) {
  #wrapper .brand--index {
    margin-bottom: 6rem;
    padding: 10rem 0 6rem; } }
#wrapper .about--index {
  padding: 15rem 0; }
  @media (max-width: 768px) {
    #wrapper .about--index {
      padding: 0 0 6rem;
      margin-bottom: 20rem; } }

body#contact .inquirySection {
  padding-top: 5%; }
  body#contact .inquirySection h1 {
    font-family: var(--enfont);
    font-weight: 400;
    font-size: max(3.6rem, 34px);
    line-height: 1;
    letter-spacing: .1em;
    text-align: center; }
    @media (max-width: 768px) {
      body#contact .inquirySection h1 {
        font-size: 2.4rem; } }

p.attention {
  display: none; }
  p.attention.deliveryShortestDay {
    display: block; }

body .main #about .blog_body .stockists--title, body .main #about .blog_body p, body .main #about .blog_body h3, body .main #about .blog_body font, body .main #about .blog_body span {
  font-family: var(--basefont) !important; }

body .waitingForSale, body .endOfSale {
  text-align: left; }

.linktxt {
  position: relative;
  padding-left: 1.8rem; }
  .linktxt:before, .linktxt:after {
    content: "";
    width: 1.2rem;
    height: 0.8rem;
    background: url(../images/common/icon-arrow.svg) no-repeat center center/contain;
    display: inline-block;
    top: calc(50% - 6px);
    margin-top: 0.2rem;
    left: 0;
    position: absolute;
    transition: .2s ease-in; }
    @media (max-width: 1023px) {
      .linktxt:before, .linktxt:after {
        /* margin-top: 0; */ } }
  .linktxt:before {
    top: calc(50% - 3px); }
  .linktxt:after {
    background-position: -1.2rem top;
    transition: .2s ease-out;
    top: calc(50% - 7px); }
  .linktxt--sp {
    display: none; }
    @media (max-width: 1023px) {
      .linktxt--sp {
        display: inline-block; } }
  @media (max-width: 1023px) {
    .linktxt--pc {
      display: none; } }
  .linktxt:hover:before {
    background-position: 1.2rem top; }
  .linktxt:hover:after {
    background-position: left top; }

a:hover .linktxt:before {
  background-position: 1.2rem top; }
a:hover .linktxt:after {
  background-position: left top; }

.linktxt--prev:before, .linktxt--prev:after {
  transform: rotate(180deg);
  top: calc(50% - 6px); }

.linktxt--next:before, .linktxt--next:after {
  left: auto;
  right: 0; }

.moretxt, button.moretxt {
  display: inline-block;
  text-align: center;
  margin-top: 6rem;
  font-family: var(--enfont) !important;
  font-weight: 400;
  font-size: max(1.4rem, 16px);
  line-height: 1;
  letter-spacing: .1em;
  position: relative;
  cursor: pointer;
  background: none;
  border: none; }
  @media (max-width: 768px) {
    .moretxt, button.moretxt {
      margin-top: 4rem;
      font-size: 1.4rem; } }
  .moretxt:after, .moretxt:before, button.moretxt:after, button.moretxt:before {
    content: "";
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: -2.5rem;
    width: 1.6rem;
    height: 0.9rem;
    background: url(../images/common/icon-arrow-bottom.svg) no-repeat center center/contain;
    transition: .2s ease-out; }
    @media (max-width: 768px) {
      .moretxt:after, .moretxt:before, button.moretxt:after, button.moretxt:before {
        bottom: -1.5rem; } }
  .moretxt:before, button.moretxt:before {
    background-position: center -0.9rem;
    transition: .2s ease-out; }
  .moretxt:hover:before, button.moretxt:hover:before {
    background-position: center top; }
  .moretxt:hover:after, button.moretxt:hover:after {
    /* bottom: rem(-30); */
    background-position: center 0.9rem; }

p.close-text {
  font-size: max(1.6rem, 18px);
  text-align: center;
  margin: 10rem auto; }

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