@charset "UTF-8";

/* -----------------------------------------------------------
   闇市パスワード入力画面
----------------------------------------------------------- */
#sysItemDetail .sysYamiForm {
  width:1200px;
  margin: 0 auto;
  padding: 80px 0 100px 0;
}
#sysItemDetail .sysYamiForm input[value=送信] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: 20px auto 0 auto;
}
@media screen and (max-width: 768px) {
  #sysItemDetail .sysYamiForm {
  width:94%;
  margin: 0 auto;
 }
}
/* -----------------------------------------------------------
   お知らせ
----------------------------------------------------------- */
.r_notice1 {
  padding: 0;
  margin: 0 0 30px 0;
  width: 100%;
  background-color: transparent; 
}
.r_notice1 a {
  color: #418f94;
  text-decoration: underline;
  font-weight: bold;
}
.r_notice1 a:hover {
  opacity: 0.8;
}
.r_notice1__inner {
  background-color: #fff; 
border:1px solid #39b29a;
  width: 100% !important;
  max-width: 75rem !important; 
  margin: 0 auto !important; 
  padding: 3px 3px 3px 3px;
  text-align: center;
  box-sizing: border-box;
  border-radius: 10px; 
}
.r_notice1__title {
  font-size: clamp(1rem, 2vw, 1rem); 
  font-weight: bold;
  color: #333;
  margin-bottom: 0.5rem;
  letter-spacing: 0.05em;
  background: #ebf4f5;
  padding: 8px;
  display: flex;
  align-items: center;
  justify-content: center; /* 中央揃えを維持 */
  gap: 8px; /* アイコンと文字の間隔 */
}
.r_notice1__title::before {
  content: "";
  display: inline-block;
  width: 1.2rem; /* 文字サイズに合わせて調整 */
  height: 1.2rem;
  background-image: url('/img/web/info_icon.svg'); /* ←画像パスを差し替えてください */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0; /* アイコンが潰れないように固定 */
}
.r_notice1__title span {
  color: #418f94;
}
.r_notice1__text {
  font-size: 0.875rem; 
  color: #555;
  margin-bottom: 1.2rem;
}
.r_notice1__btns {
  display: flex;
  justify-content: center;
  gap: 1.5rem;
}
.r_notice1__btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(13rem, 100%); 
  height: 2.8rem;
  background-color: #428f94;
  color: #fff !important;
  text-decoration: none;
  font-weight: bold;
  font-size: 0.9rem;
  border-radius: 2px;
  transition: opacity 0.3s;
}
.r_notice2 {
  padding: 0;
  margin: 0 0 30px 0;
  width: 100%;
  background-color: transparent; 
}
.r_notice2__inner {
  background-color: #fff; 
border:1px solid #39b29a;
  width: 100% !important;
  max-width: 75rem !important; 
  margin: 0 auto !important; 
  padding: 3px;
  text-align: center;
  box-sizing: border-box;
  border-radius: 10px; 
}
.r_notice2__title {
  font-size: clamp(1rem, 2vw, 1rem); 
  font-weight: bold;
  color: #333;
  letter-spacing: 0.05em;
  background: #ebf4f5;
  padding: 8px;
  display: flex;
  align-items: center;
  justify-content: center; /* 中央揃えを維持 */
  gap: 8px; /* アイコンと文字の間隔 */
}
.r_notice2__title::before {
  content: "";
  display: inline-block;
  width: 1.2rem; /* 文字サイズに合わせて調整 */
  height: 1.2rem;
  background-image: url('/img/web/info_icon.svg'); /* ←画像パスを差し替えてください */
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0; /* アイコンが潰れないように固定 */
}
/* 新規会員登録、ログイン */
@media (max-width: 768px) {
  #sysMemberRegisterIndex .r_notice1__inner,
  #sysMypageLogin .r_notice1__inner {
  width: 100% !important;
  }
  #sysMemberRegisterIndex .r_notice1,
  #sysMypageLogin .r_notice1 {
 padding-top: 0 !important;
  }
  }
/* スマホ最適化 */
@media (max-width: 768px) {
  .r_notice1__inner {
  width: 94% !important;
  }
.r_notice1__title {
    font-size: 14px;
    padding: 10px; /* スマホでは少し高さを出すと押しやすく見えます */
    justify-content: flex-start; /* スマホでテキストが左寄せならここも左寄せがおすすめ */
    text-align: left;
  }
  .r_notice1 {
    padding: 15px 0;
    margin-bottom:15px;
  }
  .r_notice1__inner {
    padding: 15px 2%; 
    text-align: left;
  }
  .r_notice1__btns {
    align-items: center;
    gap: 12px;
  }
  .r_notice1__btn {
    width: 100%;
    max-width: 280px;
  }
　.r_notice1__text {text-align:left !important; margin-bottom: 0.5rem;}
  .r_notice1__title { font-size:14px;}
  #contractor .r_notice1 { margin-bottom: 0;}
  }
/* -----------------------------------------------------------
   会員登録とショッピングページの利用規約
   ----------------------------------------------------------- */
#sysMemberRegisterIndex .sysMemberAgreement .txt_before {
display: none !important;
}

/* 規約全体 */
.kiyaku-wrapper {
    line-height: 1.8;
    color: #333;
    max-width: 1000px;
    margin: 0 auto;
    padding: 20px;
}

/* 第〇条（見出し） */
.kiyaku-wrapper dt {
    margin-top: 30px;
    margin-bottom: 10px;
}

.kiyaku-wrapper dt b {
    font-size: 1.1rem;
}

/* リスト全体のリセット */
.kiyaku-wrapper dd,
.kiyaku-wrapper ul {
    margin: 0;
    padding: 0;
    list-style: none; /* 標準のポッチは消す */
}

/* （１）の階層：ぶら下げインデント */
.kiyaku-wrapper ul.level-1 > li {
    padding-left: 1.5em; /* 全体を右に寄せる */
    text-indent: -1.5em; /* 1行目だけ左に戻す */
    margin-bottom: 0.5em;
}

/* （a）の階層：さらに深くする */
.kiyaku-wrapper ul.level-2 {
    margin-top: 5px;
    margin-left: 1.5em;
}

.kiyaku-wrapper ul.level-2 > li {
    padding-left: 2em; /* 全体を右に寄せる */
    text-indent: -2em; /* 1行目だけ左に戻す */
    margin-bottom: 3px;
}

/* 計算式などのボックス */
.calculation-box {
    margin: 15px 0 30px 2.5em;
    padding: 15px;
    background: #f9f9f9;
    border: 1px solid #eee;
    font-size: 0.95em;
}
@media screen and (max-width: 768px) {
  .kiyaku-wrapper {
    padding: 0;
  }
}
/* -----------------------------------------------------------
   見積ボタン（見積書エリアの中にあるセカンダリボタンだけに限定）
   ----------------------------------------------------------- */

/* ボタンを包む親要素 */
.sysCheckoutBasketEstimate {
    margin-top: 15px !important;
}

/* 見積ボタンエリアの中にある .sysCheckoutButtonSecondary だけに適用 */
.sysCheckoutBasketEstimate .sysCheckoutButtonSecondary {
    border: 1px solid #666 !important;
}

/* ボタン内部のレイアウト調整 */
.sysCheckoutBasketEstimate .sysCheckoutButtonSecondary .sysCheckoutButtonContent {
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    padding: 0 50px !important;
}

/* テキストの前のアイコン設定 */
.sysCheckoutBasketEstimate .sysCheckoutButtonSecondary .sysCheckoutButtonContentText::before {
    content: "" !important;
    display: inline-block !important;
    width: 20px !important;
    height: 20px !important;
    background: url("/img/web/icon_mitsumori.png") no-repeat center center / contain !important;
    margin-right: 8px !important;
    flex-shrink: 0 !important;
    vertical-align: middle !important;
    vertical-align: -4px !important;
}

/* --- スマホ表示設定 --- */
@media screen and (max-width: 768px) {
    .sysCheckoutBasketEstimate {
        margin-bottom: 15px !important;
        margin-top: 0.75rem !important;
    }

    /* 見積エリア内のボタンを横幅いっぱいにする */
    .sysCheckoutBasketEstimate .sysCheckoutButtonSecondary {
        width: 100% !important;
        max-width: none !important;
    }

    .sysCheckoutBasketEstimate .sysCheckoutButtonSecondary .sysCheckoutButtonContent {
        padding: 5px 0 !important;
        font-size: 13px !important;
        margin-bottom: 0px; /* ここにマージンがあるとボタンがズレる場合があるので調整 */
    }
}
/* -----------------------------------------------------------
   コラムセクション
   ----------------------------------------------------------- */
.r_column_btn {
  margin-bottom: 80px !important;
}
.r_blog_new {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto 30px auto;
}
.r_blog_new h2 {
  margin-bottom: 5px;
}
.r_blog_new .sysFuncRss.r_blog_new .sysHeadline {
    display: flex;
    align-items: center;
    margin-bottom: 20px;
    padding-left: 10px;
}
.r_blog_new .sysRss {
    list-style: none;
    padding: 0;
    margin: 0;
    border-top: 1px solid #e0e0e0;
}
.r_blog_new .sysRssItem {
    position: relative;
    border-bottom: 1px solid #e0e0e0;
}
.r_blog_new .sysRssItem {
    display: flex !important;
    align-items: center !important;
    padding: 20px 40px 20px 40px !important; /* 右側に矢印用の余白 */
    transition: background-color 0.3s;
}
.r_blog_new .sysRssItem:hover {
    background-color: #f9f9f9;
}
.r_blog_new .sysRssPubDate {
    flex-shrink: 0;
    width: 100px; /* 日付の幅を固定 */
    font-size: 14px;
    margin: 0 !important;
    order: 1; /* 配置順序を1番目に */
}
.r_blog_new .sysRssTitle {
    flex-grow: 1;
    font-size: 16px;
    margin: 0 !important;
    order: 2; /* 配置順序を2番目に */
    padding-left: 20px; /* 日付との間の余白 */
}
.r_blog_new .sysRssTitle a {
    text-decoration: none;
    color: #4b807a;
    display: block;
}
.r_blog_new .sysRssItem::after {
    content: "";
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%) rotate(45deg);
    width: 8px;
    height: 8px;
    border-top: 1px solid #ccc;
    border-right: 1px solid #ccc;
}
@media (max-width: 768px) {
    .r_column_btn {
        margin-bottom: 40px !important;
    }
    .r_blog_new {
        width: 94%;
    }
    .r_blog_new h2.tit_icon {
      margin-top: 0 !important;
    }
    .r_blog_new .sysRssItem {
        padding: 15px 30px 15px 10px !important;
    }
    .r_blog_new .sysRssPubDate {
        width: 80px; /* スマホでは少し狭く */
        font-size: 12px;
    }
    .r_blog_new .sysRssTitle {
        padding-left: 10px;
        font-size: 14px;
        line-height: 1.4;
    }
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
  返却フォーム
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
/* 返却したい商品名（sys2）の項目専用の指定 */
.form-return .sysFormItem.sys2 .sysFormField {
    line-height: 1.8; /* 行間を広げて読みやすくする */
}

/* リンクを強制的に1行使い切るブロック要素にする */
.form-return .sysFormItem.sys2 .sysFormField a {
    display: block !important;
    margin: 10px 0 !important; /* 上下に隙間を作る */
    word-break: break-all;      /* 長いURLがはみ出さないようにする */
    text-decoration: underline;
}

/* 「のみ。」の後に隙間を作りたい場合（疑似要素で改行を作る） */
.form-return .sysFormItem.sys2 .sysFormField textarea::before {
    content: "";
    display: block;
    margin-top: 10px;
}
/* 希望日のラベルを目立たせる */
.form-return .sys10 .sysFormLabel,
.form-return .sys12 .sysFormLabel,
.form-return .sys14 .sysFormLabel {
    font-weight: bold;
    color: #333;
}
.form-return .sys10,
.form-return .sys12,
.form-return .sys14 {
  margin-bottom: 10px !important;
}

/* 各セットの区切り（希望時間の項目の下にラインを引く） */
.form-return .sys11, 
.form-return .sys13, 
.form-return .sys15 {
    border-bottom: 2px solid #ddd; /* 薄いグレーの線 */
    padding-bottom: 20px !important;
    margin-bottom: 20px !important;
}

/* 最後のセットの線は不要な場合（お好みで） */
.form-return .sys15 {
    border-bottom: none;
}

/* スマホ等で余白が詰まって見える場合の調整 */
.form-return .sysFormItem {
    padding-top: 10px;
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
  新規会員登録　確認画面
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
/* -----------------------------------------------------------
   カートに進む時の会員登録で性別、FAX、生年月日を削除
   ----------------------------------------------------------- */
body.sysCheckoutBody .sysCheckoutField:has(.sysCheckoutMemberRegistrationFieldFax) {
    display: none !important;
}
body.sysCheckoutBody .sysCheckoutMemberRegistrationFieldGender {
    display: none !important;
}
body.sysCheckoutBody .sysCheckoutMemberRegistrationFieldBirthday {
    display: none !important;
}

/* 完全に消さず、1pxの点として残す */
#sysMemberRegisterIndex .sysFax,
#sysMemberRegisterIndex .sysGender,
#sysMemberRegisterIndex .sysBirthday,
#sysDone .sysFax,
#sysDone .sysGender,
#sysDone .sysBirthday {
    all: revert !important; /* 一旦スタイルを戻す */
    display: block !important;
    width: 1px !important;
    height: 1px !important;
    overflow: hidden !important;
    opacity: 0.01 !important; /* ほぼ透明 */
    position: absolute !important;
    left: -9999px !important; /* 画面の外に飛ばす */
    border: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* ラベルや中の文字も強制的に小さくする */
#sysMemberRegisterIndex .sysFax *,
#sysMemberRegisterIndex .sysGender *,
#sysMemberRegisterIndex .sysBirthday *,
#sysDone .sysFax *,
#sysDone .sysGender *,
#sysDone .sysBirthday * {
    font-size: 0 !important;
    line-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
}

#sysMemberRegisterIndex .sysBackButton {
  margin-bottom: 60px !important;
}

/* 戻るボタンが含まれるフォームの下に余白を作る */
.sysMemberRegister #sysMain form:last-of-type {
    margin-bottom: 60px !important;
}

/* スマホ用の設定（画面幅767px以下の場合） */
@media screen and (max-width: 767px) {
    .sysMemberRegister #sysMain form:last-of-type {
        margin-bottom: 40px !important;
    }
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
  パスワードリセットページ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */

/* パスワード再設定ボタンのカスタマイズ */
input[name="submit"].sysRemindSubmit, /* クラスがある場合 */
.sysRemindForm input[type="submit"] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

/* ホバー（マウスを乗せた時）の反応 */
.sysRemindForm input[type="submit"]:hover {
    opacity: 0.8;
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
  404ページ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */

/* 404ページ全体の余白調整 */
.page-404 #sysMain {
    padding: 100px 20px;
    text-align: center;
}

/* メッセージのスタイル */
.page-404 .error-message {
    font-size: 1.2rem;
    margin-bottom: 30px;
    line-height: 1.6;
}

/* 「トップへ戻る」ボタンのデザイン */
.page-404 .btn-back-home {
    display: inline-block;
    background-color: #333; /* サイトのテーマカラーに合わせて */
    color: #fff;
    padding: 15px 40px;
    text-decoration: none;
    border-radius: 30px;
    transition: 0.3s;
}

.page-404 .btn-back-home:hover {
    opacity: 0.8;
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
  マイページ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
#sysMypageIndex #sysMain,
#sysMypageRepeat #sysMain,
#sysMypageWithdrawalConfirm #sysMain,
#sysMypageLogin #sysMain,
#sysMypageReminder #sysMain,
#sysMypageEditMember #sysMain,
#sysMypageEditDelivery #sysMain,
#sysMypageMessageCard #sysMain,
#sysMypageAshiato #sysMain,
#sysMypageOrderHistory #sysMain,
#sysMypageReview #sysMain,
#sysMypageLogout #sysMain,
#sysMypageEditDeliveryinput #sysMain,
#sysFormConfirm #sysMain,
#sysFormThanks #sysMain,
#sysMypageEditConfirm #sysMain,
#sysMypageEditSave #sysMain {
padding-bottom:80px;
}
@media screen and (max-width: 768px) {
  #sysMypageIndex #sysMain,
  #sysMypageRepeat #sysMain,
  #sysMypageWithdrawalConfirm #sysMain,
  #sysMypageLogin #sysMain,
  #sysMypageReminder #sysMain,
  #sysMypageEditMember #sysMain,
  #sysMypageEditDelivery #sysMain,
  #sysMypageMessageCard #sysMain,
  #sysMypageAshiato #sysMain,
  #sysMypageOrderHistory #sysMain,
  #sysMypageReview #sysMain,
  #sysMypageLogout #sysMain {
  padding-bottom:40px;
  }
}
/* マイページの見出しカスタマイズ */
.sysMypage h1.title-medium-sub {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    font-size: 28px !important;
    font-weight: bold !important;
    color: #333 !important;
    border: none !important;
    margin-bottom: 30px !important;
}
.sysMypage h1.title-medium-sub span {
    display: none !important;
}
.sysMypage h1.title-medium-sub::after {
    content: "" !important;
    display: block !important;
    width: 10px !important;    /* ドットの大きさ */
    height: 10px !important;
    background-color: #799496 !important; /* 画像のくすみカラー */
    border-radius: 50% !important;        /* 正円にする */
    margin-top: 15px !important;          /* 文字との間隔 */
}
.sysMypage form[action*="cartIn"] {
    text-align: left;
}
/* -----------------------------------------------------------
   マイページへログイン画面
   ----------------------------------------------------------- */


/* 登録ボタン（sysLoginButton）のカスタマイズ */
#sysMypageLogin .sysLoginButton {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border-radius: 0;
    background-image: none;
    display: block;
    width: 100%;             /* 横幅いっぱいに広げる（親のmax-widthに従う） */
    max-width: 400px;        /* ボタンの最大幅（適宜調整してください） */
    height: 60px;            /* ボタンの高さ */
    margin: 20px auto;       /* 上下に余白を作り、左右中央に配置 */
    background-color: #333333; /* 背景色（画像に近い濃いグレー） */
    color: #ffffff !important; /* 文字色（白：iPhone対策で!importantを推奨） */
    font-size: 18px;         /* 文字サイズ */
    font-weight: bold;       /* 太字 */
    line-height: 60px;       /* 文字を垂直方向の中央に */
    text-align: center;      /* 文字を水平方向の中央に */
    border: none;            /* 枠線を消す */
    border-radius: 30px;     /* 高さを60pxにしているので、30pxで綺麗な半円になります */
    cursor: pointer;
    transition: opacity 0.2s; /* ホバー時の演出用 */
    
    /* --- iPhone対策：文字を確実に表示させるための指定 --- */
    opacity: 1 !important;
    visibility: visible !important;
}

/* ホバー（マウスを乗せた時）の演出 */
#sysMypageLogin .sysLoginButton:hover {
    opacity: 0.8;
}
/* -----------------------------------------------------------
   マイページへログイン画面のパスワードを忘れた場合ボタンがiPhoneで消えるのを解消
   ----------------------------------------------------------- */
form[action*="reminder.html"] .sysButton,
form[action*="reminder.html"] input[type="submit"] {
    -webkit-appearance: none !important;
    appearance: none !important;
    visibility: visible !important;
    opacity: 1 !important;
    display: block !important;
    color: #333333 !important;           /* 文字の色 */
    min-height: 40px !important;
    width: 100% !important;
    text-indent: 0 !important; /* 文字がどっかに飛ばないように */
}

form[action*="reminder.html"] {
    background: transparent !important;
    display: block !important;
    visibility: visible !important;
}
/* -----------------------------------------------------------
   マイページナビ：デザイン上書き
   ----------------------------------------------------------- */

/* 【1】ボタンを2列に並べる設定 */
.sysMypage #sysWrap #sysMain .sysMypageNav {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important; /* 2列にする */
    gap: 16px 12px !important;                 /* ボタン同士の隙間 */
    margin-top: 40px !important;
}

/* 各フォームの幅をリセット（gridで制御するため） */
.sysMypage #sysWrap #sysMain .sysMypageNav form {
    width: 100% !important;
}

/* 【2】ボタン本体のデザイン（白い背景・黒い枠・角丸） */
.sysMypage .sysMypageNav .sysButton {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important; /* テキストを左寄せ */
    width: 100% !important;
    height: 64px !important;               /* ボタンの高さ */
    padding: 0 40px 0 60px !important;     /* 左にアイコン分、右に矢印分の余白 */
    background: #ffffff !important;
    border: 1px solid #333333 !important;  /* 黒い枠線 */
    border-radius: 10px !important;        /* 楕円の角丸 */
    font-size: 15px !important;
    font-weight: 700 !important;
    color: #333333 !important;
    position: relative !important;
    cursor: pointer !important;
    box-sizing: border-box !important;
}

/* 【3】右側の矢印「＞」を全ボタンに共通で作成 */
.sysMypage .sysMypageNav form::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 20px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #333333;
    border-right: 2px solid #333333;
    transform: translateY(-50%) rotate(45deg);
    pointer-events: none;
    z-index: 5;
}

/* 【4】左側のアイコンを配置するための準備 */
.sysMypage .sysMypageNav form {
    position: relative !important;
}

.sysMypage .sysMypageNav form::before {
    content: "";
    position: absolute;
    left: 20px;
    top: 50%;
    transform: translateY(-50%);
    width: 24px;
    height: 24px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    z-index: 5;
    pointer-events: none;
}

@media (max-width: 767px) {
    .sysMypage #sysWrap #sysMain .sysMypageNav {
        grid-template-columns: 1fr !important; /* 1列にする */
        gap: 12px !important;
    }
    .sysMypage .sysMypageNav .sysButton {
        height: 56px !important;
        font-size: 14px !important;
    }
    /* 【1】Grid（2列）を解除して、1つの外枠にする */
    .sysMypage #sysWrap #sysMain .sysMypageNav {
        display: block !important;       /* grid解除 */
        border: 1px solid #333 !important; /* 外枠の黒線 */
        border-radius: 15px !important;    /* 角丸を少し強めに */
        overflow: hidden !important;
        background: #fff !important;
        gap: 0 !important;                /* 隙間をなくす */
        padding: 0 !important;
        margin-top: 20px !important;
    }

    /* 【2】各項目の枠線とアイコン設定の打ち消し */
    .sysMypage #sysWrap #sysMain .sysMypageNav form {
        border-bottom: 1px solid #e0e0e0 !important;
        margin: 0 auto !important;
        width: 90% !important;
    }
    .sysMypage #sysWrap #sysMain .sysMypageNav form:last-child {
        border-bottom: none !important;
    }
    .sysMypage .sysMypageNav form::before {
        display: none !important;
    }
    .sysMypage .sysMypageNav .sysButton {
        height: auto !important;
        min-height: 60px !important;
        padding: 15px 40px 15px 20px !important;
        border: none !important;
        border-radius: 0 !important;
        background: transparent !important;
        font-size: 16px !important;
        justify-content: flex-start !important;
    }
    .sysMypage .sysMypageNav form::after {
        right: 20px !important;
        width: 10px !important;
        height: 10px !important;
        border-color: #999 !important;
    }
    .sysMypage h1.title-medium-sub {
    margin-bottom: 20px !important;
    }
}
/* -----------------------------------------------------------
   ★青いリンクボタンエリア
 ----------------------------------------------------------- */
.r_maypage_link .sysContent p {
  text-align: center !important;
  margin-bottom: 40px;
}
.r_maypage_link {
  width: 100%;
  max-width: 1200px;
  margin: 30px auto;
  padding: 0;
}
.r_maypage_link .custom-nav-grid {
  display: grid !important;
  grid-template-columns: repeat(2, 1fr) !important;
  gap: 12px !important;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
@media screen and (min-width: 768px) {
  .r_maypage_link .custom-nav-grid {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 20px !important;
  }
}
@media screen and (max-width: 768px) {
  .r_maypage_link .sysContent p {
  text-align: left !important;
  }
}
.r_maypage_link .custom-nav-link {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  background-color: #f1f7f6 !important;
  border: 1px solid #333333 !important;
  border-radius: 12px !important;
  box-shadow: 0 2px 5px rgba(0,0,0,0.05) !important;
  text-decoration: none !important;
  padding: 20px 10px !important;
  min-height: 160px !important;
  transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}
.r_maypage_link .custom-nav-link:hover {
  transform: translateY(-3px) !important;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1) !important;
  background: #d6f0f0 !important;
  opacity: 1;
}
.r_maypage_link .custom-nav-icon {
  margin-bottom: 10px;
}
.r_maypage_link .custom-nav-icon img {
  display: block;
  width: 50px;
  height: auto;
}
.r_maypage_link .custom-nav-title {
  font-size: 16px !important;
  font-weight: bold !important;
  color: #333 !important;
  margin-bottom: 6px !important;
  text-align: center !important;
  line-height: 1.2 !important;
}
.r_maypage_link .custom-nav-lead {
  font-size: 12px !important;
  color: #666 !important;
  text-align: center !important;
  line-height: 1.5 !important;
}
/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   カート
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ *
/* -----------------------------------------------------------
   ★カート共通
 ----------------------------------------------------------- */
 /* 全体の背景 */
.sysCheckoutBody #sysMain {
  background: #edf4f4 !important;
  padding: 40px 0 !important;
  margin-bottom: 0 !important;
}
.sysCheckoutProgressBar {
  background: #edf4f4 !important;
}
.sysCheckoutPrice {
  font-size: 24px !important;
}
.sysCheckoutMain {
  padding-bottom: 0 !important;
}
#r_cart_con sysCheckoutMain {
  width: 700px !important;
}
.sysCheckoutPageTitle {
  display: none !important;
}
.sysCheckoutHomeDeliveryForm .sysCheckoutHomeDeliveryComment {
  color: #222 !important;
}
.sysCheckoutThanksAreaContent {
  text-align: center !important;
  padding: 0 !important;
}
/* ショッピングカートの見出し全体（h1） */
#sysCheckout .sysCheckoutPageTitle.sysCheckoutHeading {
  border: none !important;
  padding-left: 0 !important; 
  text-align: center !important;
  display: block !important;
  position: relative !important;
  margin-bottom: 40px !important; 
  font-size: 24px !important; /* 少し小さめに */
  color: #333 !important;
  letter-spacing: 0.05em !important; /* 少し文字間を広げる */
}
#sysCheckout .sysCheckoutPageTitle.sysCheckoutHeading::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  bottom: -30px !important; /* 文字からの距離（画像に合わせる） */
  width: 8px !important;  /* ドットの大きさ */
  height: 8px !important; /* ドットの大きさ */
  background-color: #668888 !important; /* 画像のくすんだ緑青色 */
  border-radius: 50% !important; /* 完全な丸にする */
  display: block !important;
}
.sysCheckoutAreaFreeTop {
  margin-bottom: 15px !important;
}
.sysCheckoutAreaFreeTop a {
  text-decoration: underline !important;
  color: #948140 !important;
}
.sysCheckoutAreaContent .sysCheckoutBasketEmpty {
  border: none !important;
  box-shadow:none !important;
}
.sysCheckoutAreaContent .sysCheckoutFieldAgreementText a {
  text-decoration: underline;
  color: #418f94;
}
.sysCheckoutOrderCompleteSection {
  border: none !important;
  box-shadow:none !important;
}
@media screen and (max-width: 768px) {
  .sysCheckoutBody #sysMain {
  padding: 20px 3% 10px 3% !important;
  width: 100% !important;
  }
  .sysCheckoutBody .sysCheckout {
  margin: 0 auto !important;
  }
  #sysCheckout .sysCheckoutPageTitle.sysCheckoutHeading {
  margin-bottom: 40px !important; 
}
  .sysCheckoutBody #sysWrap #sysAside {
    display: block !important;
  }
}
/* -----------------------------------------------------------
   ★注文完了画面
 ----------------------------------------------------------- */
.sysCheckoutThanks .sysCheckoutOrderCompleteSection {
  border: none !important;
  text-align: center;
}
/* 1. 完了画面全体を中央揃えにする設定 */
.sysCheckoutThanks .sysCheckoutOrderCompleteSectionSuccess {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important; /* 横方向の中央揃え */
    text-align: center !important; /* テキストの中央揃え */
    padding-top: 20px !important; /* マークの上の余白 */
}
.sysCheckoutThanks .sysCheckoutOrderCompleteSectionThankYou::before {
    content: '' !important;
    display: block !important;
    background-image: url('/img/web/finish.svg') !important;
    background-repeat: no-repeat !important;
    background-position: center !important;
    background-size: contain !important; /* サイズに合わせて自動調整 */
    width: 80px !important;  /* マークの横幅（画像の緑丸のサイズ） */
    height: 80px !important; /* マークの高さ */
    margin: 0 auto 25px auto !important; /* マークの下（文字との間）の余白 */
}
.sysCheckoutThanks .sysCheckoutText {
    text-align: center !important; /* すべてのテキストを中央寄せ */
}
.sysCheckoutThanks .sysCheckoutOrderCompleteSectionThankYou {
    font-size: 22px !important; /* 少し大きく */
    font-weight: bold !important; /* 太字に */
    margin-bottom: 20px !important;
}
.sysCheckoutThanks .sysCheckoutOrderCompleteSectionOrderNumberLabel {
    font-size: 14px !important;
    color: #333 !important;
    margin-bottom: 5px !important;
}
.sysCheckoutThanks .sysCheckoutOrderCompleteSectionOrderNumberValue {
    font-size: 24px !important;
    color: #418f94 !important; /* 画像のような青緑色 */
    margin-top: 0 !important;
}
/* ----- 流れセクション ----- */
.r_cart_flow {
  padding: 60px 0;
}
.r_cart_flow .flow_tit {
  text-align: center;
  font-size: 26px;
  font-weight: bold;
  padding-bottom: 20px;
}
.r_cart_flow .flow_txt {
  text-align: center;
  padding-bottom: 20px;
}
@media screen and (max-width: 768px) {
  .r_cart_flow {
  padding: 20px 0;
  } 
  .r_cart_flow .flow_txt {
  width: 94%;
  margin: 0 auto;
  }
  .sysCheckoutThanks {
    width: 100% !important;
  }
  .sysCheckoutThanks .sysCheckoutOrderCompleteSection {
    padding: 0 !important;
  }
}


/* 数量選択エリアを強制横並び */
@media screen and (max-width: 640px) {
       .sysCheckoutFieldSelectInput.flex.items-center.gap-xs {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        align-items: center !important;
        gap: 4px !important;
    }
    .sysCheckoutFieldProductQuantityDecrement,
    .sysCheckoutFieldProductQuantityIncrement {
        flex-shrink: 0 !important;
        width: 36px !important; /* スマホ用に少しコンパクトに */
        height: 36px !important;
        padding: 0 !important;
    }
    .sysCheckoutFieldProductQuantity select {
        flex: 1 !important; /* 伸び縮みするように設定 */
        min-width: 60px !important;
        height: 36px !important;
        text-align: center;
    }
}
/* -----------------------------------------------------------
   ★注文確認画面
 ----------------------------------------------------------- */
.sysCheckoutPageFreeAreaTop {
  margin-top: -20px !important;
}
.sysCheckoutPageFreeAreaTop ul {
    display: inline-block !important;
    text-align: left !important;
    margin-top: 15px !important;
    padding-left: 0 !important;
    list-style: none !important;
}

/* リスト項目のインデント調整 */
.sysCheckoutPageFreeAreaTop ul li {
    position: relative !important;
    padding-left: 1.2em !important; /* 「・」の分だけ左に余白を作る */
    text-indent: -1.2em !important; /* 1行目だけ左に突き出させて「・」を配置 */
    margin-bottom: 8px !important;
    line-height: 1.6 !important;
}

.sysCheckoutConfirmArea .sysCheckoutAreaContent .sysCheckoutButtonPrimary {
  padding: 20px 0 !important;
  font-size: 20px !important;
}
.sysCheckoutConfirmSummaryRepeatInfo {
  display: none !important;
}
.sysCheckoutCheckoutSummaryArea .sysCheckoutDescriptionListItemTerm {
  margin-top: 10px !important;
}
@media screen and (max-width: 768px) {
  .sysCheckoutConfirmArea .sysCheckoutAreaContent .sysCheckoutButtonPrimary {
  padding: 15px 0 !important;
  font-size: 16px !important;
  }
  .sysCheckoutConfirmSummaryFooter .text-center {
    margin-top: 10px !important;
  }
  .sysCheckoutConfirm .sysCheckoutPageActions,
  .sysCheckoutBasket .sysCheckoutPageActions {
    margin-top: 0 !important;
  }
}
/* -----------------------------------------------------------
   ★カートになにも入ってない画面
 ----------------------------------------------------------- */
 @media screen and (max-width: 768px) {
   .sysCheckoutBasket .sysCheckoutBasketEmpty {
    padding: 0 !important;
   }
}

/* -----------------------------------------------------------
   ★情報入力画面
 ----------------------------------------------------------- */
.sysCheckoutPageActions {
  margin-bottom: 20px !important;
}
 /* 2つめのプルダウン（間隔選択）だけ背景色を変更 */
.sysCheckoutRepeatCycleFieldFreeInterval select {
    background-color: #fff2f2 !important;
    border-color: #ed8e8e !important; /* ついでに枠線も変えるとかわいいです */
}

/* 選択された時（フォーカス時）の色も変えたい場合 */
.sysCheckoutRepeatCycleFieldFreeInterval select:focus {
    background-color: #ffffff !important;
    outline: none !important;
}


.sysCheckoutRepeatCycleForm { 
  background: #f1eee5 !important;
  border-radius: 10px !important;
  border: 1px solid #988853 !important;
}
.sysCheckoutRepeatCycleForm .sysCheckoutRadioTile {
  border: none !important;
  background:none !important;
}
.sysCheckoutRepeatCycleForm p:first-of-type {
  display: none !important;
}
.sysCheckoutRepeatCycleTimesHeader {
  margin-left: 35px !important;
}
.sysCheckoutRepeatCycleFieldCourseTimes {
  margin: 0 0 20px 35px !important;
}
.sysCheckoutPageActions {
  padding-bottom: 30px !important;
}

/* タブレット・スマホ向けの調整（例：1024px以下） */
@media screen and (max-width: 1024px) {
  
  /* 1. 外側のマージンをリセットまたは縮小して「はみ出し」を防ぐ */
  .sysCheckoutRepeatCycleFieldCourseTimes {
    margin-left: 0 !important; /* 左マージンをなくす */
    margin-bottom: 20px !important;
    padding-left: 10px; /* 必要なら微調整用のパディングに変更 */
  }

  /* 2. セレクトボックスが親要素を突き破らないようにする */
  .sysCheckoutRepeatCycleFieldCourseTimes select {
    width: 100% !important;   /* 幅を親要素いっぱいに広げる */
    max-width: 192px;         /* w-48相当のサイズ以上には広がらないように制限 */
    box-sizing: border-box;   /* パディングを含めた幅計算にする */
  }

  /* 3. 親のフレックス要素（「〜から」「〜にお届け」など）の折り返し許可 */
  .sysCheckoutRepeatCycleFreeContent {
    flex-wrap: wrap; /* 要素が横に並び切らない時に自動で段落ちさせる */
    gap: 10px;       /* 要素間の余白を確保 */
  }
  /* 契約プランなどの入力エリア全体の調整 */
  .sysCheckoutRepeatCycleCycleTypeSelection .sysCheckoutRadioTileDetails {
    padding: 15px !important; /* 内側に余白を作る */
    margin-left: 0 !important; /* 突き抜けの原因になるマージンは0のまま */
  }

  /* 「契約更新方法」のブロックも同様に調整 */
  .sysCheckoutRepeatCycleFieldCourseTimes {
    padding-left: 15px !important; /* 左側に15pxの余白を確保 */
    padding-right: 15px !important; /* 右側も同様 */
    margin-left: 0 !important;
  }

  /* セレクトボックスの横幅が広がりすぎないように制限（任意） */
  .sysCheckoutRepeatCycleForm select {
    max-width: 100% !important;
    width: auto !important;
    min-width: 200px; /* ある程度の幅を維持 */
  }
}
/* -------お届けサイクルの横スクロール発生---------- */
@media screen and (max-width: 767px) {
    /* 1. 横並びを解除して縦に並べる、または折り返しを許可する */
    .sysCheckoutRepeatCycleFreeContent {
        flex-wrap: wrap !important; /* 入りきらない時に自動で改行させる */
        gap: 10px 5px !important;  /* 上下の隙間を作る */
        align-items: center !important;
    }

    /* 2. セレクトボックスの固定幅（w-48）を解除する */
    .sysCheckoutRepeatCycleFreeContent .sysCheckoutFieldSelectInput select {
        width: auto !important;     /* 固定幅をキャンセル */
        min-width: 100px !important; /* 最低限の幅だけ確保 */
        max-width: 100% !important;
        padding-right: 30px !important; /* 矢印と重ならないように */
    }

    /* 3. 「から」「にお届け」などのテキストの隙間を調整 */
    .sysCheckoutRepeatCycleFreeContent .whitespace-nowrap {
        font-size: 14px !important;
        margin: 0 2px !important;
    }
    
     /* お届け回数などの単独セレクトボックスも幅を調整 */
    .sysCheckoutRepeatCycleForm .sysCheckoutFieldSelectInput select {
        width: 100% !important; /* 単独のものは横いっぱいに広げると押しやすい */
    }
    .sysCheckoutRepeatCycleFieldCourseTimes {
    margin: 0 5% 20px 5% !important;
    width: 90% !important;
    }
    .sysCheckoutRepeatCycleTimesHeader {
      margin-left: 5% !important;
    }
}

/* -----------------------------------------------------------
   ★レジ画面
 ----------------------------------------------------------- */
 /* 「同意しました」ボタンの上下の幅を広げて大きくする */
.sysCheckoutBasketSummaryButtons .sysCheckoutButtonPrimary {
    padding-top: 1.25rem !important;    /* 上の余白（お好みで1.5remなどに調整してください） */
    padding-bottom: 1.25rem !important; /* 下の余白 */
    font-size: 1rem !important;      /* 文字も少し大きくするとバランスが良いです */
    font-weight: bold !important;       /* 文字を太字にして目立たせる */
    min-height: 60px !important;        /* 最低限の高さも保証しておくと安心です */
}

/* ボタンの中のテキストの位置調整 */
.sysCheckoutBasketSummaryButtons .sysCheckoutButtonContent {
    line-height: 1 !important;
}

.sysCheckoutBody #sysAside .r_category {
  margin-top: 0 !important;
  background: #fff !important;
}
.sysCheckoutBody .r_category .r_category_sec {
  box-shadow: 0 0 0 100vw #fff !important;
  border: 1px solid #ccc;
  border-radius: 20px;
  margin-bottom: 20px !important;
}
#sysCheckout .shadow-\[0_1px_6px_rgba\(0\,0\,0\,0\.05\)\] {
    box-shadow: none !important;
    --tw-shadow: 0 0 #0000 !important;
    --tw-shadow-colored: 0 0 #0000 !important;
}
.sysCheckoutBorderedTitle {
  background: #fff !important;
}
.sysCheckoutAreaContent .sysCheckoutBasketSummary .sysCheckoutDescriptionListItemContent {
  background: #fff !important;
  border-radius: 10px !important;
  border: 1px solid #222 !important;
  padding: 20px !important;
}

/* ---- 規約ボックス ------ */
.sysCheckoutBasketSummaryCard {
  background: #d0e4e4 !important;
  opacity: 1 !important;
  padding: 30px 30px 10px 30px !important;
}
/* 1. 全体の背景色とレイアウト */
.sysCheckoutBasketSummaryTerm {
    padding: 0 !important;
    border-radius: 8px;
}

/* 2. タイトルと説明文のセンター寄せ */
.r_kiyaku_tit {
    text-align: center !important;
    font-weight: bold !important;
    font-size: 1.1rem !important;
    margin-bottom: 8px !important;
    color: #333 !important;
}

.r_kiyaku_txt {
    text-align: center !important;
    font-size: 0.9rem !important;
    margin-bottom: 20px !important;
    color: #333 !important;
}

/* 3. 規約項目（白いボックス）のデザイン */
.sysCheckoutTermListItem {
    background-color: #ffffff !important;
    margin-bottom: 12px !important;
    padding: 16px !important;
    border-radius: 12px !important; /* 角丸 */
    box-shadow: 0 2px 4px rgba(0,0,0,0.05); /* 軽い影 */
    border: none !important;
}

/* 4. チェックボックスとラベルの配置調整 */
.sysCheckoutTermListItem label.sysCheckoutCheckbox {
    display: flex !important;
    align-items: flex-start !important; /* テキストが長くてもチェックを上に固定 */
    width: 100%;
    cursor: pointer;
}

/* チェックボックス本体のサイズと位置 */
.sysCheckoutTermListItem input[type="checkbox"] {
    margin-top: 4px !important; /* テキストの1行目と高さを合わせる */
    flex-shrink: 0;
    width: 20px !important;
    height: 20px !important;
    border: 1px solid #666 !important;
}

/* テキストラベルの調整 */
.sysCheckoutCheckboxLabel {
    font-size: 0.95rem;
    line-height: 1.5;
    color: #333;
    padding-left: 4px;
}

/* 5. スマホ最適化（画面が狭い時） */
@media (max-width: 640px) {
  .sysCheckoutBasketSummaryCard {
  padding: 10px !important;
  }
  .sysCheckoutBasketSummaryTerm {
  padding: 0 !important;
  }
  .sysCheckoutTermListItem {
  padding: 12px !important;
  }
  .sysCheckoutCheckboxLabel {
  font-size: 0.85rem; /* スマホでは少し文字を小さく */
  }
}

/* -----------------------------------------------------------
   ★カート画面：２カラムを１カラムに変更し、規約を下に変更
 ----------------------------------------------------------- */
/* 1. 親要素のグリッドを解除して、強制的に縦並び(Flex)にする */
.sysCheckoutBasketContainer.grid {
  display: flex !important;
  flex-direction: column !important; /* 縦に並べる */
  gap: 40px !important; /* 商品と合計エリアの間の余白 */
}

/* 2. 商品リストを「1番（上）」に持ってくる */
.sysCheckoutBasketProducts {
  order: 1 !important;
  width: 100% !important;
  max-width: 100% !important;
  grid-column: span 3 / span 3 !important; /* 元のグリッド列指定を上書き */
}

/* 3. 合計・規約エリアを「2番（下）」に持ってくる */
.sysCheckoutBasketSummary {
  order: 2 !important;
  width: 100% !important;
  max-width: 100% !important;
  grid-column: span 3 / span 3 !important; /* 元のグリッド列指定を上書き */
  position: static !important; /* 横に張り付く設定を解除 */
  margin-top: 0 !important;
}

/* 4. PC時に横並びにする命令(lg:col-start-3など)をすべて無効化 */
[class*="lg:grid-cols-3"], 
[class*="lg:col-start-3"], 
[class*="lg:col-span-2"] {
    display: flex !important;
    flex-direction: column !important;
}
/* -----------------------------------------------------------
   重要事項のdl調節
   ----------------------------------------------------------- */
/* チェックボックス横のラベル部分が flex になっているので、縦並びを許可する */
.sysCheckoutBasketSummaryTerm .sysCheckoutCheckboxLabel {
    display: block !important; /* 強制的にブロック要素化して dl を正しく表示させる */
    width: 100%;
}

/* dl全体の余白調整 */
.sysCheckoutBasketSummaryTerm dl {
    padding: 0 !important;
}

/* dt: 太字にする */
.sysCheckoutBasketSummaryTerm dt {
    font-size: 16px !important;
    font-weight: bold !important;
    display: block !important;
    margin-bottom: 5px !important;
    color: #418f94 !important;
}

/* dd: アイコンをつけてインデントする */
.sysCheckoutBasketSummaryTerm dd {
    display: block !important;
    position: relative !important;
    padding-left: 1.2em !important; /* アイコンが入るスペース */
    margin-left: 0 !important;
    margin-bottom: 6px !important;
    line-height: 1.5 !important;
}
.sysCheckoutBasketSummaryTerm a {
  color: #418f94 !important;
  text-decoration: underline !important;
}
/* ddの前にアイコン（今回は確実に表示される「・」で設定） */
.sysCheckoutBasketSummaryTerm dd::before {
    content: "・" !important;
    position: absolute !important;
    left: 0 !important;
    font-weight: bold !important;
    color: #3b82f6; /* 青色（お好みで変更してください） */
}
/* -----------------------------------------------------------
   見積ボタンが重要事項に隠れるのを解消
   ----------------------------------------------------------- */
/* 右側の注文サマリーカードの「追いかけ」設定を解除して、ボタンが見えるようにする */
.sysCheckoutBasketSummaryCard.sticky {
    position: static !important; /* または position: relative !important; */
}

/* もしカードが長すぎて見積書ボタンが離れすぎている場合は、マージンを調整 */
.sysCheckoutBasketSummaryContent {
    margin-bottom: 20px !important;
}
/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   ご契約中のお客様へ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
#contractor .r_contractor_titbox {
    max-width: 1200px;
    margin: 0 auto;
    text-align: center;
}
#contractor .r_contractor_titbox p {
    text-align: center;
}
#contractor .r_contractor_titbox a {
    text-align: center;
}
#contractor .r_contractor_titbox .r_btn1 {
    margin-top: 15px;
}
#contractor .r_reminder_btn {
  color: #418f94;
  text-decoration: underline;
  font-size: 14px;
  margin-top: 10px;
  display: block;
}
#contractor .r_reminder_btn a {
  opacity: 0.8;
}
/* 外枠のリセット */
#contractor .r_contractor_link {
    max-width: 1200px;
    margin: 20px auto 50px auto;
    padding: 0 10px; /* スマホ時の端の余白 */
}
#contractor .r_contractor_mypage h2 {
  padding-left: 0 !important; 
  text-align: center !important;
  display: block !important;
  position: relative !important;
  margin-bottom: 40px !important;
  padding-top: 30px !important;
  font-size: 24px !important;
  color: #333 !important;
  letter-spacing: 0.05em !important;
}
#contractor .r_contractor_mypage h2::after {
  content: "" !important;
  position: absolute !important;
  left: 50% !important;
  transform: translateX(-50%) !important;
  bottom: -20px !important;
  width: 8px !important;
  height: 8px !important;
  background-color: #668888 !important;
  border-radius: 50% !important;
  display: block !important;
}
/* 見出し：線の色と太さを画像に合わせる */
#contractor .r_contractor_link h3 {
    font-size: 20px;
    font-weight: bold;
    color: #333;
    padding-bottom: 8px;
    margin-bottom: 25px;
    border-bottom: 2px solid #7a9293; /* 少し濃いめのグレーグリーン */
}

/* リスト：aishipのデフォルト余白を打ち消す */
#contractor .r_contractor_link ul {
    display: flex;
    flex-wrap: wrap;
    gap: 12px 15px; /* 縦・横の隙間 */
    padding: 0 !important;
    margin: 0 !important;
    list-style: none !important;
}

/* 2列計算 */
#contractor .r_contractor_link li {
    width: calc(50% - 8px);
    margin: 0 !important;
    padding: 0 !important;
    list-style-type: none !important;
}

/* ボタン本体：paddingをしっかり確保 */
#contractor .r_contractor_link li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    min-height: 54px; 
    padding: 10px 15px 10px 20px !important;
    background-color: #e5eeef;
    color: #333;
    text-decoration: none;
    font-size: 16px;
    font-weight: bold;
    border-radius: 4px;
    transition: 0.3s;
    box-sizing: border-box;
}

/* 右側の矢印：位置を調整 */
#contractor .r_contractor_link li a::after {
    content: '';
    display: block;
    width: 6px;
    height: 6px;
    border-top: 2px solid #666;
    border-right: 2px solid #666;
    transform: rotate(45deg);
    margin-left: 10px;
}

#contractor .r_contractor_link li a:hover {
    background-color: #d8e6e7;
    opacity: 0.9;
}

/* スマホ：1列 */
@media (max-width: 768px) {
    #contractor .r_contractor_titbox {
    width: 94%;
    margin-bottom: 40px;
    }
    #contractor .r_contractor_titbox p {
    text-align: left;
    }
    #contractor .r_contractor_mypage h2 {
    padding-top: 0 !important;
    }
    #contractor .r_contractor_link li {
        width: 100%;
    }
    #contractor .r_contractor_link h3 {
    font-size: 18px;
  }
}
/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   法人ページ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
.r_houjin_tit + .r_houjin_cta {
  margin-top: -50px !important;
  z-index: 5;
  position: relative;
}
#houjin h2.tit_flow {
  text-align: center;
  font-weight: bold;
  font-size: 26px;
  color: #fff;
  background: #5f9697;
  padding: 20px 0;
  margin-bottom: 20px;
}
#houjin h3.tit_icon {
  display: flex;
  align-items: center; /* ドットと文字の上下中央を合わせる */
  gap: 15px;           /* ドットと文字の間の距離 */
  font-size: 24px;     /* PCサイズの見出し */
  font-weight: bold;
  color: #333;
  margin: 0 auto 30px auto; /* 周囲の余白調整 */
  width: 100%;
  max-width: 1200px;
  border-bottom: 1px solid #428f94;
  padding-bottom: 15px;
}
#houjin h3.tit_icon::before {
  content: "";
  display: inline-block;
  width: 13px;         /* デザインに合わせたサイズ */
  height: 13px;
  background-color: #428f94; /* 添付画像の色味を再現 */
  border-radius: 50%;  /* 正円にする */
  flex-shrink: 0;      /* 画面が狭くなっても円を潰さない */
  margin-top: 5px auto !important;
}
/* -----------------------------------------------------------
   ★タイトル
 ----------------------------------------------------------- */
/* --- 外側の背景100%エリア --- */
.r_houjin_titcon {
  width: 100vw !important;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  background-color: #ebf4f9; /* 背景の薄い水色 */
  padding: 100px 0 80px !important;
  margin-bottom: 40px !important;
  overflow: hidden;
  box-sizing: border-box;
    background-image: url('/img/web/houjin_bg.jpg');
  background-repeat: no-repeat;
    background-size: cover;
    text-align: center;
    z-index: 1;
}

/* --- コンテンツ中央寄せ --- */
.r_houjin_inner {
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  position: relative;
  /* 右側のイラスト画像を入れる場合はここに追加 */

}

/* --- メインタイトル --- */
.r_houjin_titcon .sysHeadline {
  display: inline-block;
  position: relative;
  font-size: 64px; /* 画像のようにどっしりと */
  font-weight: 700;
  color: #333;
  letter-spacing: 0.05em;
  line-height: 1.2;
  border: none !important;
  background: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

/* --- 【重要】画像再現：黒背景×黄文字の吹き出し --- */
.r_houjin_label {
  position: absolute;
  top: -85px; /* 位置を上に調整 */
  left: 50%;
  transform: translateX(-50%); /* 完全に中央 */
  background-color: #428f94; /* 画像(061757.png)の濃いグレー */
  color: #f9f9ad; /* 画像(061757.png)の淡いイエロー文字 */
  font-size: 28px;
  font-weight: bold;
  padding: 12px 45px;
  border-radius: 60px; /* カプセル型の丸み */
  white-space: nowrap;
  box-shadow: 0 4px 8px rgba(0,0,0,0.15);
}

/* 吹き出しの三角部分 */
.r_houjin_label::after {
  content: '';
  position: absolute;
  bottom: -14px; /* 下に配置 */
  left: 50%;
  transform: translateX(-50%);
  border-width: 15px 12px 0 12px;
  border-style: solid;
  border-color: #428f94 transparent transparent transparent;
}
.r_houjin_titcon p {
  margin-top: 20px;
}
#houjin .r_first_flow {
    margin-top: 60px;
}
#houjin .r_first_flow .r_btn1 {
  display: none;
}
/* --- スマホ用 --- */
@media screen and (max-width: 767px) {
  #houjin h3.tit_icon {
    margin-bottom: 0;
  }
  #houjin .r_first_flow {
    margin-top: 30px;
  }
  .r_houjin_titcon {
    padding: 70px 0 50px !important;
  }
  .r_houjin_titcon .sysHeadline {
    font-size: 36px;
  }
  .r_houjin_label {
    top: -55px;
    font-size: 18px;
    padding: 8px 30px;
  }
  .r_houjin_label::after {
    bottom: -10px;
    border-width: 10px 8px 0 8px;
  }
}
/* -----------------------------------------------------------
   ★法人CTA：修正版
 ----------------------------------------------------------- */
.r_houjin_cta {
  width: 100%;
  max-width: 1200px !important;
  background-color: #428f94; 
  padding: 30px 0 !important;
  margin: 40px auto !important;
  box-sizing: border-box;
  border-radius: 20px;
  overflow: hidden; /* 角丸をはみ出させない */
}

/* --- 中のコンテンツ（フレックスボックスで比率調整） --- */
.r_houjin_cta_inner {
  padding: 0 40px;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}

/* 左側のテキストカラム (55%比率) */
.r_houjin_cta_text_col {
  flex: 60;
  color: #fff;
}

/* 左側：大見出し */
.r_houjin_cta_title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 20px;
  letter-spacing: 0.05em;
  border-bottom: 1px solid #fff; 
  padding-bottom: 10px;
  display: inline-block;
}

/* 左側：説明文 */
.r_houjin_cta_lead {
  font-size: 16px;
  line-height: 1.8;
}

.r_houjin_cta_lead p {
  margin-bottom: 5px;
}

/* 左側：注釈 */
.r_houjin_cta_note {
  font-size: 14px;
  font-weight: 700;
  margin-top: 10px;
}

/* 右側のボタンカラム (45%比率) */
.r_houjin_cta_btn_col {
  flex: 40;
  display: flex;
  justify-content: flex-end;
}

/* 右側：白いお問い合わせボタン */
.r_houjin_cta_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  color: #333 !important;
  text-decoration: none !important;
  font-size: 18px; /* 文字を少し大きく */
  font-weight: bold;
  padding: 22px 0; /* 左右はwidth100%に任せる */
  border-radius: 4px;
  transition: all 0.3s ease;
  box-shadow: 0 6px 15px rgba(0,0,0,0.15);
  position: relative;
  white-space: nowrap;
  width: 100%; /* 親の45%エリアいっぱいに広げる */
  max-width: 480px; /* PCで大きくなりすぎないガード */
}

/* メールアイコン */
.r_houjin_cta_btn::before {
  content: '✉';
  font-size: 24px;
  margin-right: 15px;
  font-weight: normal;
}

/* ホバー時の動き */
.r_houjin_cta_btn:hover {
  background-color: #f5f5f5;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,0.2);
}

/* --- スマホ用の最適化 --- */
@media screen and (max-width: 767px) {
  .r_houjin_cta {
    width: 94% !important; /* 画面端に少し余白を作る */
    margin: 30px auto !important;
    padding: 30px 0 !important;
  }

  .r_houjin_cta_inner {
    flex-direction: column; /* 縦並び */
    align-items: flex-start;
    gap: 30px;
    padding: 0 20px;
  }

  .r_houjin_cta_text_col,
  .r_houjin_cta_btn_col {
    flex: none; /* 比率指定を解除 */
    width: 100%;
  }

  .r_houjin_cta_title {
    font-size: 22px;
  }

  .r_houjin_cta_btn {
    font-size: 18px;
    max-width: none;
    white-space: normal; /* スマホでは改行OKに */
    padding: 18px 20px;
  }
}
/* -----------------------------------------------------------
   ★悩みありませんか？
 ----------------------------------------------------------- */
 /* --- 外側コンテナ --- */
.r_houjin_nayami {
  width: 100%;
  max-width: 1200px;
  margin: 60px auto !important;
  padding: 0 20px;
  box-sizing: border-box;
}

/* タイトル設定 */
.r_houjin_nayami_title {
  text-align: center;
  font-size: 36px;
  font-weight: bold;
  color: #333;
  margin-bottom: 40px;
}

.r_houjin_nayami_title span {
  color: #428f94; /* 「お悩み」の部分にアクセント色 */
  border-bottom: 2px solid #2c4b61;
  padding-bottom: 2px;
}

/* コンテンツ配置（PCは横並び） */
.r_houjin_nayami_content {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 40px;
}

/* イラストエリア */
.r_houjin_nayami_image {
  flex: 0 0 300px; /* イラストの幅を固定 */
  text-align: center;
}

.r_houjin_nayami_image img {
  max-width: 100%;
  height: auto;
}

/* 悩みリスト */
.r_houjin_nayami_list {
  flex: 1;
  list-style: none;
  padding: 0;
  margin: 0;
}

.r_houjin_nayami_list li {
  position: relative;
  background-color: #f1f7fa; /* 非常に薄いブルー背景 */
  padding: 15px 20px 15px 55px; /* 左側にチェックマーク用の余白 */
  margin-bottom: 15px !important;
  border-radius: 4px;
  font-size: 18px;
  line-height: 1.6;
  color: #333;
  font-weight: 500;
}

/* チェックマーク（CSSで再現） */
.r_houjin_nayami_list li::before {
  content: '';
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
  width: 8px;
  height: 16px;
  border-right: 3px solid #2c4b61;
  border-bottom: 3px solid #2c4b61;
}

/* --- スマホ用の最適化 --- */
@media screen and (max-width: 767px) {
  .r_houjin_nayami {
    margin-bottom: 30px !important;
    margin-top: 30px !important;
  }
  .r_houjin_nayami_title {
    font-size: 24px;
    margin-bottom: 30px;
  }

  .r_houjin_nayami_content {
    flex-direction: column; /* 縦並びに変更 */
    gap: 20px;
  }

  .r_houjin_nayami_image {
    flex: none;
    width: 60%; /* スマホではイラストを少し小さめに表示 */
    margin: 0 auto;
  }

  .r_houjin_nayami_list li {
    font-size: 14px;
    padding: 12px 15px 12px 45px;
  }

  .r_houjin_nayami_list li::before {
    left: 15px;
    width: 6px;
    height: 12px;
  }
}
/* -----------------------------------------------------------
   ★選ばれる理由
 ----------------------------------------------------------- */
 /* --- 外側コンテナ（背景100%） --- */
.r_houjin_riyu {
  width: 100vw !important;
  position: relative;
  left: 50%;
  right: 50%;
  margin-left: -50vw !important;
  margin-right: -50vw !important;
  /* 背景画像：暗めのオーバーレイをかけた画像を指定 */
  background: linear-gradient(rgba(66, 143, 148, 0.85), rgba(66, 143, 148, 0.85)), url('背景画像のパス');
  background-size: cover;
  background-position: center;
  background-attachment: fixed; /* パララックス風 */
  padding: 80px 0 !important;
  box-sizing: border-box;
}

/* --- 中のコンテンツ（1200px中央寄せ） --- */
.r_houjin_riyu_inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0;
}

/* セクションタイトル */
.r_houjin_riyu_title {
  color: #fff;
  text-align: center;
  font-size: 36px;
  font-weight: bold;
  margin-bottom: 60px;
  line-height: 1.4;
}

/* グリッドレイアウト（PC 4カラム） */
.r_houjin_riyu_grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}

/* カード単体 */
.r_riyu_card {
  background-color: #fff;
  padding: 20px;
  display: flex;
  flex-direction: column;
}

/* カード内画像 */
.r_riyu_img {
  width: 100%;
  margin-bottom: 20px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
}

.r_riyu_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* カード内テキスト */
.r_riyu_body h3 {
  font-size: 18px;
  color: #333;
  margin-bottom: 15px;
  line-height: 1.5;
  font-weight: bold;
  height: 3em; /* タイトルの高さを揃える */
  display: flex;
  align-items: center;
}

.r_riyu_body p {
  font-size: 16px;
  color: #333;
  line-height: 1.7;
  text-align: justify;
}

/* --- スマホ用の最適化 --- */
@media screen and (max-width: 1024px) {
  .r_houjin_riyu_grid {
    grid-template-columns: repeat(2, 1fr); /* タブレットでは2列 */
  }
}

/* --- スマホ用の最適化（767px以下） --- */
@media screen and (max-width: 767px) {
  .r_houjin_riyu_title {
  font-size: 24px;
  margin-bottom: 30px;
}
  .r_houjin_riyu {
    padding: 40px 0 !important;
  }

  .r_houjin_riyu_grid {
    grid-template-columns: 1fr; /* 縦に1列並べる */
    gap: 20px;
    width: 94%;
    margin: 0 auto;
  }

  .r_riyu_card {
    padding: 15px;
    display: block; /* floatを使うためにblockに戻す */
    overflow: hidden; /* float解除用 */
  }
  
  /* 画像エリア：左に浮かせる */
  .r_riyu_img {
    float: left;
    width: 35%; /* 横幅の35%を使用 */
    margin-right: 15px;
    margin-bottom: 5px;
  }
  
  /* タイトル：画像の横に回り込む */
  .r_riyu_body h3 {
    height: auto; /* PC用の高さ固定を解除 */
    font-size: 17px;
    line-height: 1.4;
    margin-bottom: 0;
    display: block; /* 回り込みを許容 */
  }
  
  /* 説明文：画像の下に回り込ませて幅いっぱいに */
  .r_riyu_body p {
    clear: both; /* 回り込みを一度解除して画像の下から始める */
    padding-top: 10px;
    font-size: 14px;
  }
}
/* -----------------------------------------------------------
   ★事例
 ----------------------------------------------------------- */
/* --- 全体コンテナ --- */
.r_houjin_jirei {
  width: 100%;
  padding: 60px 0;
  background-color: #fff; /* 背景は白 */
}

.r_houjin_jirei_inner {
  max-width: 1200px;
  margin: 0 auto !important; /* 強制的に中央寄せ */
  padding: 0;
}

.r_jirei_main_title {
  text-align: center;
  font-size: 32px;
  font-weight: bold;
  margin-bottom: 50px;
  color: #333;
}

/* カードを並べるコンテナ */
.r_jirei_container {
  display: flex;
  flex-direction: column;
  align-items: center; /* これでカード自体を中央に寄せる */
  width: 100%;
}

/* --- 事例カード単体 --- */
.r_jirei_card {
  display: flex;
  width: 100%; /* インナー幅いっぱいに使う */
  max-width: 1200px; /* 少し余裕を持たせる */
  background-color: #f1f7fa; /* 画像701856の薄いブルー */
  margin-bottom: 40px;
  position: relative;
  text-align: left; /* 文字は左寄せ */
}

/* 左上の三角アクセント */
.r_jirei_card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  border-style: solid;
  border-width: 25px 25px 0 0;
  border-color: #418f94 transparent transparent transparent; /* 画像の色味に調整 */
  z-index: 1;
}

/* 画像カラム */
.r_jirei_img_col {
  flex: 0 0 40%; /* 4割を画像に */
  padding: 30px;
  display: flex;
  align-items: center;
}

.r_jirei_img_col img {
  width: 100%;
  height: auto;
  box-shadow: 0 4px 12px rgba(0,0,0,0.1);
}

/* テキストカラム */
.r_jirei_text_col {
  flex: 1;
  padding: 30px 40px 30px 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.r_jirei_title {
  font-size: 20px;
  font-weight: bold;
  margin-bottom: 15px;
  line-height: 1.5;
  color: #418f94;
}

.r_jirei_price {
  font-size: 16px;
  font-weight: bold;
  color: #333;
  margin-bottom: 15px;
}

.r_jirei_desc {
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 25px;
}

/* ボタン */
.r_jirei_btn {
  align-self: flex-start; /* ボタンを左側に固定 */
  background-color: #418f94;
  color: #fff !important;
  padding: 12px 50px;
  border-radius: 4px;
  text-decoration: none !important;
  font-weight: bold;
  font-size: 16px;
}

/* --- スマホ用の最適化 --- */
@media screen and (max-width: 767px) {
  .r_houjin_jirei {
  padding: 30px 0 0;
  }
  .r_jirei_main_title {
  font-size: 24px;
  margin-bottom: 20px !important;
  }
  .r_jirei_card {
    flex-direction: column;
    max-width: 100%;
  }

  .r_jirei_img_col {
    padding: 20px;
    width: 100%;
  }

  .r_jirei_text_col {
    padding: 0 20px 30px 20px;
  }
  
  .r_jirei_title {
    font-size: 18px;
  }
  .r_jirei_container {
    width: 94%;
    margin: 0 auto;
  }
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   フォームページ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
/* -----返却依頼フォーム----- */
/* お知らせボックスのデザイン */
.custom-important-box {
    background-color: #fff2f2; /* 指定の薄いピンク */
    border: 1px solid #ffcaca;   /* 枠線を少しだけ濃く */
    border-radius: 12px;         /* 角丸 */
    padding: 20px;
    margin: 20px 0;
    color: #444;                 /* 文字色 */
    font-family: sans-serif;
    line-height: 1.6;
}

/* タイトル部分 */
.custom-important-box .box-title {
    display: block;
    font-weight: bold;
    color: #d32f2f;              /* 重要な赤 */
    font-size: 1.1em;
    margin-bottom: 12px;
    padding-bottom: 8px;
    border-bottom: 1px dashed #ffb2b2; /* 区切り線 */
}

/* 小見出し */
.custom-important-box .box-subtitle {
    display: block;
    font-weight: bold;
    margin-bottom: 5px;
    font-size: 1em;
}

/* 本文 */
.custom-important-box .box-text {
    margin: 0;
    font-size: 0.95em;
}






/* -----フォーム共通----- */
#sysFormIndex #sysMain {
  margin-bottom: 60px;
  margin-top: -20px;
}
#sysFormIndex #sysMain .sysButton {
  width: auto;
}
.form-contact p {
  text-align: center;
}
.form-contact form p {
  text-align: left;
} 
.form-contact #sysMain {
  margin-bottom: 80px !important;
}
.r_form_tit {
  text-align: center;
  margin: 40px 0;
  font-size: 30px;
  font-weight: bold;
}
/* ボタンの外側の余白 */
.r_form_btn {
  text-align: center;
  margin: 20px auto;
  padding: 0 20px;
}

/* ボタン本体 */
.r_form_btn a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background-color: #729494; /* サイトカラー */
  color: #fff !important;
  text-decoration: none !important;
  font-size: 14px;
  font-weight: bold;
  padding: 10px 20px;
  border-radius: 4px;
  transition: all 0.3s ease;
  width: 100%;
  max-width: 300px; /* PCでの最大幅 */
  box-sizing: border-box;
  box-shadow: 0 3px 6px rgba(0,0,0,0.1);
  position: relative;
}


/* ホバー（マウスを乗せた時）の動き */
.r_form_btn a:hover {
  background-color: #88a8a8; /* 少し明るく */
  box-shadow: 0 5px 15px rgba(0,0,0,0.15);
}

/* スマホ用の微調整 */
@media screen and (max-width: 480px) {
  #sysFormIndex #sysMain {
    margin-top: 5px;
  }
  #sysFormIndex #sysHeader {
    border-bottom: 1px solid #ddd;
  }
  .form-contact #sysHeader {
  border-bottom: 1px solid #eee;
}
  .r_form_tit {
  font-size: 24px;
  }
  .r_form_btn a {
    font-size: 14px;
    padding: 8px 20px;
  }
  .form-contact p {
  text-align: left;
  }
  .form-contact #sysMain {
  margin-bottom: 60px !important;
  }
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   プライバシーポリシー
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
.r_privacy,
.r_kiyaku,
.r_kiyaku_archive {
  width: 100% !important;
  max-width: 1200px !important;
  margin: 60px auto !important;
  padding: 0;
  box-sizing: border-box;
}

/* 導入文 */
.r_privacy_intro,
.r_kiyaku_intro {
  margin-bottom: 40px;
}

/* 各章のセクション */
.r_privacy_section,
.r_kiyaku_section {
  margin-bottom: 50px;
}

/* 章の見出し（グレー背景） */
.r_privacy_section h2,
.r_kiyaku_section h2 {
  background-color: #f2f2f2; /* 画像に合わせた薄いグレー */
  padding: 15px 20px !important;
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 20px !important;
  width: 100% !important;
  max-width: 100% !important;
  box-sizing: border-box;
}

/* 本文テキスト */
.r_privacy_section p,
.r_kiyaku_section p {
  margin-bottom: 15px;
  padding: 0 10px;
}

/* 箇条書きリスト */
.r_privacy_section ul,
.r_kiyaku_section ul {
  padding-left: 30px !important;
  margin-bottom: 20px;
}

.r_privacy_section a {
  text-decoration: underline;
}
.r_privacy_section ul li,
.r_kiyaku_section ul li {
  margin-bottom: 10px;
}

/* お問い合わせ窓口のボックス */
.r_privacy_contact {
  background-color: #fff;
  border: 1px solid #ddd;
  padding: 20px;
  margin-top: 15px;
  border-radius: 4px;
}

.r_privacy_contact p {
  margin-bottom: 5px;
  padding: 0;
}
/* --- 1階層目 (数字) --- */
.r_privacy ol,
.r_kiyaku ol,
.r_kiyaku_archive ol {
  list-style: none;
  counter-reset: item;
  padding-left: 0 !important;
  margin: 15px 0 !important;
}

.r_privacy ol > li,
.r_kiyaku ol > li,
.r_kiyaku_archive ol > li {
  display: table;
  counter-increment: item;
  margin-bottom: 10px;
  line-height: 1.8;
  padding-left: 10px;
}

.r_privacy ol > li::before,
.r_kiyaku ol > li::before,
.r_kiyaku_archive ol > li::before {
  content: counter(item) ".";
  display: table-cell;
  width: 1.8em; /* 数字の幅 */
  padding-right: 5px;
  font-weight: bold;
  white-space: nowrap;
}

/* --- 2階層目 (アルファベット) --- */
.r_privacy ol li ol,
.r_kiyaku ol li ol,
.r_kiyaku_archive ol li ol {
  counter-reset: subitem; /* 子要素用のカウンターリセット */
  margin: 10px 0 10px 10px !important; /* 左にインデントを追加 */
}

.r_privacy ol li ol > li,
.r_kiyaku ol li ol > li,
.r_kiyaku_archive ol li ol > li {
  display: table;
  counter-increment: subitem;
  margin-bottom: 5px;
  padding-left: 0;
}

.r_privacy ol li ol > li::before,
.r_kiyaku ol li ol > li::before,
.r_kiyaku_archive ol li ol > li::before {
  /* アルファベット小文字 (a. b. c.) に設定 */
  content: "(" counter(subitem, lower-latin) ")"; 
  display: table-cell;
  width: 2.2em; /* アルファベット部分の幅 */
  padding-right: 5px;
  font-weight: normal;
}
.r_kiyaku a {
  text-decoration: underline;
  color: #418f94;
}
/* --- スマホ用の最適化 --- */
@media screen and (max-width: 767px) {
  .r_privacy,
  .r_kiyaku,
  .r_kiyaku_archive {
    margin: 40px auto !important;
    width: 94% !important;
  }
  .r_privacy ol,
  .r_kiyaku ol,
  .r_kiyaku_archive ol {
   font-size: 14px;
  }
  .r_privacy_intro,
   .r_kiyaku_intro {
    font-size: 14px;
    margin-bottom: 20px;
  }
  .r_privacy_section h2,
  .r_kiyaku_section h2 {
    font-size: 15px;
    padding: 12px 15px !important;
  }
  .r_privacy_section,
  .r_kiyaku_section {
  margin-bottom: 30px;
  }
  .r_privacy_section p, 
  .r_privacy_section ul,
  .r_kiyaku_section p, 
  .r_kiyaku_section ul {
    font-size: 14px;
    padding-left: 15px !important;
  }
}
/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   サイトマップ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
/* 外側の枠線と背景 */

#sitemap .r_sitemap {
    background-color: #f4f8f8; /* 薄い水色の背景 */
    padding: 40px;
    border-radius: 20px;
    width: 1200px;
    margin: 40px auto;
    box-sizing: border-box;
}

#sitemap .r_sitemap1 {
    display: flex;
    justify-content: space-between;
    gap: 30px;
}

/* 各カラムの設定 */
#sitemap .sitemap_column {
    flex: 1; /* 3等分にする */
}
#sitemap h2 {
  padding-bottom: 15px;
}
#sitemap h2::before {
  content: "";
  display: inline-block;
  width: 10px;
  height: 10px;
  background-color: #428f94;
  border-radius: 50%;
  flex-shrink: 0;
  margin-right: 10px;
}
/* カラムの見出し */
#sitemap .r_sitemap h3,
#sitemap .r_sitemap_lower h3 {
    font-size: 16px;
    font-weight: bold;
    color: #333;
    padding-bottom: 10px;
    border-bottom: 1px solid #5f9697; /* 指定のライン色 */
    margin-bottom: 15px;
}

/* リストの設定 */
#sitemap .sitemap_list {
    list-style: none;
    padding: 0;
    margin: 0;
}

#sitemap .sitemap_list li {
    position: relative;
    padding-left: 18px;
    margin-bottom: 12px;
    line-height: 1.4;
}

/* リストの先頭の「▶」 */
#sitemap .sitemap_list li::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 4px 0 4px 6px;
    border-color: transparent transparent transparent #5f9697;
}

#sitemap .sitemap_list li a {
    text-decoration: none;
    color: #333;
    font-size: 15px;
    transition: opacity 0.2s;
}

#sitemap .sitemap_list li a:hover {
    opacity: 0.7;
    text-decoration: underline;
}

/* --- スマホ用（768px以下） --- */
@media screen and (max-width: 768px) {
    #sitemap .r_sitemap {
        padding: 30px 20px;
        margin: 20px 15px;
        width: 94%;
    }

    #sitemap .r_sitemap1 {
        flex-direction: column; /* 縦並びに変更 */
        gap: 40px;
    }
    
    #sitemap h3 {
        font-size: 18px; /* スマホで見やすいよう少し大きく */
    }
}


/* 下段全体のコンテナ */
#sitemap .r_sitemap_lower {
    max-width: 1200px;
    margin: 0 auto 40px auto !important;
    width: 100%;
    box-sizing: border-box;
}

/* 2カラムを並べるインナー */
#sitemap .r_sitemap2 {
    display: flex;
    justify-content: space-between;
    gap: 20px; /* ボックス同士の隙間 */
}

/* 各ボックスの設定 */
#sitemap .sitemap_box {
    flex: 1;
    background-color: #f4f8f8; /* 薄い水色の背景 */
    padding: 30px;
    border-radius: 20px;
    box-sizing: border-box;
}

/* ボックス内のタイトル（丸ポチ付き） */
#sitemap .box_title {
    font-size: 22px;
    font-weight: bold;
    color: #333;
    margin-bottom: 20px;
    display: flex;
    align-items: center;
}

/* タイトル横の丸ポチ */
#sitemap .box_title::before {
    content: '';
    display: inline-block;
    width: 10px;
    height: 10px;
    background-color: #5f9697; /* 指定のアクセント色 */
    border-radius: 50%;
    margin-right: 12px;
}

/* リストの設定（上段の共通スタイルがある場合は流用可能） */
#sitemap .sitemap_list {
    list-style: none;
    padding: 0;
    margin: 0;
}

#sitemap .sitemap_list li {
    position: relative;
    padding-left: 18px;
    margin-bottom: 12px;
}



#sitemap .sitemap_list li a {
    text-decoration: none;
    color: #333;
    font-size: 15px;
}

/* --- スマホ用（768px以下） --- */
@media screen and (max-width: 768px) {
    #sitemap .r_sitemap_lower {
        padding: 0 15px;
    }

    #sitemap .r_sitemap2 {
        flex-direction: column; /* 縦並びに変更 */
        gap: 15px;
    }
    
    #sitemap .sitemap_box {
        padding: 20px;
    }
    
    #sitemap .box_title {
        font-size: 18px;
    }
}
/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   特定商取引法に基づく表示表示・会社概要
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
/* 全体のコンテナ設定 */
.r_tokuteisyou,.r_about,.r_tokuteisyou_archive {
  width: 100% !important;
  max-width: 1200px !important; /* PCでの最大幅 */
  margin: 60px auto !important;
  padding: 0;
  box-sizing: border-box;
  font-family: "Noto Sans JP", sans-serif;
  color: #333;
}

/* ページタイトル */
.r_tokuteisyou_title,.r_about_title {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  margin-bottom: 50px;
  padding-bottom: 20px;
  border-bottom: 2px solid #729494; /* サイトカラーのアクセント */
}

/* リスト全体の調整 */
.r_tokuteisyou_list,.r_about_list {
  display: flex;
  flex-wrap: wrap;
  margin: 0;
  border-top: 1px solid #eee;
}

/* 項目（左側） */
.r_tokuteisyou_list dt,.r_about_list dt {
  width: 30%;
  padding: 25px 20px;
  background-color: #f9fbfb;
  font-weight: bold;
  border-bottom: 1px solid #eee;
  box-sizing: border-box;
}

/* 内容（右側） */
.r_tokuteisyou_list dd,.r_about_list dd {
  width: 70%;
  margin: 0;
  padding: 25px 20px;
  border-bottom: 1px solid #eee;
  box-sizing: border-box;
  line-height: 1.8;
}

/* 小さな注釈 */
.r_tokuteisyou_list dd small,.r_about_list dd small {
  display: block;
  font-size: 0.85em;
  color: #666;
  margin-top: 5px;
}

.r_tokuteisyou a,.r_tokuteisyou_archive a {
  text-decoration: underline;
  color: #418f94;
}
/* --- スマホ用の最適化 --- */
@media screen and (max-width: 767px) {
  .r_tokuteisyou,.r_sbout,.r_tokuteisyou_archive {
    margin: 40px auto !important;
  }
  .r_about {
  width: 94% !important;
  }
  .r_tokuteisyou_title,.r_about_title {
    font-size: 20px;
    margin-bottom: 30px;
  }

  .r_tokuteisyou_list dt,
  .r_tokuteisyou_list dd,
  .r_about_list dt,
  .r_about_list dd {
    width: 100%; /* 縦並びに変更 */
    padding: 15px 10px;
    font-size: 14px;
  }

  .r_tokuteisyou_list dt,.r_about_list dt {
    background-color: transparent;
    padding-bottom: 5px;
    border-bottom: none;
  }

  .r_tokuteisyou_list dd,.r_sbout_list dd {
    padding-top: 0;
    margin-bottom: 10px;
  }
}
/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   よくある質問
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
/* メニュー全体のコンテナ */
.r_faq_menu {
  width: 100% !important;
  max-width: 1200px !important;
  margin: 40px auto !important;
  padding: 0;
  box-sizing: border-box;
}

.r_faq_answer span {
  font-weight: bold;
}
/* リストのスタイル */
.r_faq_menu_list {
  display: grid;
  /* PCでは3列 */
  grid-template-columns: repeat(3, 1fr);
  gap: 15px;
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
}
/* 各リンクボタン */
.r_faq_menu_list li a {
  display: flex;
  align-items: center;
  /* 文字は中央寄り、矢印を端に置くための準備 */
  justify-content: center; 
  min-height: 50px; /* 縦幅を少し小さく調整 */
  padding: 8px 35px 8px 15px; /* 右側に矢印用のスペースを広めに確保 */
  background-color: #f0f7f7;
  color: #222 !important;
  text-decoration: none !important;
  font-size: 15px;
  font-weight: bold;
  border-radius: 4px;
  text-align: center;
  transition: all 0.3s ease;
  position: relative; /* 矢印を絶対配置するために必要 */
  box-sizing: border-box;
}

/* 右端の矢印アイコン（＞） */
.r_faq_menu_list li a::after {
  content: '';
  /* 矢印を少し大きく調整 */
  width: 8px;
  height: 8px;
  border-top: 2.5px solid #729494;
  border-right: 2.5px solid #729494;
  transform: translateY(-50%) rotate(45deg);
  
  /* ボタンの右端に固定 */
  position: absolute;
  top: 50%;
  right: 15px;
  
  flex-shrink: 0;
  transition: all 0.3s ease;
}

/* ホバー時の動き */
.r_faq_menu_list li a:hover {
  background-color: #729494;
  color: #fff !important;
}
.r_faq_menu_list li a:hover::after {
  border-color: #fff;
  right: 10px; /* ホバー時に少し右に動く演出（不要なら消してください） */
}

/* --- レスポンシブ設定 --- */

/* タブレット（991px以下） */
@media screen and (max-width: 991px) {
  .r_faq_menu_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
    width: 94%;
    margin: 0 auto !important;
  }
}

/* スマホ（480px以下） */
@media screen and (max-width: 480px) {
  .r_faq_menu {
  margin: 20px auto !important;
}
  .r_faq_menu_list {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  
  .r_faq_menu_list li a {
    min-height: 44px; /* スマホではさらに縦幅をコンパクトに */
    font-size: 12px;
    padding: 6px 25px 6px 10px; /* 右側の余白をスマホ用に微調整 */
    line-height: 1.3;
  }

  .r_faq_menu_list li a::after {
    /* スマホでも矢印の存在感を出す */
    width: 6px;
    height: 6px;
    border-width: 2px;
    right: 10px;
  }
  .r_faq_menu_list li span {
  display: none;
}
}


#faq .tit_icon {
  width: 100% !important;
  max-width: 1200px !important;
  margin: 40px auto 20px auto;
  box-sizing: border-box !important;
}
#faq .r_faq_container {
  /* PCでの横幅制限 */
  width: 100% !important;
  max-width: 1200px !important;
  margin: 0 auto 60px auto;
  box-sizing: border-box !important;
}
#faq .r_faq_container a {
  text-decoration: underline;
}

/* スマホ用の最適化（画面が小さい時は100%幅にする） */
@media screen and (max-width: 767px) {
  #faq .r_faq_container {
    padding-left: 15px !important;
    padding-right: 15px !important;
  }
  #faq .tit_icon {
    width: 94% !important;
    margin: 0 auto 10px auto !important;
  }
}
/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   ★初めての方へ・法人のご利用のながれ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */

#first .r_anshin {
  background: #fff !important;
}
#first .r_anshin h2 {
  padding-top: 30px !important;
}
#first .r_anshin .r_btn1 {
  display: none;
}
#first h3.tit_flow {
  text-align: center;
  font-weight: bold;
  font-size: 26px;
  color: #fff;
  background: #5f9697;
  padding: 20px 0;
  margin-bottom: 20px;
}
#first h5.tit_icon {
  display: flex;
  align-items: center; /* ドットと文字の上下中央を合わせる */
  gap: 15px;           /* ドットと文字の間の距離 */
  font-size: 24px;     /* PCサイズの見出し */
  font-weight: bold;
  color: #333;
  margin: 0 auto 30px auto; /* 周囲の余白調整 */
  width: 100%;
  max-width: 1200px;
  border-bottom: 1px solid #428f94;
  padding-bottom: 15px;
}

#first h5.tit_icon::before {
  content: "";
  display: inline-block;
  width: 13px;         /* デザインに合わせたサイズ */
  height: 13px;
  background-color: #428f94; /* 添付画像の色味を再現 */
  border-radius: 50%;  /* 正円にする */
  flex-shrink: 0;      /* 画面が狭くなっても円を潰さない */
  margin-top: 5px auto !important;
}

@media (max-width: 46.875em) {
  #first h4.tit_icon,
  #houjin h4.tit_icon {
    font-size: 18px;   /* スマホ向けに少し小さく */
    gap: 10px;
    margin: 0 auto 5px auto;
    width: 94%;
  }

  #first h4.tit_icon::before,
  #houjin h4.tit_icon::before {
    width: 12px;
    height: 12px;
    margin-top: -2px !important;
  }
} 
/* -----------------------------------------------------------
   ★ファストレンタルとは？
 ----------------------------------------------------------- */
#first .r_first_what {
  max-width: 1200px !important;
  /* 左右中央寄せの鉄板設定 */
  margin-left: auto !important;
  margin-right: auto !important;
  margin-bottom: 60px !important;
  padding: 0 20px !important;
  display: block !important;
  float: none !important; /* floatが邪魔している場合を考慮 */
  clear: both !important;
  
  font-family: "Noto Sans JP", sans-serif !important;
  color: #333 !important;
}
#first .r_first_what .r_f_what_container {
  display: flex;
  justify-content: space-between;
  gap: 20px;
}
#first .r_first_what .r_f_what_item {
  flex: 1;
  display: flex;
  flex-direction: column;
}
/* 画像エリア：16:9くらいの比率で確保 */
#first .r_first_what .r_f_what_image {
  width: 100%;
  aspect-ratio: 1.6 / 1; 
  background-color: #f0f0f0; /* 画像が入る前の仮色 */
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 20px;
}
#first .r_first_what .r_f_what_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
#first .r_first_what .r_f_what_sub_title {
  font-size: 18px;
  line-height: 1.4;
  margin-bottom: 15px;
  text-align: center;
  font-weight: bold;
  min-height: 3em; /* 高さを揃えてガタつき防止 */
  display: flex;
  align-items: center;
  justify-content: center;
}
#first .r_first_what .r_f_what_text {
  font-size: 14px;
  line-height: 1.8;
  color: #555;
  text-align: justify;
}
@media screen and (max-width: 768px) {
  #first .r_first_what {
  max-width: 96% !important;
  padding: 0 !important;
  margin: 0 auto 40px auto !important;
  }
  #first .r_first_what h2 {
  padding-bottom: 0;
  }
  #first .r_first_what .r_f_what_container {
    flex-direction: column;
    gap: 30px;
  }
  #first .r_first_what .r_f_what_item {
    width: 100%;
  }
  #first .r_first_what .r_f_what_sub_title {
    font-size: 20px !important;
    min-height: auto;
    margin-bottom: 10px;
  }
  #first .r_first_what .r_f_what_text {
    font-size: 14px; /* スマホは少し読みやすく大きく */
  }
}
/* -----------------------------------------------------------
   ★ご利用の流れ　個人
 ----------------------------------------------------------- */
#first .first_btn {
    margin: 20px 0;
}

#first .first_btn .r_f_flow_btn {
    display: inline-block;
    padding: 8px 40px;      /* ボタンの上下左右の余白 */
    text-decoration: none;   /* リンクの下線を消す */
    border-radius: 50px;     /* 角丸（大きく設定するとカプセル型になります） */
    font-size: 16px;
    font-weight: bold;
    transition: all 0.3s ease;
    border: 1px solid #418f94;
}

/* ホバー時の動き（色が反転するスタイル） */
#first .first_btn .r_f_flow_btn:hover {
    background-color: #fff;
    color: #333 !important;
    opacity: 1;
}

#first .r_first_flow .r_f_flow_detail .first_btn a {
  text-decoration: none;
}

#first .r_first_flow {
  margin: 0 auto !important;
  padding: 0 20px 60px;
  color: #333;
  background: #d0e4e4;
}
#first .r_first_flow h2 {
  padding: 40px 0 20px 0;
}
#first .r_first_flow_nav {
    display: flex;
    justify-content: center;
    gap: 15px;
    padding: 0 20px 40px 20px;
}
#first .r_first_flow_nav .nav_item {
    flex: 1;
    max-width: 400px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 18px 20px;
    border-radius: 5px;
    background-color: #fff;
    text-decoration: none;
    transition: all 0.3s ease;
}
#first .r_first_flow_nav .nav_text {
    position: relative;
    padding-right: 25px;
    color: #333;
    font-size: 16px;
    font-weight: normal;
    line-height: 1;
}
#first .r_first_flow_nav .nav_text::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 0;
    transform: translateY(-30%); 
    border-style: solid;
    border-width: 8px 6px 0 6px;
    border-color: #333 transparent transparent transparent;
}
#first .r_first_flow_nav .nav_item:hover {
    background-color: #f6f6f6;
    border-color: #999;
}
#first .r_first_flow .r_f_flow_step {
  background-color: #fff;
  border: 1px solid #5c9292;
  border-radius: 15px;
  padding: 40px;
  margin: 0 auto;
  box-shadow: 0 5px 15px rgba(0,0,0,0.05);
  max-width: 1200px;
}
#first .r_first_flow .r_f_flow_step_header {
  text-align: center;
  margin-bottom: 40px;
}
#first .r_first_flow .r_f_flow_step_label {
  display: block;
  font-size: 14px;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.1em;
}
#first .r_first_flow .r_f_flow_step_title {
  font-size: 22px;
  font-weight: bold;
  margin-bottom: 15px;
  padding: 5px 30px;
  display: flex;
  align-items: center;    /* 上下の中央を揃える */
  gap: 12px;
  background-color: #418f94;
  color: #fff;
  border-radius: 200px;
}
#first .r_first_flow .r_f_flow_item {
  display: flex;
  align-items: flex-start;
  gap: 30px;
  margin-bottom: 30px;
  position: relative;
  padding-bottom: 40px;
}
#first .r_f_flow_item::after {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    background-image: url("/img/web/arrow.svg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    width: 30px;
    height: 30px;
    bottom: 0;
}
#first .r_f_flow_item_none::after {
  background: none !important;
}
#first .r_f_flow_item_none {
  padding-bottom: 0 !important;
}
/* 最後のアイテムには矢印を表示させない */
#first .r_f_flow_item:last-child {
    padding-bottom: 0;
    margin-bottom: 0;
}
#first .r_f_flow_item::before {
    content: "";
    position: absolute;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 2px; 
    height: 80px;
    background-color: #dcdcdc;
    z-index: -1;
}
#first .r_first_flow .r_f_flow_image {
  flex: 0 0 300px;
  aspect-ratio: 3 / 2;
  border-radius: 10px;
  overflow: hidden;
  background-color: #f9f9f9;
  border: 1px solid #86b1b0;
}
#first .r_first_flow .r_f_flow_image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 10px;
}
#first .r_first_flow .r_f_flow_image2 {
  flex: 0 0 300px;
  aspect-ratio: 3 / 2;
  border-radius: 10px;
  overflow: hidden;
  background-color: #eff5f7;
  display: flex;
  justify-content: center;
  align-items: center;
}
#first .r_first_flow .r_f_flow_image2 img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
#first .r_first_flow .r_f_flow_detail {
  flex: 1;
}
#first .r_first_flow .r_f_flow_detail a {
  color: #418f94;
  text-decoration: underline;
}
#first .r_first_flow .r_f_flow_detail a:hover {
  opacity: 0.8;
} 
#first .r_first_flow .r_f_flow_detail h5 {
  font-size: 18px;
  font-weight: bold;
  margin-bottom: 10px;
  color: #333;
}

#first .r_first_flow .r_f_flow_detail p {
  font-size: 15px;
  line-height: 1.7;
  color: #666;
}
@media screen and (max-width: 768px) {
  #first .r_first_flow .r_f_flow_detail h5 {
  font-size: 20px;
  }
}

/* -----------------------------------------------------------
   ★ご利用の流れ　法人
 ----------------------------------------------------------- */
#first .r_houjin_link,
#houjin .r_houjin_link {
  background: #418f94;
  color: #fff;
  padding: 10px 40px;
  border-radius: 50px;
  display: block;
  max-width: 350px;
  text-align: center;
}
#first .r_houjin_link:hover,
#houjin .r_houjin_link:hover {
  opacity: 0.8;
}

#first .r_first_flow .r_f2_flow_step,
#houjin .r_first_flow .r_f2_flow_step {
  background-color: #fff;
  border: 1px solid #5c9292;
  border-radius: 15px;
  padding: 40px;
  margin: 0 auto 60px auto;
  box-shadow: 0 5px 15px rgba(0,0,0,0.05);
  max-width: 1200px;
}
#first .r_f2_flow_item,
#houjin .r_f2_flow_item {
  margin-bottom: 40px;
}
#first .r_first_flow .r_f2_flow_step_title,
#houjin .r_first_flow .r_f2_flow_step_title {
  font-size: 22px;
  font-weight: bold;
  margin-top: 5px;
}
#first .r_f2_flow_sbox,
#houjin .r_f2_flow_sbox {
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
    font-family: sans-serif;
}
#first .r_flow_item,
#houjin .r_flow_item {
    display: flex;
    align-items: flex-start;
    border-bottom: 1px solid #e0e0e0;
    padding: 30px 0;
}
#first .r_flow_item:last-child,
#houjin .r_flow_item:last-child {
    border-bottom: none;
}
#first .r_flow_num_wrap,
#houjin .r_flow_num_wrap {
    flex: 0 0 70px;
    margin-right: 25px;
}
#first .r_flow_num,
#houjin .r_flow_num {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 70px;
    height: 70px;
    background-color: #5d5d5d;
    color: #ffffff;
    font-size: 28px;
    font-weight: bold;
    border-radius: 50%;
    font-family: Arial, sans-serif;
}
#first .r_flow_text_wrap,
#houjin .r_flow_text_wrap {
    flex: 1;
}
/* STEPタイトル */
#first .r_flow_title,
#houjin .r_flow_title {
    font-size: 22px;
    font-weight: bold;
    color: #333333;
    margin: 0 0 10px 0;
    line-height: 1.3;
}
/* STEP説明文 */
#first .r_flow_desc,
#houjin .r_flow_desc {
    font-size: 16px;
    color: #333;
    margin: 0;
    line-height: 1.6;
}
@media screen and (max-width: 768px) {
  #houjin .r_first_flow .r_f2_flow_step {
  margin: 0 auto 0 auto;
  }
  #first .r_houjin_link,
  #houjin .r_houjin_link {
  padding: 10px 15px;
  }
  #houjin .r_f2_flow_step .r_btn1 {
  margin-top: 0;
  }
  #first .r_first_flow .r_f2_flow_step,
  #houjin .r_first_flow .r_f2_flow_step {
    width: 94%;
    padding: 25px 15px;
  }
  #first .r_flow_num,
  #houjin .r_flow_num {
  width: 40px;
  height: 40px;
  font-size: 22px;
  }
  #first .r_flow_num_wrap,
  #houjin .r_flow_num_wrap {
  flex: 0 0 10px;
  margin-right: 15px;
  }
  #first .r_flow_item {
    padding: 15px 0;
  }
  #first .r_first_flow .r_f2_flow_step_title,
  #houjin .r_first_flow .r_f2_flow_step_title {
  font-size: 18px;
  }
  #first .r_houjin_link {
  padding: 10px;
}
  #first .r_first_f1 {
    padding-bottom: 20px !important;
  }
  #first .r_first_flow .r_f_flow_btn_area {
    margin-top: 0;
  }
  #first h3.tit_flow {
    padding: 10px 0;
    font-size: 20px;
  }
  #first .r_first_flow .r_f_flow_step {
    margin-bottom: 0;
  }
  #first .r_first_flow .r_f_flow_step_title {
  font-size: 16px;
  margin: 30px 0 15px 0;
  width: 100%;
  padding: 10px 5px 10px 10px;
  }

  #first .r_first_flow {
    width: 100%;
    padding: 0 0 5px;
    margin: 0 auto;
  }
  #first .r_first_flow .r_f_flow_step {
    padding: 25px 15px;
    width: 94%;
  }
  #first .r_first_flow .r_f_flow_image {
    flex: none;
    width: 100%;
  }
  #first .r_first_flow .r_f_flow_item {
    flex-direction: column; /* 縦並び */
    gap: 15px;
    flex-direction: column; 
    gap: 15px;
    padding-bottom: 40px;
    text-align: center;
    margin-bottom: 10px;
  }
  #first .r_first_flow .r_f_flow_item a {
    text-align: left !important;
  }
  #first .r_first_flow .r_f_flow_detail p {
    text-align: left;
  }
  /* 縦ラインの長さもスマホ用に調整 */
  #first .r_f_flow_item::before {
    height: 60px; 
  }
  #first .r_first_flow .r_f_flow_image2 {
    flex: 0 1 auto; 
    width: 100%;
    max-width: 100%;
    aspect-ratio: 3 / 2; 
  }
  #first .r_first_flow_nav {
    padding: 15px 0;
    width: 94%;
    margin: 0 auto !important;
  }
  #first .r_first_f2 .r_flow_title {
    font-size: 18px;
  }
  #first .r_f2_flow_item {
  margin-bottom: 20px;
  }
  #first .r_flow_title,
  #houjin .r_flow_title {
    font-size: 18px;
  }
}


/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   共通設定
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
.sysDisplayPcNone {
  display: none !important;
}
@media screen and (min-width: 768px) and (max-width: 1024px) {
  .sysDisplayTabletNone {
    display: none !important;
  }
}
@media (max-width: 768px) {
.sysDisplayPcNone {
  display: block !important;
}
.sysDisplayMobileNone {
  display: none !important;
}
.sysDisplayTabletNone {
    display: block !important;
}
}
/* -----------------------------------------------------------
   ★改行制御
 ----------------------------------------------------------- */
.br_sp { display: none;}
@media (max-width: 768px) {
  .br_sp { display: block;}
  .br_pc { display: none;}
}
/* -----------------------------------------------------------
   ★コンテンツページタイトル
 ----------------------------------------------------------- */
.r_con_tit {
  text-align: center;
  background: #86b1b0;
  color: #fff;
  padding: 60px 0;
  font-size: 1.8em;
  font-weight: bold;
}
@media screen and (max-width: 768px) {
  .r_con_tit {
  padding: 30px 0;
  font-size: 1.3em;
  }
}
/* -----------------------------------------------------------
   ★料金
 ----------------------------------------------------------- */
 .sysItemPrice {
  color: #428f94;
 }
 .sysItemPrice .tax-small {
  font-size: 0.65em;
  font-weight: 400;
  vertical-align: middle;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemPrice {
  font-size: 18px;
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
@media screen and (max-width: 768px) {
  #sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemPrice {
  font-size: 15px !important;
  }
}
/* -----------------------------------------------------------
   ★ボタンデザイン
 ----------------------------------------------------------- */
.r_btn1 { 
    text-align: center; 
    margin: 30px auto 0 auto; 
} 
.r_btn1 a { 
    display: inline-flex; 
    align-items: center; 
    justify-content: center; 
    position: relative; 
    min-width: min(20rem, 80vw); 
    padding: 20px 50px 20px 40px;
    background-color: #ffffff; 
    border: 1px solid #428f94; 
    border-radius: 50px; 
    color: #333333; 
    text-decoration: none; 
    font-weight: bold; 
    font-size: 16px; 
    line-height: 1; 
    transition: all 0.3s ease; 
    z-index: 1;
} 

/* 1. アイコンの「丸い背景」 */ 
.r_btn1 a::after { 
    content: ""; 
    position: absolute; 
    right: 20px; 
    width: 24px; 
    height: 24px; 
    background-color: #428f94; /* 初期：サイトカラー */ 
    border-radius: 50%; 
    transition: all 0.3s ease; 
    z-index: 2;
} 

/* 2. アイコンの中の「▶」（CSSで描く三角形） */ 
.r_btn1 a::before { 
    content: ""; 
    position: absolute; 
    right: 27px; /* 丸の中央に来るよう調整 */ 
    width: 0; 
    height: 0; 
    border-style: solid; 
    border-width: 5px 0 5px 8px; 
    border-color: transparent transparent transparent #ffffff; /* 初期：白 */ 
    transition: all 0.3s ease; 
    z-index: 3; /* 一番上に重ねる */ 
} 

/* アニメーション */ 
.r_btn1 a:hover { 
    background-color: #428f94; /* ボタン背景：サイトカラー */ 
    color: #ffffff;            /* 文字色：白 */ 
    opacity: 1 !important;
} 

/* ホバー時：丸の背景を「白」にして右に動かす */ 
.r_btn1 a:hover::after { 
    background-color: #ffffff; 
    transform: translateX(5px); 
} 

/* ホバー時：三角形の色を「サイトカラー」にして右に動かす */ 
.r_btn1 a:hover::before { 
    border-color: transparent transparent transparent #428f94; 
    transform: translateX(5px); 
} 

/* スマホ用の微調整 */ 
@media (max-width: 767px) { 
    .r_btn1 a { 
        padding: 20px 40px 20px 30px; 
        font-size: 15px; 
    } 
    .r_btn1 a::after { 
        width: 20px; 
        height: 20px; 
        right: 12px; 
    } 
    .r_btn1 a::before { 
        right: 17px; 
        border-width: 4px 0 4px 6px; 
    } 
}
/* -----------------------------------------------------------
   ★noimageの画像を書き換える
 ----------------------------------------------------------- */
/* 「noImage.gif」という名前が含まれるimgタグを特定して差し替え */
.sysItemImage img[src*="noImage.gif"] {
  /* 元の画像を透明にして消す */
  visibility: hidden;
  object-fit: contain;
}

.sysItemImage a:has(img[src*="noImage.gif"]) {
  /* 代わりの画像を背景として表示する */
  background-image: url("/img/web/noimg.png");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
  display: block;
  width: 100%;
  height: 100%;
   border-radius: 10px; 
}
  /* noimageと画像ありの場合の画像の高さを調節 */
.sysItemImage {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  background-color: #fff;
  aspect-ratio: 1 / 1;    /* どんな時も「正方形」を維持する */
  display: flex;          /* 中の画像を中央に配置 */
  align-items: center;
  justify-content: center;
}

.sysItemImage a {
  display: block;
  width: 100%;
  height: 100%;
}

.sysItemImage img {
  width: 100%;
  height: 100%;
  object-fit: contain;    /* 画像を枠内に収める（はみ出さない） */
  display: block;
}

/* noimageの時の調整 */
.sysItemImage img[src*="noImage.gif"] {
  visibility: hidden;
  width: 100%;
  height: 100%; /* 透明になっても高さを維持させる */
}
/* -----------------------------------------------------------
   ★見出し：●のアイコン
 ----------------------------------------------------------- */
 h2.tit_icon3 {
  display: flex;
  align-items: center; /* ドットと文字の上下中央を合わせる */
  gap: 15px;           /* ドットと文字の間の距離 */
  font-size: 24px;     /* PCサイズの見出し */
  font-weight: bold;
  color: #333;
  margin: 0 auto; /* 周囲の余白調整 */
  width: 100%;
  max-width: 1200px;
}

h2.tit_icon3::before {
  content: "";
  display: inline-block;
  width: 13px;         /* デザインに合わせたサイズ */
  height: 13px;
  background-color: #428f94; /* 添付画像の色味を再現 */
  border-radius: 50%;  /* 正円にする */
  flex-shrink: 0;      /* 画面が狭くなっても円を潰さない */
  margin-top: 5px auto !important;
}

@media (max-width: 46.875em) {
  h2.tit_icon3 {
    font-size: 18px;   /* スマホ向けに少し小さく */
    gap: 10px;
    margin: 0 auto 5px auto;
    width: 94%;
  }

  h2.tit_icon3::before {
    width: 12px;
    height: 12px;
    margin-top: -2px !important;
  }
} 
/* -----------------------------------------------------------
   ★見出し：●のアイコン：リンクありバージョン
 ----------------------------------------------------------- */
h2.tit_icon {
  display: flex;
  align-items: center; /* ドットと文字の上下中央を合わせる */
  gap: 15px;           /* ドットと文字の間の距離 */
  font-size: 24px;     /* PCサイズの見出し */
  font-weight: bold;
  color: #333;
  margin: 0; /* 周囲の余白調整 */
  width: auto !important;
}
h2.tit_icon::before {
  content: "";
  display: inline-block;
  width: 13px;         /* デザインに合わせたサイズ */
  height: 13px;
  background-color: #428f94; /* 添付画像の色味を再現 */
  border-radius: 50%;  /* 正円にする */
  flex-shrink: 0;      /* 画面が狭くなっても円を潰さない */
  margin-top: 5px;
}
h2.tit_icon + a {
  display: inline-block;
  font-size: 14px;
  color: #666;
  text-decoration: underline;
  margin-left: 0 !important;
  white-space: nowrap;
  transition: color 0.3s ease;
  align-self: center;
}
h2.tit_icon + a:hover {
  color: #428f94;
  text-decoration: none;
}
@media (max-width: 46.875em) {
  h2.tit_icon {
    font-size: 18px;   /* スマホ向けに少し小さく */
    gap: 10px;
    margin: 30px 0 0;
  }
  h2.tit_icon::before {
    width: 12px;
    height: 12px;
    margin-top: -2px !important;
  }
}
/* -----------------------------------------------------------
   ★見出し：ハートアイコン
 ----------------------------------------------------------- */
h2.tit_icon2 {
  display: flex;
  align-items: center; 
  gap: 12px;
  font-size: 24px;
  font-weight: bold;
  color: #333;
  margin: 0 auto;
  width: min(75rem, 100%);
  padding-bottom: 20px;
}
h2.tit_icon2::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 24px;
  background-image: url("/img/web/r_heart.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  flex-shrink: 0;
  color: #689c9d;
}
@media (max-width: 46.875em) {
  h2.tit_icon2 {
    font-size: 18px;
    gap: 10px;
    width: 94%;
    margin: 0 auto;
    padding-bottom: 10px;
  }
  h2.tit_icon2::before {
    width: 24px;
    height: 20px;
  }
}
/* -----------------------------------------------------------
   ★内部リンクボタン　デザイン設定
 ----------------------------------------------------------- */
.btn-common {
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  margin: min(1.875rem, 8vw) auto 0;
}
.btn-common a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: min(3.75rem, 16vw);
  font-size: min(0.9375rem, 4vw);
  font-weight: 700;
  line-height: 1.4;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: 100px;
  background-color: #ffffff;
  padding-block: min(0.625rem, 2.6666666667vw);
  padding-inline: min(2.5rem, 10.6666666667vw);
  position: relative;
  transition: 200ms;
}
.btn-common a::after {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(0.5rem, 2.1333333333vw);
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: min(1.25rem, 5.3333333333vw);
  transform: translateY(-50%);
  transition: 200ms;
}
.btn-common a:hover {
  color: #ffffff;
  background-color: #333333;
  opacity: 1;
}
.btn-common a:hover::after {
  background-image: url(../img/layout/common/arrow_right_white.png);
}

.sysFuncItemBlock .sysCartButton {
  width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  border-radius: 100px;
  background-color: #333333;
  padding: min(0.625rem, 2.6666666667vw) min(0.625rem, 2.6666666667vw) min(0.5625rem, 2.4vw);
  margin-top: min(0.8125rem, 3.4666666667vw);
  position: relative;
}

/* ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆
   共通パーツ
   ◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆◆ */
/* -----------------------------------------------------------
   ★よくある質問バナー
 ----------------------------------------------------------- */
/* バナー全体の設定 */
.r_faq_banner {
    display: block;
    text-decoration: none;
    color: #333;
    border: 1px solid #5f9697;
    border-radius: 15px;
    padding: 20px;
    margin: 40px auto 60px auto !important;
    transition: background-color 0.3s;
    max-width: 900px;
}
.r_faq_banner:hover {
    background-color: #f9fdfd;
}
.r_faq_banner .faq_banner_inner {
    display: flex;
    align-items: center;
}
.r_faq_banner .faq_title_group {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    padding-right: 30px;
    border-right: 1px solid #ccc;
}
.r_faq_banner .faq_icon {
    width: 60px;
    height: 60px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.r_faq_banner .faq_icon img {
    width: 60%;
    height: auto;
}
.r_faq_banner .faq_title {
    font-size: 22px;
    font-weight: bold;
    white-space: nowrap;
}

/* 説明文（PC用） */
.r_faq_banner p {
    padding-left: 30px;
    font-size: 14px;
    line-height: 1.6;
}

/* --- スマホ用レイアウト（幅768px以下） --- */
@media screen and (max-width: 768px) {
    .r_faq_banner { 
      width: 94%;
      margin: 0 auto;
      padding: 10px 15px 20px 15px;
    }
  
    .r_faq_banner .faq_banner_inner {
        justify-content: center; /* 中央寄せ */
        display: block;
    }
    
    .r_faq_banner .faq_title_group {
        border-right: none; /* 区切り線を消す */
        padding-right: 0;
    }

    
    .r_faq_banner .faq_title {
        font-size: 18px; /* スマホ用に少し小さく */
    }
    
    .r_faq_banner .faq_icon {
        width: 50px;
        height: 50px;
    }
}
/* -----------------------------------------------------------
   ★ハンバーガーメニュー
 ----------------------------------------------------------- */

/* --- アコーディオン全体 --- */
.y_menu_group {
  border-bottom: 1px solid #ddd;
  background-color: #fff;
  z-index: 1;
}

/* タイトル部分 */
.y_menu_title {
  cursor: pointer;
  position: relative;
  padding: 18px 20px;
  font-size: 15px;
  font-weight: bold;
  margin: 0 !important;
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: #333;
}

/* 矢印アイコン */
.y_menu_title::after {
  content: '';
  width: 10px;
  height: 10px;
  border-right: 1px solid #222;
  border-bottom: 1px solid #222;
  transform: rotate(45deg);
  transition: 0.3s;
}

/* 開いた時の矢印 */
.y_menu_group.is-open .y_menu_title::after {
  transform: rotate(-135deg);
}

/* リストの中身（1列） */
.y_menu_list {
  display: none; /* JSで制御 */
  padding: 0 20px 20px !important;
  margin: 0 !important;
  list-style: none !important;
  background-color: #fff;
}

.y_menu_list li {
  padding: 0;
  border-top: 1px solid #f9f9f9; /* 項目間に薄い線を入れると見やすいです */
}

.y_menu_list a {
  text-decoration: none;
  color: #333;
  font-size: 14px;
  display: block;
  padding: 10px 0 !important;
}

.r_f_vertical_menu li {
  border-bottom: 1px solid #ddd;
  padding: 18px 20px;
  font-size: 15px;
}
.r_f_vertical_menu li:last-child {
  border-bottom: none;
}
/* --- 下段：薄いベージュ背景のエリア --- */
.r_h_bottom_area {
  background-color: #f6f5f1; /* 画像に合わせた明るいベージュ */
  padding: 30px 25px 50px;    /* 上下にしっかり余白を持たせる */
  clear: both;
}

/* ----------------------------------------------------------- 
    ★スマホヘッダーのフォーム風リンク
    ----------------------------------------------------------- */ 

/* スマホのみ適用 */
@media screen and (max-width: 767px) {
    .header-search { display: none;}
    .r_h_spbtn {
        padding: 10px 15px; /* 外側の余白 */
        background: #e3f0f0;
    }

    .r_h_spbtn a {
        display: flex;
        align-items: center;
        justify-content: flex-start;
        position: relative;
        
        /* 見た目の設定 */
        height: 50px;
        padding: 0 45px; /* 虫眼鏡と矢印のスペースを確保 */
        background-color: #fff;
        border: 1px solid #e0e0e0; /* 薄いグレーの枠線 */
        border-radius: 25px; /* 完全に丸くする */
        
        /* テキスト設定 */
        color: #333;
        text-decoration: none;
        font-size: 13px;
        font-weight: 500;
        letter-spacing: 0.03em;
    }

    /* 左側の虫眼鏡アイコン（疑似要素） */
    .r_h_spbtn a::before {
        content: "";
        position: absolute;
        left: 15px;
        width: 18px;
        height: 18px;
        background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%23666'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z'%3E%3C/path%3E%3C/svg%3E");
        background-repeat: no-repeat;
        background-position: center;
        background-size: contain;
    }

    /* 右側の三角矢印（疑似要素） */
    .r_h_spbtn a::after {
        content: "";
        position: absolute;
        right: 20px;
        width: 8px;
        height: 8px;
        border-top: 2px solid #729494; /* あの緑色のドットと同じ色 */
        border-right: 2px solid #729494;
        transform: rotate(45deg);
    }
}

/* PCでは非表示にする場合 */
@media screen and (min-width: 768px) {
    .r_h_spbtn {
        display: none;
    }
}

/* ----------------------------------------------------------- 
    ★ヘッダー設定（モーダルも） 
    ----------------------------------------------------------- */ 
/* 【1】ナビ全体を強制的に横並びにする */ 
.rep_h_gnav > ul { 
    display: flex !important; 
    flex-direction: row !important; /* 強制横並び */ 
    align-items: center !important; 
    justify-content: flex-start !important; /* 左寄せ */ 
    gap: 40px !important;            /* 項目間の余白 */ 
    list-style: none !important; 
    padding: 0 !important; 
    margin: 0 !important; 
    width: auto !important; 
} 
.rep_h_gnav > ul > li { 
    display: inline-block !important; 
    white-space: nowrap !important; /* 改行禁止 */ 
} 
/* 【2】ヘッダー本体：一番上に固定（被り防止） */ 
#sysHeader { 
    z-index: 10005 !important; /* 全てより上に設定 */ 
    background-color: #ffffff !important; 
    position: fixed !important; /* relativeからfixedに変更  */ 
    top: 0 !important;          /* 画面の一番上に固定 */ 
    left: 0 !important; 
    width: 100% !important; 
    z-index: 10005 !important; 
} 
/* 【3】モーダル本体：位置をヘッダーのすぐ下に固定 */ 
.mega-modal { 
    display: none; 
    position: fixed !important; 
    /* ↓ヘッダーの高さ（青い線の位置）に合わせて調整 */ 
    top: 122px !important;  
    left: 0 !important; 
    width: 100% !important; 
    background: #ffffff !important; 
    /* ★重要：ヘッダー(10005)より少し下げ、暗転(10000)より上に */ 
    z-index: 10001 !important;  
    margin-top: -3px; 
    background: #efefec !important;  
} 
/* 【4】暗転レイヤー */ 
#h_nav_mega-overlay { 
    display: none; 
    position: fixed !important; 
    top: 0 !important; 
    left: 0 !important; 
    width: 100% !important; 
    height: 100vh !important; 
    background: rgba(0, 0, 0, 0.6) !important; 
    z-index: 10000 !important;  
} 
@keyframes fadeIn { 
    from { opacity: 0; } 
    to { opacity: 1; } 
} 
/* 表示用のクラスがついた時にアニメーションを実行 */ 
body.modal-active #h_nav_mega-overlay { 
    display: block !important; 
    animation: fadeIn 0.5s ease forwards; 
} 
/* 親要素の制限をすべて解除（横並び） */ 
#sysHeader,  
.header-content,  
.header-bottom,  
.rep_h_gnav_sec,  
.rep_h_gnav, 
.rep_h_gnav > ul, 
.has-modal { 
    overflow: visible !important; 
} 
/* 通常のときの矢印（▼） */ 
.modal-trigger .arrow::before { 
    content: "▼"; 
    margin-left: 5px; 
    display: inline-block; 
    color: #5f9697; 
    font-size: 0.7em; 
} 
/* モーダルが開いているとき（is-openクラスがあるとき）の矢印（▲） */ 
.has-modal.is-open .modal-trigger .arrow::before { 
    content: "▲"; 
    color: #5f9697; 
    font-size: 0.7em; 
} 
/* --------モーダル内部：コンテンツ配置 -------- */ 
/* 【1】中身を縦に並べる（家電が上、家具が下） */ 
.mega-modal-inner { 
    display: flex !important; 
    flex-direction: column !important; /* 縦並びに変更 */ 
    gap: 30px !important;            /* 家電と家具の間の余白 */ 
    max-width: min(75rem, 320vw) !important;    /* 画像のゆったり感に合わせる */ 
    margin: 0 auto !important; 
    padding: 20px 0 30px 0 !important; 
} 
/* 【2】セクション（家電/家具）ごとの設定 */ 
.mega-section { 
    width: 100% !important; 
} 
/* 【3】見出しエリア（タイトルと「一覧をみる」） */ 
.mega-head { 
    display: flex !important; 
    align-items: center !important; 
    gap: 20px !important; 
    margin-bottom: 5px !important; 
} 
.mega-head h3 { 
    font-size: 26px !important;   
    font-weight: bold !important; 
    color: #333 !important; 
    margin: 0 !important; 
    letter-spacing: 0.1em !important; 
} 
.mega-modal-inner .all-link { 
    font-size: 14px !important; 
    color: #666 !important; 
    text-decoration: underline !important; 
    margin-top: 8px !important; 
} 
/* 【4】アイコンリスト：横に並べて折り返す */ 
.mega-modal-inner .icon-list { 
    display: flex !important; 
    flex-wrap: wrap !important;      /* 幅がいっぱいになったら自動で折り返す */ 
    justify-content: flex-start !important; 
    gap: 20px 10px !important;       /* 上下25px、左右15pxの隙間 */ 
    list-style: none !important; 
    padding: 0 !important; 
    margin: 0 !important; 
} 
.mega-modal-inner .icon-list li { 
    width: 90px !important;         /* 1つのアイテムの横幅 */ 
} 
/* アイコンと文字のセット */ 
.mega-modal-inner .icon-list a { 
    display: flex !important; 
    flex-direction: column !important; 
    align-items: center !important; 
    text-decoration: none !important; 
    color: #333 !important; 
} 
/* ◯ 丸い背景画像枠 ◯ */ 
.mega-modal-inner .icon-list [class^="img-p"],.mega-modal-inner .icon-list [class^="img-k"] { 
    width: 85px !important; 
    height: 85px !important; 
    border-radius: 50% !important; 
    border: 1px solid #ccc !important; 
    background-color: #fff !important; 
    background-repeat: no-repeat !important; 
    background-position: center !important; 
    background-size: contain !important; /* または 70% などの数値で余白調整 */ 
    display: flex !important; 
    margin-bottom: 12px !important; 
} 
/* 家電の画像設定 */ 
.img-p1  { background-image: url('/img/web/cat_e1.png') !important; } 
.img-p2  { background-image: url('/img/web/cat_e2.png') !important; } 
.img-p3  { background-image: url('/img/web/cat_e3.png') !important; } 
.img-p4  { background-image: url('/img/web/cat_e4.png') !important; } 
.img-p5  { background-image: url('/img/web/cat_e5.png') !important; } 
.img-p6  { background-image: url('/img/web/cat_e6.png') !important; background-size: 90% !important;} 
.img-p7  { background-image: url('/img/web/cat_e7.png') !important; } 
.img-p8  { background-image: url('/img/web/cat_e8.png') !important; } 
.img-p9  { background-image: url('/img/web/cat_e9.png') !important; } 
.img-p10  { background-image: url('/img/web/cat_e10.png') !important; } 
.img-p11  { background-image: url('/img/web/cat_e11.png') !important; } 
/* 家具の画像設定 */ 
.img-k1 { background-image: url('/img/web/cat_k1.png') !important; } 
.img-k2 { background-image: url('/img/web/cat_k2.png') !important; } 
.img-k3 { background-image: url('/img/web/cat_k3.png') !important; } 
.img-k4 { background-image: url('/img/web/cat_k4.png') !important; } 
.img-k5 { background-image: url('/img/web/cat_k5.png') !important; } 
.img-k6 { background-image: url('/img/web/cat_k6.png') !important; } 
.mega-modal-inner .icon-list img { 
    max-width: 100% !important; 
    max-height: 100% !important; 
    object-fit: contain !important; 
} 
/* アイコン下のテキスト */ 
.mega-modal-inner .icon-list span { 
    font-size: 11px !important; 
    font-weight: normal !important; 
    line-height: 1.4 !important; 
    text-align: center !important; 
    white-space: normal !important;  /* 長い名前は折り返し */ 
} 
/* --------カートボタン共通設定 -------- */ 
.sysFuncCartInfo.header-cart { 
    position: relative !important; 
    display: flex !important; 
    align-items: center !important; 
    justify-content: center !important; 
    width: auto !important; 
    background: none !important; 
    width: 50px !important; /* 他のボタンと幅を合わせる */
    height: 50px !important;
    z-index: 10 !important;
} 
.sysFuncCartInfo.header-cart .sysHeadline::before { 
     content: "" !important; 
     display: block !important; 
     width: 22px !important;  
     height: 22px !important; 
     background-image: url(/img/web/r_cart.svg) !important;  
     background-size: contain !important; 
     background-repeat: no-repeat !important; 
     background-position: center bottom !important;
   } 

/* カートを見るリンク（aタグ）をボタン全体に広げて一番上に配置 */
.sysFuncCartInfo.header-cart .sysCartInfoCartIn a {
    display: block !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    font-size: 0 !important;      /* 「カートを見る」という文字は消す */
    background: transparent !important; /* 背景は透明に */
    z-index: 100 !important;     /* ★最前面に持ってくる */
    text-indent: -9999px;        /* 文字を確実に飛ばす */
}

/* カートボタンのアイコンとテキストの上下を入れ替える */

.sysFuncCartInfo.header-cart .sysHeadline {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    pointer-events: none !important; /* 下のリンクを触れるように、自身はスルーさせる */
    font-size: 11px !important;
    font-weight: bold;
    gap: 2px !important;
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    background: none !important;
}
@media screen and (max-width: 768px) {
  .sysFuncCartInfo.header-cart .sysHeadline {
    font-size: 8.5px !important;
  }
  #sysHeader .header-cart .sysCartInfoCartIn a {
    display: block !important;
    position: absolute !important;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    font-size: 0 !important;      /* 「カートを見る」という文字は消す */
    background: none !important;  /* 背景画像も消して透明にする */
    z-index: 5 !important;        /* 一番上に持ってくる */
    background-size: 80% 80% !important;
  }
  .sysFuncCartInfo.header-cart .sysHeadline::before {
    width: 20px !important; 
    height: 20px !important;
    background-position: center top !important; /* 位置を調整 */
    margin-bottom: 0 !important;
  }
}

/* --------スマホメニュー・レスポンシブ設定 -------- */ 
@media (max-width: 767px) { 
   #sysHeader { 
     background-color: transparent !important; 
     transition: box-shadow 0.4s ease-in-out !important; 
     position: fixed !important; 
     top: 0 !important; 
     left: 0 !important; 
     width: 100% !important; 
     z-index: 10005 !important; 
     box-shadow: none !important; 
   } 
   #sysHeader.header-shadow { 
     box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08) !important; 
   } 
   .header-top { 
     position: relative !important; 
     z-index: 10006 !important; 
     background-color: #ffffff !important;  
     border-bottom: 1px solid #eee; 
   } 
   .header-bottom_sec { 
     position: relative !important; 
     z-index: 10005 !important; 
     background-color: #ffffff !important;  
     transition: opacity 0.2s ease-in-out, visibility 0.2s !important; 
     opacity: 1 !important; 
     visibility: visible !important; 
   } 
   .header-bottom_sec.header-hide { 
     opacity: 0 !important; 
     visibility: hidden !important; 
     pointer-events: none !important; 
     position: absolute !important; 
   } 
   .header-bottom-left { 
     display: none !important; 
   } 
   .header-bottom-right { 
     width: 100% !important; 
     padding: 0 !important; 
     margin: 0 !important; 
   } 
   .sp_h_menu, 
   .sp_h_menu .sysContent, 
   .sp_h_menu nav { 
     width: 100% !important; 
     display: block !important; 
   } 
   .sp_h_menu ul { 
     display: flex !important; 
     justify-content: space-around !important; 
     align-items: center !important; 
     list-style: none !important; 
     padding: 0 !important; 
     margin: 0 !important; 
     width: 100% !important; 
   } 
   .sp_h_menu li.sysText { 
     width: auto !important; 
     flex: 1 !important; 
     text-align: center !important; 
   } 
   .sp_h_menu li.sysText a { 
     display: block !important; 
     text-decoration: none !important; 
     color: #333 !important;  
     font-size: 13px !important; 
     white-space: nowrap !important; 
     padding: 8px 0 !important; 
     font-weight: bold;
   } 
   /* スマホ：カートボタンを縦並びに */ 
   .sysFuncCartInfo.header-cart .sysHeadline { 
     display: flex !important; 
     flex-direction: column !important; 
     align-items: center !important; 
     font-size: 8.5px !important; 
     gap: 2px !important; 
   } 
   .sysFuncCartInfo.header-cart .sysHeadline::before { 
     content: "" !important; 
     display: block !important; 
     width: 20px !important;  
     height: 20px !important; 
     background-image: url(/img/web/r_cart.svg) !important;  
     background-size: contain !important; 
     background-repeat: no-repeat !important; 
     background-position: center bottom !important;
   } 
   .header-user-menu li img { 
     width:80%; 
   } 
} 



/* -----------------------------------------------------------
   ★フッターメイン
 ----------------------------------------------------------- */
/* --- 全体共通 --- */
.r_footer { background-color: #555 !important; color: #fff !important; padding: 50px 0 !important; font-family: sans-serif !important; }
.r_footer a { color: #fff !important; text-decoration: none !important; }
.r_footer ul { list-style: none !important; padding: 0 !important; margin: 0 !important; }
.r_footer .r_footer_inner { max-width: 100%; margin: 0 auto;}
.r_footer .r_f_catch { text-align: center; margin-bottom: 30px; font-size: 14px; color: #fff !important; letter-spacing: 0.5em;}

/* --- PCレイアウト：常に表示させる --- */
.r_footer .r_f_main_nav { max-width: 1200px; margin: 0 auto; display: flex !important; justify-content: space-between !important; gap: 30px !important; }
.r_footer .r_f_nav_group { flex: 1 !important; }
.r_footer .r_f_nav_title { font-size: 16px; border-bottom: 1px solid #888; padding-bottom: 10px; margin-bottom: 15px; font-weight: bold; color: #fff !important; letter-spacing: 0.2em;}

/* 【修正】PCではリストを強制的に表示 */
.r_footer .r_f_nav_list { display: block !important; margin: 0 !important; }
.r_footer .r_f_nav_list li { margin-bottom: 8px !important; font-size: 13px !important; }

/* 家電の2カラム設定 */
.r_footer .r_f_nav_list_2col { display: grid !important; grid-template-columns: 1fr 1fr !important; }

.r_footer .r_f_line { border: none; border-top: 1px solid #777; margin: 40px 0; }
.r_footer .r_f_sbox { text-align: center; }
.r_footer .r_f_logo { width:250px; margin:0 auto 15px auto; color: #fff !important; }
.r_f_address { font-style: normal !important; font-size: 14px; color: #ccc !important; }
.r_f_address p { font-size: 12px;}

/* --- 追加メニュー（サブナビゲーション） --- */
.r_footer .r_f_sub_nav {
  max-width: 1200px;
  margin: 0 auto 30px;
  text-align: center;
}

.r_footer .r_f_sub_list {
  display: flex !important;
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 15px 30px !important;
}

.r_footer .r_f_sub_list li {
  font-size: 13px !important;
  letter-spacing: 0.05em;
}

.r_footer .r_f_sub_list a:hover {
  text-decoration: underline !important;
}

.r_footer .r_f_address .r_f_copyright {
  margin-top: 50px !important;
}
/* --- スマホレイアウト（768px以下） --- */
@media screen and (max-width: 768px) {
  .r_footer { padding-top: 30px !important;}
  .r_footer .r_f_main_nav {
    flex-direction: column !important;
    border: 1px solid rgba(255, 255, 255, 0.6) !important; /* 細い白線 */
    border-radius: 15px !important; /* 画像に合わせた大きな角丸 */
    overflow: hidden;
    margin: 0 15px !important; /* 左右に少し余白を作る */
    background-color: transparent !important;
    gap: 0 !important;
  }
  .r_footer .r_f_nav_group { border-bottom: 1px solid #888; width: 96%; margin: 0 auto !important;}
  .r_footer .r_f_nav_group:last-child { border-bottom: none; }
  .r_footer .r_f_nav_title {
    font-size: 15px !important;
    margin: 0 !important; 
    padding: 20px !important; 
    border-bottom: none !important; /* PC版の下線を消す */
    text-align: center !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    font-weight: normal !important;
    letter-spacing: 0.1em;
    cursor: pointer;
    position: relative;
    color: #fff !important;
    gap: 0 !important;
  }
  .r_footer .r_f_nav_title::after {
    content: ''; 
    position: absolute;
    right: 20px;
    width: 8px;
    height: 8px;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    transform: rotate(45deg); /* V字を作る */
    transition: 0.3s;
    margin-top: -4px;
  }
  .r_footer .r_f_nav_group.rf-open .r_f_nav_title::after {
    transform: rotate(-135deg); /* 上向きにする */
    margin-top: 2px;
  } 
  .r_footer .r_f_nav_list {
    padding: 0 20px 20px !important;
    text-align: left;
  }
  .r_footer .r_f_nav_group.rf-open .r_f_nav_list {
    display: block !important;
  }
  
  .r_footer .r_f_nav_list { display: none !important; padding: 0 15px 15px !important; }
  .r_footer .r_f_nav_group.rf-open .r_f_nav_list { display: block !important; }
/* リストを縦並びにする */
  .r_footer .r_f_sub_list {
    flex-direction: column !important; /* 縦方向に並べる */
    align-items: center !important;    /* 中央に寄せる */
    gap: 15px !important;              /* 縦の間隔を調整 */
    padding: 20px 0 !important;        /* 上下の余白 */
  }

  .r_footer .r_f_sub_list li {
    width: 100%;                       /* 横幅いっぱい使ってタップしやすく */
    text-align: center;
    font-size: 14px !important;        /* スマホで見やすいサイズに少し大きく */
  }

  .r_footer .r_f_sub_nav {
    margin-bottom: 20px;               /* 下のロゴとの距離を微調整 */
  }

/* --- 2カラムリストの強制設定 --- */
  .r_f_nav_list_2col {
  display: block !important; 
  overflow: hidden !important;
  padding: 10px 15px 20px !important;
  list-style: none !important;
  }

  .r_f_nav_list_2col li {
  /* floatを使って左に詰めて並べる */
  float: left !important;
  /* 横幅を50%にすることで、2つ並んだら自動で次にいく */
  width: 50% !important;
  box-sizing: border-box !important;
  margin: 5px 0 !important;
  padding-right: 5px !important; /* 隣との隙間 */
  font-size: 13px !important;
  text-align: left !important;
  }

  /* 最後の項目でfloatを解除するおまじない */
  .r_f_nav_list_2col::after {
  content: "";
  display: block;
  clear: both;
  }
  .r_f_line { display: none;}
  .r_footer .r_f_catch { margin-bottom: 10px; font-size: 11px;}
}
/* -----------------------------------------------------------
   ★フッター案内リンク設定
 ----------------------------------------------------------- */
 /* 全体背景とパディング */
.r_f_info {
  padding: 60px 20px;
  background: #e9eae7;
}

.r_f_info_inner {
  max-width: 1200px;
  margin: 0 auto;
}

/* ナビゲーションの並び */
.r_f_nav {
  display: flex;
  justify-content: space-between;
  margin-bottom: 40px;
}

.r_f_nav_item {
  display: flex;
  align-items: center;
  text-decoration: none;
  color: #333;
  width: 25%;
  padding: 0 20px;
  position: relative;
  transition: opacity 0.3s;
}

.r_f_nav_item:hover {
  opacity: 0.7;
}

/* PC時の仕切り線 */
.r_f_nav_item:not(:last-child)::after {
  content: "";
  position: absolute;
  right: 0;
  top: 10%;
  height: 80%;
  width: 1px;
  background-color: #ccc;
}

/* アイコン枠 */
.r_f_nav_icon {
  width: 60px;
  height: 60px;
  background-color: #fff;
  border-radius: 12px;
  flex-shrink: 0;
  margin-right: 15px;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.r_f_nav_icon img {
  width: 70%; /* アイコンの余白感はお好みで */
  height: auto;
}

/* テキスト部分 */
.r_f_nav_text div:first-child {
  font-size: 16px;
  font-weight: bold;
  margin: 0 0 5px 0;
}

.r_f_nav_text p {
  font-size: 12px;
  color: #666;
  margin: 0;
  line-height: 1.4;
}

/* 法人ボタン */
.r_f_btn_area {
  text-align: center;
}

.r_f_btn_biz {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 600px;
  height: 50px;
  background-color: #fff;
  border: 1px solid #729494; /* サイトカラー */
  border-radius: 10px;
  text-decoration: none;
  color: #333;
  font-weight: bold;
  position: relative;
}

.r_f_btn_biz::before {
  content: "";
  width: 8px;
  height: 8px;
  background-color: #729494;
  border-radius: 50%;
  margin-right: 10px;
}

.r_f_btn_biz::after {
  content: "";
  position: absolute;
  right: 20px;
  width: 8px;
  height: 8px;
  border-top: 2px solid #ccc;
  border-right: 2px solid #ccc;
  transform: rotate(45deg);
}

/* スマホ対応 */
@media (max-width: 768px) {
  .r_f_info {
    padding: 20px 15px 30px;
  }

  .r_f_nav {
    flex-direction: column;
  }

  .r_f_nav_item {
    width: 100%;
    padding: 20px 0;
    border-bottom: 1px solid #ccc; /* スマホは横線 */
  }

  .r_f_nav_item:not(:last-child)::after {
    display: none;
  }

  .r_f_nav_item::before {
    /* スマホ時の右矢印 */
    content: "";
    position: absolute;
    right: 5px;
    width: 8px;
    height: 8px;
    border-top: 2px solid #ccc;
    border-right: 2px solid #ccc;
    transform: rotate(45deg);
  }

  .r_f_btn_biz {
    height: 50px;
    font-size: 14px;
  }
}
/* ----------------------------------------------------------- 
    ★最近チェックした商品：スマホの横スクロール 
----------------------------------------------------------- */ 
#top .r_check {
  background: #eff0ee;
}
 /* セクションの画像にシャドウを適用 */
.r_check .sysItemImage {
  position: relative;
  border-radius: 10px;
  /* overflow: hidden; はそのままでOK */
  overflow: hidden; 
  background-color: #fff;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 10px 2px rgba(0, 0, 0, 0.05);
  margin: 5px; 
  border: 1px solid #eee;
}
.r_check .sysItemImage img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  box-shadow: none !important; /* img単体の影は消す */
}
.r_check .sysItemImage img:hover {
  box-shadow: 0 0 15px 3px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.3s ease;
}
.r_check { padding-bottom: 60px;}
/* --- 最近チェックした商品のスマホ用横スクロール設定 --- */
@media (max-width: 767px) {
  #top .r_check {
    padding-bottom: 20px;
  }
  /* セクション全体の余白調整（人気商品と同じ感触に） */
  .r_check {
    padding-block: min(0rem, 8vw);
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }

  .r_check .sysItemBlock {
    padding-inline: 0 !important;
  }

  /* 【神器1】親要素：絶対に折り返さず、はみ出しをスクロールさせる */
  .r_check .sysItemBlock ul {
    display: flex !important;
    flex-wrap: nowrap !important; /* 1行に強制 */
    gap: 0 !important;
    overflow-x: auto !important; /* スクロール有効化 */
    -ms-overflow-style: none;    /* IE/Edge用スクロールバー非表示 */
    scrollbar-width: none;       /* Firefox用スクロールバー非表示 */
    padding-right: 10px;
  }

  /* Chrome/Safari用スクロールバー非表示 */
  .r_check .sysItemBlock ul::-webkit-scrollbar {
    display: none;
  }

  /* 【神器2】左右の余白：最初と最後のアイテムが壁に張り付かないようにする */
  .r_check .sysItemBlock ul::before,
  .r_check .sysItemBlock ul::after {
    content: "";
    flex-shrink: 0;
    display: block;
    width: min(0.9375rem, 4vw);
    height: 1px;
  }

  /* 【神器3】子要素：カードの幅を固定して縮ませない */
  .r_check .sysItemBlock ul li {
    flex-shrink: 0 !important; /* 縮み防止（超重要！） */
    width: min(10rem, 42.6666666667vw) !important; /* 人気商品と同じ幅 */
    margin-right: min(0.625rem, 2.6666666667vw) !important;
    list-style: none !important;
  }

  .r_check .sysItemBlock ul li:last-of-type {
    margin-right: 0 !important;
  }

  /* 商品画像と名前の微調整 */
  .r_check .sysItemImage img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
    object-fit: cover;
  }
}


/* -----------------------------------------------------------
   ★人気商品セクション
 ----------------------------------------------------------- */
 /* 人気商品セクションの画像にシャドウを適用 */
.top-ranking .sysItemImage {
  position: relative;
  border-radius: 10px;
  /* overflow: hidden; はそのままでOK */
  overflow: hidden; 
  background-color: #fff;
  aspect-ratio: 1 / 1;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 10px 2px rgba(0, 0, 0, 0.05);
  margin: 5px; 
  border: 1px solid #eee;
}
.top-ranking .sysItemImage img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
  box-shadow: none !important; /* img単体の影は消す */
}
.top-ranking .sysItemImage img:hover {
  box-shadow: 0 0 15px 3px rgba(0, 0, 0, 0.1);
  transition: box-shadow 0.3s ease;
}
/* タイトル横のリンク */
.top-ranking .sysHeadline {
  display: flex;
  align-items: baseline;
  gap: 15px;
  width: min(75rem, 100%);
  margin: 0 auto 20px;
  padding: 0 10px; 
}
.top-ranking .sysHeadline a {
  font-size: 14px;
  color: #666;
  text-decoration: underline;
  white-space: nowrap;      /* 改行させない */
  line-height: 1.8;         /* 見出しとの高さ微調整 */
  transition: color 0.3s ease;
}

.top-ranking .sysHeadline a:hover {
  color: #729494;
  text-decoration: none;
}
@media screen and (max-width: 768px) {
  .top-ranking .sysHeadline  {
    width: 94%;
    margin: 0 auto 20px auto;
    padding-top: 30px !important;
    display: flex !important;
    align-items: center !important; /* 上下中央揃え */
    justify-content: flex-start !important;
    gap: 10px !important;
    height: auto !important;
  }
/* 見出し：余計な高さや余白を消す */
  .top-ranking .sysHeadline h2.tit_icon {
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important; /* 行の高さを詰めるとリンクと揃いやすくなります */
    display: flex !important;
    align-items: center !important;
  }

  /* リンク：見出しの真ん中に来るように調整 */
  .top-ranking .sysHeadline a {
    margin-top: 2px !important; /* 文字の重心を合わせるための微調整 */
    line-height: 1 !important;
    font-size: 13px !important;
    white-space: nowrap !important;
  }
}

/* -----------------------------------------------------------
   ★セットでお得に：スマホの横スクロール 
 ----------------------------------------------------------- */
#top .r_set {
  background: #eff0ee;
  padding-top: 0;
}
.r_set {
  padding-top: 40px;
}
/* タイトル横のリンク */
.r_set .sysHeadline {
  display: flex;
  align-items: baseline;
  gap: 15px;
  width: min(75rem, 100%);
  margin: 0 auto 20px;
  padding: 0 10px; 
}
.r_set .sysHeadline a {
  font-size: 14px;
  color: #666;
  text-decoration: underline;
  white-space: nowrap;      /* 改行させない */
  line-height: 1.8;         /* 見出しとの高さ微調整 */
  transition: color 0.3s ease;
}

.r_set .sysHeadline a:hover {
  color: #729494;
  text-decoration: none;
}
/* --- 画像の「お得」装飾 --- */
.r_set .sysItemImage {
  position: relative;
  border: 1px solid #b3a479; /* 枠線はゴールド */
  border-radius: 15px;       /* 全体の角丸 */
  overflow: hidden;         /* 画像を枠の角丸で切り取る */
  background-color: #fff;
  padding: 0 !important;    /* 内側の余白はなし */
  box-shadow: 0 0 10px 2px rgba(0, 0, 0, 0.05);
}

.r_set .sysItemImage img {
  width: 100%;
  height: 100%;
  object-fit: cover; /* 枠いっぱいに表示 */
  display: block;
}

.r_set .sysItemImage::before {
  content: "お得";
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  background-color: #b3a479; 
  color: #fff;
  font-size: 14px;
  font-weight: bold;
  padding: 6px 12px;
  border-bottom-right-radius: 15px; /* 右下のみ丸くして枠に馴染ませる */
  line-height: 1;
}

.r_set .sysItemImage:hover {
  opacity: 0.9;
  transition: 0.3s;
}
/* スマホの横スクロール */
@media (max-width: 767px) {
  .r_set {
    padding-block: min(0rem, 8vw);
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }

  .r_set .sysItemBlock {
    padding-inline: 0 !important;
  }

  .r_set .sysItemBlock ul {
    display: flex !important;
    flex-wrap: nowrap !important; /* 横一列に固定 */
    gap: 0 !important;
    overflow-x: auto !important; /* 横スクロールを許可 */
    -ms-overflow-style: none;    /* スクロールバー非表示(IE) */
    scrollbar-width: none;       /* スクロールバー非表示(Firefox) */
  }

  .r_set .sysItemBlock ul::-webkit-scrollbar {
    display: none;
  }

  .r_set .sysHorizontal { padding-right: 10px;}
  .r_set .sysItemBlock ul::before,
  .r_set .sysItemBlock ul::after {
    content: "";
    flex-shrink: 0;
    display: block;
    width: min(0.9375rem, 4vw);
    height: 1px;
  }

  .r_set .sysItemBlock ul li {
    flex-shrink: 0 !important; /* 親の幅に負けない */
    width: min(10rem, 42.6666666667vw) !important; /* カードの横幅 */
    margin-right: min(0.625rem, 2.6666666667vw) !important;
    list-style: none !important;
  }

  .r_set .sysItemBlock ul li:last-of-type {
    margin-right: 0 !important;
  }

  .r_set .sysItemImage img {
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 1 / 1;
    object-fit: cover;
  }
  .r_set .sysHeadline  {
    width: 94%;
    margin: 0 auto 20px auto;
    padding-top: 30px !important;
    display: flex !important;
    align-items: center !important; /* 上下中央揃え */
    justify-content: flex-start !important;
    gap: 10px !important;
    height: auto !important;
  }
/* 見出し：余計な高さや余白を消す */
  .r_set .sysHeadline h2.tit_icon {
    margin: 0 !important;
    padding: 0 !important;
    line-height: 1.2 !important; /* 行の高さを詰めるとリンクと揃いやすくなります */
    display: flex !important;
    align-items: center !important;
  }

  /* リンク：見出しの真ん中に来るように調整 */
  .r_set .sysHeadline a {
    margin-top: 2px !important; /* 文字の重心を合わせるための微調整 */
    line-height: 1 !important;
    font-size: 13px !important;
    white-space: nowrap !important;
  }
}
/* -----------------------------------------------------------
   ★対応エリアセクション
 ----------------------------------------------------------- */
 .area_list {
  background: #eff0ee;
  padding: 40px 0 60px !important;
 }

 .area_list h2 {
  padding-bottom: 5px;
 }

 /* --- 対応エリアアコーディオン全体 --- */
.area-accordion {
  max-width: min(75rem, 95%);
  margin: 0 auto;
  background: #fff;
  border: 1px solid #dddddd;
  border-radius: 12px;
  overflow: hidden;
   /* ボックスにシャドウ */
  background-color: #fff; /* 背景が白だと影が綺麗に見えます */
  margin-bottom: 15px;    /* ボックス同士の間隔 */
  border-radius: 20px;     /* 少し角を丸くすると柔らかい印象に */
  border: none;           /* 枠線があると影と喧嘩するので消すのがおすすめ */
  box-shadow: 0 0 15px rgba(0, 0, 0, 0.05); 
  transition: box-shadow 0.3s ease; /* 動きを滑らかに */
}

.area-item {
  width: 96%; /* 全部 96% に統一 */
  margin: 0 auto;
}

.area-item:not(:last-child) {
  border-bottom: 1px solid #dddddd;
}

/* ヘッダー部分 */
.area-header {
  list-style: none;
  padding: 20px 25px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center; /* 県名を中央に */
  position: relative;
  transition: background-color 0.2s;
}

/* デフォルトの矢印を消す(Safari対策含む) */
.area-header::-webkit-details-marker {
  display: none;
}

/* 県名テキスト */
.area-pref {
  font-weight: bold;
  font-size: 18px;
  color: #333;
}

/* 右端の矢印アイコン */
.area-icon {
  position: absolute;
  right: 25px;
  width: 10px;
  height: 10px;
  border-right: 2px solid #999;
  border-bottom: 2px solid #999;
  transform: rotate(45deg);
  transition: transform 0.3s;
}

/* 開いている時の矢印の向き */
.area-item[open] .area-icon {
  transform: rotate(-135deg);
}

/* 中身（市区町村リスト）の部分 */
.area-details {
  padding: 25px;
  background-color: #fff;
}

.area-city-group {
  font-weight: bold;
  color: #729494; /* サイトカラーに合わせて調整してください */
  margin: 0;
  font-size: 17px;
}

.area-city-list {
  font-size: 14px;
  color: #666;
  line-height: 1.6;
  margin-bottom: 10px;
}

/* スマホ用の微調整 */
@media (max-width: 767px) {
  .area-header {
    padding: 15px;
  }
  .area-pref {
    font-size: 16px;
  }
  .area-icon {
    right: 15px;
  }
  .area_list {
  background: #eff0ee;
  padding: 30px 0 !important;
 }
}
/* -----------------------------------------------------------
   ★よくある質問セクション
 ----------------------------------------------------------- */
.r_faq {
  padding: 60px 0;
  max-width: min(75rem, 95%) !important;;
  margin: 0 auto !important;;
}

.r_faq h2 {
  padding-bottom: 5px;
}

.r_faq_container {
  display: flex;
  flex-direction: column;
  gap: 15px;
}

/* --- アコーディオン外枠 --- */
.r_faq_item {
  border: 1px solid #dddddd;
  border-radius: 12px;
  background-color: #fff;
  overflow: hidden;
  transition: all 0.3s ease;
}

/* --- 質問部分（クリックエリア） --- */
.r_faq_question {
  list-style: none; /* デフォルトの三角を消す */
  padding: 20px 25px;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 15px;
  position: relative;
  justify-content: space-between;
}

.r_faq_question::-webkit-details-marker {
  display: none;
}

/* Qアイコンの土台 */
.faq_q_icon {
    width: 30px;
    height: 30px;
    display: block;
    flex-shrink: 0;
    /* 緑の丸をCSSで作る */
    background-color: #428f94;
    border-radius: 50%;
    /* その上に白いQのSVGを重ねる */
    background-image: url("/img/web/q.svg"); 
    background-repeat: no-repeat;
    background-size: 50%; /* 丸の中でのQのサイズ感 */
    background-position: 50% 52% !important;
}

.faq_text {
  flex: 1;
  font-weight: bold;
  color: #333;
  line-height: 1.5;
  margin-right: auto;
}

/* 右側の矢印 (V字) */
.faq_arrow {
  width: 12px;
  height: 12px;
  border-right: 2px solid #999;
  border-bottom: 2px solid #999;
  transform: rotate(45deg);
  transition: transform 0.3s ease;
  flex-shrink: 0;
  margin-right: 5px;
}

/* --- 回答部分 --- */
.r_faq_answer {
  padding: 0 25px 25px 72px; /* Qアイコンの幅に合わせて左余白を調整 */
  color: #428f94;
  line-height: 1.8;
  font-size: 15px;
}

/* --- 開いている時の動き --- */
.r_faq_item[open] .faq_arrow {
  transform: rotate(-135deg); /* 矢印を上向きに */
  margin-top: 10px;
}

/* -----   レスポンシブ：スマホ用 ----- */
@media (max-width: 46.875em) {
  .r_faq {
  padding: 0 0 40px;
  }
  .r_faq_question {
    padding: 15px;
    gap: 10px;
  }
  
  .faq_q_icon {
    width: 28px;
    height: 28px;
  }
  
  .r_faq_answer {
    padding: 0 15px 15px 53px;
    font-size: 14px;
  }
  .faq_arrow {
  width: 10px;
  height: 10px;
  }
  .faq_text {
    font-size: 14px;
  }
}
/* -----------------------------------------------------------
   ★ファストレンタルの使い方
 ----------------------------------------------------------- */
.r_howto {
    padding: 30px 0 60px;
    background-color: #fff;
}

.r_howto h2 {
  padding-bottom: 20px;
}

.r_howto_container {
    max-width: min(75rem, 95%);
    margin: 0 auto;
    display: flex;
    align-items: center; /* 矢印とカードの高さを中央に */
    justify-content: space-between;
}

/* --- カード本体 --- */
.r_howto_item {
    flex: 1;
    background-color: #ebf2f2; /* 薄いグリーンの背景 */
    border: 1.5px solid #729494; /* 枠線 */
    border-radius: 20px;
    padding: 10px 20px 20px;
    min-height: 200px;
    display: flex;
    align-items: center;
}

.r_howto_content {
    display: flex;
    align-items: center;
    gap: 15px;
    width: 100%;
}

/* --- アイコン画像 --- */
.r_howto_img {
    width: 80px;
    flex-shrink: 0;
}
.r_howto_img img {
    width: 100%;
    height: auto;
}

/* --- テキストエリア --- */
.r_howto_text {
    flex: 1;
}

.r_howto_step {
    font-size: 14px;
    font-weight: bold;
    color: #333;
    margin-bottom: 5px;
}

/* 数字部分（1. など）だけ色を変える */
.r_howto_step span {
    color: #428f94;
    font-size: 24px;
    margin-left: 4px;
}

.r_howto_text h3 {
    font-size: 20px;
    font-weight: bold;
    margin-bottom: 10px;
    color: #333;
}

.r_howto_desc {
    font-size: 13px;
    line-height: 1.6;
    color: #444;
}

/* --- 矢印アイコン (PC：横向き) --- */
.r_howto_arrow {
    width: 40px;
    height: 40px;
    flex-shrink: 0;
    background-image: url("/img/web/arrow2.svg");
    background-repeat: no-repeat;
    background-position: center;
    background-size: 24px;
    margin: 0 10px;
}

/* -----   レスポンシブ：スマホ用----- */
@media (max-width: 46.875em) {
  #top .r_howto {
    padding-bottom: 40px;
  }
    .r_howto_container {
        flex-direction: column; /* 縦並びに */
        gap: 0;
    }

    .r_howto_item {
        width: 100%;
        margin-bottom: 0;
    }

    /* スマホ用の矢印：下向きに変更 */
    .r_howto_arrow {
        height: 40px; /* 縦の隙間を確保 */
        width: 100%;
        background-image: url("/img/web/arrow.svg");
    }
    .r_howto h2 {
        padding-bottom: 10px;
    }
    .r_howto_item {
    padding: 10px 20px 20px;
    min-height: 180px;
    }
}
/* -----------------------------------------------------------
   ★安心で選ぶなら
 ----------------------------------------------------------- */
#top .r_anshin {
  background: #fff;
  border-bottom: 1px solid #ddd;
}
#top .r_anshin_item {
  border-radius: 20px;
  box-shadow: 0 4px 14px 4px rgba(48,49,51,.12);
  border: 1px solid #729494;
}
 /* --- セクション全体 --- */
.r_anshin {
  background-color: #eff0ee;
  padding-bottom: 60px;
  width: 100%;
}

.r_anshin h2 span {
  color: #5f9697;
  display: block;
  font-size: 20px;
}

.r_anshin_container {
  /* PCでは最大1200px、スマホでは柔軟に */
  width: min(75rem, 92%);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  gap: 40px;
}

/* --- カード本体 --- */
.r_anshin_item {
  position: relative;
  background-color: #fff;
  flex: 1;
  padding: 30px 30px 40px;
  box-sizing: border-box;
  text-align: center;
  box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.01);
}

/* --- リボン画像の設定 --- */
.r_anshin_badge {
  position: absolute;
  top: -1px;
  left: 20px;
  width: 54px; /* 書き出す画像サイズに合わせて調整 */
  z-index: 2;
}

.r_anshin_badge img {
  width: 100%;
  height: auto;
  display: block;
}

/* --- いびつな円の画像エリア --- */
.r_anshin_img_wrap {
  width: 85%;
  margin: 0 auto 20px auto;
  overflow: hidden;
}

.r_anshin_img_wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* --- テキスト設定 --- */
.r_anshin_text_content h3 {
  font-size: 18px; /* 約13.5pt */
  font-weight: bold;
  margin-bottom: 15px;
  color: #333;
  line-height: 1.4;
}

.r_anshin_text_content p {
  font-size: 14px; /* 約10.5pt */
  line-height: 1.8;
  color: #666;
  text-align: left;
}

/* ----- レスポンシブ：スマホ用------ */
@media (max-width: 46.875em) {
  .r_anshin {
    padding-bottom: 40px;
  }
  .r_anshin_container {
    flex-direction: column; /* 縦に3つ並べる */
    gap: 30px;
  }

  .r_anshin_item {
    padding: 0px 20px 35px;
  }
  .r_anshin h2 span {
  font-size: 16px;
  }
  .r_anshin_badge {
    left: 15px;
    width: 48px; /* スマホでは少し小さく */
  }
  .r_anshin_img_wrap {
    margin-bottom: 0 !important;
  }
}

/* -----------------------------------------------------------
   ★「安心」セクションの見出しデザイン
 ----------------------------------------------------------- */
.r_anshin h2 {
    position: relative;
    padding: 70px 0 40px !important;
    text-align: center;
    overflow: visible;
}

.r_anshin .sysHeadline {
    position: relative;
    z-index: 2;
    font-size: 1.9rem; /* お好みに合わせて（24ptなら2rem） */
    font-weight: 700;
    letter-spacing: 0.1em;
    color: #333;
}

.r_anshin .sysHeadline::before {
    content: ""; /* これがないと絶対に出ません！ */
    display: block; /* 領域を確保します */
    position: absolute;
    top: 22%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: -1;
    width: 100%;
    height: 100px; /* 英語の高さに合わせて調整 */
    background-image: url(""); /* ★ここを実際のパスに！ */
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;  
    pointer-events: none;
    opacity: 0.7;
}

@media screen and (max-width: 767px) {
    .r_anshin .sysHeadline {
        font-size: 1.2rem;
        padding: 30px 0;
    }
    .r_anshin .sysHeadline::before {
        width: 90%;
        height: 80%;
        top: 22%;
    }
    .r_anshin h2 {
    padding: 30px 0px !important;
}
}
/* -----------------------------------------------------------
   ★カテゴリーから探す
 ----------------------------------------------------------- */
.r_category { background:#eff0ee; padding: 40px 0 60px;}
.r_category_sec {
  position: relative;
  z-index: 1;
  max-width: 1200px;
  margin: 10px auto 0 auto !important; 
  padding: 30px 50px;
  display: flex;
  align-items: flex-start;
  box-sizing: border-box;
  width: 100%;
  background-color: transparent;
  box-shadow: 0 0 0 100vw #eff0ee;
  clip-path: inset(0 -100vw);
}
.r_category_sec::after {
  content: "";
  position: absolute;
  /* top/bottomを0から少し内側に寄せることで上下にベージュが露出します */
  top: 10px;
  bottom: 10px;
  left: 0;
  right: 0;
  background-color: #fff;
  border-radius: 20px; /* 角丸の指定 */
  z-index: -1;
  pointer-events: none;
}

.r_category_sec .repHeadline {
  width: 160px;
  flex-shrink: 0;
  padding-top: 20px;
}

.r_category_sec .repHeadline h3 {
  font-size: 24px;
  font-weight: bold;
  margin: 0 0 8px 0;
  color: #333;
}

.r_category_sec .repHeadline a {
  font-size: 14px;
  color: #666;
  text-decoration: underline;
}

.r_category_sec .repContent {
  flex: 1;
}

.r_category_sec ul {
  display: flex;
  flex-wrap: wrap;
  gap: 5px 20px;
  padding: 0;
  margin: 0;
  list-style: none;
}

.r_category_sec li.repText {
  width: calc((100% - (20px * 6)) / 7) !important;
  margin: 0 !important;
  text-align: center;
}

.r_category_sec li.repText a {
  display: block;
  text-decoration: none;
  color: #333;
  font-size: 13px;
  line-height: 1.4;
}

/* 丸枠アイコン */
.r_category_sec li.repText a::before {
  content: "";
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  border: 1px solid #ddd;
  background-color: #fff;
  background-size: 85%;
  background-position: center;
  background-repeat: no-repeat;
  margin-bottom: 5px;
  transition: transform 0.3s ease, box-shadow 0.3s ease;
}

/* ホバー演出 */
.r_category_sec li.repText a:hover::before {
  transform: translateY(-5px);
  box-shadow: 0 5px 15px rgba(0,0,0,0.1);
}

/* --- 家電 --- */
.r_category_e li:nth-child(1) a::before { background-image: url('/img/web/cat_e1.png'); }
.r_category_e li:nth-child(2) a::before { background-image: url('/img/web/cat_e2.png'); }
.r_category_e li:nth-child(3) a::before { background-image: url('/img/web/cat_e3.png'); }
.r_category_e li:nth-child(4) a::before { background-image: url('/img/web/cat_e4.png'); }
.r_category_e li:nth-child(5) a::before { background-image: url('/img/web/cat_e5.png'); }
.r_category_e li:nth-child(6) a::before { background-image: url('/img/web/cat_e6.png'); }
.r_category_e li:nth-child(7) a::before { background-image: url('/img/web/cat_e7.png'); }
.r_category_e li:nth-child(8) a::before { background-image: url('/img/web/cat_e8.png'); }
.r_category_e li:nth-child(9) a::before { background-image: url('/img/web/cat_e9.png'); }
.r_category_e li:nth-child(10) a::before { background-image: url('/img/web/cat_e10.png'); }
.r_category_e li:nth-child(11) a::before { background-image: url('/img/web/cat_e11.png'); }

/* --- 家具 --- */
.r_category_k li:nth-child(1) a::before { background-image: url('/img/web/cat_k1.png'); }
.r_category_k li:nth-child(2) a::before { background-image: url('/img/web/cat_k2.png'); }
.r_category_k li:nth-child(3) a::before { background-image: url('/img/web/cat_k3.png'); }
.r_category_k li:nth-child(4) a::before { background-image: url('/img/web/cat_k4.png'); }
.r_category_k li:nth-child(5) a::before { background-image: url('/img/web/cat_k5.png'); }
.r_category_k li:nth-child(6) a::before { background-image: url('/img/web/cat_k6.png'); background-size: cover;}

/* --- スマホ対応 (image_f1c9e4.png再現) --- */
@media (max-width: 768px) {
  .r_category { padding: 20px 0;}
  .r_category_sec {
    flex-direction: column;
    padding: 15px;
    gap: 10px;
    width: 94%;
  }
  
  .r_category_sec::after {
    top: 5px;
    bottom: 5px;
  }

  .r_category_sec .repHeadline {
    width: 100%;
    display: flex;
    align-items: baseline;
    gap: 15px;
  }

  .r_category_sec li.repText {
    width: calc((100% - (20px * 3)) / 4) !important; /* スマホ4列 */
  }
  .r_category_sec ul {
  gap: 5px 20px;
}
.r_category_sec .repHeadline {  padding-top: 0;}
.r_category_sec li.repText a { font-size: 11px; font-weight: bold;}
.r_category_sec .repHeadline h3 { margin: 0; font-size: 20px;}
}




/* -----------------------------------------------------------
   商品一覧（サムネイル）カードスタイル
   ----------------------------------------------------------- */

/* リスト全体のコンテナ */
.sysThumbnail {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
    list-style: none;
    margin: 0;
}

/* 各カード本体 */
.sysThumbnail li {
    background-color: #fff;
    border-radius: 12px;
    overflow: hidden;
    width: calc(50% - 10px); /* 2カラム表示（スマホ想定） */
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    display: flex;
    flex-direction: column;
    padding: 0 0 15px 0;
    box-sizing: border-box;
}

/* PCなどの広い画面では4カラムにする */
@media (min-width: 768px) {
    .sysThumbnail li {
        width: calc(25% - 15px);
    }
}

/* 商品画像エリア */
.sysThumbnailImage {
    width: 100%;
    aspect-ratio: 1 / 1;
    overflow: hidden;
    background-color: #f9f9f9;
}

.sysThumbnailImage img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.3s ease;
}

.sysThumbnailImage a:hover img {
    transform: scale(1.05);
}

/* テキスト情報エリア */
.sysThumbnail li > div:nth-child(2) {
    padding: 12px;
    flex-grow: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

/* 商品名 */
.sysItemName {
    font-size: 14px;
    font-weight: bold;
    line-height: 1.4;
    overflow: hidden;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

.sysItemName a {
    text-decoration: none;
    color: #333;
}

/* 価格 */
.sysRetailPrice {
    font-size: 15px;
    color: #428f94; /* 少し強調した赤系 */
    font-weight: bold;
}

/* ボタンエリア（フォーム） */
form[action*="cartIn"] {
    margin-bottom: 8px;
    text-align: center;
}
#sysItemCategory form[action*="cartIn"] {
    width: 90%;
    margin: 0 auto;
}

/* カートボタン共通 */
.sysCartButton {
    width: 100%;
    border: none;
    padding: 10px;
    border-radius: 6px;
    font-weight: bold;
    cursor: pointer;
    transition: opacity 0.2s;
    font-size: 13px;
}

/* オプション選択・カートに入れるボタンの色分け */
.sysSelectCartButton {
    background-color: #8ba398; /* 先程のカリモク風グリーン */
    color: #fff;
}

.sysCartInButton {
    background-color: #333;
    color: #fff;
}

/* お気に入りボタン */
.sysWishListButtonFormAjax {
    padding: 0;
    text-align: center;
}

.sysWishListButton {
    width: 100%;
    background-color: transparent;
    border: 1px solid #ccc;
    color: #666;
    padding: 6px;
    border-radius: 6px;
    font-size: 12px;
    cursor: pointer;
}

.sysWishListButton:hover {
    background-color: #f5f5f5;
}

/*! ========================================================
   商品スペック表
   ========================================================= */
    /* 見出しのデザイン：■を消して、今風のラインデザインに */
    #sysItemDetail .sysSpecViewName {
      display: block;
      font-size: 16px;
      font-weight: bold;
      color: #333;
      margin: 20px 0 10px;
      padding-left: 12px;
      border-left: 4px solid #000; /* 黒のアクセントライン */
    }

    /* テーブル全体のデザイン変更 */
    #sysItemDetail .sysSpecTable {
      width: 100%;
      border-collapse: collapse;
      border: none !important; /* 囲み枠を消去 */
      border-top: 2px solid #333 !important; /* 上線だけ太く */
      margin-bottom: 30px;
    }

    /* 各行の下線 */
    #sysItemDetail .sysSpecTable tr {
      border-bottom: 1px solid #e0e0e0;
    }

    /* 左側の項目名セル */
    #sysItemDetail .sysSpecTable .sysSpecItemFieldName {
      width: 30%;
      background-color: #f9f9f9 !important; /* ほんのりグレー */
      color: #555;
      font-weight: 600;
      padding: 15px !important;
      border: none !important; /* 縦線を消去 */
      font-size: 14px;
    }

    /* 右側の内容セル */
    #sysItemDetail .sysSpecTable .sysSpecItemFieldContent {
      background-color: #ffffff !important;
      color: #333;
      padding: 15px !important;
      border: none !important; /* 縦線を消去 */
      font-size: 14px;
      line-height: 1.6;
    }

    /* マウスを乗せた時に少し色を変える（PC用） */
    #sysItemDetail .sysSpecTable tr:hover {
      background-color: #f5f5f5;
    }

    /* スマホで見やすくするための調整 */
    @media (max-width: 600px) {
      #sysItemDetail .sysSpecTable .sysSpecItemFieldName {
        width: 40%;
        padding: 12px 10px !important;
        font-size: 13px;
      }
      #sysItemDetail .sysSpecTable .sysSpecItemFieldContent {
        padding: 12px 10px !important;
        font-size: 13px;
      }
    }

/*! ========================================================
   ブログのRSS表示テスト
   ========================================================= */
/* タイトルを2行で省略 */
        .line-clamp-2 {
            display: -webkit-box;
            -webkit-line-clamp: 2;
            -webkit-box-orient: vertical;  
            overflow: hidden;
        }
        /* aishipなどの埋め込み先を考慮したスタイル */
        .blog-card {
            transition: transform 0.2s ease;
        }
        .blog-card:hover {
            transform: translateY(-2px);
        }

/*! ========================================================
   ★トップスライダー
   ========================================================= */

/* --- 1. 外側の親：右側の余白をカットしつつ、上に10px空ける --- */
.top-mv {
    width: 100% !important;
    overflow: hidden !important;
}

/* --- 2. スライダー本体 --- */
.top-mv__content.swiper {
    width: 100% !important;
    max-width: 100vw !important;
    overflow: hidden !important; /* スマホでは1枚で見せる */
    margin: 0 auto !important;
}

.top-mv__wrap.swiper-wrapper {
    display: flex !important;
    box-sizing: content-box;
}

/* スライド1枚1枚の基本設定 */
.top-mv__block {
    width: 100%;
    flex-shrink: 0;
    box-sizing: border-box !important;
}

.top-mv__block img {
    width: 100%;
    height: auto;
    display: block;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.1);
}

/* --- PCの時：1025px以上 --- */
@media (min-width: 1025px) {
    .top-mv__content.swiper {
        /* margin-topを「!important」で強制し、数値を少し増やして20pxにしてみます */
        margin-top: 20px !important; 
        
        /* 念の為、上に余計なものを寄せ付けない設定 */
        clear: both !important;
        display: block !important;

        /* 以下はこれまでのズレ防止・中央寄せの設定 */
        width: 85% !important; 
        max-width: 1220px !important; 
        margin-left: auto !important;
        margin-right: auto !important;
        overflow: visible !important; 
        padding-bottom: 20px !important;
    }
    .top-mv__block {
        /* 親の85%幅に対して、スライドがピッタリ100%になるように固定（ズレ防止） */
        transition: opacity 0.3s;
        opacity: 0.5;
        padding: 0 !important;
    }
    
    .top-mv__block.swiper-slide-active {
        opacity: 1; /* アクティブなスライドだけハッキリ */
    }
}

/* ページネーション全体の配置 */
.top-mv__content .swiper-pagination {
    bottom: 0 !important;
    position: relative !important;
    margin-top: 10px !important;
}

/* 待機中の線（細くて薄いグレー） */
.top-mv__content .swiper-pagination-bullet {
    width: 40px !important; /* 横幅を長く */
    height: 2px !important; /* 高さを低く */
    border-radius: 0 !important; /* 四角くする場合（丸みが欲しければ2pxとかに） */
    background: #e0e0e0 !important;
    opacity: 1 !important;
    margin: 0 4px !important;
    transition: all 0.4s;
}

/* アクティブな線（色が濃くなり、少し太くなる） */
.top-mv__content .swiper-pagination-bullet-active {
    background: #7a9a9a !important; /* 2枚目画像のようなニュアンスカラー */
    height: 2px !important; /* 少し太くして目立たせる */
}
@media screen and (max-width: 768px) {
  .top-mv {
    padding-top: 10px !important;
    }
}


/*! ========================================================
家具リンク
========================================================= */
/* 親コンテナ：見出しとボタンエリアを横並びに */
.sysFuncItemCategory.kagu_link {
    max-width: 1200px;
    width: 94%;
    margin: 0 auto;
    padding: 20px 0;
    display: flex;
    align-items: center; /* 垂直中央 */
    gap: 20px;
}

/* 見出し：幅を固定 */
.kagu_link .sysHeadline {
    width: 120px;
    flex-shrink: 0;
    font-weight: bold;
}

/* ボタンエリア：残りの幅を埋める */
.kagu_link .sysContent {
    flex-grow: 1;
    min-width: 0; /* はみ出し防止 */
}

/* リスト：横並び */
.kagu_link ul {
    display: flex;
    list-style: none;
    padding: 0;
    margin: 0;
    gap: 10px;
}

/* 各ボタン：巨大化を防ぐために max-width を設定 */
.kagu_link li.sysText {
    flex: 1; /* 均等に分配 */
    max-width: calc(100% / 6); /* 巨大化防止 */
    list-style: none;
}

/* ボタン本体：正方形を維持しつつ、テキスト下に余白を空ける */
.kagu_link li.sysText a {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-end; /* テキストを下寄せ */
    
    aspect-ratio: 1 / 1;
    width: 100%;
    /* 下に20pxの空きを強制 */
    padding-bottom: 20px !important; 
    box-sizing: border-box;
    
    text-decoration: none;
    color: #333;
    font-size: 13px;
    font-weight: bold;
    border: 1px solid #bbb;
    border-radius: 8px;
    background-color: #fff;
    
    /* 背景アイコン */
    background-repeat: no-repeat;
    background-position: center 30%; 
    background-size: 50% auto; /* 枠に対して適切なサイズに */
    
    transition: all 0.3s ease;
}

/* ホバーで影 */
.kagu_link li.sysText a:hover {
    box-shadow: 0 8px 20px rgba(0,0,0,0.15);
    transform: translateY(-2px);
    border: 2px solid #669d9c;
}

/* アイコン画像設定 */
.kagu_link li:nth-child(1) a { background-image: url('https://reproz-trial.aispr.jp/img/icon.svg'); }
.kagu_link li:nth-child(2) a { background-image: url('https://reproz-trial.aispr.jp/img/icon.svg'); }
.kagu_link li:nth-child(3) a { background-image: url('https://reproz-trial.aispr.jp/img/icon.svg'); }
.kagu_link li:nth-child(4) a { background-image: url('https://reproz-trial.aispr.jp/img/icon.svg'); }
.kagu_link li:nth-child(5) a { background-image: url('https://reproz-trial.aispr.jp/img/icon.svg'); }
.kagu_link li:nth-child(6) a { background-image: url('https://reproz-trial.aispr.jp/img/icon.svg'); }

/* スマホ用の設定（750px以下） */
@media (max-width: 750px) {
    /* 1. 親：縦並びにして、はみ出しを隠す（余白対策） */
    .sysFuncItemCategory.kagu_link {
        display: block !important;
        width: 100% !important;
        overflow: hidden !important;
    }

.kagu_link .sysHeadline {
        width: 100% !important;
        padding: 0 15px 15px !important; /* 下の余白を少し調整 */
        box-sizing: border-box !important;

        /* --- ここからが左右振分けの魔法 --- */
        display: flex !important;
        justify-content: space-between !important; /* 左右の両端に寄せる */
        align-items: baseline !important; /* 文字の下端を揃える（スッキリ見えます） */
    }

    /* 中にある <br> は邪魔なので消す */
    .kagu_link .sysHeadline br {
        display: none !important;
    }

    /* 「一覧を見る」リンクの調整 */
    .kagu_link .sysHeadline a {
        font-size: 11px !important; /* 少し小さめに */
        color: #669d9c !important; /* リンク色 */
        text-decoration: underline !important; /* リンクだと分かりやすく */
        font-weight: normal !important; /* 家具（太字）と差をつける */
    }

    /* 2. スクロールさせる箱：ここがスクロールの「窓」になります */
    .kagu_link .sysContent {
        display: block !important;
        width: 100% !important;
        overflow-x: auto !important; /* 横スクロール許可 */
        overflow-y: hidden !important;
        -webkit-overflow-scrolling: touch; /* 指に吸い付く動き */
    }

    /* 3. 中のnavとul：HTMLの16.66%を無視させる設定 */
    .kagu_link nav {
        display: block !important; /* navが邪魔しないように */
    }

    .kagu_link ul {
        display: flex !important; /* 横並び強制 */
        flex-wrap: nowrap !important; /* 絶対に折り返さない */
        width: max-content !important; /* ボタンの合計分だけ横に伸びる */
        gap: 12px !important;
        padding: 0 15px 15px !important;
        margin: 0 !important;
    }

    /* 4. 各ボタン：インラインの「16.66%」を最強の !important で粉砕 */
    .kagu_link li.sysText {
        /* ここが重要！flex-basisを固定して、絶対に縮ませない */
        flex: 0 0 110px !important; 
        width: 110px !important;
        min-width: 110px !important;
        max-width: 110px !important; /* これで16.66%を上書き */
        
        list-style: none !important;
        padding: 0 !important;
    }

    /* ボタンの中身（リンク） */
    .kagu_link li.sysText a {
        display: flex !important;
        aspect-ratio: 1 / 1;
        width: 100% !important;
        font-size: 11px;
        padding-bottom: 12px !important;
    }
}




/*! ========================================================
ress.css
========================================================= */
html {
  -webkit-text-size-adjust: 100%;
  box-sizing: border-box;
  -moz-tab-size: 4;
  -o-tab-size: 4;
     tab-size: 4;
  word-break: normal;
}

*,
:after,
:before {
  background-repeat: no-repeat;
  box-sizing: inherit;
}

:after,
:before {
  text-decoration: inherit;
  vertical-align: inherit;
}

* {
  margin: 0;
  padding: 0;
}

hr {
  color: inherit;
  height: 0;
  overflow: visible;
}

details,
main {
  display: block;
}

summary {
  display: list-item;
}

small {
  font-size: 80%;
}

[hidden] {
  display: none;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
}

a {
  background-color: transparent;
}

a:active,
a:hover {
  outline-width: 0;
}

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
}

pre {
  font-size: 1em;
}

b,
strong {
  font-weight: bolder;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

table {
  border-color: inherit;
  text-indent: 0;
}

iframe {
  border-style: none;
}

input {
  border-radius: 0;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

textarea {
  overflow: auto;
  resize: vertical;
}

button,
input,
optgroup,
select,
textarea {
  font: inherit;
}

optgroup {
  font-weight: 700;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

[role=button],
[type=button],
[type=reset],
[type=submit],
button {
  cursor: pointer;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button:-moz-focusring {
  outline: 1px dotted ButtonText;
}

[type=reset],
[type=submit],
button,
html [type=button] {
  -webkit-appearance: button;
}

button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
  outline-width: 0;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
}

select::-ms-expand {
  display: none;
}

select::-ms-value {
  color: currentColor;
}

legend {
  border: 0;
  color: inherit;
  display: table;
  max-width: 100%;
  white-space: normal;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  color: inherit;
  font: inherit;
}

[disabled] {
  cursor: default;
}

img {
  border-style: none;
}

progress {
  vertical-align: baseline;
}

[aria-busy=true] {
  cursor: progress;
}

[aria-controls] {
  cursor: pointer;
}

[aria-disabled=true] {
  cursor: default;
}

/*! ========================================================
基本設定
========================================================= */
html {
  scroll-behavior: smooth;
  scroll-padding-top: 0;
}
html.fixed {
  overflow: hidden;
}

body {
 font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", sans-serif;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: 0;
  color: #333333;
}
body * {
  word-break: break-word;
  line-break: normal;
}

a {
  color: inherit;
  text-decoration: none;
}

a,
button,
input[type=submit],
input[type=button] {
  transition: 200ms;
}
a:hover,
button:hover,
input[type=submit]:hover,
input[type=button]:hover {
  opacity: 0.7;
}

.sysFuncBanner .sysContent ul li a[href=""],
.sysFuncListNav .sysContent ul li a[href=""] {
  pointer-events: none;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

.txt_small {
  font-size: min(0.75rem, 3.2vw);
}
/*! ========================================================
aishipR既存CSS打ち消し設定
========================================================= */
html {
  font-family: initial;
  font-size: initial;
  font-weight: initial;
  line-height: initial;
}

div#sysAll,
div#sysHeader,
div#sysMain,
div#sysAside,
div#sysFooter {
  padding: 0;
  margin: 0;
}

div#sysAll {
  max-width: 100%;
  background-color: transparent;
}

div#sysMain {
  width: 100%;
  min-height: 0;
  float: none;
  font-size: initial;
}

div#sysAside {
  width: 100%;
  float: none;
}

.sysFuncText,
.sysFuncCartInfo,
.sysFuncItemBlock,
.sysFuncItemSearch,
.sysFuncMemberLogin,
.sysFuncItemCategory,
.sysFuncListNav,
.sysFuncBanner {
  margin: 0;
}
.sysFuncText .sysHeadline,
.sysFuncCartInfo .sysHeadline,
.sysFuncItemBlock .sysHeadline,
.sysFuncItemSearch .sysHeadline,
.sysFuncMemberLogin .sysHeadline,
.sysFuncItemCategory .sysHeadline,
.sysFuncListNav .sysHeadline,
.sysFuncBanner .sysHeadline {
  padding: 0;
}
.sysFuncText .sysContent,
.sysFuncCartInfo .sysContent,
.sysFuncItemBlock .sysContent,
.sysFuncItemSearch .sysContent,
.sysFuncMemberLogin .sysContent,
.sysFuncItemCategory .sysContent,
.sysFuncListNav .sysContent,
.sysFuncBanner .sysContent {
  padding: 0;
}
.sysFuncText ul::after,
.sysFuncCartInfo ul::after,
.sysFuncItemBlock ul::after,
.sysFuncItemSearch ul::after,
.sysFuncMemberLogin ul::after,
.sysFuncItemCategory ul::after,
.sysFuncListNav ul::after,
.sysFuncBanner ul::after {
  content: none;
}
.sysFuncText ul li,
.sysFuncCartInfo ul li,
.sysFuncItemBlock ul li,
.sysFuncItemSearch ul li,
.sysFuncMemberLogin ul li,
.sysFuncItemCategory ul li,
.sysFuncListNav ul li,
.sysFuncBanner ul li {
  margin: 0;
}
.sysFuncText ul li a,
.sysFuncCartInfo ul li a,
.sysFuncItemBlock ul li a,
.sysFuncItemSearch ul li a,
.sysFuncMemberLogin ul li a,
.sysFuncItemCategory ul li a,
.sysFuncListNav ul li a,
.sysFuncBanner ul li a {
  padding: 0;
}
.sysFuncText ul li.sysText,
.sysFuncCartInfo ul li.sysText,
.sysFuncItemBlock ul li.sysText,
.sysFuncItemSearch ul li.sysText,
.sysFuncMemberLogin ul li.sysText,
.sysFuncItemCategory ul li.sysText,
.sysFuncListNav ul li.sysText,
.sysFuncBanner ul li.sysText {
  margin: 0;
}
.sysFuncText ul li.sysText a,
.sysFuncCartInfo ul li.sysText a,
.sysFuncItemBlock ul li.sysText a,
.sysFuncItemSearch ul li.sysText a,
.sysFuncMemberLogin ul li.sysText a,
.sysFuncItemCategory ul li.sysText a,
.sysFuncListNav ul li.sysText a,
.sysFuncBanner ul li.sysText a {
  padding: 0;
}

.sysFuncItemBlock .sysContent .sysItemBlock .sysHorizontal::after {
  content: none;
}
.sysFuncItemBlock .sysContent .sysItemBlock .sysHorizontal li {
  float: none;
  padding: 0;
}

.sysFuncItemCategory .sysContent ul li {
  float: none;
}
.sysFuncItemCategory .sysContent ul li a {
  overflow: initial;
  text-overflow: initial;
  white-space: initial;
}

.sysFuncListNav ul li {
  float: none;
}
.sysFuncListNav ul li a {
  overflow: initial;
  text-overflow: initial;
  white-space: initial;
}

.sysItemImages .sysImageList li {
  width: inherit;
  height: inherit;
  float: none;
  margin: 0;
}
.sysItemImages .sysImageList li img {
  border: none;
}
.sysItemImages .sysImageList li.sysCurrent img {
  border: none;
}
.sysItemImages .sysImageList::after {
  content: none;
}

.sysItemList ul.sysThumbnail::after {
  content: none;
}
.sysItemList ul.sysThumbnail li {
  float: none;
  padding: 0;
}

.sysItemList ul.sysList li {
  padding: 0;
}
.sysItemList ul.sysList li::after {
  content: none;
}
.sysItemList ul.sysList li .sysThumbnailImage {
  float: none;
}

.sysItemListDisp::after {
  content: none;
}
.sysItemListDisp #displayCount {
  float: none;
}
.sysItemListDisp .sysItemListViewType {
  float: none;
}

html:has(#sysOpc) {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  line-height: inherit;
}
html:has(#sysOpc) .sysOpcBody #sysAll #sysMain {
  font-size: inherit;
}
html:has(#sysOpc) .sysOpcBody #sysAll #sysMain #sysOpc .opcConfirm {
  padding: 0;
}

h1 {
  font-size: initial;
  color: initial;
  line-height: initial;
  letter-spacing: initial;
  margin: 0;
}

.sysBox {
  background-color: initial;
  border: initial;
  border-radius: initial;
  box-shadow: initial;
  margin: initial;
  padding: initial;
}

.sysTotal .sysTotalTxt,
.sysTotalAmount {
  text-shadow: initial;
}

.sysCartTitle {
  color: initial;
  background-color: initial;
  font-size: initial;
  font-weight: 700;
  margin: initial;
  padding: initial;
}

.sysCart #sysMain .sysNextSubmitArea .sysNextSubmit,
.sysCart #sysMain .sysNextSubmitAreaForResumeMemberSessionCart .sysNextSubmit {
  font-size: initial;
  height: initial;
  text-shadow: initial;
  min-width: initial;
}

.sysCart #sysMain input[type=submit],
.sysCart #sysMain button[type=submit],
.sysCart #sysMain button {
  height: initial;
  min-width: initial;
  overflow: initial;
  text-overflow: initial;
  white-space: initial;
}

.sysCart .sysBox img.sysProductImg {
  float: initial;
  height: initial;
  margin: initial;
  width: initial;
}

.sysCart .sysItemListArea .sysBox select {
  max-width: initial;
}

.sysCart p,
.sysOpcBody p {
  line-height: 1.7;
  letter-spacing: 0;
  padding: initial;
  margin: initial;
}

.opcCommonInputText,
.opcCommonInputSelect,
.opcCommonInputRadio,
.opcCommonInputCheckbox {
  margin-left: 0;
}

/*! ========================================================
タイトル設定
========================================================= */
.title-large {
  font-size: min(1.75rem, 7.4666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  text-align: center;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.title-large.left {
  text-align: left;
  margin-bottom: min(0.9375rem, 4vw);
}

.title-medium {
  font-size: min(1.5625rem, 6.6666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  text-align: center;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.title-medium.left {
  text-align: left;
  margin-bottom: min(0.9375rem, 4vw);
}

.title-medium-underline {
  font-size: min(1.5625rem, 6.6666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.875rem, 8vw);
}

.title-medium-sub {
  font-size: min(1.5625rem, 6.6666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  text-align: center;
  padding-top: min(2.5rem, 10.6666666667vw);
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
.title-medium-sub span {
  display: block;
  font-size: min(0.75rem, 3.2vw);
  font-weight: 400;
  line-height: 1.5;
  letter-spacing: 0;
  padding-top: min(0.375rem, 1.6vw);
}

.title-small-underline {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(3.125rem, 13.3333333333vw);
}



/*! ========================================================
カレンダー設定
========================================================= */
.shop-calender {
  width: min(19.5rem, 83.2vw);
}
.shop-calender #calendar {
  width: 100%;
  margin-inline: auto;
}
.shop-calender #calendar table {
  display: block;
  width: auto !important;
}
.shop-calender #calendar thead,
.shop-calender #calendar tbody,
.shop-calender #calendar tr,
.shop-calender #calendar th,
.shop-calender #calendar td {
  display: block;
}
.shop-calender #calendar.fc-theme-standard th,
.shop-calender #calendar.fc-theme-standard td {
  border: none;
}
.shop-calender #calendar.fc-theme-standard .fc-scrollgrid {
  border: none;
}
.shop-calender #calendar .fc-scrollgrid-section,
.shop-calender #calendar .fc-scrollgrid-section table,
.shop-calender #calendar .fc-scrollgrid-section > td {
  height: auto;
}
.shop-calender #calendar .fc-header-toolbar {
  margin-bottom: min(0.9375rem, 4vw);
}
.shop-calender #calendar .fc-header-toolbar .fc-toolbar-title {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.5;
}
.shop-calender #calendar .fc-header-toolbar .fc-button {
  width: min(1.875rem, 8vw);
  height: min(1.875rem, 8vw);
  border: none;
  border-radius: 0;
  background-color: transparent;
  background-size: 100% 100%;
  padding: 0;
  box-shadow: none !important;
}
.shop-calender #calendar .fc-header-toolbar .fc-button.fc-prev-button {
  background-image: url(../img/layout/common/arrow_left_thin_black.png);
}
.shop-calender #calendar .fc-header-toolbar .fc-button.fc-next-button {
  background-image: url(../img/layout/common/arrow_right_thin_black.png);
  margin-left: min(0.625rem, 2.6666666667vw);
}
.shop-calender #calendar .fc-header-toolbar .fc-button .fc-icon {
  display: none;
}
.shop-calender #calendar .fc-col-header {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.shop-calender #calendar .fc-col-header thead tr {
  display: flex;
  gap: min(0.625rem, 2.6666666667vw);
}
.shop-calender #calendar .fc-col-header thead tr th {
  width: calc(14.2857142857% - min(3.75rem, 16vw) / 7);
}
.shop-calender #calendar .fc-col-header thead tr th .fc-scrollgrid-sync-inner .fc-col-header-cell-cushion {
  display: flex;
  align-items: center;
  justify-content: center;
  height: min(1.3125rem, 5.6vw);
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1;
  padding: 0;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr {
  display: flex;
  align-items: flex-start;
  gap: min(0.625rem, 2.6666666667vw);
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td {
  width: calc(14.2857142857% - min(3.75rem, 16vw) / 7);
  aspect-ratio: 1/1;
  border-radius: 50%;
  position: relative;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td .fc-daygrid-day-frame {
  display: flex;
  align-items: center;
  justify-content: center;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td .fc-daygrid-day-frame .fc-daygrid-day-top {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td .fc-daygrid-day-frame .fc-daygrid-day-top .fc-daygrid-day-number {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1;
  padding: 0;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td .fc-daygrid-day-frame .fc-daygrid-day-events,
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td .fc-daygrid-day-frame .fc-daygrid-day-bg {
  display: none;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td:has(.fc-daygrid-event-harness) {
  background-color: #ffd9d9;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td.off-day {
  background-color: #ffd9d9;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td.off-day.fc-day-today {
  background-color: #ffd9d9;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td.fc-day-today {
  background-color: transparent;
  border: 1px solid #333333;
}
.shop-calender #calendar .fc-scrollgrid-sync-table tbody tr td.fc-day-other {
  background-color: transparent;
}

/*! ========================================================
商品ブロック設定
========================================================= */
#sysItemCategory #sysFooter {
 background: #fff !important;  
}
#sysMain .sysFuncItemBlock .sysItemBlock,
#sysFooter .sysFuncItemBlock .sysItemBlock {
  width: 100%;
  max-width: 1200px;
  padding-inline: 0;
  margin-inline: auto;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul,
#sysFooter .sysFuncItemBlock .sysItemBlock ul {
  display: flex;
  flex-wrap: wrap;
  gap: min(3.125rem, 13.3333333333vw) min(1.5rem, 6.4vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li,
#sysFooter .sysFuncItemBlock .sysItemBlock ul li {
  width: calc(25% - min(4.5rem, 19.2vw) / 4);
  text-align: left;
  position: relative;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysIconRank,
#sysFooter .sysFuncItemBlock .sysItemBlock ul li .sysIconRank {
  width: min(2.5rem, 10.6666666667vw);
  height: auto;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  pointer-events: none;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemImage,
#sysFooter .sysFuncItemBlock .sysItemBlock ul li .sysItemImage {
  width: 100%;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemImage a {
  display: block;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemImage a img {
  display: block;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemName a {
  display: block;
  font-size: min(0.875rem, 3.8vw);
  line-height: 1.7;
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddSelection {
  margin-top: min(0.625rem, 2.6666666667vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddSelection > div {
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddSelection > div select {
  display: block;
  width: 100%;
  height: auto;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  border: 1px solid #333333;
  background-image: none;
  background-color: #ffffff;
  color: #333333;
  padding: min(0.3125rem, 1.3333333333vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddSelection > div select::after {
  content: none;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddSelection > div label {
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddSelection > div input[type=text] {
  display: block;
  width: 100%;
  height: auto;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  border: 1px solid #333333;
  color: #333333;
  padding: min(0.3125rem, 1.3333333333vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddVariation {
  margin-top: min(0.625rem, 2.6666666667vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddVariation .sysVariationSelects {
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysMain .sysFuncItemBlock .sysItemBlock ul li .sysAddVariation select {
  display: block;
  width: 100%;
  height: auto;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  border: 1px solid #333333;
  background-image: none;
  background-color: #ffffff;
  color: #333333;
  padding: min(0.3125rem, 1.3333333333vw);
}
#sysMain .sysFuncItemBlock.item-block-col6 .sysItemBlock ul {
  gap: min(3.125rem, 13.3333333333vw) min(0.5rem, 6vw);
}
#sysMain .sysFuncItemBlock.item-block-col6 .sysItemBlock ul li {
  width: calc(17.6666666667% - min(7.5rem, 32vw) / 6);
}
#sysMain .sysFuncItemBlock.item-block-col5 .sysItemBlock ul {
  gap: min(3.125rem, 13.3333333333vw) min(1.5625rem, 6.6666666667vw);
}
#sysMain .sysFuncItemBlock.item-block-col5 .sysItemBlock ul li {
  width: calc(40% - min(6.25rem, 26.6666666667vw) / 5);
}
#sysItemDetail .sysFuncItemBlock.item-block-col5 .sysItemBlock ul {
  gap: min(3.125rem, 13.3333333333vw) min(1.5625rem, 6.6666666667vw);
}
#sysItemDetail .sysFuncItemBlock.item-block-col5 .sysItemBlock ul li {
  width: calc(40% - min(6.25rem, 26.6666666667vw) / 5);
}
#sysMain .sysFuncItemBlock.item-block-col4 .sysItemBlock ul {
  gap: min(3.125rem, 13.3333333333vw) min(1.5rem, 6.4vw);
}
#sysMain .sysFuncItemBlock.item-block-col4 .sysItemBlock ul li {
  width: calc(25% - min(4.5rem, 19.2vw) / 4);
}
#sysMain .sysFuncItemBlock.item-block-col3 .sysItemBlock ul {
  gap: min(3.125rem, 13.3333333333vw) min(2.8125rem, 12vw);
}
#sysMain .sysFuncItemBlock.item-block-col3 .sysItemBlock ul li {
  width: calc(33.3333333333% - min(5.625rem, 24vw) / 3);
}

/*! ========================================================
PRアイコン設定
========================================================= */
.sysPr,
.sysItemPrArea {
  display: flex;
  flex-wrap: wrap;
  gap: min(0.3125rem, 1.3333333333vw);
}
.sysPr span,
.sysItemPrArea span {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
  font-size: min(0.6875rem, 2.9333333333vw);
  line-height: 1.5;
  border: 1px solid #707070;
  background-color: #ffffff;
  padding: min(0.3125rem, 1.3333333333vw);
}
.sysPr span:empty,
.sysItemPrArea span:empty {
  display: none;
}

/*! ========================================================
パンくず設定
========================================================= */
.sysCategoryPankuzu,
.sysItemCategoryPankuzu {
  width: 1200px;
  font-size: min(0rem, 0vw);
  margin: 10px auto 10px auto;
}
.sysCategoryPankuzu > span:empty,
.sysItemCategoryPankuzu > span:empty {
  display: none;
}
.sysCategoryPankuzu > span:empty + br,
.sysItemCategoryPankuzu > span:empty + br {
  display: none;
}
.sysCategoryPankuzu > a,
.sysCategoryPankuzu > span,
.sysItemCategoryPankuzu > a,
.sysItemCategoryPankuzu > span {
  display: inline-block;
  width: -moz-fit-content;
  width: fit-content;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  vertical-align: sub;
}

.sysCategoryPankuzu > a::after,
.sysItemCategoryPankuzu > a::after {
  content: "";
  display: inline-block;
  width: min(0.5rem, 2.1333333333vw);
  height: min(1rem, 4.2666666667vw);
  background-image: url(/img/web/arrow_pan.svg);
  background-size: 100% 100%;
  margin-inline: min(0.625rem, 2.6666666667vw);
}
.sysCategoryPankuzu > a:last-of-type::after,
.sysItemCategoryPankuzu > a:last-of-type::after {
  content: none;
}
@media screen and (max-width: 768px) {
  .sysCategoryPankuzu,
  .sysItemCategoryPankuzu {
  width: 94%;
  margin: 0 auto;
  }
}
/* -----------------------------------------------------------
   ★フリーページのパンくず
 ----------------------------------------------------------- */
.r_sysCategoryPankuzu {
  width: 1200px;
  font-size: 13px;
  margin: 10px auto 10px auto;
  font-weight: normal;
  text-align: left;
}
.r_sysCategoryPankuzu a::after {
  content: "";
  display: inline-block;
  width: min(0.5rem, 2.1333333333vw);
  height: min(1rem, 4.2666666667vw);
  background-image: url(/img/web/arrow_pan.svg);
  background-size: 100% 100%;
  margin-inline: min(0.625rem, 2.6666666667vw);
}
@media screen and (max-width: 768px) {
  .r_sysCategoryPankuzu {
  width: 94%;
  margin: 0 auto;
  }
}

/*! ========================================================
フォーム設定
========================================================= */
#sysAll #sysMain input[type=text],
#sysAll #sysMain input[type=email],
#sysAll #sysMain input[type=search],
#sysAll #sysMain input[type=password],
#sysAll #sysMain input[type=tel],
#sysAll #sysMain input[type=number],
#sysAll #sysMain select {
  height: min(3.125rem, 13.3333333333vw);
  display: block;
  width: 100%;
  font-size: min(1rem, 4.2666666667vw);
  color: #333333;
  border: 1px solid #707070;
  border-radius: min(0.3125rem, 1.3333333333vw);
  background: #ffffff;
  padding: 0 min(0.625rem, 2.6666666667vw);
  margin: 0;
}
#sysAll #sysMain input[type=text]::-moz-placeholder, #sysAll #sysMain input[type=email]::-moz-placeholder, #sysAll #sysMain input[type=search]::-moz-placeholder, #sysAll #sysMain input[type=password]::-moz-placeholder, #sysAll #sysMain input[type=tel]::-moz-placeholder, #sysAll #sysMain input[type=number]::-moz-placeholder, #sysAll #sysMain select::-moz-placeholder {
  color: #c2c2c2;
}
#sysAll #sysMain input[type=text]::placeholder,
#sysAll #sysMain input[type=email]::placeholder,
#sysAll #sysMain input[type=search]::placeholder,
#sysAll #sysMain input[type=password]::placeholder,
#sysAll #sysMain input[type=tel]::placeholder,
#sysAll #sysMain input[type=number]::placeholder,
#sysAll #sysMain select::placeholder {
  color: #c2c2c2;
}
#sysAll #sysMain select {
  background-image: url(../img/layout/common/arrow_down_thin_black.png);
  background-size: min(0.5rem, 2.1333333333vw) min(0.25rem, 1.0666666667vw);
  background-position: right min(0.8125rem, 3.4666666667vw) center;
  background-repeat: no-repeat;
  padding-right: min(2.125rem, 9.0666666667vw);
}
#sysAll #sysMain textarea {
  width: 100%;
  min-height: min(5.625rem, 24vw);
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  color: #333333;
  border: 1px solid #707070;
  background: #ffffff;
  border-radius: min(0.3125rem, 1.3333333333vw);
  padding: min(0.625rem, 2.6666666667vw);
  margin: 0;
}
#sysAll #sysMain textarea::-moz-placeholder {
  color: #c2c2c2;
}
#sysAll #sysMain textarea::placeholder {
  color: #c2c2c2;
}
#sysAll #sysMain label:has(input[type=radio]),
#sysAll #sysMain label:has(input[type=checkbox]) {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
  font-size: min(0.8125rem, 3.4666666667vw);
  margin-right: min(1.25rem, 5.3333333333vw);
}
#sysAll #sysMain label:has(input[type=radio]) input[type=radio],
#sysAll #sysMain label:has(input[type=radio]) input[type=checkbox],
#sysAll #sysMain label:has(input[type=checkbox]) input[type=radio],
#sysAll #sysMain label:has(input[type=checkbox]) input[type=checkbox] {
  margin-right: min(0.3125rem, 1.3333333333vw);
}
#sysAll #sysMain .sysFormItem {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysAll #sysMain .sysFormLabel {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysAll #sysMain .sysAutoLoginField {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0 min(0.3125rem, 1.3333333333vw);
}
#sysAll #sysMain .sysAutoLoginField .sysAutoLoginLabel {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.5;
}
#sysAll #sysMain .sysFormItem:has(input[name=zipcode]) {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
#sysAll #sysMain .sysFormItem:has(input[name=zipcode]) .sysFormLabel,
#sysAll #sysMain .sysFormItem:has(input[name=zipcode]) .SysInvalidZipcodeError {
  width: 100%;
}
#sysAll #sysMain .sysFormItem:has(input[name=zipcode]) .sysFormField {
  width: min(14.0625rem, 60vw);
  margin-right: min(0.625rem, 2.6666666667vw);
}
#sysAll #sysMain .sysFormItem:has(input[name=zipcode]) .input-append {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: 100%;
}
#sysAll #sysMain .sysFormItem:has(input[name=zipcode]) .input-append input[type=text] {
  width: min(14.0625rem, 60vw);
  margin-right: min(0.625rem, 2.6666666667vw);
}
#sysAll #sysMain .sysFuncItemSearch .sysItemSearchForm {
  position: relative;
}
#sysAll #sysMain .sysFuncItemSearch .sysItemSearchForm input[type=search] {
  width: calc(100% - min(6.25rem, 26.6666666667vw)) !important;
  border: none;
  border-radius: min(0.3125rem, 1.3333333333vw) 0 0 min(0.3125rem, 1.3333333333vw);
}
#sysAll #sysMain .sysFuncItemSearch .sysItemSearchForm input[type=submit] {
  display: block;
  width: min(6.25rem, 26.6666666667vw);
  height: min(2.5rem, 10.6666666667vw);
  min-height: min(2.5rem, 10.6666666667vw);
  font-size: 0;
  border: 1px solid #333333;
  border-radius: 0 min(0.3125rem, 1.3333333333vw) min(0.3125rem, 1.3333333333vw) 0;
  background-color: #333333;
  background-image: url(../img/common/ico_search.png);
  background-size: min(4.375rem, 18.6666666667vw);
  background-position: center center;
  background-repeat: no-repeat;
  cursor: pointer;
  position: absolute;
  top: 0;
  right: 0;
  margin-top: 0;
}
#sysAll #sysMain .sysItemSearchFormRange {
  display: flex;
  align-items: center;
  gap: 0 min(0.3125rem, 1.3333333333vw);
}
#sysAll #sysMain .sysMemberPassword .sysFormField:not(:last-of-type) {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysAll #sysMain .sysGender .sysFormField {
  display: flex;
}
#sysAll #sysMain .sysBirthday .sysFormField {
  display: flex;
  align-items: flex-end;
  gap: min(0.3125rem, 1.3333333333vw);
}
#sysAll #sysMain .sysBirthday .sysFormField input[type=text] {
  max-width: min(5rem, 21.3333333333vw);
}

.sysOpcBody input[type=text],
.sysOpcBody input[type=email],
.sysOpcBody input[type=search],
.sysOpcBody input[type=password],
.sysOpcBody input[type=tel],
.sysOpcBody input[type=number],
.sysOpcBody select {
  height: min(3.125rem, 13.3333333333vw);
  display: block;
  width: 100%;
  font-size: min(1rem, 4.2666666667vw);
  color: #333333;
  border: 1px solid #707070;
  border-radius: min(0.3125rem, 1.3333333333vw);
  background: #ffffff;
  padding: 0 min(0.625rem, 2.6666666667vw);
  margin: 0;
}
.sysOpcBody input[type=text]::-moz-placeholder, .sysOpcBody input[type=email]::-moz-placeholder, .sysOpcBody input[type=search]::-moz-placeholder, .sysOpcBody input[type=password]::-moz-placeholder, .sysOpcBody input[type=tel]::-moz-placeholder, .sysOpcBody input[type=number]::-moz-placeholder, .sysOpcBody select::-moz-placeholder {
  color: #c2c2c2;
}
.sysOpcBody input[type=text]::placeholder,
.sysOpcBody input[type=email]::placeholder,
.sysOpcBody input[type=search]::placeholder,
.sysOpcBody input[type=password]::placeholder,
.sysOpcBody input[type=tel]::placeholder,
.sysOpcBody input[type=number]::placeholder,
.sysOpcBody select::placeholder {
  color: #c2c2c2;
}

/*! ========================================================
フォーム「必須」設定
========================================================= */
.sysFormLabel:has(.sysRequired),
.sysFormLabel:has(+ .sysRequired),
.SysImproperReviewForm li:has(.sysRequired) {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
}
.sysFormLabel:has(.sysRequired)::after,
.sysFormLabel:has(+ .sysRequired)::after,
.SysImproperReviewForm li:has(.sysRequired)::after {
  content: "必須";
  display: inline-block;
  font-size: min(0.6875rem, 2.9333333333vw);
  font-weight: 400;
  line-height: 1.5;
  color: #ffffff;
  border-radius: min(0.1875rem, 0.8vw);
  background-color: #d12e2e;
  padding: min(0.0625rem, 0.2666666667vw) min(0.5rem, 2.1333333333vw) min(0.125rem, 0.5333333333vw);
  margin-left: min(0.75rem, 3.2vw);
  position: relative;
  bottom: min(0.0625rem, 0.2666666667vw);
}
.sysFormLabel:has(.sysRequired) .sysRequired,
.sysFormLabel:has(.sysRequired) + .sysRequired,
.sysFormLabel:has(+ .sysRequired) .sysRequired,
.sysFormLabel:has(+ .sysRequired) + .sysRequired,
.SysImproperReviewForm li:has(.sysRequired) .sysRequired,
.SysImproperReviewForm li:has(.sysRequired) + .sysRequired {
  display: none;
}

/*! ========================================================
ヘッダー設定
========================================================= */
#sysHeader > div:not(.header-content) {
  display: none;
}
#sysHeader .header-content {
  width: 100%;
}
#sysHeader .header-content .header-top {
  width: 96%;
  /*!max-width: min(75rem, 320vw);*/
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: min(0.5rem, 4vw) min(0.5rem, 3.2vw);
}
@media screen and (max-width: 768px) {
#sysHeader .header-content .header-top {
  width: 100%;
}
}
#sysHeader .header-content .header-top .header-top-left {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: min(1.875rem, 8vw);
  width: -moz-fit-content;
  width: fit-content;
}
#sysHeader .header-content .header-top .header-top-right {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: -moz-fit-content;
  width: fit-content;
  width: fit-content;
  gap: 30px; 
}
@media screen and (max-width: 768px) {
  #sysHeader .header-content .header-top .header-top-right {
  gap: 8px; 
}
}

.is-shrunk #sysHeader .header-content .header-top .header-top-right {
  gap: 10px; /* 隙間も少し詰めると、よりコンパクトに見えます */
}
#sysHeader .header-content .header-bottom_sec {
  width: 100% !important;
  background: #fff;
  padding: 0 0 8px 0;
  border-bottom: 1px solid #eee;
}
#sysHeader .header-content .header-bottom {
  width: 96%;
  /*max-width: min(75rem, 320vw);*/
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#sysHeader .header-sp {
  width: 96%;
  /*max-width: min(75rem, 320vw);*/
  margin-inline: auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
#sysHeader .header-content .header-bottom .header-bottom-left {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: -moz-fit-content;
  width: fit-content;
}
#sysHeader .header-content .header-bottom .header-bottom-right {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: -moz-fit-content;
  width: fit-content;
}
#sysHeader .header-banner ul {
  width: 100%;
  background-color: #333333;
}
#sysHeader .header-banner ul li {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
}
#sysHeader .header-banner ul li a {
  display: inline;
  width: -moz-fit-content;
  width: fit-content;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  color: #ffffff;
  text-align: center;
  margin-inline: auto;
}
#sysHeader .header-drawer-menu > .sysHeadline {
  display: flex;
  align-items: center;
  justify-content: center;
  width: min(2.5rem, 8vw);
  height: min(1.0625rem, 4.5333333333vw);
  cursor: pointer;
  position: relative;
}
#sysHeader .header-drawer-menu > .sysHeadline .header-drawer-menu__line {
  display: block;
  width: 100%;
  height: 0.083rem;
  border-radius: 100px;
  background-color: #333333;
}
#sysHeader .header-drawer-menu > .sysHeadline .header-drawer-menu__line::before, #sysHeader .header-drawer-menu > .sysHeadline .header-drawer-menu__line::after {
  content: "";
  display: block;
  width: 100%;
 height: 0.08rem;
  border-radius: 100px;
  background-color: #333333;
  position: absolute;
  left: 0;
  right: 0;
  margin-inline: auto;
}
#sysHeader .header-drawer-menu > .sysHeadline .header-drawer-menu__line::before {
  top: 0;
}
#sysHeader .header-drawer-menu > .sysHeadline .header-drawer-menu__line::after {
  bottom: 0;
}
#sysHeader .header-drawer-menu > .sysHeadline.is-open + .sysContent {
  pointer-events: auto;
}
#sysHeader .header-drawer-menu > .sysHeadline.is-open + .sysContent .header-drawer-menu__bg {
  opacity: 1;
}
#sysHeader .header-drawer-menu > .sysHeadline.is-open + .sysContent .header-drawer-menu__content {
left: auto !important;   /* 左待機を完全に打ち消す */
  right: 0 !important;      /* 画面の右端ピッタリに表示させる */
}
#sysHeader .header-drawer-menu > .sysContent {
  pointer-events: none;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__bg {
  width: 100%;
  height: 100dvh;
  background-color: rgba(51, 51, 51, 0.4);
  position: fixed;
  top: 0;
  left: 0;
  z-index: 10;
  opacity: 0;
  transition: 600ms;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content {
  width: 100%;
  max-width: min(25.3125rem, 108vw);
  height: 100dvh;
  background-color: #ffffff;
  padding: 0;
  position: fixed;
  top: 0;
  left: auto !important; 
  right: -100% !important;
  z-index: 20;
  transition: 600ms;
  overflow-y: scroll;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top {
  display: flex;
  flex-direction: row-reverse !important; /* これで左右が入れ替わります */
  align-items: center;
  margin-bottom: min(1.25rem, 5.3333333333vw);
  padding: 5%;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .btn-close {
  width: min(1.5625rem, 6.6666666667vw);
  height: min(1.5625rem, 6.6666666667vw);
  cursor: pointer;
  position: relative;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .btn-close::before, #sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .btn-close::after {
  content: "";
  display: block;
  width: min(1.5rem, 6.4vw);
  height: min(0.125rem, 0.5333333333vw);
  border-radius: 100px;
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  margin-inline: auto;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .btn-close::before {
  transform: translateY(-50%) rotate(45deg);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .btn-close::after {
  transform: translateY(-50%) rotate(-45deg);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .link-user {
  width: -moz-fit-content;
  width: fit-content;
  margin-left: 0 !important;      /* 元の margin-left: auto を打ち消し */
  margin-right: auto !important;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .link-user a {
  display: flex;
  align-items: center;
  gap: min(0.625rem, 2.6666666667vw);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .link-user a .icon-user {
  display: block;
  width: min(1.5625rem, 6.6666666667vw);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .link-user a span:not(.icon-user) {
  font-size: min(0.9375rem, 4vw);
  font-weight: 700;
  line-height: 1.5;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top .link-user a span:not(.icon-user).text-status__logged-in {
  display: none;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__shop-menu {
  border-bottom: 1px solid #c2c2c2;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory {
  border-top: 1px solid #c2c2c2;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  padding-block: min(0.6875rem, 2.9333333333vw) min(0.625rem, 2.6666666667vw);
  padding-right: min(1.5rem, 6.4vw);
  cursor: pointer;
  position: relative;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline::before, #sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline::after {
  content: "";
  display: block;
  width: min(0.75rem, 3.2vw);
  height: min(0.125rem, 0.5333333333vw);
  background-color: #333333;
  position: absolute;
  top: 50%;
  right: min(0.375rem, 1.6vw);
  transition: 200ms;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline::before {
  transform: translateY(-50%);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline::after {
  transform: translateY(-50%) rotate(90deg);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline.is-open::before {
  opacity: 0;
  transform: translateY(-50%) rotate(-90deg);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline.is-open::after {
  transform: translateY(-50%);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline + .sysContent {
  display: none;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory ul {
  padding-inline: min(0.625rem, 2.6666666667vw);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory ul li a {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw) min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  position: relative;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory ul li a::before {
  content: "";
  display: block;
  width: min(0.5rem, 2.1333333333vw);
  height: 1px;
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory ul li a::after {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(0.5rem, 2.1333333333vw);
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: 0;
  transform: translateY(-50%);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncListNav ul li,
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncText ul li {
  border-top: 1px solid #c2c2c2;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncListNav ul li a,
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncText ul li a {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
  padding-block: min(0.6875rem, 2.9333333333vw) min(0.625rem, 2.6666666667vw);
  padding-right: min(1.5rem, 6.4vw);
  position: relative;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncListNav ul li a::after,
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncText ul li a::after {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(0.5rem, 2.1333333333vw);
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: min(0.625rem, 2.6666666667vw);
  transform: translateY(-50%);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncListNav ul li a .icon,
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncText ul li a .icon {
  display: none;
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .footer-sns {
  margin-top: min(1.875rem, 8vw);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .footer-sns ul {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: min(0.9375rem, 4vw);
}
#sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .footer-sns ul li {
  width: min(1.25rem, 5.3333333333vw);
}
#sysHeader .header-logo {
  width: min(15rem, 51.4666666667vw);
}
#sysHeader .header-search {
  width: -moz-fit-content;
  width: fit-content;
}
#sysHeader .header-search form {
  width: min(21.5625rem, 92vw);
  position: relative;
}
#sysHeader .header-search form input[type=search] {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
  border: 1px solid #428f94;
  border-radius: 100px;
  background-color: #ffffff;
  padding: min(0.75rem, 3.2vw) min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw) min(3.1875rem, 13.6vw);
}
#sysHeader .header-search form input[type=search]::-moz-placeholder {
  color: #c2c2c2;
}
#sysHeader .header-search form input[type=search]::placeholder {
  color: #c2c2c2;
}
#sysHeader .header-search form input[type=submit] {
  display: block;
  width: min(1.5625rem, 6.6666666667vw);
  height: min(1.5625rem, 6.6666666667vw);
  font-size: 0;
  background-image: url(../img/layout/common/icon_search.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  left: min(0.625rem, 2.6666666667vw);
  transform: translateY(-50%);
}
#sysHeader .header-user-menu {
  width: -moz-fit-content;
  width: fit-content;
}
#sysHeader .header-user-menu ul {
  display: flex;
  align-items: flex-start !important;
  gap: min(3rem, 4vw);
}
#sysHeader .header-user-menu ul li {
  width: min(1.5625rem, 6.6666666667vw);
}
#sysHeader .header-user-menu ul li a {
  display: flex !important;
  flex-direction: column !important;   /* アイコンと文字を縦に */
  align-items: center !important;      /* 中央寄せ */
  text-align: center !important;
  gap: 2px !important;
}
#sysHeader .header-user-menu ul li a::after {
    font-size: 10px !important;          /* 小さい文字サイズ */
    font-weight: 700 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;      /* 改行させない */
    color: #333333 !important;
}
@media screen and (max-width: 768px) {
  #sysHeader .header-user-menu ul li a::after {
    font-size: 8px !important;  
    }
  #sysHeader .header-user-menu ul {
  gap: min(3rem, 6vw);
}
}
/* 各メニューの文字指定（順番に合わせて変えてください） */
#sysHeader .header-user-menu ul li:nth-child(1) a::after {
    content: "マイページ" !important;
}
#sysHeader .header-user-menu ul li:nth-child(2) a::after {
    content: "新規会員登録" !important;
}
#sysHeader .header-cart {
  position: relative;
}
#sysHeader .header-cart .sysCartInfoItemCount dt {
  display: none;
}
#sysHeader .header-cart .sysCartInfoItemCount dd {
  font-size: 0;
}
#sysHeader .header-cart .sysCartInfoItemCount dd span {
  display: none;
  align-items: center;
  width: min(0.9375rem, 4vw);
  height: min(0.9375rem, 4vw);
  font-size: min(0.625rem, 2.6666666667vw);
  font-weight: 500;
  line-height: 1;
  color: #ffffff;
  white-space: nowrap;
  border-radius: 50%;
  background-color: #d12e2e;
  position: absolute;
  top: 0rem;
  right: -0.1rem;
  pointer-events: none;
  z-index: 1;
  padding-left: min(0.3125rem, 1.3333333333vw);
}
#sysHeader .header-cart .sysCartInfoCartIn {
  width: min(1.5625rem, 6.6666666667vw);
  height: min(1.5625rem, 6.6666666667vw);
  font-size: 0;
}

#sysHeader .header-cart:not([data-item-count]) .sysCartInfoItemCount dd span, #sysHeader .header-cart[data-item-count=""] .sysCartInfoItemCount dd span, #sysHeader .header-cart[data-item-count="0"] .sysCartInfoItemCount dd span {
  display: none !important;
}
#sysHeader .header-cart:not([data-item-count="0"]) .sysCartInfoItemCount dd span {
  display: flex;
}




#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left {
  position: relative;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysHeadline {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  padding-block: min(0.625rem, 2.6666666667vw);
  padding-right: min(1.4375rem, 6.1333333333vw);
  cursor: pointer;
  position: relative;
  transition: 200ms;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysHeadline:hover {
  opacity: 0.7;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysHeadline:hover::after {
  transform: translateY(-50%) rotate(180deg);
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysHeadline:hover + .sysContent {
  opacity: 1;
  pointer-events: auto;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysHeadline:has(+ .sysContent:hover)::after {
  transform: translateY(-50%) rotate(180deg);
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysHeadline::after {
  content: "";
  display: block;
  width: min(0.5rem, 2.1333333333vw);
  height: min(0.25rem, 1.0666666667vw);
  background-image: url(../img/layout/common/arrow_down_black.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: min(0.3125rem, 1.3333333333vw);
  transform: translateY(-50%);
  transition: 200ms;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysContent {
  min-width: min(19.6875rem, 84vw);
  padding-top: 1px;
  position: absolute;
  top: 100%;
  left: -1.875rem;
  z-index: 10;
  opacity: 0;
  pointer-events: none;
  transition: 200ms;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysContent:hover {
  opacity: 1;
  pointer-events: auto;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysContent nav {
  display: block;
  background-color: #ffffff;
  padding: 1.875rem;
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysContent nav ul {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
#sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysContent nav ul li a {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
}
#sysHeader .header-bottom .sysFuncListNav.header-content-bottom-left ul {
  display: flex;
  align-items: center;
  gap: min(2.1875rem, 9.3333333333vw);
}
#sysHeader .header-bottom .sysFuncListNav.header-content-bottom-left ul li {
  width: -moz-fit-content !important;
  width: fit-content !important;
}
#sysHeader .header-bottom .sysFuncListNav.header-content-bottom-left ul li a {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  padding-block: min(0.625rem, 2.6666666667vw);
}
#sysHeader .header-bottom .header-shop-info ul {
  display: flex;
  align-items: center;
  gap: min(2.1875rem, 9.3333333333vw);
}
#sysHeader .header-bottom .header-shop-info ul li {
  width: -moz-fit-content;
  width: fit-content;
}
#sysHeader .header-bottom .header-shop-info ul li a {
  display: flex;
  align-items: center;
  gap: min(0.625rem, 2.6666666667vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  padding-block: min(0.625rem, 2.6666666667vw);
}
#sysHeader .header-bottom .header-shop-info ul li a .icon {
  display: block;
  width: min(1.5rem, 6.4vw);
}

/*! ========================================================
アサイド設定
========================================================= */
#sysWrap #sysAside {
  width: min(19.0625rem, 81.3333333333vw);
}
#sysWrap #sysAside .aside-category {
  border-bottom: none;
  padding: 0;
}
#sysWrap #sysAside .aside-category:first-of-type {
  border-top: none;
}
#sysWrap #sysAside .aside-category .sysHeadline,
#sysWrap #sysAside .aside-set .sysHeadline {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  padding: 20px 25px; /* 余白を広く */
  margin: 0;
  border-bottom: 1px solid #e0e0e0; /* 見出しの下に薄い線を入れる */
}
#sysWrap #sysAside .aside-category ul,
#sysWrap #sysAside .aside-set ul {
  padding: 10px 0; /* 上下に少し余白 */
  margin: 0;
  list-style: none;
}
#sysWrap #sysAside .aside-category ul li {
  margin: 0;
  padding: 0;
}
#sysWrap #sysAside .aside-category ul li a,
#sysWrap #sysAside .aside-set ul li a,
#sysWrap #sysAside .aside-set .sysItemName a {
  display: flex; /* 矢印と文字を横並びにする */
  align-items: center;
  font-size: 15px; /* 文字サイズ */
  font-weight: normal;
  text-decoration: none;
  padding: 12px 25px 12px 50px; /* 左側に矢印用の広い余白を作る */
  position: relative;
  transition: background-color 0.3s; /* ホバー時のアニメーション */
}
/* ホバー時の背景色変更 */
#sysWrap #sysAside .aside-category ul li a:hover,
#sysWrap #sysAside .aside-set ul li a:hover,
#sysWrap #sysAside .aside-set .sysItemName a:hover {
  color: #888;
}

#sysWrap #sysAside .aside-category ul li a::after,
#sysWrap #sysAside .aside-set ul li a::after,
#sysWrap #sysAside .aside-set .sysItemName a::after {
  content: "";
  display: block;
  width: 7px; /* 矢印の横幅 */
  height: 12px; /* 矢印の縦幅 */
  /* aiship標準の矢印画像パス（グレー） */
  background-image: url(/img/layout/common/arrow_right_thin_gray.png); 
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  
  /* 絶対配置で左側に固定 */
  position: absolute;
  top: 50%;
  left: 25px; /* 左端からの位置 */
  transform: translateY(-50%); /* 上下中央揃え */
  
  right: auto; /* 既存の右配置設定をリセット */
}

/*!
 * animate.css - https://animate.style/
 * Version - 4.1.1
 * Licensed under the MIT license - http://opensource.org/licenses/MIT
 *
 * Copyright (c) 2020 Animate.css
 */
:root {
  --animate-duration: 1s;
  --animate-delay: 1s;
  --animate-repeat: 1;
}

.animate__animated {
  animation-duration: 1s;
  animation-duration: var(--animate-duration);
  animation-fill-mode: both;
}

.animate__animated.animate__infinite {
  animation-iteration-count: infinite;
}

.animate__animated.animate__repeat-1 {
  animation-iteration-count: 1;
  animation-iteration-count: var(--animate-repeat);
}

.animate__animated.animate__repeat-2 {
  animation-iteration-count: 2;
  animation-iteration-count: calc(var(--animate-repeat) * 2);
}

.animate__animated.animate__repeat-3 {
  animation-iteration-count: 3;
  animation-iteration-count: calc(var(--animate-repeat) * 3);
}

.animate__animated.animate__delay-1s {
  animation-delay: 1s;
  animation-delay: var(--animate-delay);
}

.animate__animated.animate__delay-2s {
  animation-delay: 2s;
  animation-delay: calc(var(--animate-delay) * 2);
}

.animate__animated.animate__delay-3s {
  animation-delay: 3s;
  animation-delay: calc(var(--animate-delay) * 3);
}

.animate__animated.animate__delay-4s {
  animation-delay: 4s;
  animation-delay: calc(var(--animate-delay) * 4);
}

.animate__animated.animate__delay-5s {
  animation-delay: 5s;
  animation-delay: calc(var(--animate-delay) * 5);
}

.animate__animated.animate__faster {
  animation-duration: 0.5s;
  animation-duration: calc(var(--animate-duration) / 2);
}

.animate__animated.animate__fast {
  animation-duration: 0.8s;
  animation-duration: calc(var(--animate-duration) * 0.8);
}

.animate__animated.animate__slow {
  animation-duration: 2s;
  animation-duration: calc(var(--animate-duration) * 2);
}

.animate__animated.animate__slower {
  animation-duration: 3s;
  animation-duration: calc(var(--animate-duration) * 3);
}
@keyframes bounce {
  0%, 20%, 53%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translateZ(0);
  }
  40%, 43% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -30px, 0) scaleY(1.1);
  }
  70% {
    animation-timing-function: cubic-bezier(0.755, 0.05, 0.855, 0.06);
    transform: translate3d(0, -15px, 0) scaleY(1.05);
  }
  80% {
    transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
    transform: translateZ(0) scaleY(0.95);
  }
  90% {
    transform: translate3d(0, -4px, 0) scaleY(1.02);
  }
}
.animate__bounce {
  animation-name: bounce;
  transform-origin: center bottom;
}
@keyframes flash {
  0%, 50%, to {
    opacity: 1;
  }
  25%, 75% {
    opacity: 0;
  }
}
.animate__flash {
  animation-name: flash;
}
@keyframes pulse {
  0% {
    transform: scaleX(1);
  }
  50% {
    transform: scale3d(1.05, 1.05, 1.05);
  }
  to {
    transform: scaleX(1);
  }
}
.animate__pulse {
  animation-name: pulse;
  animation-timing-function: ease-in-out;
}
@keyframes rubberBand {
  0% {
    transform: scaleX(1);
  }
  30% {
    transform: scale3d(1.25, 0.75, 1);
  }
  40% {
    transform: scale3d(0.75, 1.25, 1);
  }
  50% {
    transform: scale3d(1.15, 0.85, 1);
  }
  65% {
    transform: scale3d(0.95, 1.05, 1);
  }
  75% {
    transform: scale3d(1.05, 0.95, 1);
  }
  to {
    transform: scaleX(1);
  }
}
.animate__rubberBand {
  animation-name: rubberBand;
}
@keyframes shakeX {
  0%, to {
    transform: translateZ(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translate3d(-10px, 0, 0);
  }
  20%, 40%, 60%, 80% {
    transform: translate3d(10px, 0, 0);
  }
}
.animate__shakeX {
  animation-name: shakeX;
}
@keyframes shakeY {
  0%, to {
    transform: translateZ(0);
  }
  10%, 30%, 50%, 70%, 90% {
    transform: translate3d(0, -10px, 0);
  }
  20%, 40%, 60%, 80% {
    transform: translate3d(0, 10px, 0);
  }
}
.animate__shakeY {
  animation-name: shakeY;
}
@keyframes headShake {
  0% {
    transform: translateX(0);
  }
  6.5% {
    transform: translateX(-6px) rotateY(-9deg);
  }
  18.5% {
    transform: translateX(5px) rotateY(7deg);
  }
  31.5% {
    transform: translateX(-3px) rotateY(-5deg);
  }
  43.5% {
    transform: translateX(2px) rotateY(3deg);
  }
  50% {
    transform: translateX(0);
  }
}
.animate__headShake {
  animation-timing-function: ease-in-out;
  animation-name: headShake;
}
@keyframes swing {
  20% {
    transform: rotate(15deg);
  }
  40% {
    transform: rotate(-10deg);
  }
  60% {
    transform: rotate(5deg);
  }
  80% {
    transform: rotate(-5deg);
  }
  to {
    transform: rotate(0deg);
  }
}
.animate__swing {
  transform-origin: top center;
  animation-name: swing;
}
@keyframes tada {
  0% {
    transform: scaleX(1);
  }
  10%, 20% {
    transform: scale3d(0.9, 0.9, 0.9) rotate(-3deg);
  }
  30%, 50%, 70%, 90% {
    transform: scale3d(1.1, 1.1, 1.1) rotate(3deg);
  }
  40%, 60%, 80% {
    transform: scale3d(1.1, 1.1, 1.1) rotate(-3deg);
  }
  to {
    transform: scaleX(1);
  }
}
.animate__tada {
  animation-name: tada;
}
@keyframes wobble {
  0% {
    transform: translateZ(0);
  }
  15% {
    transform: translate3d(-25%, 0, 0) rotate(-5deg);
  }
  30% {
    transform: translate3d(20%, 0, 0) rotate(3deg);
  }
  45% {
    transform: translate3d(-15%, 0, 0) rotate(-3deg);
  }
  60% {
    transform: translate3d(10%, 0, 0) rotate(2deg);
  }
  75% {
    transform: translate3d(-5%, 0, 0) rotate(-1deg);
  }
  to {
    transform: translateZ(0);
  }
}
.animate__wobble {
  animation-name: wobble;
}
@keyframes jello {
  0%, 11.1%, to {
    transform: translateZ(0);
  }
  22.2% {
    transform: skewX(-12.5deg) skewY(-12.5deg);
  }
  33.3% {
    transform: skewX(6.25deg) skewY(6.25deg);
  }
  44.4% {
    transform: skewX(-3.125deg) skewY(-3.125deg);
  }
  55.5% {
    transform: skewX(1.5625deg) skewY(1.5625deg);
  }
  66.6% {
    transform: skewX(-0.78125deg) skewY(-0.78125deg);
  }
  77.7% {
    transform: skewX(0.390625deg) skewY(0.390625deg);
  }
  88.8% {
    transform: skewX(-0.1953125deg) skewY(-0.1953125deg);
  }
}
.animate__jello {
  animation-name: jello;
  transform-origin: center;
}
@keyframes heartBeat {
  0% {
    transform: scale(1);
  }
  14% {
    transform: scale(1.3);
  }
  28% {
    transform: scale(1);
  }
  42% {
    transform: scale(1.3);
  }
  70% {
    transform: scale(1);
  }
}
.animate__heartBeat {
  animation-name: heartBeat;
  animation-duration: 1.3s;
  animation-duration: calc(var(--animate-duration) * 1.3);
  animation-timing-function: ease-in-out;
}
@keyframes backInDown {
  0% {
    transform: translateY(-1200px) scale(0.7);
    opacity: 0.7;
  }
  80% {
    transform: translateY(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.animate__backInDown {
  animation-name: backInDown;
}
@keyframes backInLeft {
  0% {
    transform: translateX(-2000px) scale(0.7);
    opacity: 0.7;
  }
  80% {
    transform: translateX(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.animate__backInLeft {
  animation-name: backInLeft;
}
@keyframes backInRight {
  0% {
    transform: translateX(2000px) scale(0.7);
    opacity: 0.7;
  }
  80% {
    transform: translateX(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.animate__backInRight {
  animation-name: backInRight;
}
@keyframes backInUp {
  0% {
    transform: translateY(1200px) scale(0.7);
    opacity: 0.7;
  }
  80% {
    transform: translateY(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: scale(1);
    opacity: 1;
  }
}
.animate__backInUp {
  animation-name: backInUp;
}
@keyframes backOutDown {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  20% {
    transform: translateY(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: translateY(700px) scale(0.7);
    opacity: 0.7;
  }
}
.animate__backOutDown {
  animation-name: backOutDown;
}
@keyframes backOutLeft {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  20% {
    transform: translateX(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: translateX(-2000px) scale(0.7);
    opacity: 0.7;
  }
}
.animate__backOutLeft {
  animation-name: backOutLeft;
}
@keyframes backOutRight {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  20% {
    transform: translateX(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: translateX(2000px) scale(0.7);
    opacity: 0.7;
  }
}
.animate__backOutRight {
  animation-name: backOutRight;
}
@keyframes backOutUp {
  0% {
    transform: scale(1);
    opacity: 1;
  }
  20% {
    transform: translateY(0) scale(0.7);
    opacity: 0.7;
  }
  to {
    transform: translateY(-700px) scale(0.7);
    opacity: 0.7;
  }
}
.animate__backOutUp {
  animation-name: backOutUp;
}
@keyframes bounceIn {
  0%, 20%, 40%, 60%, 80%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  20% {
    transform: scale3d(1.1, 1.1, 1.1);
  }
  40% {
    transform: scale3d(0.9, 0.9, 0.9);
  }
  60% {
    opacity: 1;
    transform: scale3d(1.03, 1.03, 1.03);
  }
  80% {
    transform: scale3d(0.97, 0.97, 0.97);
  }
  to {
    opacity: 1;
    transform: scaleX(1);
  }
}
.animate__bounceIn {
  animation-duration: 0.75s;
  animation-duration: calc(var(--animate-duration) * 0.75);
  animation-name: bounceIn;
}
@keyframes bounceInDown {
  0%, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    opacity: 0;
    transform: translate3d(0, -3000px, 0) scaleY(3);
  }
  60% {
    opacity: 1;
    transform: translate3d(0, 25px, 0) scaleY(0.9);
  }
  75% {
    transform: translate3d(0, -10px, 0) scaleY(0.95);
  }
  90% {
    transform: translate3d(0, 5px, 0) scaleY(0.985);
  }
  to {
    transform: translateZ(0);
  }
}
.animate__bounceInDown {
  animation-name: bounceInDown;
}
@keyframes bounceInLeft {
  0%, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    opacity: 0;
    transform: translate3d(-3000px, 0, 0) scaleX(3);
  }
  60% {
    opacity: 1;
    transform: translate3d(25px, 0, 0) scaleX(1);
  }
  75% {
    transform: translate3d(-10px, 0, 0) scaleX(0.98);
  }
  90% {
    transform: translate3d(5px, 0, 0) scaleX(0.995);
  }
  to {
    transform: translateZ(0);
  }
}
.animate__bounceInLeft {
  animation-name: bounceInLeft;
}
@keyframes bounceInRight {
  0%, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    opacity: 0;
    transform: translate3d(3000px, 0, 0) scaleX(3);
  }
  60% {
    opacity: 1;
    transform: translate3d(-25px, 0, 0) scaleX(1);
  }
  75% {
    transform: translate3d(10px, 0, 0) scaleX(0.98);
  }
  90% {
    transform: translate3d(-5px, 0, 0) scaleX(0.995);
  }
  to {
    transform: translateZ(0);
  }
}
.animate__bounceInRight {
  animation-name: bounceInRight;
}
@keyframes bounceInUp {
  0%, 60%, 75%, 90%, to {
    animation-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
  }
  0% {
    opacity: 0;
    transform: translate3d(0, 3000px, 0) scaleY(5);
  }
  60% {
    opacity: 1;
    transform: translate3d(0, -20px, 0) scaleY(0.9);
  }
  75% {
    transform: translate3d(0, 10px, 0) scaleY(0.95);
  }
  90% {
    transform: translate3d(0, -5px, 0) scaleY(0.985);
  }
  to {
    transform: translateZ(0);
  }
}
.animate__bounceInUp {
  animation-name: bounceInUp;
}
@keyframes bounceOut {
  20% {
    transform: scale3d(0.9, 0.9, 0.9);
  }
  50%, 55% {
    opacity: 1;
    transform: scale3d(1.1, 1.1, 1.1);
  }
  to {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
}
.animate__bounceOut {
  animation-duration: 0.75s;
  animation-duration: calc(var(--animate-duration) * 0.75);
  animation-name: bounceOut;
}
@keyframes bounceOutDown {
  20% {
    transform: translate3d(0, 10px, 0) scaleY(0.985);
  }
  40%, 45% {
    opacity: 1;
    transform: translate3d(0, -20px, 0) scaleY(0.9);
  }
  to {
    opacity: 0;
    transform: translate3d(0, 2000px, 0) scaleY(3);
  }
}
.animate__bounceOutDown {
  animation-name: bounceOutDown;
}
@keyframes bounceOutLeft {
  20% {
    opacity: 1;
    transform: translate3d(20px, 0, 0) scaleX(0.9);
  }
  to {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0) scaleX(2);
  }
}
.animate__bounceOutLeft {
  animation-name: bounceOutLeft;
}
@keyframes bounceOutRight {
  20% {
    opacity: 1;
    transform: translate3d(-20px, 0, 0) scaleX(0.9);
  }
  to {
    opacity: 0;
    transform: translate3d(2000px, 0, 0) scaleX(2);
  }
}
.animate__bounceOutRight {
  animation-name: bounceOutRight;
}
@keyframes bounceOutUp {
  20% {
    transform: translate3d(0, -10px, 0) scaleY(0.985);
  }
  40%, 45% {
    opacity: 1;
    transform: translate3d(0, 20px, 0) scaleY(0.9);
  }
  to {
    opacity: 0;
    transform: translate3d(0, -2000px, 0) scaleY(3);
  }
}
.animate__bounceOutUp {
  animation-name: bounceOutUp;
}
@keyframes fadeIn {
  0% {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
.animate__fadeIn {
  animation-name: fadeIn;
}
@keyframes fadeInDown {
  0% {
    opacity: 0;
    transform: translate3d(0, -100%, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInDown {
  animation-name: fadeInDown;
}
@keyframes fadeInDownBig {
  0% {
    opacity: 0;
    transform: translate3d(0, -2000px, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInDownBig {
  animation-name: fadeInDownBig;
}
@keyframes fadeInLeft {
  0% {
    opacity: 0;
    transform: translate3d(-100%, 0, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInLeft {
  animation-name: fadeInLeft;
}
@keyframes fadeInLeftBig {
  0% {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInLeftBig {
  animation-name: fadeInLeftBig;
}
@keyframes fadeInRight {
  0% {
    opacity: 0;
    transform: translate3d(100%, 0, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInRight {
  animation-name: fadeInRight;
}
@keyframes fadeInRightBig {
  0% {
    opacity: 0;
    transform: translate3d(2000px, 0, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInRightBig {
  animation-name: fadeInRightBig;
}
@keyframes fadeInUp {
  0% {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInUp {
  animation-name: fadeInUp;
}
@keyframes fadeInUpBig {
  0% {
    opacity: 0;
    transform: translate3d(0, 2000px, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInUpBig {
  animation-name: fadeInUpBig;
}
@keyframes fadeInTopLeft {
  0% {
    opacity: 0;
    transform: translate3d(-100%, -100%, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInTopLeft {
  animation-name: fadeInTopLeft;
}
@keyframes fadeInTopRight {
  0% {
    opacity: 0;
    transform: translate3d(100%, -100%, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInTopRight {
  animation-name: fadeInTopRight;
}
@keyframes fadeInBottomLeft {
  0% {
    opacity: 0;
    transform: translate3d(-100%, 100%, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInBottomLeft {
  animation-name: fadeInBottomLeft;
}
@keyframes fadeInBottomRight {
  0% {
    opacity: 0;
    transform: translate3d(100%, 100%, 0);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__fadeInBottomRight {
  animation-name: fadeInBottomRight;
}
@keyframes fadeOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
.animate__fadeOut {
  animation-name: fadeOut;
}
@keyframes fadeOutDown {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(0, 100%, 0);
  }
}
.animate__fadeOutDown {
  animation-name: fadeOutDown;
}
@keyframes fadeOutDownBig {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(0, 2000px, 0);
  }
}
.animate__fadeOutDownBig {
  animation-name: fadeOutDownBig;
}
@keyframes fadeOutLeft {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(-100%, 0, 0);
  }
}
.animate__fadeOutLeft {
  animation-name: fadeOutLeft;
}
@keyframes fadeOutLeftBig {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(-2000px, 0, 0);
  }
}
.animate__fadeOutLeftBig {
  animation-name: fadeOutLeftBig;
}
@keyframes fadeOutRight {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(100%, 0, 0);
  }
}
.animate__fadeOutRight {
  animation-name: fadeOutRight;
}
@keyframes fadeOutRightBig {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(2000px, 0, 0);
  }
}
.animate__fadeOutRightBig {
  animation-name: fadeOutRightBig;
}
@keyframes fadeOutUp {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(0, -100%, 0);
  }
}
.animate__fadeOutUp {
  animation-name: fadeOutUp;
}
@keyframes fadeOutUpBig {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(0, -2000px, 0);
  }
}
.animate__fadeOutUpBig {
  animation-name: fadeOutUpBig;
}
@keyframes fadeOutTopLeft {
  0% {
    opacity: 1;
    transform: translateZ(0);
  }
  to {
    opacity: 0;
    transform: translate3d(-100%, -100%, 0);
  }
}
.animate__fadeOutTopLeft {
  animation-name: fadeOutTopLeft;
}
@keyframes fadeOutTopRight {
  0% {
    opacity: 1;
    transform: translateZ(0);
  }
  to {
    opacity: 0;
    transform: translate3d(100%, -100%, 0);
  }
}
.animate__fadeOutTopRight {
  animation-name: fadeOutTopRight;
}
@keyframes fadeOutBottomRight {
  0% {
    opacity: 1;
    transform: translateZ(0);
  }
  to {
    opacity: 0;
    transform: translate3d(100%, 100%, 0);
  }
}
.animate__fadeOutBottomRight {
  animation-name: fadeOutBottomRight;
}
@keyframes fadeOutBottomLeft {
  0% {
    opacity: 1;
    transform: translateZ(0);
  }
  to {
    opacity: 0;
    transform: translate3d(-100%, 100%, 0);
  }
}
.animate__fadeOutBottomLeft {
  animation-name: fadeOutBottomLeft;
}
@keyframes flip {
  0% {
    transform: perspective(400px) scaleX(1) translateZ(0) rotateY(-1turn);
    animation-timing-function: ease-out;
  }
  40% {
    transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-190deg);
    animation-timing-function: ease-out;
  }
  50% {
    transform: perspective(400px) scaleX(1) translateZ(150px) rotateY(-170deg);
    animation-timing-function: ease-in;
  }
  80% {
    transform: perspective(400px) scale3d(0.95, 0.95, 0.95) translateZ(0) rotateY(0deg);
    animation-timing-function: ease-in;
  }
  to {
    transform: perspective(400px) scaleX(1) translateZ(0) rotateY(0deg);
    animation-timing-function: ease-in;
  }
}
.animate__animated.animate__flip {
  backface-visibility: visible;
  animation-name: flip;
}
@keyframes flipInX {
  0% {
    transform: perspective(400px) rotateX(90deg);
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotateX(-20deg);
    animation-timing-function: ease-in;
  }
  60% {
    transform: perspective(400px) rotateX(10deg);
    opacity: 1;
  }
  80% {
    transform: perspective(400px) rotateX(-5deg);
  }
  to {
    transform: perspective(400px);
  }
}
.animate__flipInX {
  backface-visibility: visible !important;
  animation-name: flipInX;
}
@keyframes flipInY {
  0% {
    transform: perspective(400px) rotateY(90deg);
    animation-timing-function: ease-in;
    opacity: 0;
  }
  40% {
    transform: perspective(400px) rotateY(-20deg);
    animation-timing-function: ease-in;
  }
  60% {
    transform: perspective(400px) rotateY(10deg);
    opacity: 1;
  }
  80% {
    transform: perspective(400px) rotateY(-5deg);
  }
  to {
    transform: perspective(400px);
  }
}
.animate__flipInY {
  backface-visibility: visible !important;
  animation-name: flipInY;
}
@keyframes flipOutX {
  0% {
    transform: perspective(400px);
  }
  30% {
    transform: perspective(400px) rotateX(-20deg);
    opacity: 1;
  }
  to {
    transform: perspective(400px) rotateX(90deg);
    opacity: 0;
  }
}
.animate__flipOutX {
  animation-duration: 0.75s;
  animation-duration: calc(var(--animate-duration) * 0.75);
  animation-name: flipOutX;
  backface-visibility: visible !important;
}
@keyframes flipOutY {
  0% {
    transform: perspective(400px);
  }
  30% {
    transform: perspective(400px) rotateY(-15deg);
    opacity: 1;
  }
  to {
    transform: perspective(400px) rotateY(90deg);
    opacity: 0;
  }
}
.animate__flipOutY {
  animation-duration: 0.75s;
  animation-duration: calc(var(--animate-duration) * 0.75);
  backface-visibility: visible !important;
  animation-name: flipOutY;
}
@keyframes lightSpeedInRight {
  0% {
    transform: translate3d(100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }
  60% {
    transform: skewX(20deg);
    opacity: 1;
  }
  80% {
    transform: skewX(-5deg);
  }
  to {
    transform: translateZ(0);
  }
}
.animate__lightSpeedInRight {
  animation-name: lightSpeedInRight;
  animation-timing-function: ease-out;
}
@keyframes lightSpeedInLeft {
  0% {
    transform: translate3d(-100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
  60% {
    transform: skewX(-20deg);
    opacity: 1;
  }
  80% {
    transform: skewX(5deg);
  }
  to {
    transform: translateZ(0);
  }
}
.animate__lightSpeedInLeft {
  animation-name: lightSpeedInLeft;
  animation-timing-function: ease-out;
}
@keyframes lightSpeedOutRight {
  0% {
    opacity: 1;
  }
  to {
    transform: translate3d(100%, 0, 0) skewX(30deg);
    opacity: 0;
  }
}
.animate__lightSpeedOutRight {
  animation-name: lightSpeedOutRight;
  animation-timing-function: ease-in;
}
@keyframes lightSpeedOutLeft {
  0% {
    opacity: 1;
  }
  to {
    transform: translate3d(-100%, 0, 0) skewX(-30deg);
    opacity: 0;
  }
}
.animate__lightSpeedOutLeft {
  animation-name: lightSpeedOutLeft;
  animation-timing-function: ease-in;
}
@keyframes rotateIn {
  0% {
    transform: rotate(-200deg);
    opacity: 0;
  }
  to {
    transform: translateZ(0);
    opacity: 1;
  }
}
.animate__rotateIn {
  animation-name: rotateIn;
  transform-origin: center;
}
@keyframes rotateInDownLeft {
  0% {
    transform: rotate(-45deg);
    opacity: 0;
  }
  to {
    transform: translateZ(0);
    opacity: 1;
  }
}
.animate__rotateInDownLeft {
  animation-name: rotateInDownLeft;
  transform-origin: left bottom;
}
@keyframes rotateInDownRight {
  0% {
    transform: rotate(45deg);
    opacity: 0;
  }
  to {
    transform: translateZ(0);
    opacity: 1;
  }
}
.animate__rotateInDownRight {
  animation-name: rotateInDownRight;
  transform-origin: right bottom;
}
@keyframes rotateInUpLeft {
  0% {
    transform: rotate(45deg);
    opacity: 0;
  }
  to {
    transform: translateZ(0);
    opacity: 1;
  }
}
.animate__rotateInUpLeft {
  animation-name: rotateInUpLeft;
  transform-origin: left bottom;
}
@keyframes rotateInUpRight {
  0% {
    transform: rotate(-90deg);
    opacity: 0;
  }
  to {
    transform: translateZ(0);
    opacity: 1;
  }
}
.animate__rotateInUpRight {
  animation-name: rotateInUpRight;
  transform-origin: right bottom;
}
@keyframes rotateOut {
  0% {
    opacity: 1;
  }
  to {
    transform: rotate(200deg);
    opacity: 0;
  }
}
.animate__rotateOut {
  animation-name: rotateOut;
  transform-origin: center;
}
@keyframes rotateOutDownLeft {
  0% {
    opacity: 1;
  }
  to {
    transform: rotate(45deg);
    opacity: 0;
  }
}
.animate__rotateOutDownLeft {
  animation-name: rotateOutDownLeft;
  transform-origin: left bottom;
}
@keyframes rotateOutDownRight {
  0% {
    opacity: 1;
  }
  to {
    transform: rotate(-45deg);
    opacity: 0;
  }
}
.animate__rotateOutDownRight {
  animation-name: rotateOutDownRight;
  transform-origin: right bottom;
}
@keyframes rotateOutUpLeft {
  0% {
    opacity: 1;
  }
  to {
    transform: rotate(-45deg);
    opacity: 0;
  }
}
.animate__rotateOutUpLeft {
  animation-name: rotateOutUpLeft;
  transform-origin: left bottom;
}
@keyframes rotateOutUpRight {
  0% {
    opacity: 1;
  }
  to {
    transform: rotate(90deg);
    opacity: 0;
  }
}
.animate__rotateOutUpRight {
  animation-name: rotateOutUpRight;
  transform-origin: right bottom;
}
@keyframes hinge {
  0% {
    animation-timing-function: ease-in-out;
  }
  20%, 60% {
    transform: rotate(80deg);
    animation-timing-function: ease-in-out;
  }
  40%, 80% {
    transform: rotate(60deg);
    animation-timing-function: ease-in-out;
    opacity: 1;
  }
  to {
    transform: translate3d(0, 700px, 0);
    opacity: 0;
  }
}
.animate__hinge {
  animation-duration: 2s;
  animation-duration: calc(var(--animate-duration) * 2);
  animation-name: hinge;
  transform-origin: top left;
}
@keyframes jackInTheBox {
  0% {
    opacity: 0;
    transform: scale(0.1) rotate(30deg);
    transform-origin: center bottom;
  }
  50% {
    transform: rotate(-10deg);
  }
  70% {
    transform: rotate(3deg);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
.animate__jackInTheBox {
  animation-name: jackInTheBox;
}
@keyframes rollIn {
  0% {
    opacity: 0;
    transform: translate3d(-100%, 0, 0) rotate(-120deg);
  }
  to {
    opacity: 1;
    transform: translateZ(0);
  }
}
.animate__rollIn {
  animation-name: rollIn;
}
@keyframes rollOut {
  0% {
    opacity: 1;
  }
  to {
    opacity: 0;
    transform: translate3d(100%, 0, 0) rotate(120deg);
  }
}
.animate__rollOut {
  animation-name: rollOut;
}
@keyframes zoomIn {
  0% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  50% {
    opacity: 1;
  }
}
.animate__zoomIn {
  animation-name: zoomIn;
}
@keyframes zoomInDown {
  0% {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -1000px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}
.animate__zoomInDown {
  animation-name: zoomInDown;
}
@keyframes zoomInLeft {
  0% {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(-1000px, 0, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(10px, 0, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}
.animate__zoomInLeft {
  animation-name: zoomInLeft;
}
@keyframes zoomInRight {
  0% {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(1000px, 0, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-10px, 0, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}
.animate__zoomInRight {
  animation-name: zoomInRight;
}
@keyframes zoomInUp {
  0% {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 1000px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }
  60% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}
.animate__zoomInUp {
  animation-name: zoomInUp;
}
@keyframes zoomOut {
  0% {
    opacity: 1;
  }
  50% {
    opacity: 0;
    transform: scale3d(0.3, 0.3, 0.3);
  }
  to {
    opacity: 0;
  }
}
.animate__zoomOut {
  animation-name: zoomOut;
}
@keyframes zoomOutDown {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, -60px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }
  to {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, 2000px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}
.animate__zoomOutDown {
  animation-name: zoomOutDown;
  transform-origin: center bottom;
}
@keyframes zoomOutLeft {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(42px, 0, 0);
  }
  to {
    opacity: 0;
    transform: scale(0.1) translate3d(-2000px, 0, 0);
  }
}
.animate__zoomOutLeft {
  animation-name: zoomOutLeft;
  transform-origin: left center;
}
@keyframes zoomOutRight {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(-42px, 0, 0);
  }
  to {
    opacity: 0;
    transform: scale(0.1) translate3d(2000px, 0, 0);
  }
}
.animate__zoomOutRight {
  animation-name: zoomOutRight;
  transform-origin: right center;
}
@keyframes zoomOutUp {
  40% {
    opacity: 1;
    transform: scale3d(0.475, 0.475, 0.475) translate3d(0, 60px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }
  to {
    opacity: 0;
    transform: scale3d(0.1, 0.1, 0.1) translate3d(0, -2000px, 0);
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1);
  }
}
.animate__zoomOutUp {
  animation-name: zoomOutUp;
  transform-origin: center bottom;
}
@keyframes slideInDown {
  0% {
    transform: translate3d(0, -100%, 0);
    visibility: visible;
  }
  to {
    transform: translateZ(0);
  }
}
.animate__slideInDown {
  animation-name: slideInDown;
}
@keyframes slideInLeft {
  0% {
    transform: translate3d(-100%, 0, 0);
    visibility: visible;
  }
  to {
    transform: translateZ(0);
  }
}
.animate__slideInLeft {
  animation-name: slideInLeft;
}
@keyframes slideInRight {
  0% {
    transform: translate3d(100%, 0, 0);
    visibility: visible;
  }
  to {
    transform: translateZ(0);
  }
}
.animate__slideInRight {
  animation-name: slideInRight;
}
@keyframes slideInUp {
  0% {
    transform: translate3d(0, 100%, 0);
    visibility: visible;
  }
  to {
    transform: translateZ(0);
  }
}
.animate__slideInUp {
  animation-name: slideInUp;
}
@keyframes slideOutDown {
  0% {
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    transform: translate3d(0, 100%, 0);
  }
}
.animate__slideOutDown {
  animation-name: slideOutDown;
}
@keyframes slideOutLeft {
  0% {
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    transform: translate3d(-100%, 0, 0);
  }
}
.animate__slideOutLeft {
  animation-name: slideOutLeft;
}
@keyframes slideOutRight {
  0% {
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    transform: translate3d(100%, 0, 0);
  }
}
.animate__slideOutRight {
  animation-name: slideOutRight;
}
@keyframes slideOutUp {
  0% {
    transform: translateZ(0);
  }
  to {
    visibility: hidden;
    transform: translate3d(0, -100%, 0);
  }
}
.animate__slideOutUp {
  animation-name: slideOutUp;
}

/*! ========================================================
トップページ
========================================================= */
#top .top-mv .top-mv__content {
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block {
  width: 100%;
  position: relative;
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a {
  display: block;
  margin: 0 10px;
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .img-block picture,
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .img-block img {
  display: block;
  width: 100%;
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block {
  display: flex;
  gap: min(1.25rem, 5.3333333333vw);
  width: min(23.75rem, 101.3333333333vw);
  padding: min(1.25rem, 5.3333333333vw);
  background-color: #ffffff;
  position: absolute;
  bottom: min(1.25rem, 5.3333333333vw);
  right: 0;
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-img {
  width: min(10rem, 42.6666666667vw);
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info {
  display: flex;
  flex-direction: column;
  width: min(12.5rem, 53.3333333333vw);
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-name {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-bottom: min(0.5625rem, 2.4vw);
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-price {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-button {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  text-align: right;
  padding-right: min(1.1875rem, 5.0666666667vw);
  margin-top: auto;
  position: relative;
}
#top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-button::after {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(0.5rem, 2.1333333333vw);
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: min(0.3125rem, 1.3333333333vw);
  transform: translateY(-50%);
}
#top .top-banner ul {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(3.75rem, 16vw);
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-banner ul li {
  width: calc(33.3333333333% - min(7.5rem, 32vw) / 3);
}
#top .top-banner ul li a {
  display: block;
}

#top .top-ranking {
  background-color: #eff0ee;
  padding: 40px 0 40px;
}
#top .top-ranking .sysItemBlock {
  margin-bottom: 0;
}
#top .top-category-img {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#top .top-category-img > .sysHeadline {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
}
#top .top-category-img > .sysContent {
  position: relative;
}
#top .top-category-img .img-block {
  width: 100%;
  height: min(33.75rem, 144vw);
}
#top .top-category-img .img-block picture,
#top .top-category-img .img-block img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: center;
     object-position: center;
}
#top .top-category-img .top-category-item {
  width: 100%;
  max-width: min(55rem, 234.6666666667vw);
  padding-inline: min(1.875rem, 8vw);
  position: absolute;
  top: 50%;
  right: min(6.875rem, 29.3333333333vw);
  transform: translateY(-50%);
}
#top .top-category-img .top-category-item .sysItemBlock {
  padding: 0;
  margin-bottom: 0;
}
#top .top-category-img .top-category-item .sysItemBlock ul {
  justify-content: center;
  gap: min(1.25rem, 5.3333333333vw);
}
#top .top-category-img .top-category-item .sysItemBlock ul li {
  width: calc(33.3333333333% - min(2.5rem, 10.6666666667vw) / 3);
  background-color: #ffffff;
  padding: min(1.25rem, 5.3333333333vw);
}
#top #sysMain > .top-category-item {
  display: none;
}
#top .top-category-btn {
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-category-list-item {
  background-color: #eeeeee;
  padding-block: min(3.125rem, 13.3333333333vw);
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-category-list-item .sysContent {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
}
#top .top-category-list-item .sysContent ul {
  display: flex;
  flex-wrap: wrap;
  gap: min(1.5rem, 6.4vw);
}
#top .top-category-list-item .sysContent ul li {
  width: calc(25% - min(4.5rem, 19.2vw) / 4);
}
#top .top-category-list-item .sysContent ul li a {
  display: block;
  background-color: #ffffff;
  padding: min(0.6875rem, 2.9333333333vw) min(0.6875rem, 2.9333333333vw) min(1rem, 4.2666666667vw);
}
#top .top-category-list-item .sysContent ul li a p {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  margin-top: min(0.9375rem, 4vw);
}
#top .top_item-pickup {
  margin-bottom: min(3.75rem, 16vw);
}
#top .top_item-pickup .sysHeadline {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
}
#top .top_item-pickup .sysItemBlock ul {
  display: block;
}
#top .top_item-pickup .sysItemBlock ul li {
  display: grid;
  grid-template-columns: minmax(0, min(37.5rem, 160vw)) minmax(0, min(34.6875rem, 148vw));
  grid-template-rows: max-content max-content max-content 1fr;
  grid-column-gap: min(2.8125rem, 12vw);
  width: 100%;
}
#top .top_item-pickup .sysItemBlock ul li .sysItemImage {
  grid-area: 1/1/5/2;
  margin: 0;
}
#top .top_item-pickup .sysItemBlock ul li .sysItemImage a img {
  width: 100%;
}
#top .top_item-pickup .sysItemBlock ul li .sysItemImage a::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
#top .top_item-pickup .sysItemBlock ul li .sysItemName {
  order: 1;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#top .top_item-pickup .sysItemBlock ul li .sysItemName a {
  display: block;
  font-size: min(1.625rem, 6.9333333333vw);
  line-height: 1.5;
}
#top .top_item-pickup .sysItemBlock ul li .sysItemPrice {
  order: 2;
  display: block;
  font-size: min(1.375rem, 5.8666666667vw);
  line-height: 1.5;
  border-bottom: 1px solid #707070;
  padding-bottom: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#top .top_item-pickup .sysItemBlock ul li .sysItemPrArea {
  order: 3;
  margin-bottom: min(1.875rem, 8vw);
}
#top .top_item-pickup .sysItemBlock ul li #sysDescriptionPc,
#top .top_item-pickup .sysItemBlock ul li #sysDescriptionMobile {
  order: 4;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
}
#top .top-review {
  width: 100%;
  max-width: min(75rem, 320vw);
  background-color: #eeeeee;
  padding: min(3.125rem, 13.3333333333vw) min(6.25rem, 26.6666666667vw) min(1.875rem, 8vw);
  margin-inline: auto;
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 min(1.875rem, 8vw);
  width: 100%;
  border: none;
  border-radius: min(0.625rem, 2.6666666667vw);
  background-color: #ffffff;
  padding: min(1.875rem, 8vw) min(1.875rem, 8vw) min(4.125rem, 17.6vw);
  position: relative;
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysThumbnailImage {
  width: min(6.25rem, 26.6666666667vw);
  margin: 0;
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysThumbnailImage a {
  display: block;
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysThumbnailImage a img {
  width: 100%;
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .review-info {
  width: calc(100% - min(8.125rem, 34.6666666667vw));
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .review-info .review-info-inner {
  display: flex;
  align-items: center;
  gap: min(0.9375rem, 4vw);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewItemName a:nth-of-type(1) {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewItemName a:nth-of-type(2) {
  display: block;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  white-space: nowrap;
  padding-left: min(0.875rem, 3.7333333333vw);
  position: absolute;
  bottom: min(1.9375rem, 8.2666666667vw);
  left: min(1.875rem, 8vw);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewItemName a:nth-of-type(2)::before {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(0.5rem, 2.1333333333vw);
  background-image: url(../img/layout/common/arrow_left_black.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysNickname {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  padding-left: min(2.8125rem, 12vw);
  position: relative;
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysNickname::before {
  content: "";
  display: block;
  width: min(1.875rem, 8vw);
  height: min(1.875rem, 8vw);
  background-image: url(../img/layout/common/icon_user.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysEvaluation {
  flex-shrink: 0;
  font-size: min(1.0625rem, 4.5333333333vw);
  line-height: 1.5;
  color: #e69b05;
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewText {
  width: 100%;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-top: min(0.9375rem, 4vw);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewDatetime {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
  position: absolute;
  bottom: min(1.875rem, 8vw);
  right: min(1.875rem, 8vw);
}
#top .top-review .sysContent .sysReviewItemList .sysReviewList li form,
#top .top-review .sysContent .sysReviewItemList .sysReviewList li .both {
  display: none;
}
#top .top-review-btn {
  max-width: min(75rem, 320vw);
  background-color: #eeeeee;
  padding-inline: min(1.875rem, 8vw);
  padding-bottom: min(3.125rem, 13.3333333333vw);
  margin-inline: auto;
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-review-btn .sysContent .btn-common {
  margin-top: 0;
}
#top .top-scene {
  max-width: min(75rem, 320vw);
  margin-inline: auto;
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-scene .top-scene__content {
  position: relative;
}
#top .top-scene .top-scene__content .img-block {
  width: 100%;
  height: min(30rem, 128vw);
}
#top .top-scene .top-scene__content .img-block picture,
#top .top-scene .top-scene__content .img-block img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -o-object-position: left;
     object-position: left;
}
#top .top-scene .top-scene__content .text-block {
  width: 100%;
  max-width: min(25rem, 106.6666666667vw);
  position: absolute;
  top: 50%;
  left: min(3.125rem, 13.3333333333vw);
  transform: translateY(-50%);
}
#top .top-scene .top-scene__content .text-block p {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
}
#top .top-scene .top-scene__content .text-block .btn-common {
  margin-left: 0;
}
#top .category-list {
  background-color: #eeeeee;
  padding-block: min(3.125rem, 13.3333333333vw);
  margin-bottom: min(3.75rem, 16vw);
}
#top .category-list .sysContent {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
}
#top .category-list .sysContent ul {
  display: flex;
  flex-wrap: wrap;
  gap: min(1.5rem, 6.4vw);
}
#top .category-list .sysContent ul li {
  width: calc(33.3333333333% - min(3rem, 12.8vw) / 3) !important;
}
#top .category-list .sysContent ul li a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  text-align: center;
  background-color: #ffffff;
  padding: min(1.5625rem, 6.6666666667vw) min(0.75rem, 3.2vw);
}
#top .top-topic {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#top .top-topic .top-topic__content {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
}
#top .top-topic .top-topic__content .img-block {
  width: 100%;
  max-width: min(43.125rem, 184vw);
}
#top .top-topic .top-topic__content .text-block {
  width: 100%;
  max-width: min(35rem, 149.3333333333vw);
  background-color: #f8f8f8;
  padding: min(3.125rem, 13.3333333333vw);
  margin-right: -3.125rem;
  position: relative;
}
#top .top-topic .top-topic__content .text-block p {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
}
#top .top-topic-btn {
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-banner-large {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-banner-large ul {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
#top .top-banner-large ul li a {
  display: block;
}
#top .top-news {
  max-width: min(75rem, 320vw);
  background-color: #eeeeee;
  padding: min(3.125rem, 13.3333333333vw) min(6.25rem, 26.6666666667vw);
  margin-inline: auto;
  margin-bottom: min(3.75rem, 16vw);
}
#top .top-news nav ul {
  display: flex;
  flex-direction: column;
  gap: min(0.3125rem, 1.3333333333vw);
}
#top .top-news nav ul li a {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  background-color: #ffffff;
  padding: min(0.9375rem, 4vw) min(3.375rem, 14.4vw) min(0.9375rem, 4vw) min(1.5625rem, 6.6666666667vw);
  position: relative;
}
#top .top-news nav ul li a::after {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(0.5rem, 2.1333333333vw);
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  right: min(1.5625rem, 6.6666666667vw);
  transform: translateY(-50%);
}

/*! ========================================================
★商品詳細ページ：パーツの調整
========================================================= */
/* セット商品のプルダウン調節 */
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div select {
  font-size: 14px !important;
  font-weight: normal !important;
  appearance: none;
  -webkit-appearance: none;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div select option {
  font-weight: normal !important;
}

/* カートに入れるとカートに入れるボタンが非表示、以下１行のcss */
#sysItemDetail .is-hidden-custom {
    display: none !important;
}

#sysItemDetail .tax-label {
  font-weight: normal;
  font-size: 16px;
}
#sysItemDetail .label-subtotal {
  font-weight: normal;
  font-size: 16px;
}
#sysItemDetail h1 {
  /* 文字の並びを制御 */
  display: flex;
  align-items: center;
}

/* h1の直下にあるテキスト（空白など）を飛ばす */
#sysItemDetail h1::first-letter {
  margin-left: -1em; /* 全角1文字分左にずらして消し去る力技 */
  /* または */
  font-size: 0;
}

/* 予期せぬ挙動を防ぐためのもっと安全な方法 */
#sysItemDetail h1 {
  text-indent: -1em; /* 全角スペース分、左に引っ込める */
  padding-left: 1em; /* その分パディングで戻す（これで空白が相殺されます） */
}
/* --- タイトル回り --- */
@media screen and (max-width: 768px) {
#sysItemDetail .sysDisplayMobileNone h1 {
  display: none !important;
}
#sysItemDetail .sysDisplayPcNone h1 {
  font-size: 20px !important;
  margin: 15px 0;
}
#sysItemDetail .tax-label {
  font-size: 12px;
}
#sysItemDetail .label-subtotal {
  font-size: 12px;
}
}

#sysItemDetail .sysRetailPrice {color: #222 !important;}
/* --- 数量と小計を横並び --- */
#sysItemDetail .sysCartInForm {
  display: flex;
  flex-wrap: wrap; /* スマホなどで溢れた時に折り返す設定 */
  align-items: center; /* 上下中央揃え */
  justify-content: space-between; 
  width: 100%;
}

#sysItemDetail #sysNumber {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 !important; /* 余計な余白をリセット */
}

#sysItemDetail #sysSubtotal {
  margin: 0 !important;
  text-align: right;
}

#sysItemDetail #sysNumber select {
  padding: 5px 10px;
  border: 1px solid #ccc;
  border-radius: 4px;
}

#sysItemDetail .sysSubtotalPrice {
  font-weight: bold;
  color: #222; /* 重要ボタンと同じ赤系にすると統一感が出ます */
}

#sysItemDetail #sysSubmit, #sysWishlist, .sysShare {
  width: 100%; /* これらは横並びにせず、下の行へ */
  margin-top: 0;
}
/* --- 商品の特徴 --- */
#sysItemDetail .sysExplanation dl {
  background-color: #fff !important;
  border: 1px solid #e0e0e0 !important; /* 非常に薄いグレーの枠線 */
  border-radius: 12px !important; /* 角丸 */
  padding: 40px !important;
  max-width: 1200px;
  margin: 0 auto !important;
  box-sizing: border-box;
}

#sysItemDetail .sysExplanation dt {
  font-size: 18px !important;
  font-weight: bold !important;
  color: #428f94 !important;
  margin-bottom: 10px !important;
  margin-top: 30px !important;
}

#sysItemDetail .sysExplanation dt:first-child {
  margin-top: 0 !important;
}

#sysItemDetail .sysExplanation dd {
  font-size: 15px !important;
  line-height: 1.8 !important;
  color: #222 !important;
  margin-left: 0 !important; /* 標準のインデントをリセット */
  margin-bottom: 20px !important;
  white-space: pre-wrap; /* 改行を反映させる */
}

@media screen and (max-width: 767px) {
  #sysItemDetail .sysExplanation {
    border-radius: 8px !important;
  }
  
  #sysItemDetail .sysExplanation h2 {
    font-size: 18px !important;
  }

  #sysItemDetail .sysExplanation dt {
    font-size: 16px !important;
  }

  #sysItemDetail .sysExplanation dd {
    font-size: 14px !important;
  }
  #sysItemDetail .sysExplanation dl {
  padding: 20px !important;
  }
  #sysSubmit, #sysWishlist, .sysShare {
  margin-top: 0 !important;
  }
  #sysNumber {
  gap: 0 !important;
  }
  #sysItemDetail .r_category h2 {
    width: 94%;
    margin: 0 auto;
  }
  #sysItemDetail .r_howto h2 {
    width: 94%;
    margin: 0 auto;
  }
}


/* --- 商品説明箇所の調節 --- */
@media screen and (max-width: 768px) {
  #sysItemDetail #sysWrap #sysMain > article {
    width: 94% !important;
    margin: 0 auto !important;
  }
}

/* --- カテゴリーセクションの調節 --- */
#sysItemDetail .r_category {
  background: #fff;
  margin-top:0 !important;
  padding-top: 0;
}
#sysItemDetail .r_category_sec {
  box-shadow: 0 0 0 100vw #fff;
}
#sysItemDetail .r_category_sec {
  border: 1px solid #ccc;
  border-radius: 20px;
}
#sysItemDetail .r_category_e {
  margin-bottom: 30px !important;
}

/* --- チェックした商品セクションの調節 --- */
#sysItemDetail .r_check {
  background: #fff;
  padding-top: 60px;
}

/* --- 流れセクションの調節 --- */
#sysItemDetail .r_howto {
  padding-bottom: 60px;
}

/* --- セットでお得セクションの調節 --- */
#sysItemDetail .r_set {
  background: #fff;
  padding: 0 0 60px;
}
#sysItemDetail .r_set1_faq {
  max-width: 1200px;
  margin: 0 auto;
}
#sysItemDetail .r_osusume_set .sysContent .sysVertical .sysItemImage img{
  width:100% !important;
}
/* --- おすすめセクションの調節 --- */
#sysItemDetail .r_osusume_set {
  max-width: 1200px;
  margin: 0 auto;
}
#sysItemDetail .r_osusume_set {
 padding: 60px 0 !important;
}
#sysItemDetail .r_osusume_set h2 {
  margin-bottom: 10px;
}

#sysItemDetail #sysMain .sysFuncItemBlock .sysItemBlock {
  padding-inline: 0;
}

#sysItemDetail .r_category_faq {
  width: 1200px;
  margin: 0 auto;
}
#sysItemDetail .r_category_faq h2 {
  margin-bottom: 15px;
}
/* --- スマホ用設定 --- */
@media screen and (max-width: 767px) {
  #sysItemDetail .r_osusume_set h2 span {
    display: none;
  }
  #sysItemDetail h2.ditail_tit_faq {
    width: 94% !important;
    margin: 0 auto 10px auto;
    }
  #sysItemDetail .r_faq_container {
  width: 94%;
  margin: 0 auto;
  }
  #sysItemDetail .r_category {
    padding-bottom: 40px !important;
  }
  #sysItemDetail .r_check {
    padding: 40px 0 40px !important;
  }
  #sysItemDetail .r_osusume_set h2 {
    margin-top: 0;
  }
  #sysItemDetail #sysMain .sysFuncItemBlock .sysItemBlock {
    margin-bottom: 0 !important;
  }
  #sysItemDetail .r_set .sysHeadline {
    margin-top: 0 !important;
  }
  #sysItemDetail .r_osusume_set {
    padding: 40px 0 !important; /* 左右の余白はul側で管理 */
  }

  #sysItemDetail .r_osusume_set .sysHeadline {
    padding-inline: min(0.9375rem, 4vw); /* タイトルだけ左右余白を入れる */
  }

  /* 【重要】親要素をフレックスボックスにして折り返しを禁止する */
  #sysItemDetail .r_osusume_set .sysItemBlock ul {
    display: flex !important;
    flex-wrap: nowrap !important; /* 1行に強制 */
    overflow-x: auto !important;   /* 横スクロール有効 */
    -ms-overflow-style: none;      /* IE用バー非表示 */
    scrollbar-width: none;         /* Firefox用バー非表示 */
    padding-bottom: 10px;          /* スクロール時に影が切れないように */
    padding-left: min(0.9375rem, 4vw) !important; /* 開始位置の余白 */
    gap: 0 !important;             /* gapではなくliのmarginで調整 */
  }

  /* スクロールバー非表示（Chrome系） */
  #sysItemDetail .r_osusume_set .sysItemBlock ul::-webkit-scrollbar {
    display: none;
  }

  /* 【重要】子要素（各アイテム）が縮まないように固定する */
  #sysItemDetail .r_osusume_set .sysItemBlock ul li {
    flex-shrink: 0 !important;   /* 縮み防止（超重要！） */
    width: 160px !important;     /* スマホで見やすい固定幅 */
    margin-right: 15px !important;
    list-style: none !important;
  }

  /* 最後のアイテムの右側にも余白を作るためのダミー要素 */
  #sysItemDetail .r_osusume_set .sysItemBlock ul::after {
    content: "";
    flex-shrink: 0;
    width: min(0.9375rem, 4vw);
  }

  /* 画像の比率を整える */
  #sysItemDetail .r_osusume_set .sysItemImage img {
    width: 100% !important;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  }

  /* 商品名などの調整 */
  #sysItemDetail .r_osusume_set .sysItemName a {
    font-size: 13px !important;
    line-height: 1.4;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2; /* 名前が長い場合2行で省略 */
    overflow: hidden;
  }
  #sysItemDetail .r_category_faq {
  width: 100% !important;
  margin: 0 auto;
  }
}





/* -----------------------------------------------------------
   ★商品詳細の画像スライドのページネーションと矢印
 ----------------------------------------------------------- */
/* メイン画像の親要素 */
#sysItemDetail .sysItemImages {
  position: relative;
}

#sysItemDetail .sysMainImage {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* 共通の矢印スタイル（デフォルトは非表示） */
#sysItemDetail .slider-arrow {
  display: none; /* JSでis-activeが付くまで隠す */
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid #689c9d;
  color: #689c9d;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  z-index: 10;
  font-size: 18px;
  transition: 0.3s;
  padding: 0;
}

/* 表示許可が出た時だけ出す */
#sysItemDetail .slider-arrow.is-active {
  display: flex;
}

#sysItemDetail .slider-arrow:hover {
  background: #689c9d;
  color: #fff;
}

#sysItemDetail .arrow-prev { left: 10px; }
#sysItemDetail .arrow-next { right: 10px; }

/* ページネーション（バー）全体のレイアウト */
#sysItemDetail article .item-container .sysItemImages .sysImageList {
  display: flex;
  justify-content: center;
  gap: 8px;
  padding: 0;
  list-style: none;
  margin-top: 15px;
}

/* 各バーの土台 */
#sysItemDetail article .item-container .sysItemImages .sysImageList li {
  width: 40px;
  height: 2px;
  background-color: #e0e0e0;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  border: none !important;
}

/* 中の画像は隠す */
#sysItemDetail article .item-container .sysItemImages .sysImageList li img {
  display: none;
}

/* 選択中のバーの色 */
#sysItemDetail article .item-container .sysItemImages .sysImageList li.sysCurrent {
  background-color: #689c9d;
}

/* 余計な枠線を消す */
#sysItemDetail article .item-container .sysItemImages .sysImageList li.sysCurrent::after {
  display: none;
}

/* スマホ調整 */
@media screen and (max-width: 768px) {
  #sysItemDetail .slider-arrow {
    width: 30px;
    height: 30px;
    font-size: 14px;
  }
}






/*! ========================================================
★商品詳細：商品サイズ・スペック
========================================================= */
/* --- コンテナ全体の幅 --- */
.r_ditail_specs-container {
  width: 100% !important;
  margin: 20px 0;
}
.r_ditail_specs-inner ul {
  padding: 0 0 15px 15px;
}
.r_ditail_specs-inner ul li {
  list-style: circle !important;
}
.r_ditail_specs-inner dl dd {
  list-style: circle !important;
}
.r_ditail_specs-inner dl dd {
  position: relative;
  padding-left: 1.2em; /* ドットの分だけ左を空ける */
}
.r_ditail_specs-inner dl dd::before {
  content: "・"; /* または "●" */
  position: absolute;
  left: 0;
  color: #222; /* アコーディオンの色に合わせると統一感が出ます */
}
.r_ditail_specs-inner a {
  text-decoration: underline;
  color: #418f94;
}
/* --- タイトル部分（水色デザインを再現） --- */
.r_ditail_specs-header {
  display: flex !important;
  align-items: center;
  width: 100% !important;
  background-color: #fff !important; /* 初期：非常に薄いグレーがかった水色 */
  color: #333 !important;
  padding: 10px 15px !important;
  text-align: left !important;
  font-weight: bold !important;
  font-size: 16px !important;
  cursor: pointer;
  position: relative;
  transition: background-color 0.2s; /* キレのある切り替え */
  border: 1px solid #c5d8d9;
}

/* ★ホバー：不透明なまま、しっかりした水色にする */
.r_ditail_specs-header:hover {
  background-color: #78c2c4 !important; /* 画像のアイコンに近い水色 */
  color: #fff !important;
}

/* 左側の「！」アイコン */
.r_ditail_specs-header::before {
  content: "!";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background-color: #78c2c4; /* 画像の赤い丸 */
  color: #fff;
  border-radius: 50%;
  margin-right: 12px;
  font-size: 16px;
  flex-shrink: 0;
}

/* 右側の「＋」記号 */
.r_ditail_specs-header::after {
  content: "+";
  position: absolute;
  right: 20px;
  font-size: 24px;
  font-weight: normal;
  color: #333;
  transition: transform 0.3s;
}

/* 開いている時の「＋」を「ー」にするか回転させる */
.r_ditail_specs-header.is-open::after {
  content: "−"; /* マイナス記号 */
  transform: rotate(180deg); /* 動きをつけてもオシャレです */
}

/* ホバー時のアイコン反転 */
.r_ditail_specs-header:hover::before {
  background-color: #187274 !important;
  color: #fff !important;
}

/* --- 開いている状態の色固定 --- */
.r_ditail_specs-header.is-open {
  background-color: #5eaeb0 !important; /* ホバーより一段濃い水色で固定 */
  color: #fff !important;
}

.r_ditail_specs-header.is-open::after {
  content: "−";
}

/* --- 中身（隠れる部分） --- */
.r_ditail_specs-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out;
  background-color: #f7f9f9 !important;
}

.r_ditail_specs-inner {
  padding: 20px 20px 25px 20px; /* アイコン分、左を空けて揃える */
  line-height: 1.8;
}
.r_ditail_specs-inner dl dt {
  font-weight: bold;
}
.r_ditail_specs-inner dl {
  margin-top: 20px;
}


/* スマホ用調整 */
@media screen and (max-width: 767px) {
  .r_ditail_specs-inner {
    padding: 0 15px 20px 15px;
  }
  .r_ditail_specs-header {
    font-size: 15px;
  }
  .r_ditail_specs-container {
  margin-bottom: 0;
  }
  .r_ditail_specs-inner ul {
  padding-top: 15px;
 }
}







/*! ========================================================
★商品詳細：洗濯機　左右開き
========================================================= */
/* --- コンテナ全体の幅 --- */
.r_ditail_washingmachine-container {
  width: 100% !important;
  margin: 20px 0;
}

/* --- タイトル部分（水色デザインを再現） --- */
.r_ditail_washingmachine-header {
  display: flex !important;
  align-items: center;
  width: 100% !important;
  background-color: #fff !important; /* 初期：非常に薄いグレーがかった水色 */
  color: #333 !important;
  padding: 10px 15px !important;
  text-align: left !important;
  font-weight: bold !important;
  font-size: 16px !important;
  cursor: pointer;
  position: relative;
  transition: background-color 0.2s; /* キレのある切り替え */
  border: 1px solid #c5d8d9;
}

/* ★ホバー：不透明なまま、しっかりした水色にする */
.r_ditail_washingmachine-header:hover {
  background-color: #78c2c4 !important; /* 画像のアイコンに近い水色 */
  color: #fff !important;
}

/* 左側の「！」アイコン */
.r_ditail_washingmachine-header::before {
  content: "!";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background-color: #78c2c4; /* 画像の赤い丸 */
  color: #fff;
  border-radius: 50%;
  margin-right: 12px;
  font-size: 16px;
  flex-shrink: 0;
}

/* 右側の「＋」記号 */
.r_ditail_washingmachine-header::after {
  content: "+";
  position: absolute;
  right: 20px;
  font-size: 24px;
  font-weight: normal;
  color: #333;
  transition: transform 0.3s;
}

/* 開いている時の「＋」を「ー」にするか回転させる */
.r_ditail_washingmachine-header.is-open::after {
  content: "−"; /* マイナス記号 */
  transform: rotate(180deg); /* 動きをつけてもオシャレです */
}

/* ホバー時のアイコン反転 */
.r_ditail_washingmachine-header:hover::before {
  background-color: #187274 !important;
  color: #fff !important;
}

/* --- 開いている状態の色固定 --- */
.r_ditail_washingmachine-header.is-open {
  background-color: #5eaeb0 !important; /* ホバーより一段濃い水色で固定 */
  color: #fff !important;
}

.r_ditail_washingmachine-header.is-open::after {
  content: "−";
}

/* --- 中身（隠れる部分） --- */
.r_ditail_washingmachine-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out;
  background-color: #f7f9f9 !important;
}

.r_ditail_washingmachine-inner {
  padding: 20px 20px 25px 20px; /* アイコン分、左を空けて揃える */
  line-height: 1.8;
}
.r_ditail_washingmachine-inner dl dt {
  font-weight: bold;
}
.r_ditail_washingmachine-inner dl:nth-of-type(2) {
  margin-top: 20px;
}

/* スマホ用調整 */
@media screen and (max-width: 767px) {
  .r_ditail_washingmachine-inner {
    padding: 0 15px 20px 15px;
  }
  .r_ditail_washingmachine-header {
    font-size: 15px;
  }
  .r_ditail_washingmachine-container {
  margin-bottom: 0;
  }
}
/*! ========================================================
★商品詳細：冷蔵庫　左右開き
========================================================= */
/* --- コンテナ全体の幅 --- */
.r_ditail_refrigerator-container {
  width: 100% !important;
  margin: 20px 0;
}

/* --- タイトル部分（水色デザインを再現） --- */
.r_ditail_refrigerator-header {
  display: flex !important;
  align-items: center;
  width: 100% !important;
  background-color: #fff !important; /* 初期：非常に薄いグレーがかった水色 */
  color: #333 !important;
  padding: 10px 15px !important;
  text-align: left !important;
  font-weight: bold !important;
  font-size: 16px !important;
  cursor: pointer;
  position: relative;
  transition: background-color 0.2s; /* キレのある切り替え */
  border: 1px solid #c5d8d9;
}

/* ★ホバー：不透明なまま、しっかりした水色にする */
.r_ditail_refrigerator-header:hover {
  background-color: #78c2c4 !important; /* 画像のアイコンに近い水色 */
  color: #fff !important;
}

/* 左側の「！」アイコン */
.r_ditail_refrigerator-header::before {
  content: "!";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background-color: #78c2c4; /* 画像の赤い丸 */
  color: #fff;
  border-radius: 50%;
  margin-right: 12px;
  font-size: 16px;
  flex-shrink: 0;
}

/* 右側の「＋」記号 */
.r_ditail_refrigerator-header::after {
  content: "+";
  position: absolute;
  right: 20px;
  font-size: 24px;
  font-weight: normal;
  color: #333;
  transition: transform 0.3s;
}

/* 開いている時の「＋」を「ー」にするか回転させる */
.r_ditail_refrigerator-header.is-open::after {
  content: "−"; /* マイナス記号 */
  transform: rotate(180deg); /* 動きをつけてもオシャレです */
}

/* ホバー時のアイコン反転 */
.r_ditail_refrigerator-header:hover::before {
  background-color: #187274 !important;
  color: #fff !important;
}

/* --- 開いている状態の色固定 --- */
.r_ditail_refrigerator-header.is-open {
  background-color: #5eaeb0 !important; /* ホバーより一段濃い水色で固定 */
  color: #fff !important;
}

.r_ditail_refrigerator-header.is-open::after {
  content: "−";
}

/* --- 中身（隠れる部分） --- */
.r_ditail_refrigerator-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out;
  background-color: #f7f9f9 !important;
}

.r_ditail_refrigerator-inner {
  padding: 20px 20px 25px 20px; /* アイコン分、左を空けて揃える */
  line-height: 1.8;
}

/* スマホ用調整 */
@media screen and (max-width: 767px) {
  .r_ditail_refrigerator-inner {
    padding: 0 15px 20px 15px;
  }
  .r_ditail_refrigerator-header {
    font-size: 15px;
  }
  .r_ditail_refrigerator-container {
  margin-bottom: 0;
  }
}
/*! ========================================================
★商品詳細：エアコン注意事項
========================================================= */
/* --- コンテナ全体の幅 --- */
.r_ditail_aircon-container {
  width: 100% !important;
  margin: 20px 0;
}

/* --- タイトル部分（水色デザインを再現） --- */
.r_ditail_aircon-header {
  display: flex !important;
  align-items: center;
  width: 100% !important;
  background-color: #fff !important; /* 初期：非常に薄いグレーがかった水色 */
  color: #333 !important;
  padding: 10px 15px !important;
  text-align: left !important;
  font-weight: bold !important;
  font-size: 16px !important;
  cursor: pointer;
  position: relative;
  transition: background-color 0.2s; /* キレのある切り替え */
  border: 1px solid #c5d8d9;
}

/* ★ホバー：不透明なまま、しっかりした水色にする */
.r_ditail_aircon-header:hover {
  background-color: #78c2c4 !important; /* 画像のアイコンに近い水色 */
  color: #fff !important;
}

/* 左側の「！」アイコン */
.r_ditail_aircon-header::before {
  content: "!";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background-color: #78c2c4; /* 画像の赤い丸 */
  color: #fff;
  border-radius: 50%;
  margin-right: 12px;
  font-size: 16px;
  flex-shrink: 0;
}

/* 右側の「＋」記号 */
.r_ditail_aircon-header::after {
  content: "+";
  position: absolute;
  right: 20px;
  font-size: 24px;
  font-weight: normal;
  color: #333;
  transition: transform 0.3s;
}

/* 開いている時の「＋」を「ー」にするか回転させる */
.r_ditail_aircon-header.is-open::after {
  content: "−"; /* マイナス記号 */
  transform: rotate(180deg); /* 動きをつけてもオシャレです */
}

/* ホバー時のアイコン反転 */
.r_ditail_aircon-header:hover::before {
  background-color: #187274 !important;
  color: #fff !important;
}

/* --- 開いている状態の色固定 --- */
.r_ditail_aircon-header.is-open {
  background-color: #5eaeb0 !important; /* ホバーより一段濃い水色で固定 */
  color: #fff !important;
}

.r_ditail_aircon-header.is-open::after {
  content: "−";
}

/* --- 中身（隠れる部分） --- */
.r_ditail_aircon-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out;
  background-color: #f7f9f9 !important;
}

.r_ditail_aircon-inner {
  padding: 20px 20px 25px 20px; /* アイコン分、左を空けて揃える */
  line-height: 1.8;
}
.r_ditail_aircon-sbox {
  background: #fff;
  border: 1px solid #ccc;
  padding: 10px;
  margin : 10px 0;
}
.r_ditail_aircon-sbox ul li {
  position: relative;
  list-style-type: none;
  padding: 0.5em 0.5em 0.5em 0.5em;
  margin-bottom: 5px;
  line-height: 1.5;
  vertical-align: middle;
  color: #333;
  border-radius: 15px;
}

.r_ditail_aircon-sbox ul li:before{ 
  display:inline-block; 
  vertical-align: middle;
  content:'';
  width:1em;
  height: 1em;
  background: #418f94;
  border-radius: 50%;
  margin-right: 8px;
}
.r_ditail_aircon-sbox dl {
  padding-bottom: 20px;
}
.r_ditail_aircon-sbox dt {
  font-weight: bold;
}

/* スマホ用調整 */
@media screen and (max-width: 767px) {
  .r_ditail_aircon-inner {
    padding: 0 15px 20px 15px;
  }
  .r_ditail_aircon-header {
    font-size: 15px;
  }
  .r_ditail_aircon-container {
  margin-bottom: 0;
  }
  .r_ditail_aircon-sbox {
    font-size: 14px;
  }
}
/*! ========================================================
★商品詳細：法人注意事項
========================================================= */
/* 左側のアイコン（画像に変更） */
.r_ditail_houjin-header::before {
  content: ""; /* テキストの "!" を消す */
  display: block;
  width: 24px;
  height: 24px;
  background: url("/img/web/houjin_icon.svg") no-repeat center center / contain;
  margin-right: 12px;
  flex-shrink: 0;
}
.r_ditail_houjin-header:hover::before {
background-image: url("/img/web/houjin_icon.svg") !important;
  
  /* 元の背景色指定は画像に干渉するので削除、または background-color: transparent !important; に */
  background-color: transparent !important;
}

/* --- 以下、既存のデザイン維持（変更なし） --- */

/* --- コンテナ全体の幅 --- */
.r_ditail_houjin-container {
  width: 100% !important;
  margin: 20px 0;
}

/* --- タイトル部分 --- */
.r_ditail_houjin-header {
  display: flex !important;
  align-items: center;
  width: 100% !important;
  background-color: #fff !important;
  color: #333 !important;
  padding: 10px 15px !important;
  text-align: left !important;
  font-weight: bold !important;
  font-size: 16px !important;
  cursor: pointer;
  position: relative;
  transition: background-color 0.2s;
  border: 1px solid #c5d8d9;
}

.r_ditail_houjin-header:hover {
  background-color: #78c2c4 !important;
  color: #fff !important;
}

/* 右側の「＋」記号 */
.r_ditail_houjin-header::after {
  content: "+";
  position: absolute;
  right: 20px;
  font-size: 24px;
  font-weight: normal;
  color: #333;
  transition: transform 0.3s;
}

.r_ditail_houjin-header.is-open {
  background-color: #5eaeb0 !important;
  color: #fff !important;
}

.r_ditail_houjin-header.is-open::after {
  content: "−";
  transform: rotate(180deg);
}

/* --- 中身（隠れる部分） --- */
.r_ditail_houjin-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out;
  background-color: #f7f9f9 !important;
}

.r_ditail_houjin-inner {
  padding: 20px 20px 25px 20px;
  line-height: 1.8;
}
.r_ditail_houjin-inner a {
  text-decoration: underline;
  color: #418f94;
}
.r_ditail_houjin-sbox {
  background: #fff;
  border: 1px solid #ccc;
  padding: 10px;
  margin : 10px 0;
}

.r_ditail_houjin-sbox ul li {
  position: relative;
  list-style-type: none;
  padding: 0.5em 0.5em 0.5em 0.5em;
  margin-bottom: 5px;
  line-height: 1.5;
  vertical-align: middle;
  color: #333;
  border-radius: 15px;
}

.r_ditail_houjin-sbox ul li:before { 
  display:inline-block; 
  vertical-align: middle;
  content:'';
  width:1em;
  height: 1em;
  background: #418f94;
  border-radius: 50%;
  margin-right: 8px;
}

.r_ditail_houjin-sbox dl {
  padding-bottom: 20px;
}

.r_ditail_houjin-sbox dt {
  font-weight: bold;
}

/* スマホ用調整 */
@media screen and (max-width: 767px) {
  .r_ditail_houjin-inner {
    padding: 0 15px 20px 15px;
  }
  .r_ditail_houjin-header {
    font-size: 15px;
  }
  .r_ditail_houjin-container {
    margin-bottom: 0;
  }
  .r_ditail_houjin-sbox {
    font-size: 14px;
  }
}
/*! ========================================================
★商品詳細：重要事項
========================================================= */
/* --- コンテナ全体の幅 --- */
.r_attention-container {
  width: 100% !important;
  margin: 20px 0;
}

/* --- タイトル部分（画像デザインを再現） --- */
.r_attention-header {
  display: flex !important; /* 横並びにする */
  align-items: center;
  width: 100% !important;
  background-color: #fff3f3 !important; /* 画像に近い非常に薄いピンク */
  color: #333 !important;
  padding: 10px 15px !important;
  text-align: left !important;
  font-weight: bold !important;
  font-size: 16px !important;
  cursor: pointer;
  position: relative;
  transition: background-color 0.3s;
  border: 1px solid #f1c7c7;
}

/* ★ホバー時の挙動：全体を濃い赤にする */
.r_attention-header:hover {
  background-color: #ee9996 !important; /* 画像の赤アイコンと同じ色を背景に */
  color: #fff !important;
  opacity: 1;
}

/* 左側の「！」アイコン */
.r_attention-header::before {
  content: "!";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  background-color: #d9534f; /* 画像の赤い丸 */
  color: #fff;
  border-radius: 50%;
  margin-right: 12px;
  font-size: 16px;
  flex-shrink: 0;
}

/* 右側の「＋」記号 */
.r_attention-header::after {
  content: "+";
  position: absolute;
  right: 20px;
  font-size: 24px;
  font-weight: normal;
  color: #333;
  transition: transform 0.3s;
}
.r_attention-inner a {
  text-decoration: underline;
  color: #d9534f;
}
/* ホバー時のアイコン反転 */
.r_attention-header:hover::before {
  background-color: #c43531 !important;
  color: #fff !important;
}

/* 開いている時の「＋」を「ー」にするか回転させる */
.r_attention-header.is-open::after {
  content: "−"; /* マイナス記号 */
  transform: rotate(180deg); /* 動きをつけてもオシャレです */
}

/* --- 中身（隠れる部分） --- */
.r_attention-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease-out;
  background-color: #fff3f3 !important; /* 背景色を合わせる */
}

/* --- 開いている状態の色固定 --- */
.r_attention-header.is-open {
  background-color: #ee9996 !important; /* ホバーより一段濃い水色で固定 */
  color: #fff !important;
}

.r_attention-inner {
  padding: 20px 20px 25px 20px; /* アイコンの分、左の余白を広くして文字を揃える */
  background-color: #fff3f3 !important;
  font-size: 14px;
  line-height: 1.8;
}

/* スマホ用微調整 */
@media screen and (max-width: 767px) {
  .r_attention-header {
    font-size: 15px !important;
    padding: 15px !important;
  }
  .r_attention-inner {
    padding: 0 15px 20px 15px; /* スマホでは文字を左に寄せて読みやすく */
  }
}







/*! ========================================================
★商品詳細　基本
========================================================= */

#sysItemDetail {
  background: #eff0ee;
}
#sysItemDetail #sysWrap {
  width: 100%;
  padding-inline: 0;
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysItemDetail #sysAside {
  display: none;
}
#sysItemDetail article .item-container {
  display: flex;
  align-items: flex-start;
  gap: 40px;
  margin: 0 auto;
  max-width: 1200px;
}
#sysItemDetail article .item-container .sysItemImages {
  flex: 0 0 calc(55% - 20px); /* 余ったスペースを埋める、または具体的な幅を指定 */
  max-width: 100%; /* デザインに合わせて調整してください */
}
#sysItemDetail article .item-container .sysItemImages .sysMainImage {
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemDetail article .item-container .sysItemImages .sysMainImage a {
  display: block;
}
#sysItemDetail article .item-container .sysItemImages .sysMainImage a img {
  width: 100%;
}
#sysItemDetail article .item-container .sysItemImages .sysImageList {
  display: flex;
  flex-wrap: wrap;
  gap: min(1rem, 2.1333333333vw);
}
#sysItemDetail article .item-container .sysItemImages .sysImageList li {
  width: calc(12.5% - min(3.5rem, 14.9333333333vw) / 8);
  position: relative;
}
#sysItemDetail article .item-container .sysItemImages .sysImageList li img {
  width: 100%;
}
#sysItemDetail article .item-container .sysItemImages .sysImageList li.sysCurrent::after {
  content: "";
  width: calc(100% + 0.125rem);
  height: calc(100% + 0.125rem);
  border: 1px solid #689c9d;
  border-radius: 0.125rem;
  position: absolute;
  top: -0.125rem;
  left: -0.125rem;
  border-radius: 10px;
}
#sysItemDetail article .item-container .item-info-container {
  flex: 0 0 calc(45% - 20px);
max-width: 45%;
  max-width: 100%;
  border-radius: 30px;
}
#sysItemDetail article .item-container .item-info-container .sysItemName {
  margin-bottom: min(0.75rem, 3.2vw);
}
#sysItemDetail article .item-container .item-info-container .sysItemName h1 {
  font-size: min(1.625rem, 6.9333333333vw);
  font-weight: bold;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
#sysItemDetail article .item-container .item-info-container .sysRetailPrice {
  margin-bottom: min(0.6875rem, 2.9333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysRetailPrice span {
  font-size: 24px;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
}
#sysItemDetail article .item-container .item-info-container .sysRetailPrice span .tax-label {
  font-weight: normal;
  font-size: 0.8em;
}
#sysItemDetail article .item-container .item-info-container .sysPr {
  margin-bottom: 0;
}
#sysItemDetail article .item-container .item-info-container .sysDescription {
  border-top: 1px solid #d6d3cc;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysDescription p {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 400;
  line-height: 1.7;
}
#sysItemDetail article .item-container .item-info-container .sysItemId {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  text-align: right;
}
#sysItemDetail article .item-container .item-info-container .sysShippingCost {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  text-align: right;
}
#sysItemDetail article .item-container .item-info-container .sysStockQuantity {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  text-align: right;
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate {
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateViewName {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm {
  border: 1px solid #707070;
  padding: min(0.9375rem, 4vw);
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateSelectPrefStateArea {
  display: flex;
  align-items: center;
  gap: 0 min(0.3125rem, 1.3333333333vw);
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateSelectPrefStateArea .sysDeliveryDateSelectPrefStateLabel {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateSelectPrefStateArea #prefStateId {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea > div {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 400;
  line-height: 1.7;
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea .sysDeliveryDateShippingPeriodDatetime,
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea .sysDeliveryDateEarliestDeliveryDate {
  text-decoration: underline;
  text-underline-offset: min(0.125rem, 0.5333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea .sysDeliveryDateAppendComment,
#sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea .sysDeliveryDateNoAvailableDatesMessage {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation > div {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable {
  width: 100%;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable th {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 400;
  line-height: 1.7;
  background-color: #eeeeee;
  border: 1px solid #707070;
  padding: min(0.5rem, 2.1333333333vw) min(0.9375rem, 4vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable td {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  border: 1px solid #707070;
  padding: min(0.5rem, 2.1333333333vw) min(0.9375rem, 4vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable td br {
  display: none;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable td input[type=radio] {
  display: block;
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable tr:nth-of-type(n + 2) th {
  text-align: left;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections {
  margin-bottom: min(1.875rem, 8vw);
  width: 100%;
}


#sysItemDetail article .item-container .item-info-container #sysSelections label {
    display: block !important; /* 強制的にブロック要素（縦並び）にします */
    float: none !important;    /* もし回り込み（float）が設定されていても解除します */
    width: 100% !important;    /* 横幅をいっぱいまで広げます */
    margin-bottom: 10px;       /* 選択肢ごとの隙間 */
    text-align: left !important;
}


#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  font-size: clamp(0.8125rem, 2vw + 0.5rem, 1rem);
  font-weight: bold;
  line-height: 1.7;
  margin-bottom: min(0.9375rem, 4vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div::before {
  content: "";
  display: block;
  width: 100%;
  height: min(0.3125rem, 1.3333333333vw);
  order: 1; /* テキストの次に配置 */
  border-bottom: 1px solid #669d9c;
  margin: 2px 0 10px; /* 下に少し余裕を持たせる */
}
/* --- セレクトボックスの調整 --- */
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div select {
  order: 2; /* 境界線の後に配置 */
  width: 100%; /* 横幅いっぱいにすると左端が揃いやすいです（お好みでfit-contentに） */
  max-width: 100%; /* 必要に応じて最大幅を設定 */
  height: min(2.5rem, 10.6666666667vw);
  margin-top: 5px;
  padding: 0 10px;
  border-radius: 4px;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div:last-of-type {
  margin-bottom: 0;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div:has(input[type=radio]) {
  display: flex;
  flex-wrap: wrap;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div:has(input[type=radio])::before {
  content: "";
  display: block;
  width: 100%;
  height: min(0.3125rem, 1.3333333333vw);
  order: 1;
  border-bottom:1px solid #669d9c;
  margin: 2px 0 4px;
}
@media screen and (max-width: 768px) {
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div:has(input[type=radio])::before {
  margin: 8px 0 8px !important;
}
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: 100%;
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div label {
  order: 2;
  font-weight: normal;
}
@media screen and (max-width: 768px) {
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div label {
    margin-bottom: 8px;
  }
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div input[type=text] {
  height: min(3.125rem, 13.3333333333vw);
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules {
  width: 100%;
  max-width: min(28.5rem, 121.6vw);
  margin-inline: auto;
  margin-bottom: min(1.875rem, 8vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalStartDate {
  display: none;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars {
  width: 100%;
  position: relative;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarCtl {
  float: none;
  margin: 0;
  position: absolute;
  top: 0;
  left: 0;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarCtl .sysPrevCalendar,
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarCtl .sysNextCalendar {
  width: min(1.875rem, 8vw);
  height: min(1.875rem, 8vw);
  border: none;
  position: relative;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarCtl .sysPrevCalendar::after,
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarCtl .sysNextCalendar::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  background-size: 100% 100%;
  position: absolute;
  top: 0;
  left: 0;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarCtl .sysPrevCalendar::after {
  background-image: url(../img/layout/common/arrow_left_thin_black.png);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarCtl .sysNextCalendar::after {
  background-image: url(../img/layout/common/arrow_right_thin_black.png);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar {
  table-layout: fixed;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar caption {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar th {
  height: min(3.0625rem, 13.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  color: #333333;
  border: 1px solid #707070;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar td {
  height: min(3.0625rem, 13.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  border: 1px solid #707070;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar td.sysRentalSchedulesReserved {
  text-decoration: none;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar td.sysRentalSchedulesInvalid {
  text-decoration-color: #b3b6b3;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar td .sysRentalSchedulesDay {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar td .sysRentalSchedulesValidPrice {
  display: block;
  font-size: min(0.625rem, 2.6666666667vw);
  line-height: 1.2;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalScheduleInfo {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalScheduleInfo > div:not(.sysRentalScheduleNotice) {
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalScheduleInfo > div:not(.sysRentalScheduleNotice) span {
  color: #333333;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalScheduleInfo .sysRentalScheduleNotice {
  margin-top: min(1.25rem, 5.3333333333vw);
}


/*カレンダー日時調整*/
#sysItemDetail .sysRentalSchedulesCalendarsMonth {
line-height: normal;
}

#sysItemDetail .sysRentalSchedulesCalendarSelectMonthTypeCtl {
 margin-bottom:min(1.25rem, 5.3333333333vw);
}


#sysItemDetail article .item-container .item-info-container .sysForm #sysGetPoint {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  text-align: center;
  margin-bottom: min(1.875rem, 8vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysNumber {
  display: flex;
  align-items: center;
  margin-bottom: min(0.9375rem, 4vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysNumber select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysNumber .sysNumArea {
  display: flex;
  align-items: center;
  gap: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysNumber .sysNumArea button {
  display: block;
  width: min(2.5rem, 10.6666666667vw);
  height: min(2.5rem, 10.6666666667vw);
  font-size: 0;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 50%;
  position: relative;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysNumber .sysNumArea button.sysBtnPlus::before, #sysItemDetail article .item-container .item-info-container .sysForm #sysNumber .sysNumArea button.sysBtnMinus::before {
  content: "";
  display: block;
  width: min(0.75rem, 3.2vw);
  height: min(0.125rem, 0.5333333333vw);
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysNumber .sysNumArea button.sysBtnPlus::after {
  content: "";
  display: block;
  width: min(0.125rem, 0.5333333333vw);
  height: min(0.75rem, 3.2vw);
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSubtotal {
  font-size: 30px;
  font-weight: 700;
  line-height: 1.5;
  text-align: right;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSubmit {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSubmit > div:not([class]) img {
  margin-inline: auto;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSubmit .sysCartInDone {
  text-align: center;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSubmit .sysCartButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 100%;
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #988853;
  border: 1px solid #988853;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: 20px;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysSubmit .sysCartButton .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysWishlist {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysWishlist .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 100%;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #cccccc;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.4rem, 1.8vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

/* お気に入りボタンの基本設定にアイコン用スペースを追加 */
#sysItemDetail article .item-container .item-info-container .sysForm #sysWishlist .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px; /* ハートと文字の間の隙間 */
  position: relative;
  /* 既存のスタイルはそのまま維持 */
}

/* ハートのアイコンを追加 */
#sysItemDetail article .item-container .item-info-container .sysForm #sysWishlist .sysButton::before {
  content: "";
  display: inline-block;
  width: 20px;  /* ハートのサイズ */
  height: 20px;
  background-image: url("/img/web/r_heart.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  flex-shrink: 0; /* アイコンが潰れないように固定 */
}

/* 「お気に入り登録済み」になった時の対応 */
#sysItemDetail article .item-container .item-info-container .sysForm #sysWishlist .sysButton[disabled]::before {
  /* 登録済みでアイコンを消したい場合は display: none; */
  /* 色を変えたい場合は filter: grayscale(1); なども使えます */
}

#sysItemDetail article .item-container .item-info-container .sysForm #sysWishlist .sysButton[disabled] {
  opacity: 0.5;
  pointer-events: none;
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysWishSum {
  text-align: center;
  margin-bottom: min(1.875rem, 8vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm #sysWishSum span {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysShare {
  padding: 0;
  margin-inline: auto;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysShare ul {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: min(0.3125rem, 1.3333333333vw);
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysShare ul li {
  display: block;
  width: -moz-fit-content;
  width: fit-content;
}
#sysItemDetail article .item-container .item-info-container .sysForm .sysShare ul li iframe {
  display: block;
}
#sysItemDetail article .item-container .item-info-container .sysFreeForm {
  margin-bottom: min(1.875rem, 8vw);
}
#sysItemDetail article .item-container .item-info-container .sysFreeForm input[type=submit] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(2.5rem, 10.6666666667vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background-color: #ffffff;
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: min(0.25rem, 1.0666666667vw) min(0.5rem, 2.1333333333vw);
  background-position: right min(1.25rem, 5.3333333333vw) center;
  background-repeat: no-repeat;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysItemDetail article .sysExplanation {
  margin: 40px auto 60px auto;
  max-width: 1200px;
}
@media screen and (max-width: 768px) {
    #sysItemDetail article .sysExplanation {
  margin-top: 0px !important;
  }
}
#sysItemDetail article .sysExplanation p {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 400;
  line-height: 1.7;
}
#sysItemDetail article .sysReview {
  width: 100%;

  background-color: #eeeeee;
  padding: min(3.125rem, 13.3333333333vw) min(6.25rem, 26.6666666667vw);
  margin-inline: auto;
  margin-bottom: min(5rem, 21.3333333333vw);
  position: relative;
}
#sysItemDetail article .sysReview:not(:has(.sysReviewHistoryList li)) {
  display: none;
}
#sysItemDetail article .sysReview > span {
  display: block;
  font-size: min(1.75rem, 7.4666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemDetail article .sysReview > br {
  display: none;
}
#sysItemDetail article .sysReview .sysReviewHistoryList {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
#sysItemDetail article .sysReview .sysReviewHistoryList li {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 min(0.9375rem, 4vw);
  width: 100%;
  border: none;
  border-radius: min(0.625rem, 2.6666666667vw);
  background-color: #ffffff;
  padding: min(1.875rem, 8vw) min(1.875rem, 8vw) min(4.125rem, 17.6vw);
  position: relative;
}
#sysItemDetail article .sysReview .sysReviewHistoryList li .sysNickname {
  max-width: calc(100% - min(6.25rem, 26.6666666667vw));
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  padding-left: min(2.8125rem, 12vw);
  position: relative;
}
#sysItemDetail article .sysReview .sysReviewHistoryList li .sysNickname::before {
  content: "";
  display: block;
  width: min(1.875rem, 8vw);
  height: min(1.875rem, 8vw);
  background-image: url(../img/layout/common/icon_user.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
#sysItemDetail article .sysReview .sysReviewHistoryList li .sysEvaluation {
  flex-shrink: 0;
  font-size: min(1.0625rem, 4.5333333333vw);
  line-height: 1.5;
  color: #e69b05;
}
#sysItemDetail article .sysReview .sysReviewHistoryList li .sysReviewText {
  width: 100%;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-top: min(0.9375rem, 4vw);
}
#sysItemDetail article .sysReview .sysReviewHistoryList li .sysReviewDatetime {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
  position: absolute;
  bottom: min(1.875rem, 8vw);
  right: min(1.875rem, 8vw);
}
#sysItemDetail article .sysReview form input[type=submit] {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  color: #333333;
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: min(0.25rem, 1.0666666667vw) min(0.5rem, 2.1333333333vw);
  background-position: right min(0.3125rem, 1.3333333333vw) center;
  background-repeat: no-repeat;
  padding-right: min(1.25rem, 5.3333333333vw);
  position: absolute;
  top: min(3.6875rem, 15.7333333333vw);
  right: min(6.25rem, 26.6666666667vw);
}
#sysItemDetail .related-item .sysItemBlock {
  padding-inline: 0;
  margin-bottom: min(5rem, 21.3333333333vw);
}

#sysModalWindow {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: rgba(0, 0, 0, 0.8);
  padding: min(5rem, 21.3333333333vw) min(0.9375rem, 4vw);
  overflow-y: scroll;
}
#sysModalWindow .sysModalContent {
  width: 100%;
  max-width: min(50rem, 213.3333333333vw);
  height: auto;
  border: none;
  border-radius: 0;
  box-shadow: none;
  overflow: auto;
  position: relative;
  padding: min(0.9375rem, 4vw);
  margin: auto;
}
#sysModalWindow .sysModalContent .sysRemoveElement {
  width: min(3.125rem, 13.3333333333vw);
  height: min(3.125rem, 13.3333333333vw);
  position: fixed;
  top: min(1.25rem, 5.3333333333vw);
  right: min(1.25rem, 5.3333333333vw);
  border-radius: 50%;
  background-color: #ffffff;
}
#sysModalWindow .sysModalContent .sysRemoveElement::before, #sysModalWindow .sysModalContent .sysRemoveElement::after {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(1.375rem, 5.8666666667vw);
  border-radius: 4px;
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 50%;
}
#sysModalWindow .sysModalContent .sysRemoveElement::before {
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
}
#sysModalWindow .sysModalContent .sysRemoveElement::after {
  transform: translateX(-50%) translateY(-50%) rotate(-45deg);
}
#sysModalWindow .sysModalContent .sysModalMainImage {
  max-width: 100%;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysModalWindow .sysModalContent .sysModalMainImage img {
  width: 100%;
}
#sysModalWindow .sysModalContent .sysModalImageList {
  display: flex;
  flex-wrap: wrap;
  gap: min(0.3125rem, 1.3333333333vw);
}
#sysModalWindow .sysModalContent .sysModalImageList li {
  float: none;
  width: calc(16.6666666667% - min(1.5625rem, 6.6666666667vw) / 6);
  height: auto;
  position: relative;
  margin: 0;
}
#sysModalWindow .sysModalContent .sysModalImageList li img {
  border: none;
}
#sysModalWindow .sysModalContent .sysModalImageList li.sysCurrent img {
  border: none;
}
#sysModalWindow .sysModalContent .sysModalImageList li.sysCurrent::after {
  content: "";
  width: calc(100% + 0.125rem);
  height: calc(100% + 0.125rem);
  border: 0.125rem solid #333333;
  border-radius: 0.125rem;
  position: absolute;
  top: -0.125rem;
  left: -0.125rem;
}

.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper {
  padding: min(6.25rem, 26.6666666667vw) min(0.9375rem, 4vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container {
  display: block;
  max-width: min(31.25rem, 133.3333333333vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container {
  padding: min(1.875rem, 8vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistThumbnailGroup {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistThumbnailGroup img {
  width: 100%;
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistMessageGroup {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistMessageGroup .sysWishlistMessage {
  text-align: center;
  color: #333333;
  padding: 0;
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistInformationGroup {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistInformationGroup .sysWishlistInformation {
  text-align: center;
  color: #333333;
  padding: 0;
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistLoginGroup input[type=submit],
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistMemberRegisterGroup input[type=submit] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistLoginGroup input[type=submit] .fa,
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistMemberRegisterGroup input[type=submit] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistShowGroup input[type=submit] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistShowGroup input[type=submit] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysWishlistCloseBottomButtonGroup button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-close {
  background-color: #ffffff !important;
}
.modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-close::before, .modaal-wrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-close::after {
  background-color: #333333 !important;
}

/*! ========================================================
商品カテゴリページ／商品検索結果ページ
========================================================= */
#sysItemCategory,
#sysItemSearch {
  background: #eff0ee;
}
#sysItemSearch #sysFooter {
  background: #fff;
}
#sysItemSearch .r_check {
  padding-top: 60px;
  margin-bottom: 0;
}
#sysItemCategory #sysMain {
  margin-bottom: 60px;
}

/* ----- タイトル画像 ----- */
#sysItemCategory .category-header {
  display: flex;
  align-items: stretch; /* これで左右の高さを揃える */
  background-color: #fff; /* 画像背景に近い薄いグレー系 */
  width: 100%;
  max-width: 100%;
  margin: 0 0 30px 0;
  border-radius: 20px; /* 画像に合わせた少し大きめの角丸 */
  overflow: hidden;
}

#sysItemCategory .category-image {
  flex: 0 0 45%; /* 幅を45%で固定 */
  line-height: 0;
}

#sysItemCategory .category-image img {
  width: 100%;
  height: 100%; /* 親の高さ（テキスト量）に合わせる */
  object-fit: cover; /* 画像を歪ませずに枠を埋める魔法の1行 */
  display: block;
}

#sysItemCategory .category-content {
  flex: 1;
  padding: clamp(20px, 5vw, 60px); /* 画面幅に合わせて余白を可変にする */
  display: flex;
  flex-direction: column;
  justify-content: center; /* 上下中央に配置 */
}

#sysItemCategory .en-title {
  font-size: 14px;
  color: #8bbbbd; /* サンプル画像の淡い色味 */
  letter-spacing: 0.1em;
  display: block;
  margin-bottom: 8px;
}

#sysItemCategory .jp-title {
  font-size: clamp(24px, 4vw, 42px); /* レスポンシブな文字サイズ */
  font-weight: bold;
  color: #333;
  margin: 0 0 20px 0;
 line-height: 1.2;
}

#sysItemCategory .category-description {
  font-size: 15px;
  line-height: 1.8;
  color: #444;
  margin: 0;
 max-width: 600px; /* テキストが横に伸びすぎないように制限 */
}

@media (max-width: 767px) {
  #sysItemCategory .category-header {
  flex-direction: column; /* 縦並びに変更 */
  border-radius: 0px;
  }
  #sysItemCategory .category-image {
  flex: 0 0 auto;
  width: 100%;
  height: 200px; /* スマホ時は画像の高さを固定 */
    }
  #sysItemCategory .category-content {
  padding: 30px 20px;
  }
}


#sysItemCategory .sysItemList {
  width: 100%;
  margin: 0 auto;
}
@media screen and (max-width: 768px) {
  #sysItemCategory .sysItemList {
  width: 94%;
  margin: 0 auto 30px auto;
  }
}


#sysItemCategory #sysWrap,
#sysItemSearch #sysWrap {
  width: 100%;
  max-width: min(78.75rem, 336vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  display: flex;
  flex-wrap: wrap;
  flex-direction: row-reverse;
  align-items: flex-start;
  gap: 0 min(2.8125rem, 12vw);
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysItemCategory #sysWrap #sysMain,
#sysItemSearch #sysWrap #sysMain {
  width: calc(100% - min(21.875rem, 93.3333333333vw));
}
#sysItemCategory .sysItemList,
#sysItemSearch .sysItemList {
  text-align: center;
}

#sysItemCategory .sysItemCategoryForm {
  margin-bottom: min(1.875rem, 8vw);
}
#sysItemCategory .sysItemCategoryForm .sysItemCategoryCtl {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  border-bottom: 1px solid #dfdedb;
  padding-block: min(1.25rem, 5.3333333333vw) min(0.9375rem, 4vw);
  margin: 0;
}
#sysItemCategory .sysItemCategoryForm .sysItemCategoryCtl a {
  display: inline-block;
  border-radius: 100px;
  background-color: #fff;
  padding: min(0.25rem, 1.0666666667vw) min(0.625rem, 2.6666666667vw);
  margin-right: min(0.1875rem, 0.8vw);
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysItemCategory .sysItemCategoryForm .sysItemCategoryCtl a:hover {
  background-color: #d6efec;
  opacity: 1;
}
#sysItemSearch #sysMain > h2 {
  font-size: min(1.5625rem, 6.6666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  text-align: center;
  margin-bottom: min(0.9375rem, 4vw);
}

#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  background-color: #fff;
  border-radius: 20px;
  padding: min(1.875rem, 8vw);
  margin-bottom: 40px;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormWord {
  width: 100%;
  margin-bottom: min(0.4375rem, 1.8666666667vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormWord input[type=search] {
  border: none;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchAndOr {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: min(1.25rem, 5.3333333333vw);
  width: 100%;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchAndOr label {
  font-size: min(0.875rem, 3.7333333333vw);
  margin: 0;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormRange {
  width: -moz-fit-content;
  width: fit-content;
  margin-right: min(1.875rem, 8vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormRange input[type=text] {
  border: none;
  margin-inline: min(0.375rem, 1.6vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormRange input[type=text]:first-of-type {
  margin-left: 0;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormCategory {
  display: flex;
  align-items: center;
  width: calc(100% - min(19.0625rem, 81.3333333333vw));
  white-space: nowrap;
  margin-left: auto;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormCategory select {
  border: none;
  margin-left: min(0.625rem, 2.6666666667vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups {
  width: 100%;
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups .sysItemSearchFormItemCategoryGroupsTitle {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] {
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] span[class*=itemCategoryGroupTitle] {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.7;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] ul {
  display: flex;
  flex-wrap: wrap;
  gap: min(0.5rem, 2.1333333333vw) min(1.25rem, 5.3333333333vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] ul li {
  display: flex;
  align-items: center;
  width: -moz-fit-content;
  width: fit-content;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] ul li input[type=checkbox] {
  display: block;
  margin-right: min(0.3125rem, 1.3333333333vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] ul li label {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.2;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormSort {
  width: min(8.75rem, 37.3333333333vw);
  margin-right: min(0.625rem, 2.6666666667vw);
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormSort select {
  height: min(2.5rem, 10.6666666667vw);
  border: none;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormLimit {
  width: calc(100% - min(9.375rem, 40vw));
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormLimit select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
  border: none;
}
#sysItemSearch .sysItemSearchForm .sysItemSearchFormInput input[type=submit] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(2.5rem, 10.6666666667vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background-color: #ffffff;
  background-image: url(../img/layout/common/arrow_right_black.png);
  background-size: min(0.25rem, 1.0666666667vw) min(0.5rem, 2.1333333333vw);
  background-position: right min(1.25rem, 5.3333333333vw) center;
  background-repeat: no-repeat;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  height: min(2.5rem, 10.6666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  padding-block: 0;
  margin-top: min(1.25rem, 5.3333333333vw);
}
#sysItemCategory .sysItemListDisp,
#sysItemSearch .sysItemListDisp {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-block: min(1.875rem, 8vw) min(0.9375rem, 4vw);
  width: 100%;
  margin: 0 auto;
}
#sysItemCategory .sysItemListDisp #displayCount,
#sysItemSearch .sysItemListDisp #displayCount {
  width: -moz-fit-content;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
}
#sysItemCategory .sysItemListDisp .sysItemListViewType,
#sysItemSearch .sysItemListDisp .sysItemListViewType {
  display: flex;
  align-items: center;
  gap: min(1.25rem, 5.3333333333vw);
  width: -moz-fit-content;
  width: fit-content;
}
#sysItemCategory .sysItemListDisp .sysItemListViewType label,
#sysItemSearch .sysItemListDisp .sysItemListViewType label {
  display: flex;
  align-items: center;
  font-size: min(0.875rem, 3.7333333333vw) !important;
  line-height: 1.7;
  margin: 0 !important;
}

#sysItemCategory .sysItemList ul.sysThumbnail,
#sysItemSearch .sysItemList ul.sysThumbnail {
  display: flex;
  flex-wrap: wrap;
  gap: min(2.5rem, 10.6666666667vw) min(1.625rem, 6.9333333333vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li,
#sysItemSearch .sysItemList ul.sysThumbnail li {
  width: calc(33.333% - (min(1.625rem, 6.9333333333vw) * 2) / 3);
  text-align: left;
  position: relative;
  padding-bottom: 15px;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysThumbnailImage,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysThumbnailImage {
  width: 100%;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysThumbnailImage a,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysThumbnailImage a {
  display: block;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysThumbnailImage a img,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysThumbnailImage a img {
  display: block;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysItemName a,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysItemName a {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li #sysDescriptionPc,
#sysItemCategory .sysItemList ul.sysThumbnail li #sysDescriptionMobile,
#sysItemSearch .sysItemList ul.sysThumbnail li #sysDescriptionPc,
#sysItemSearch .sysItemList ul.sysThumbnail li #sysDescriptionMobile {
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  margin-bottom: min(0.25rem, 1.0666666667vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysRetailPrice,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysRetailPrice {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li > form input[type=submit],
#sysItemSearch .sysItemList ul.sysThumbnail li > form input[type=submit] {
  width: 90%;
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  border-radius: 100px;
  background-color: #988853;
  padding: min(0.625rem, 2.6666666667vw) min(0.625rem, 2.6666666667vw) min(0.5625rem, 2.4vw);
  margin-top: 0 auto;
  position: relative;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button {
  width: 90%;
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  vertical-align: middle !important;
  color: #333333;
  border: none;
  border-radius: 100px;
  background-color: #ffffff;
  padding: 0;
  position: relative;
}
/* ハートアイコンの設定 */
#sysItemCategory .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button::before,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button::before {
  content: "";
  display: inline-block;
  width: 18px;  /* アイコンの横幅 */
  height: 18px; /* アイコンの縦幅 */
  margin-right: 8px; /* アイコンと文字の間隔 */
  
  /* ハート画像の読み込み */
  background-image: url(/img/web/r_heart.svg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddSelection > div,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddSelection > div {
  font-size: min(0.75rem, 3.2vw);
  font-weight: bold;
  line-height: 1.5;
  margin-top: min(0.8125rem, 3.4666666667vw);
  text-align: left;
  margin-bottom: 20px;
}
#sysItemCategory #sysAll #sysMain label:has(input[type="radio"]), #sysItemCategory #sysAll #sysMain label:has(input[type="checkbox"]) {
  font-weight: normal;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddSelection > div select,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddSelection > div select {
  display: block;
  width: 100%;
  height: auto;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  border: 1px solid #333333;
  background-image: none;
  color: #333333;
  padding: min(0.3125rem, 1.3333333333vw);
  overflow: clip;
  margin-top: min(0.375rem, 1.6vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddSelection > div label,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddSelection > div label {
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddSelection > div label:first-of-type,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddSelection > div label:first-of-type {
  margin-top: min(0.375rem, 1.6vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddSelection > div input[type=text],
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddSelection > div input[type=text] {
  display: block;
  width: 100%;
  height: auto;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  border: 1px solid #333333;
  color: #333333;
  padding: min(0.3125rem, 1.3333333333vw);
  margin-top: min(0.375rem, 1.6vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddVariation,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddVariation {
  margin-top: min(0.625rem, 2.6666666667vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddVariation .sysVariationSelects,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddVariation .sysVariationSelects {
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddVariation select,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddVariation select {
  display: block;
  width: 100%;
  height: auto;
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  border: 1px solid #333333;
  background-image: none;
  color: #333333;
  padding: min(0.3125rem, 1.3333333333vw);
  overflow: clip;
}
#sysItemCategory .sysItemList ul.sysThumbnail li .sysAddVariation select::after,
#sysItemSearch .sysItemList ul.sysThumbnail li .sysAddVariation select::after {
  content: none;
}
#sysItemCategory .sysItemList ul.sysList li,
#sysItemSearch .sysItemList ul.sysList li {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0 min(1.25rem, 5.3333333333vw);
  width: 100%;
  text-align: left;
  border-top: none;
  border-bottom: 1px solid #c2c2c2;
  padding-block: min(1.25rem, 5.3333333333vw);
  position: relative;
}
#sysItemCategory .sysItemList ul.sysList li:first-of-type,
#sysItemSearch .sysItemList ul.sysList li:first-of-type {
  padding-top: 0;
}
#sysItemCategory .sysItemList ul.sysList li:last-of-type,
#sysItemSearch .sysItemList ul.sysList li:last-of-type {
  border-bottom: 1px solid #c2c2c2;
}
#sysItemCategory .sysItemList ul.sysList li .sysThumbnailImage,
#sysItemSearch .sysItemList ul.sysList li .sysThumbnailImage {
  width: min(8.125rem, 34.6666666667vw);
  margin: 0;
}
#sysItemCategory .sysItemList ul.sysList li .sysThumbnailImage a,
#sysItemSearch .sysItemList ul.sysList li .sysThumbnailImage a {
  display: block;
}
#sysItemCategory .sysItemList ul.sysList li .sysThumbnailImage a img,
#sysItemSearch .sysItemList ul.sysList li .sysThumbnailImage a img {
  display: block;
}
#sysItemCategory .sysItemList ul.sysList li > div:not([class]),
#sysItemSearch .sysItemList ul.sysList li > div:not([class]) {
  width: calc(100% - min(9.375rem, 40vw));
}
#sysItemCategory .sysItemList ul.sysList li > div:not([class]) .sysItemName a,
#sysItemSearch .sysItemList ul.sysList li > div:not([class]) .sysItemName a {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-bottom: min(0.1875rem, 0.8vw);
}
#sysItemCategory .sysItemList ul.sysList li > div:not([class]) #sysDescriptionPc,
#sysItemCategory .sysItemList ul.sysList li > div:not([class]) #sysDescriptionMobile,
#sysItemSearch .sysItemList ul.sysList li > div:not([class]) #sysDescriptionPc,
#sysItemSearch .sysItemList ul.sysList li > div:not([class]) #sysDescriptionMobile {
  font-size: min(0.75rem, 3.2vw);
  line-height: 1.5;
  margin-bottom: min(0.9375rem, 4vw);
}
#sysItemCategory .sysItemList ul.sysList li > div:not([class]) .sysRetailPrice,
#sysItemSearch .sysItemList ul.sysList li > div:not([class]) .sysRetailPrice {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemCategory .sysItemList ul.sysList li > form,
#sysItemSearch .sysItemList ul.sysList li > form {
  width: 100%;
  padding-left: min(9.375rem, 40vw);
}
#sysItemCategory .sysItemList ul.sysList li > form input[type=submit],
#sysItemSearch .sysItemList ul.sysList li > form input[type=submit] {
  width: 100%;
  max-width: min(12.0625rem, 51.4666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  border-radius: 100px;
  background-color: #333333;
  padding: min(0.625rem, 2.6666666667vw) min(0.625rem, 2.6666666667vw) min(0.5625rem, 2.4vw);
  margin-top: min(0.9375rem, 4vw);
  position: relative;
}
#sysItemCategory .sysItemList ul.sysList li .sysWishListButtonFormAjax,
#sysItemSearch .sysItemList ul.sysList li .sysWishListButtonFormAjax {
  width: 100%;
  padding-left: min(9.375rem, 40vw);
}
#sysItemCategory .sysItemList ul.sysList li .sysWishListButtonFormAjax button,
#sysItemSearch .sysItemList ul.sysList li .sysWishListButtonFormAjax button {
  width: 100%;
  max-width: min(12.0625rem, 51.4666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: 100px;
  background-color: #ffffff;
  padding: min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw) min(0.4375rem, 1.8666666667vw);
  margin-top: min(0.3125rem, 1.3333333333vw);
  position: relative;
}
#sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div,
#sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  margin-top: min(0.9375rem, 4vw);
}
#sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div:has(input[type=radio]),
#sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div:has(input[type=radio]) {
  display: flex;
  flex-wrap: wrap;
}
#sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div:has(input[type=radio])::before,
#sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div:has(input[type=radio])::before {
  content: "";
  display: block;
  width: 100%;
  height: min(0.3125rem, 1.3333333333vw);
  order: 1;
}
#sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div select,
#sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div label,
#sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div label {
  order: 2;
  font-size: min(0.875rem, 3.7333333333vw);
}
#sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div input[type=text],
#sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div input[type=text] {
  height: min(2.5rem, 10.6666666667vw);
  max-width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysItemCategory .sysItemList ul.sysList li .sysAddVariation .sysVariationSelects,
#sysItemSearch .sysItemList ul.sysList li .sysAddVariation .sysVariationSelects {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 400;
  line-height: 1.7;
  margin-top: min(0.9375rem, 4vw);
}
#sysItemCategory .sysItemList ul.sysList li .sysAddVariation select,
#sysItemSearch .sysItemList ul.sysList li .sysAddVariation select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  margin-top: min(0.3125rem, 1.3333333333vw);
}

#sysItemCategory .sysPagination,
#sysItemSearch .sysPagination {
  padding-block: min(3.75rem, 16vw) min(5rem, 21.3333333333vw);
}
#sysItemCategory .sysPagination ul,
#sysItemSearch .sysPagination ul {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(0.3125rem, 1.3333333333vw);
}
#sysItemCategory .sysPagination ul li,
#sysItemSearch .sysPagination ul li {
  display: block;
  width: min(2.5rem, 10.6666666667vw);
  height: min(2.5rem, 10.6666666667vw);
  padding: 0;
}
#sysItemCategory .sysPagination ul li a,
#sysItemSearch .sysPagination ul li a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  text-decoration: none;
  border: 1px solid #c2c2c2;
  background-color: #ffffff;
}
#sysItemCategory .sysPagination ul li a.sysCurrent,
#sysItemSearch .sysPagination ul li a.sysCurrent {
  color: #ffffff;
  background-color: #418f94;
}

#sysItemCategory .sysItemCategoryInfo {
  margin-bottom: min(1.875rem, 8vw);
}
#sysItemCategory .sysItemCategoryInfo .sysCategoryDescription .img {
  width: 100%;
  margin-bottom: min(1.875rem, 8vw);
}
#sysItemCategory .sysItemCategoryInfo .sysCategoryDescription .img img {
  width: 100%;
}
#sysItemCategory .sysItemCategoryInfo .sysCategoryDescription p {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-bottom: min(1.875rem, 8vw);
}

/* フッター上に入れた要素の調節 */
#sysItemCategory .r_category,
#sysItemSearch .r_category,
#sysItemCategory .r_set,
#sysItemSearch .r_set,
#sysItemCategory .r_check,
#sysItemSearch .r_check {
  background: #fff;
}
#sysItemCategory .r_set,
#sysItemSearch .r_set {
  padding-top: 0 !important;
  padding-bottom: 60px;
}
#sysItemCategory .r_category_sec,
#sysItemSearch .r_category_sec {
  border: 1px solid #ccc;
  border-radius: 20px;
  margin-bottom: 20px !important;
  box-shadow: 0 0 0 100vw #fff;
}
#sysItemCategory .r_category h2.tit_icon3,
#sysItemSearch .r_category h2.tit_icon3 {
  margin-bottom: 15px;
}
#sysItemCategory #sysFooter .sysFuncText:first-of-type {
  width: 1200px;
  margin: 60px auto;
}
#sysItemSearch #sysFooter .sysFuncText:first-of-type {
  width: 1200px;
  margin: 60px auto 0 auto;
}
#sysItemCategory #sysFooter .sysFuncText:first-of-type h2,
#sysItemSearch #sysFooter .sysFuncText:first-of-type h2 {
  margin-bottom: 15px;
}
#sysItemCategory .item-block-col6 .sysItemBlock ul,
#sysItemSearch .item-block-col6 .sysItemBlock ul,
#sysItemDetail .item-block-col6 .sysItemBlock ul {
  gap: min(3.125rem, 13.3333333333vw) min(0.5rem, 6vw);
}
#sysItemCategory .item-block-col6 .sysItemBlock ul li,
#sysItemSearch .item-block-col6 .sysItemBlock ul li,
#sysItemDetail .item-block-col6 .sysItemBlock ul li {
  width: calc(17.6666666667% - min(7.5rem, 32vw) / 6);
}

@media screen and (max-width: 768px) {
  #sysMain .sysFuncItemBlock.item-block-col6 .sysItemBlock ul, 
  #sysMain .sysFuncItemBlock.item-block-col5 .sysItemBlock ul, 
  #sysMain .sysFuncItemBlock.item-block-col4 .sysItemBlock ul, 
  #sysMain .sysFuncItemBlock.item-block-col3 .sysItemBlock ul {
    gap: min(1.875rem, 8vw) min(0.9375rem, 4vw);
  }
  #sysMain .sysFuncItemBlock.item-block-col6 .sysItemBlock ul li, 
  #sysMain .sysFuncItemBlock.item-block-col5 .sysItemBlock ul li, 
  #sysMain .sysFuncItemBlock.item-block-col4 .sysItemBlock ul li, 
  #sysMain .sysFuncItemBlock.item-block-col3 .sysItemBlock ul li {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  #sysItemCategory #sysFooter .sysFuncText:first-of-type,
  #sysItemSearch #sysFooter .sysFuncText:first-of-type {
  width: 100%;
  margin: 0 auto 30px auto;
  }
  #sysItemCategory #sysFooter .r_category h2,
  #sysItemSearch #sysFooter .r_category h2 {
  width: 94%;
  margin: 0 auto;
  }
  #sysItemCategory #sysFooter .r_howto h2,
  #sysItemSearch #sysFooter .r_howto h2 {
  width: 94%;
  margin: 0 auto;
  }
  #sysItemCategory #sysFooter .area_list h2,
  #sysItemSearch #sysFooter .area_list h2 {
  width: 94%;
  margin: 0 auto;
  }
  #sysItemCategory .r_set .sysHeadline,
  #sysItemSearch .r_set .sysHeadline {
  margin-top: 0;
  }
  #sysItemCategory .r_set,
  #sysItemSearch .r_set {
  padding-top: 0 !important;
  padding-bottom: 30px;
  }
  #sysItemCategory .r_check,
  #sysItemSearch .r_check {
  padding-bottom: 30px;
  }
  #sysItemCategory .r_category_faq,
  #sysItemSearch .r_category_faq {
  width: 94% !important;
  margin: 0 auto;
  }
}

/*! ========================================================
カートページ設定
========================================================= */
#sysBasket #sysMain .sysNextSubmit,
#sysBasket #sysMain .sysAmazonNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #d12e2e;
  border: min(0.125rem, 0.5333333333vw) solid #d12e2e;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  width: 100% !important;
  height: auto !important;
}

#sysBasket #sysMain .sysBackButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysBasket #sysMain .sysDeleteArea .sysDeleteArea {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
}

#sysBasket #sysMain #sysInputCouponCode .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin-left: 0;
}
#sysBasket #sysMain #sysInputCouponCode .sysButton .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysBasket #sysMain .sysConfirmCoupon input[type=button] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin-right: 0;
  margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
}

.basketCouponEditDialog_buttonGroup .basketCouponDialog_applyButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  display: inline-block;
}
.basketCouponEditDialog_buttonGroup .basketCouponDialog_applyButton .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.basketCouponEditDialog_buttonGroup .basketCouponDialog_cancelButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  display: inline-block;
}

.sysCart #sysMain .sysSocialGiftReceiveUrlCopyButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: min(1.25rem, 5.3333333333vw);
}

.sysCart #sysMain .sysSocialGiftReceiveUrlSendLineButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}

#sysRegi #sysMain input[value=ログイン] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysRegi #sysMain input[value=ログイン] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysRegi #sysMain input[value=ログインパスワードを忘れた場合] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysRegi #sysMain .sysBackSubmitArea .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysRegi #sysMain .sysNextSubmitArea .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #d12e2e;
  border: min(0.125rem, 0.5333333333vw) solid #d12e2e;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysThanks #sysMain input[value=登録する] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysThanks #sysMain input[value=登録する] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysBasket #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysBasket #sysWrap #sysMain .sysNextSubmitAreaForUseAmazon {
  display: block;
  width: 100%;
  padding: 0;
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysNextSubmitAreaForUseAmazon #useAmazonSubmitButton {
  padding: 0;
}
#sysBasket #sysWrap #sysMain .sysNextSubmitAreaForUseAmazon #amazonPayTopLoginButton,
#sysBasket #sysWrap #sysMain .sysNextSubmitAreaForUseAmazon #amazonPayBottomLoginButton {
  max-width: min(21.5625rem, 92vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  padding: 0;
}
#sysBasket #sysWrap #sysMain div:not(#sysInputCouponCode) .sysBox {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
}
#sysBasket #sysWrap #sysMain .sysTotal {
  margin-block: min(2.5rem, 10.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysTotal .sysBox > div {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
  letter-spacing: 0.04em;
}
#sysBasket #sysWrap #sysMain .sysTotal .sysBox > div .sysCartAttention {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  color: #d12e2e;
  padding-inline: min(0.25rem, 1.0666666667vw);
}
#sysBasket #sysWrap #sysMain .sysTotal .sysBox > div .sysCartAttention:empty {
  display: none;
}
#sysBasket #sysWrap #sysMain .sysTotal .sysBox > div .sysCartAttention[data-name=total-item], #sysBasket #sysWrap #sysMain .sysTotal .sysBox > div .sysCartAttention[data-name=free-shipping] {
  color: #333333;
}
#sysBasket #sysWrap #sysMain .sysInputCouponCode {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysInputCouponCode .sysBox {
  font-weight: 500;
}
#sysBasket #sysWrap #sysMain .sysInputCouponCode .sysBox input[type=text] {
  font-weight: 400;
  margin-top: min(0.5rem, 2.1333333333vw);
}
#sysBasket #sysWrap #sysMain .sysCartTitle {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  border-bottom: 1px solid #333333;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysBasket #sysWrap #sysMain .sysCartItemAreaMessage {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  text-align: center;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea {
  margin-bottom: min(3.75rem, 16vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox {
  display: flex;
  flex-wrap: wrap;
  gap: 0 min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.9375rem, 4vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > hr {
  display: none;
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > a {
  width: min(7.5rem, 32vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysProduct {
  width: calc(100% - min(8.75rem, 37.3333333333vw));
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysProduct .sysItemName {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysProduct > div:not(.sysItemName) {
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: 100%;
  padding-top: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) > div:not([class]) {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) .sysNumArea {
  display: flex;
  align-items: center;
  gap: min(0.3125rem, 1.3333333333vw);
  margin-left: min(1.25rem, 5.3333333333vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) .sysNumArea button {
  display: block;
  width: min(2.5rem, 10.6666666667vw);
  height: min(2.5rem, 10.6666666667vw);
  font-size: 0;
  background: none;
  background-color: #eeeeee;
  border: none;
  border-radius: 50%;
  position: relative;
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) .sysNumArea button.sysBtnPlus::before, #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) .sysNumArea button.sysBtnMinus::before {
  content: "";
  display: block;
  width: min(0.75rem, 3.2vw);
  height: min(0.125rem, 0.5333333333vw);
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) .sysNumArea button.sysBtnPlus::after {
  content: "";
  display: block;
  width: min(0.125rem, 0.5333333333vw);
  height: min(0.75rem, 3.2vw);
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translateX(-50%) translateY(-50%);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea {
  width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea .sysCartInForm {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea #sysSelections {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
  margin-top: min(0.25rem, 1.0666666667vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea input[type=text] {
  margin-top: min(0.25rem, 1.0666666667vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea > .sysCartAttention {
  display: inline-block;
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  margin-top: min(0.625rem, 2.6666666667vw);
}
#sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysDeleteArea {
  width: 100%;
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-inner-wrapper {
  padding: min(5rem, 21.3333333333vw) min(0.9375rem, 4vw);
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-close {
  width: min(3.125rem, 13.3333333333vw);
  height: min(3.125rem, 13.3333333333vw);
  position: fixed;
  top: min(1.25rem, 5.3333333333vw);
  right: min(1.25rem, 5.3333333333vw);
  border: none;
  border-radius: 50%;
  background: none;
  background-color: #ffffff;
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-close::before, #sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-close::after {
  content: "";
  display: block;
  width: min(0.25rem, 1.0666666667vw);
  height: min(1.375rem, 5.8666666667vw);
  border-radius: 4px;
  background-color: #333333;
  position: absolute;
  top: 50%;
  left: 50%;
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-close::before {
  transform: translateX(-50%) translateY(-50%) rotate(45deg);
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-close::after {
  transform: translateX(-50%) translateY(-50%) rotate(-45deg);
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container {
  width: 100%;
  max-width: min(37.5rem, 160vw);
  padding: min(1.25rem, 5.3333333333vw);
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .modaal-content-container {
  padding: 0;
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .basketCouponEditDialog .basketCouponEdit .basketCouponTitle {
  font-weight: 500;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .basketCouponEditDialog .basketCouponEdit .basketCoupon_edit {
  border: 1px solid #707070;
  padding: min(0.9375rem, 4vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .basketCouponEditDialog .basketCouponEdit .basketCoupon_edit_withCodeRow {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .basketCouponEditDialog .basketCouponEdit .basketCoupon_edit_withCodeRow_label {
  display: block;
  width: 100%;
  margin: 0;
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .basketCouponEditDialog .basketCouponEdit .basketCoupon_edit_withCodeRow_label .basketCoupon_edit_withCodeRow_checkbox {
  margin-left: 0;
}
#sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .basketCouponEditDialog .basketCouponEditDialog_buttonGroup {
  text-align: right;
}

#sysRegi #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysRegi #sysWrap #sysMain .sysCartTitle {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  border-bottom: 1px solid #333333;
  padding-top: min(2.5rem, 10.6666666667vw);
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysRegi #sysWrap #sysMain .sysBox > p {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  text-align: center;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysRegi #sysWrap #sysMain .sysFormItem.sysSubmit {
  margin-bottom: 0;
}

#sysThanks #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(8.125rem, 34.6666666667vw);
}
#sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) {
  margin-bottom: min(3.75rem, 16vw);
}
#sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) > div {
  text-align: center;
}
#sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin-block: min(3.75rem, 16vw) min(1.25rem, 5.3333333333vw);
}
#sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) .sysOrderNumber {
  font-size: min(1.5625rem, 6.6666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  margin-top: min(0.5rem, 2.1333333333vw);
}
#sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) .sysCartNote {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  letter-spacing: 0.04em;
  color: #333333;
  text-align: left;
}
#sysThanks #sysWrap #sysMain .sysBox .sysForm form > label:has(+ .sysRequired) {
  margin-top: min(0.5rem, 2.1333333333vw);
}
#sysThanks #sysWrap #sysMain .sysBox .sysForm form > label:has(+ .sysRequired)::after {
  content: "必須";
  display: inline-block;
  font-size: min(0.6875rem, 2.9333333333vw);
  line-height: 1.5;
  color: #ffffff;
  border-radius: min(0.1875rem, 0.8vw);
  background-color: #d12e2e;
  padding: min(0.0625rem, 0.2666666667vw) min(0.5rem, 2.1333333333vw) min(0.125rem, 0.5333333333vw);
  margin-left: min(0.75rem, 3.2vw);
  position: relative;
}
#sysThanks #sysWrap #sysMain .sysBox .sysForm form > label:has(+ .sysRequired) + .sysRequired {
  display: none;
}
#sysThanks #sysWrap #sysMain .sysBox > div:has(.sysMemberAgreementFormLabel) {
  margin-top: min(2.5rem, 10.6666666667vw);
}
#sysThanks #sysWrap #sysMain .sysBox > div:has(.sysMemberAgreementFormLabel) .sysMemberAgreementFormLabel {
  display: block;
  font-weight: 500;
  padding: 0;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysThanks #sysWrap #sysMain .sysBox > div:has(.sysMemberAgreementFormLabel) .sysMemberAgreement {
  font-size: min(0.875rem, 3.7333333333vw);
  padding: min(1.25rem, 5.3333333333vw);
}
#sysThanks #sysWrap #sysMain .sysBox:last-of-type {
  text-align: center;
}

.modaal-wrapper .basketCouponEditDialog_buttonGroup {
  text-align: center;
}

/*! ========================================================
マイページ設定
========================================================= */

.sysMypage .sysOrder input[value=再注文する] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
}
.sysMypage .sysOrder input[value=再注文する] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}
.sysMypage .sysOrder .sysCartInButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #d12e2e;
  border: min(0.125rem, 0.5333333333vw) solid #d12e2e;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.sysMypage .sysOrder .sysGoCartButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #d12e2e;
  border: min(0.125rem, 0.5333333333vw) solid #d12e2e;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.sysMypage .sys_mailaddress input[type=submit] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.sysMypage .sys_mailaddress input[type=submit] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageWithdrawalConfirm form:last-of-type .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysMypageWithdrawalConfirm form:last-of-type .sysButton .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageRepeat #sysRepeatOrderList input[value=詳細へ],
#sysMypageRepeat #sysRepeatOrderDetail input:not([value=戻る], [value=定期購入申込をキャンセル]),
#sysMypageRepeat #sysRepeatOrderHistory input:not([value=戻る], [value=定期購入申込をキャンセル]) {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageRepeat #sysRepeatOrderDetail input[value=戻る],
#sysMypageRepeat #sysRepeatOrderDetail [value=定期購入申込をキャンセル],
#sysMypageRepeat #sysMain form:last-of-type input[value=戻る],
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysMain form:last-of-type input[value=戻る],
#sysMypageIndex:has(form[action*="skip/done"]) #sysMain form:last-of-type input[value=戻る],
#sysMypageRepeatCancelConfirm input[value=戻る] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageRepeat #sysRepeatOrderDetail table td a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) auto 0 0;
}

#sysMypageRepeat #sysMain form:first-of-type input[value=登録する],
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysMain form:first-of-type input[value=登録する] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysMain form:first-of-type input[value=登録する] .fa,
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysMain form:first-of-type input[value=登録する] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageRepeat #sysMain .sysRepeatOrderNextOrderAttachedItemRequest input[value=商品を追加する] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysMain .sysRepeatOrderNextOrderAttachedItemRequest input[value=商品を追加する] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageRepeat .sysRepeatOrderAttachedItemDialogClose {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: min(1.25rem, 5.3333333333vw);
}

#sysMypageIndex:has(form[action*="skip/done"]) #sysMain form:first-of-type input[value=スキップする],
#sysMypageRepeatCancelConfirm input[value=キャンセルする] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: min(2.5rem, 10.6666666667vw);
}
#sysMypageIndex:has(form[action*="skip/done"]) #sysMain form:first-of-type input[value=スキップする] .fa,
#sysMypageRepeatCancelConfirm input[value=キャンセルする] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.sysCallOrderHistoryDetail button {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
}

#sysMypageOrderHistoryDetail .sysOrderCancelButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageOrderHistoryDetail .sysBackButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

.sysMypageNav + form .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageEditMember .sysBackButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageEditConfirm .sysBackButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageEditSave .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageEditDelivery .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageEditDeliveryinput .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageEditSavedelivery .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageIndex .sysItemReviewLink a,
#sysMypageOrderHistory .sysItemReviewLink a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
}

#sysMypageIndex .sysItemReviewLink span,
#sysMypageOrderHistory .sysItemReviewArea > span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  opacity: 0.5;
  margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
}

#sysMypageReview .sysMyReviewList + form .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageWithdrawalConfirm form:first-of-type .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: min(2.5rem, 10.6666666667vw);
}

#sysMypageEditMember .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysMypageEditMember .sysNextSubmit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageEditConfirm .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysMypageEditConfirm .sysNextSubmit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageEditDelivery .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysMypageEditDelivery .sysNextSubmit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageEditDeliveryinput .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysMypageEditDeliveryinput .sysNextSubmit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.sysMypage #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
.sysMypage #sysWrap #sysMain .sysMypageMajorHeadLine {
  display: none;
}
.sysMypage #sysWrap #sysMain .sysMypageMinorHeadLine {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysMypage #sysWrap #sysMain .sysMypageNav {
  display: flex;
  flex-wrap: wrap;
  gap: 0 min(0.625rem, 2.6666666667vw);
  margin-top: min(3.75rem, 16vw);
}
.sysMypage #sysWrap #sysMain .sysMypageNav form {
  width: calc(50% - min(0.625rem, 2.6666666667vw) / 2);
}
.sysMypage #sysWrap #sysMain .sysMypageNav + form {
  margin-top: min(1.25rem, 5.3333333333vw);
}
.sysMypage #sysWrap #sysMain .sysOrderHistory > div {
  font-size: min(0.875rem, 3.7333333333vw);
  text-align: right;
  margin-bottom: min(0.9375rem, 4vw);
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList {
  font-size: min(1rem, 4.2666666667vw);
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList:has(.sysOrderHeader) .sysOrders {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin: 0 0 min(0.9375rem, 4vw);
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList:not(:has(.sysOrderHeader)) .sysOrder {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin: 0 0 min(0.9375rem, 4vw);
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList .sysDatetime {
  float: none;
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList .sysTotalPrice {
  text-align: left;
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList .sysShopOrderNo {
  display: block;
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList .sysItemName {
  font-weight: 700;
  margin-top: min(1.25rem, 5.3333333333vw);
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList .sysItemName a {
  text-decoration: underline;
}
.sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList form {
  margin-top: min(0.625rem, 2.6666666667vw);
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderNumberArea {
  font-size: min(1rem, 4.2666666667vw);
  border: none;
  padding: 0;
  margin: 0;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderDetailArea {
  margin: 0 0 min(0.9375rem, 4vw);
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderDetailArea .sysOrderDatatimeGroup {
  font-size: min(1rem, 4.2666666667vw);
  border: none;
  margin: 0;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderHistoryDetailHeader {
  font-size: min(1rem, 4.2666666667vw);
  margin: min(1.5625rem, 6.6666666667vw) 0 min(0.9375rem, 4vw);
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery {
  border: none;
  padding: 0;
  margin: 0;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysDeliveryAddressHeader {
  margin-top: 0;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem {
  border: none;
  padding: 0;
  margin: 0;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemGroup {
  display: flex;
  gap: min(1.25rem, 5.3333333333vw);
  border: none;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemGroup .sysItemImageGroup {
  flex: auto;
  width: min(7.5rem, 32vw);
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemGroup .sysItemSummaryGroup {
  width: calc(100% - min(8.75rem, 37.3333333333vw));
  padding: 0;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemReviewArea {
  padding: min(0.625rem, 2.6666666667vw) 0 0;
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysCartOption_RemarkArea {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) 0 min(3.75rem, 16vw);
}
.sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysCartOption_RemarkArea .sysCartOption_RemarkHeader {
  border: none;
  margin: 0;
}

#sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword h3 {
  font-size: min(1rem, 4.2666666667vw);
}
#sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword h4 {
  font-size: min(0.875rem, 3.7333333333vw);
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword .sysMemberPasswordDescription {
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword .sysMemberPasswordDescription small {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
}

#sysMypageEditConfirm #sysWrap #sysMain > div {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysMypageEditConfirm #sysWrap #sysMain .sysForm .sysFormItem {
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.5rem, 2.1333333333vw);
}

#sysMypageEditSave #sysWrap #sysMain > p,
#sysMypageEditSavedelivery #sysWrap #sysMain > p {
  text-align: center;
  margin-bottom: min(2.5rem, 10.6666666667vw);
}

#sysMypageEditDelivery #sysWrap #sysMain .sysSelectAddress {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysMypageEditDelivery #sysWrap #sysMain .sysSelectAddress button {
  color: #333333;
  border: 1px solid #333333;
  border-radius: min(0.3125rem, 1.3333333333vw);
  padding: min(1.25rem, 5.3333333333vw);
}
#sysMypageEditDelivery #sysWrap #sysMain .sysSelectAddress:last-of-type {
  margin-bottom: min(1.875rem, 8vw);
}
#sysMypageEditDelivery #sysWrap #sysMain > form > p {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}

#sysMypagePoint #sysAll #sysMain .sysMyPoint {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}

#sysMypageReview #sysAll #sysMain .sysCoupon {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysMypageReview #sysAll #sysMain .sysCoupon .sysCouponDiscount {
  border-bottom: 1px solid #707070;
  padding-bottom: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}

#sysMypageAshiato #sysAll #sysMain .sysItemListDisp {
  margin-block: min(1.875rem, 8vw) min(0.9375rem, 4vw);
}
#sysMypageAshiato #sysAll #sysMain .sysItemListDisp .sysItemListViewType {
  display: flex;
  justify-content: flex-end;
  gap: min(1.25rem, 5.3333333333vw);
}
#sysMypageAshiato #sysAll #sysMain .sysItemListDisp .sysItemListViewType label {
  font-size: min(0.875rem, 3.7333333333vw);
  margin: 0;
}
#sysMypageAshiato #sysAll #sysMain .sysItemList {
  margin-bottom: min(1.875rem, 8vw);
}

#sysMypageReview #sysAll #sysMain .sysItemListDisp {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: min(0.875rem, 3.7333333333vw);
  margin-block: min(1.875rem, 8vw) min(0.9375rem, 4vw);
}
#sysMypageReview #sysAll #sysMain .sysItemListDisp .sysItemListViewType {
  display: flex;
  align-items: center;
  gap: min(1.25rem, 5.3333333333vw);
  width: -moz-fit-content;
  width: fit-content;
}
#sysMypageReview #sysAll #sysMain .sysItemListDisp .sysItemListViewType label {
  display: flex;
  align-items: center;
  font-size: min(0.875rem, 3.7333333333vw) !important;
  line-height: 1.7;
  margin: 0 !important;
}
#sysMypageReview #sysAll #sysMain .sysItemList {
  margin-bottom: min(1.875rem, 8vw);
}
#sysMypageReview #sysAll #sysMain .sysItemList li > div:last-of-type {
  width: 100%;
}

#sysMypageRestockRequest #sysAll #sysMain .sysItemListDisp {
  margin-block: min(1.875rem, 8vw) min(0.9375rem, 4vw);
}
#sysMypageRestockRequest #sysAll #sysMain .sysItemListDisp .sysItemListViewType {
  display: flex;
  justify-content: flex-end;
  gap: min(1.25rem, 5.3333333333vw);
}
#sysMypageRestockRequest #sysAll #sysMain .sysItemListDisp .sysItemListViewType label {
  font-size: min(0.875rem, 3.7333333333vw);
  margin: 0;
}
#sysMypageRestockRequest #sysAll #sysMain .sysItemList {
  margin-bottom: min(1.875rem, 8vw);
}
#sysMypageRestockRequest #sysAll #sysMain .sysItemList li > div:last-of-type {
  width: 100%;
}

#sysMypageAshiato .sysItemList ul.sysThumbnail,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail,
#sysMypageRestockRequest .sysItemList ul.sysThumbnail {
  display: flex;
  flex-wrap: wrap;
  gap: min(2.5rem, 10.6666666667vw) min(1.625rem, 6.9333333333vw);
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li,
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li {
  width: calc(25% - min(4.875rem, 20.8vw) / 4);
  text-align: left;
  position: relative;
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li .sysThumbnailImage,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li .sysThumbnailImage,
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li .sysThumbnailImage {
  width: 100%;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li .sysThumbnailImage a,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li .sysThumbnailImage a,
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li .sysThumbnailImage a {
  display: block;
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li .sysThumbnailImage a img,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li .sysThumbnailImage a img,
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li .sysThumbnailImage a img {
  display: block;
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li div,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li div,
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li div {
  font-size: min(1rem, 4.2666666667vw);
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li form input[type=submit],
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li form input[type=submit],
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li form input[type=submit] {
  width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  border-radius: 100px;
  background-color: #333333;
  padding: min(0.625rem, 2.6666666667vw) min(0.625rem, 2.6666666667vw) min(0.5625rem, 2.4vw);
  margin-top: min(0.8125rem, 3.4666666667vw);
  position: relative;
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li form input[type=submit][value=お気に入りから削除する],
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li form input[type=submit][value=お気に入りから削除する],
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li form input[type=submit][value=お気に入りから削除する] {
  color: #333333;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  background-color: #ffffff;
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysMypageAshiato .sysItemList ul.sysThumbnail li form input[type=submit][value=再入荷リクエストを解除する],
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li form input[type=submit][value=再入荷リクエストを解除する],
#sysMypageRestockRequest .sysItemList ul.sysThumbnail li form input[type=submit][value=再入荷リクエストを解除する] {
  font-size: min(0.75rem, 3.2vw);
  color: #333333;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  background-color: #ffffff;
  margin-top: min(0.3125rem, 1.3333333333vw);
}
#sysMypageAshiato .sysItemList ul.sysList li,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li,
#sysMypageRestockRequest .sysItemList ul.sysList li {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 0 min(1.25rem, 5.3333333333vw);
  width: 100%;
  text-align: left;
  border-top: none;
  border-bottom: 1px solid #c2c2c2;
  padding-block: min(1.25rem, 5.3333333333vw);
  position: relative;
}
#sysMypageAshiato .sysItemList ul.sysList li:first-of-type,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li:first-of-type,
#sysMypageRestockRequest .sysItemList ul.sysList li:first-of-type {
  padding-top: 0;
}
#sysMypageAshiato .sysItemList ul.sysList li:last-of-type,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li:last-of-type,
#sysMypageRestockRequest .sysItemList ul.sysList li:last-of-type {
  border-bottom: 1px solid #c2c2c2;
}
#sysMypageAshiato .sysItemList ul.sysList li .sysThumbnailImage,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li .sysThumbnailImage,
#sysMypageRestockRequest .sysItemList ul.sysList li .sysThumbnailImage {
  width: min(8.125rem, 34.6666666667vw);
  margin: 0;
}
#sysMypageAshiato .sysItemList ul.sysList li .sysThumbnailImage a,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li .sysThumbnailImage a,
#sysMypageRestockRequest .sysItemList ul.sysList li .sysThumbnailImage a {
  display: block;
}
#sysMypageAshiato .sysItemList ul.sysList li .sysThumbnailImage a img,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li .sysThumbnailImage a img,
#sysMypageRestockRequest .sysItemList ul.sysList li .sysThumbnailImage a img {
  display: block;
}
#sysMypageAshiato .sysItemList ul.sysList li > div:not([class]),
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li > div:not([class]),
#sysMypageRestockRequest .sysItemList ul.sysList li > div:not([class]) {
  width: calc(100% - min(9.375rem, 40vw));
}
#sysMypageAshiato .sysItemList ul.sysList li form,
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form,
#sysMypageRestockRequest .sysItemList ul.sysList li form {
  width: 100%;
}
#sysMypageAshiato .sysItemList ul.sysList li form input[type=submit],
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form input[type=submit],
#sysMypageRestockRequest .sysItemList ul.sysList li form input[type=submit] {
  width: 100%;
  max-width: min(12.0625rem, 51.4666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  border-radius: 100px;
  background-color: #333333;
  padding: min(0.625rem, 2.6666666667vw) min(0.625rem, 2.6666666667vw) min(0.5625rem, 2.4vw);
  margin-top: min(0.9375rem, 4vw);
  position: relative;
}
#sysMypageAshiato .sysItemList ul.sysList li form input[type=submit][value=お気に入りから削除する],
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form input[type=submit][value=お気に入りから削除する],
#sysMypageRestockRequest .sysItemList ul.sysList li form input[type=submit][value=お気に入りから削除する] {
  color: #333333;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  background-color: #ffffff;
  margin-top: min(0.3125rem, 1.3333333333vw);
  margin-left: min(9.375rem, 40vw);
}
#sysMypageAshiato .sysItemList ul.sysList li form input[type=submit][value=再入荷リクエストを解除する],
#sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form input[type=submit][value=再入荷リクエストを解除する],
#sysMypageRestockRequest .sysItemList ul.sysList li form input[type=submit][value=再入荷リクエストを解除する] {
  width: -moz-fit-content;
  width: fit-content;
  max-width: 100%;
  color: #333333;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  background-color: #ffffff;
  margin-top: min(0.3125rem, 1.3333333333vw);
  margin-left: min(9.375rem, 40vw);
}

#sysMypageMessageCard #sysAll #sysMain .sysMemberSessionCartInfo td input {
  color: #333333;
}

#sysMypageReview #sysWrap #sysMain .sysMyReviewList {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageReview #sysWrap #sysMain .sysMyReviewList .sysItemName {
  font-weight: 700;
  padding-top: min(2.5rem, 10.6666666667vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysMypageReview #sysWrap #sysMain .sysMyReviewList .sysReview {
  border-bottom: 1px solid #707070;
  padding-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageReview #sysWrap #sysMain .sysMyReviewList .sysReview:last-of-type {
  border-bottom: none;
}

#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo {
  border: none;
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: 10px;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo tr:first-of-type th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo tr:first-of-type td {
  border-top: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo td {
  padding: min(0.9375rem, 4vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo th {
  border-bottom: 1px solid #707070;
  border-left: 1px solid #707070;
  background-color: #eeeeee;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo td {
  border-bottom: 1px solid #707070;
  border-right: 1px solid #707070;
}

#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail h2 {
  font-size: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext {
  margin-top: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder h4,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext h4 {
  font-size: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo {
  border: none;
  margin-top: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo tr:first-of-type th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo tr:first-of-type td,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo tr:first-of-type th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo tr:first-of-type td {
  border-top: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo td,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo td {
  padding: min(0.9375rem, 4vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo th {
  width: 25%;
  border-bottom: 1px solid #707070;
  border-left: 1px solid #707070;
  background-color: #eeeeee;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo td,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo td {
  border-bottom: 1px solid #707070;
  border-right: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem {
  border: 1px solid #707070;
  margin-top: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr:last-of-type td,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr:last-of-type td {
  border-bottom: none;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr td,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr td {
  padding: min(0.9375rem, 4vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr th:nth-of-type(3),
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr th:nth-of-type(3) {
  width: 10%;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr td,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr td {
  border-bottom: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr td:first-of-type,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr td:first-of-type {
  text-align: left;
}
#sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div,
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div,
#sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div,
#sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div {
  font-weight: 500;
}
#sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2),
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2),
#sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2),
#sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2) {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div:has(input, select),
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select),
#sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select),
#sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div:has(input, select) {
  font-weight: 400;
  margin-top: min(0.5rem, 2.1333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div:has(input, select) input[type=radio],
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select) input[type=radio],
#sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select) input[type=radio],
#sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div:has(input, select) input[type=radio] {
  margin-right: min(0.3125rem, 1.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div:has(input, select) select,
#sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select) select,
#sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select) select,
#sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div:has(input, select) select {
  margin-top: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}

#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderSummary {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest .sysRepeatOrderNextOrderAttachedItemRequestTitle {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList {
  border: 1px solid #707070;
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr:last-of-type td {
  border-bottom: none;
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th,
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr td {
  padding: min(0.9375rem, 4vw);
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th:first-of-type {
  width: 60%;
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th:nth-of-type(2), #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th:last-of-type {
  width: 20%;
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr td {
  text-align: left;
  border-bottom: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr td:last-of-type {
  font-weight: 700;
  text-align: center;
}
#sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr td:last-of-type .sysDeleteAttachedItem {
  width: min(1.875rem, 8vw);
  height: min(1.875rem, 8vw);
}
#sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysRepeatOrderAttachedItemListBlock .sysRepeatOrderAttachedItemList {
  display: flex;
  gap: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysRepeatOrderAttachedItemListBlock .sysRepeatOrderAttachedItemList .sysRepeatOrderAttachedItemListItem {
  width: calc(50% - min(1.25rem, 5.3333333333vw) / 2);
}
#sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysRepeatOrderAttachedItemListBlock .sysRepeatOrderAttachedItemList .sysRepeatOrderAttachedItemListItem .sysThumbnailImage {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysRepeatOrderAttachedItemListBlock .sysRepeatOrderAttachedItemList .sysRepeatOrderAttachedItemListItem input[type=button] {
  width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  border-radius: 100px;
  background-color: #333333;
  padding: min(0.625rem, 2.6666666667vw) min(0.625rem, 2.6666666667vw) min(0.5625rem, 2.4vw);
  margin-top: min(0.8125rem, 3.4666666667vw);
  position: relative;
}

#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory h2 {
  font-size: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder h4 {
  font-size: min(1.25rem, 5.3333333333vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo {
  border: none;
  margin-top: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo tr:first-of-type th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo tr:first-of-type td {
  border-top: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo td {
  padding: min(0.9375rem, 4vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo th {
  width: 25%;
  border-bottom: 1px solid #707070;
  border-left: 1px solid #707070;
  background-color: #eeeeee;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo td {
  border-bottom: 1px solid #707070;
  border-right: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem {
  border: 1px solid #707070;
  margin-top: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr:last-of-type td {
  border-bottom: none;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr th,
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr td {
  padding: min(0.9375rem, 4vw);
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr th:nth-of-type(3) {
  width: 10%;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr td {
  border-bottom: 1px solid #707070;
}
#sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr td:first-of-type {
  text-align: left;
}
#sysMypageRepeat .sysRepeatOrder {
  padding-bottom: 20px;
}
#sysMypageRepeat .sysRepeatOrder .sysRepeatOrderInfo {
    border-top: 2px solid #222 !important;
}
#sysMypageRepeat #sysRepeatOrderList input[value="詳細へ"] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 300px;
  min-height: min(2rem, 10vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
}
#sysMypageLogin input[value=ログイン] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysMypageLogin input[value=ログイン] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysMypageLogin input[value=ログイン] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysMypageLogin input[value=会員ID・パスワードを忘れた場合] {
  text-align: center;
  text-decoration: underline;
  width: 100%;
  margin-top: 20px !important;
}

#sysMypageReminder input[value=確認メールを受け取る] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMypageLogin #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysMypageLogin #sysWrap #sysMain .sysMypageMajorHeadLine,
#sysMypageLogin #sysWrap #sysMain .sysMypageMinorHeadLine {
  display: none;
}

#sysMypageLogout #sysAll #sysMain .sysMypageMajorHeadLine,
#sysMypageLogout #sysAll #sysMain .sysMypageMinorHeadLine {
  display: none;
}
#sysMypageLogout #sysAll #sysMain > p {
  text-align: center;
}

#sysMypageReminder #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysMypageReminder #sysWrap #sysMain .sysMypageMajorHeadLine {
  display: none;
}
#sysMypageReminder #sysWrap #sysMain .sysMypageMinorHeadLine {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  border-bottom: 1px solid #333333;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-top: min(2.5rem, 10.6666666667vw);
  margin-bottom: min(0.9375rem, 4vw);
}
#sysMypageReminder #sysWrap #sysMain .sysFormField {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMypageReminder #sysWrap #sysMain div {
  font-size: min(1rem, 4.2666666667vw);
}

/*! ========================================================
会員登録ページ設定
========================================================= */
button[name=searchAddress] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: 0 auto 0 0;
}

#sysMemberRegisterIndex #sysMain { margin-bottom: 60px !important;}
#sysMemberRegisterIndex #sysMain form:not(#form_main) .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMemberRegisterConfirm #sysMain form:not(#sysDone) .sysBackButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMemberRegisterIndex .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #d12e2e;
  border: min(0.125rem, 0.5333333333vw) solid #d12e2e;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMemberRegisterConfirm .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #d12e2e;
  border: min(0.125rem, 0.5333333333vw) solid #d12e2e;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysMemberRegisterIndex #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysMemberRegisterIndex #sysWrap #sysMain > h2 {
  display: none;
}
#sysMemberRegisterIndex #sysWrap #sysMain > div .sysMemberAgreementFormLabel {
  display: block;
  font-weight: 500;
  padding: 0;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysMemberRegisterIndex #sysWrap #sysMain > div .sysMemberAgreement {
  font-size: min(0.875rem, 3.7333333333vw);
  padding: min(1.25rem, 5.3333333333vw);
}
#sysMemberRegisterIndex #sysWrap #sysMain #form_main .sysForm > label {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
  margin-top: min(0.5rem, 2.1333333333vw);
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysMemberRegisterIndex #sysWrap #sysMain #form_main .sysForm > label::after {
  content: "必須";
  display: inline-block;
  font-size: min(0.6875rem, 2.9333333333vw);
  font-weight: 400;
  line-height: 1.5;
  color: #ffffff;
  border-radius: min(0.1875rem, 0.8vw);
  background-color: #d12e2e;
  padding: min(0.0625rem, 0.2666666667vw) min(0.5rem, 2.1333333333vw) min(0.125rem, 0.5333333333vw);
  margin-left: min(0.75rem, 3.2vw);
  position: relative;
  bottom: min(0.0625rem, 0.2666666667vw);
}
#sysMemberRegisterIndex #sysWrap #sysMain #form_main .sysForm > label + .sysRequired {
  display: none;
}
#sysMemberRegisterIndex #sysWrap #sysMain #form_main .sysForm .sysFormCaution {
  font-size: min(0.875rem, 3.7333333333vw);
}

#sysMemberRegisterConfirm #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysMemberRegisterConfirm #sysWrap #sysMain > h2 {
  display: none;
}
#sysMemberRegisterConfirm #sysWrap #sysMain > div {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysMemberRegisterConfirm #sysWrap #sysMain #sysDone .sysForm .sysFormItem {
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.5rem, 2.1333333333vw);
}

#sysMemberRegisterRegister #sysWrap #sysMain > h2 {
  display: none;
}
#sysMemberRegisterRegister #sysWrap #sysMain > p {
  text-align: center;
  margin-bottom: min(12.5rem, 53.3333333333vw);
}

/*! ========================================================
OPC設定
========================================================= */
.opcBillingAddress_completeButton_edit,
.opcItemCommonOption_completeButton_edit,
.opcClient_completeButton_edit,
.opcDeliveryAddress_completeButton_edit,
.opcDeliveryAddressItem_completeButton_edit,
.opcDeliveryMethod_completeButton_edit,
.opcDeliveryMethodList_edit,
.opcPaymentMethod_completeButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.opcBillingAddress_completeButton_edit .fa,
.opcItemCommonOption_completeButton_edit .fa,
.opcClient_completeButton_edit .fa,
.opcDeliveryAddress_completeButton_edit .fa,
.opcDeliveryAddressItem_completeButton_edit .fa,
.opcDeliveryMethod_completeButton_edit .fa,
.opcDeliveryMethodList_edit .fa,
.opcPaymentMethod_completeButton_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcItemCommonOption_sessionCartSaveButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.opcItemCommonOption_sessionCartSaveButton_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcSelectDeliveries_deliveryToSingle_edit,
.opcSelectDeliveries_deliveryToMultiple_edit,
.opcSelectDeliveries_deliveryToSocialGift_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.opcSelectDeliveries_deliveryToSingle_edit .fa,
.opcSelectDeliveries_deliveryToMultiple_edit .fa,
.opcSelectDeliveries_deliveryToSocialGift_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcDeliveryAddress_synchronizeBillingAddressButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.opcDeliveryAddress_synchronizeBillingAddressButton_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcDeliveryAddress_openDialogButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

.opcCompletedDeliveryAddressList_addDeliveryAddress_edit,
.opcCompletedDeliveryAddressList_goDeliveryMethodArea_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.opcCompletedDeliveryAddressList_addDeliveryAddress_edit .fa,
.opcCompletedDeliveryAddressList_goDeliveryMethodArea_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcCompletedDeliveryAddressList_saveSessionCart_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  max-width: min(12.5rem, 53.3333333333vw);
  margin-top: 0;
  margin-right: 0;
}
.opcCompletedDeliveryAddressList_saveSessionCart_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcResumeOrContinueModal_resumeMemberSessionCart,
.opcResumeOrContinueModal_continueSessionCart {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.opcResumeOrContinueModal_resumeMemberSessionCart .fa,
.opcResumeOrContinueModal_continueSessionCart .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcPointAndCouponDialog_applyButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.opcPointAndCouponDialog_applyButton_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcMember_registerButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  display: inline-block;
  max-width: min(9.375rem, 40vw);
  margin-right: 0;
}
.opcMember_registerButton_edit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.opcOrderSummary_usePointAndCoupon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
}

.opcBillingAddress_zipCodeSearchButton_edit,
.opcClient_zipCodeSearchButton_edit,
.opcDeliveryAddress_zipCodeSearchButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
}

#sysOpc .opcBillingAddress_backButton_edit,
#sysOpc .opcItemCommonOption_backButton_edit,
#sysOpc .opcSelectDeliveries_backButton_edit,
#sysOpc .opcDeliveryAddress_backButton_edit,
#sysOpc .opcDeliveryAddressItem_backButton_edit,
#sysOpc .opcCompletedDeliveryAddressList_backButton_edit,
#sysOpc .opcDeliveryMethod_backButton_edit,
#sysOpc .opcDeliveryMethodList_backButton_edit,
#sysOpc .opcPaymentMethod_backButton_edit,
#sysOpc .opcOrderBackToBasket_backToBasket {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

.opcBillingAddress_editButton,
.opcPaymentMethod_editButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
}

.opcClient_editButton,
.opcDeliveryAddress_editButton,
.opcDeliveryMethod_editButton,
.opcDeliveryAddressItemTitle_editButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: 0 0 0 auto;
}

.opcItemCommonOption_messageCardPreviewButton,
.opcItem_messageCardPreviewButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  margin-top: min(1.25rem, 5.3333333333vw);
}

.opcCompletedDeliveryAddressList_changeItems_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin-top: 0;
  margin-right: 0;
}

.opcDeliveryAddressTitle_deleteButton,
.opcDeliveryAddressList_addButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: 0 0 0 auto;
}

.opcCouponCode_useButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
}

.opcPointAndCouponDialog_cancelButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

.opcMember_cancelButton_edit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  display: inline-block;
  max-width: min(9.375rem, 40vw);
  margin-right: 0;
}

.opcDeliveryAddressEditDialog_applyBillingAddressButton,
.opcDeliveryAddressEditDialog_customerDeliveryAddressButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
  max-width: 100%;
  height: auto;
  white-space: wrap;
}

.opcConfirm_requestOrder {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #d12e2e;
  border: min(0.125rem, 0.5333333333vw) solid #d12e2e;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

.sysOpcBody #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc div[style="margin-bottom:100px;"] {
  display: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCommonEditModeBlock {
  background-color: transparent;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCommonEditModeBlock,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddress,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcClient,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressSummary,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethod,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarks_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSubstituteOrderMemo_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPoint_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemPoint_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCouponCode_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCoupon_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMember_memberAgreementDescription_edit {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin-bottom: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemList,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSelectDeliveries {
  border: none;
  padding: 0;
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddressTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcClientTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarksTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSubstituteOrderMemoTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPointTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCouponCodeTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCouponTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMemberTitle,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressHeaderGroup .opcDeliveryAddressHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGiftLetterTitle {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  border-bottom: 1px solid #333333;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-top: min(3.125rem, 13.3333333333vw);
  margin-bottom: min(0.9375rem, 4vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeader {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcDeliveryAddressHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcDeliveryMethodHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcDeliveryAddressItemHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcSocialGiftLetter_letterImageTitleLabel_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcDeliveryAddressHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcDeliveryMethodHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcDeliveryAddressItemHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcSocialGiftLetter_letterImageTitleLabel_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcDeliveryAddressHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcDeliveryMethodHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcDeliveryAddressItemHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcSocialGiftLetter_letterImageTitleLabel_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryAddressHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryMethodHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryAddressItemHeader,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcSocialGiftLetter_letterImageTitleLabel_edit {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCommonEditLabel {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 500;
  line-height: inherit;
  border-left: none;
  padding-left: 0;
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc span:has(+ .opcCommonRequireLabel) {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
}
.sysOpcBody #sysWrap #sysMain #sysOpc span:has(+ .opcCommonRequireLabel)::after {
  content: "必須";
  display: inline-block;
  font-size: min(0.6875rem, 2.9333333333vw);
  line-height: 1.5;
  color: #ffffff;
  border-radius: min(0.1875rem, 0.8vw);
  background-color: #d12e2e;
  padding: min(0.0625rem, 0.2666666667vw) min(0.5rem, 2.1333333333vw) min(0.125rem, 0.5333333333vw);
  margin-left: min(0.75rem, 3.2vw);
  position: relative;
  bottom: min(0.0625rem, 0.2666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc span:has(+ .opcCommonRequireLabel) + .opcCommonRequireLabel {
  display: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalPricesAndLabelGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalPricesGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalAmount,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalPoint {
  font-size: min(1rem, 4.2666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCommonButtonGroupEdit {
  padding: 0;
  margin-top: min(3.75rem, 16vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodGroup {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_purposeAnditemCommonOptionGroup_edit .opcItem_purposeAndLabelGroup_edit {
  margin-top: min(3.75rem, 16vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcRequestOrderArea:has(form[name=order_form_top]) {
  margin-top: min(2.5rem, 10.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcRequestOrderArea:has(form[name=order_form_bottom]) {
  margin-top: min(3.75rem, 16vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCompletedDeliveryAddressListArea {
  width: 100%;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCompletedDeliveryAddressListArea .opcCompletedDeliveryAddressList_inputAddDeliveryAddressLabel,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcCompletedDeliveryAddressListArea .opcCompletedDeliveryAddressList_inputSelectDeliveryMethodLabel {
  text-align: center;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionSelectsGroup .opcItem_itemCommonOptionSelectAndLabelGroup {
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionSelectsGroup .opcItem_itemCommonOptionSelectAndLabelGroup .opcItem_itemCommonOptionImageGroup {
  max-width: min(12.5rem, 53.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_messageCardDescriptionGroup_edit {
  margin: min(1.25rem, 5.3333333333vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_messageCardDescriptionGroup_edit a {
  text-decoration: underline;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_isNoshiCorporation_edit {
  margin: 0 0 0 min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSelectDeliveries_edit {
  padding-top: min(1.875rem, 8vw);
}

.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_isWithCarrierBagAndLabelGroup_edit label,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_noshiInsideOutsideTypeAndLabelGroup_edit label,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_messageCardAndLabelGroup_edit label,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddress_genderAndLabelGroup_edit label {
  display: inline-block !important;
  width: -moz-fit-content;
  width: fit-content;
}

#sysAll #sysMain .opcItem_noshiGroup_edit label:has(input[type=radio]){
 display: inline;
}

.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_noshiRibbonTypeAndLabelGroup_edit label span,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_isWithCarrierBagAndLabelGroup_edit label span,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_noshiInsideOutsideTypeAndLabelGroup_edit label span,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_messageCardAndLabelGroup_edit label span,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddress_genderAndLabelGroup_edit label span {
  display: inline-block !important;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressViewPackage_summaryGroup {
  width: 100%;
  text-align: left;
  border: none;
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList {
  border: none;
  padding: 0;
  margin-top: min(3.125rem, 13.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList .opcPaymentMethod_edit {
  border: 1px solid #c2c2c2;
  padding: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
  position: relative;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList .opcPaymentMethod_edit:has(.opcPaymentMethod_paymentMethod_edit:checked) {
  border: 1px solid #91b4f5;
  background-color: #ebf1fc;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList .opcPaymentMethod_edit label {
  font-weight: 400;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList .opcPaymentMethod_edit label::after {
  content: "";
  display: block;
  width: 100%;
  height: 9.5vh;
  position: absolute;
  top: 0;
  left: 0;
  cursor: pointer;
}
.sysOpcBody #sysAll #sysMain .opcPaymentMethod_contentGroup_edit select {
  width:auto;;
  display:inline;
}
.sysOpcBody #sysAll #sysMain .opcPaymentMethod_contentGroup_edit .opcPaymentMethod_sbpsSecurityCode_edit,.sysOpcBody #sysAll #sysMain .opcPaymentMethod_contentGroup_edit .opcPaymentMethod_webCollectSecurityCode_edit{
  width:90px;
}

.sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList .opcPaymentMethod_edit .opcPaymentMethod_paymentMethodDetailGroup_edit {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryAddressHeader {
  display: block;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit {
  border: none;
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit:empty {
  border: none;
  padding: 0;
  margin-bottom: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit .opcDeliveryMethod_normalShippingDetailAndLabelGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit .opcDeliveryMethod_receiveAtStoreDetailAndLabelGroup_edit {
  border: none;
  padding-bottom: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_totalPricesAndLabelGroup {
  border-bottom: 1px solid #c2c2c2;
  padding: 0 0 min(0.625rem, 2.6666666667vw) 0;
  margin: 0 0 min(0.625rem, 2.6666666667vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_priceBreakDownGroup {
  padding: 0 0 0 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_priceBreakDownGroup .opcOrderSummary_feeAndLabelGroup {
  border-bottom: 1px solid #c2c2c2;
  padding: 0 0 min(0.625rem, 2.6666666667vw) 0;
  margin: 0 0 min(0.625rem, 2.6666666667vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_priceBreakDownGroup .opcOrderSummary_usePointPriceAndLabelGroup {
  border-bottom: 1px solid #c2c2c2;
  padding: 0 0 min(0.625rem, 2.6666666667vw) 0;
  margin: 0 0 min(0.625rem, 2.6666666667vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_priceBreakDownGroup .opcOrderSummary_usePointPriceAndLabelGroup:empty {
  border-bottom: none;
  padding: 0;
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddressArea .opcBillingAddress_mailaddressLabel_reference {
  margin: min(0.625rem, 2.6666666667vw) 0 min(1.875rem, 8vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddressArea .opcBillingAddress > div .opcCommonReferenceLabel {
  display: inline-block;
  width: -moz-fit-content;
  width: fit-content;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddressArea .opcBillingAddress > div .opcBillingAddress_addressGroup {
  width: auto;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_purposeAndLabelGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_purposeAndLabelGroup_edit {
  margin-bottom: min(3.125rem, 13.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_purposeAndLabelGroup_edit .opcItem_purposeLabelGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_purposeAndLabelGroup_edit .opcItem_purposeLabelGroup_edit {
  border-bottom: 1px solid #c2c2c2;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(0.9375rem, 4vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_purposeAndLabelGroup_edit select,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_purposeAndLabelGroup_edit select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit {
  margin-bottom: min(1.875rem, 8vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit .opcItem_itemCommonOptionTitleLabel_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit .opcItem_itemCommonOptionTitleLabel_edit {
  border-bottom: 1px solid #c2c2c2;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(0.9375rem, 4vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit .opcItem_itemCommonOptionUseOptionNameGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit .opcItem_itemCommonOptionUseOptionNameGroup_edit {
  display: flex;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit {
  margin-bottom: min(3.125rem, 13.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit:last-of-type,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit:last-of-type {
  margin-bottom: min(3.75rem, 16vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionSelectLabel_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionSelectLabel_edit {
  font-weight: 500;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit {
  display: flex;
  flex-wrap: wrap;
  gap: min(2.5rem, 10.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit {
  width: calc(33.3333333333% - min(5rem, 21.3333333333vw) / 3);
  cursor: pointer;
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOption_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOption_edit {
  display: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit {
  display: block;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionOptionLabel_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionOptionLabel_edit {
  display: block;
  width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
  text-align: center;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionImageGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionImageGroup_edit {
  position: relative;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionImageGroup_edit::after,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionImageGroup_edit::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border: 1px solid #c2c2c2;
  position: absolute;
  top: 0;
  left: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit:has(input[type=radio]:checked) .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionImageGroup_edit::after,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit:has(input[type=radio]:checked) .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionImageGroup_edit::after {
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(0.125rem, 0.5333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailAndLabelGroup_edit,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailAndLabelGroup_edit {
  margin-top: min(1.875rem, 8vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit {
  margin-top: min(3.75rem, 16vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcClientArea .opcClient .opcClient_normalClientGroup > div .opcCommonReferenceLabel {
  display: inline-block;
  width: -moz-fit-content;
  width: fit-content;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcClientArea .opcClient .opcClient_normalClientGroup > div .opcClient_addressGroup {
  width: auto;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryAddressHeader {
  display: block;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryAddressSummary {
  margin-top: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_deliveryAddressItemGroup_edit {
  padding: 0;
  border-top: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_numAndLabelGroup_edit {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_numAndLabelGroup_edit .opcItem_numLabel_edit {
  width: 100%;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_numAndLabelGroup_edit .opcItem_num_edit {
  height: min(3.125rem, 13.3333333333vw);
  width: -moz-fit-content;
  width: fit-content;
  margin-right: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_numAndLabelGroup_edit input[type=button] {
  display: block;
  width: min(2.5rem, 10.6666666667vw);
  height: min(2.5rem, 10.6666666667vw);
  font-size: 0;
  background: none;
  background-color: #eeeeee;
  border: none;
  border-radius: 50%;
  position: relative;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_numAndLabelGroup_edit input[type=button].opcItem_increaseNumButton_edit {
  background-image: url(../img/layout/common/icon_increase.png);
  background-size: min(0.75rem, 3.2vw) min(0.75rem, 3.2vw);
  background-position: center center;
  background-repeat: no-repeat;
  margin-right: min(0.3125rem, 1.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_numAndLabelGroup_edit input[type=button].opcItem_decreaseNumButton_edit {
  background-image: url(../img/layout/common/icon_decrease.png);
  background-size: min(0.75rem, 3.2vw) min(0.125rem, 0.5333333333vw);
  background-position: center center;
  background-repeat: no-repeat;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem {
  border-bottom: 1px solid #707070;
  padding: 0 0 min(1.25rem, 5.3333333333vw) 0;
  margin: 0 0 min(1.25rem, 5.3333333333vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem:last-of-type {
  border-bottom: none;
  padding: 0;
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup {
  gap: 0 min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_itemImageGroup {
  width: min(7.5rem, 32vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary {
  width: calc(100% - min(8.75rem, 37.3333333333vw));
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_itemNameGroup {
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_itemNumAndPricesAndLabelGroup .opcItem_itemSubTotalPricesAndLabelGroup {
  font-weight: 700;
  border-bottom: 1px solid #c2c2c2;
  padding: 0 0 min(0.3125rem, 1.3333333333vw) 0;
  margin: 0 0 min(0.3125rem, 1.3333333333vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_itemRetailPricesAndLabelGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_subTotalNumAndLabelGroup {
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_deliveryAddressItemGroup_edit {
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_deliveryAddressItemGroup_edit .opcItem_messageCardDescriptionGroup_edit {
  margin: min(0.625rem, 2.6666666667vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_itemAndLabelGroup .opcItem_deliveryAddressItemGroup_edit .opcItem_messageCardDescriptionGroup_edit a {
  text-decoration: underline;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_deliveryAddressItemGroup {
  border: none;
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcItemDataBind .opcItem .opcItem_deliveryAddressItemGroup .opcItem_itemOptionGroup .opcItem_itemOptionAndLabelGroup span {
  display: inline-block;
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcCompletedDeliveryAddressList_container {
  border-radius: 0;
  background-color: #f8f8f8;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcCompletedDeliveryAddressList_container .opcCompletedDeliveryAddressList_upsideOfListContainer {
  align-items: center;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcCompletedDeliveryAddressList_container .opcCompletedDeliveryAddressList_upsideOfListContainer .opcCompletedDeliveryAddressList_displayCompletedDeliveryAddressListLabel {
  padding: 0;
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcCompletedDeliveryAddressList_container .opcCompletedDeliveryAddressList .opcDeliveryAddressContents {
  border: none;
  border-radius: 0;
  padding: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcCompletedDeliveryAddressList_container .opcCompletedDeliveryAddressList .opcDeliveryAddressContents .opcCompletedDeliveryAddressList_requiedConfirmMessage {
  color: #d12e2e;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit {
  margin-top: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit li {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit li > div {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
  border-bottom: 1px solid #707070;
  padding-bottom: min(1.25rem, 5.3333333333vw);
  padding-left: 0;
  margin-top: min(0.625rem, 2.6666666667vw);
  margin-left: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit li > div > div {
  display: flex;
  align-items: center;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit li > div > div span {
  width: -moz-fit-content;
  width: fit-content;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit li > div > div select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcCommonReferenceLabel {
  display: inline-block;
  width: -moz-fit-content;
  width: fit-content;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit {
  margin-top: min(3.125rem, 13.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit {
  background-color: #eeeeee;
  padding: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit:last-of-type {
  margin-bottom: min(3.75rem, 16vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryAddressHeader {
  margin-top: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryAddressSummary {
  background-color: #ffffff;
  margin-bottom: min(1.875rem, 8vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit {
  border: none;
  padding: 0;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit:last-of-type {
  margin-bottom: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit > div {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit > div > div {
  display: flex;
  align-items: center;
  gap: 0 min(0.3125rem, 1.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit > div > div select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit + .opcDeliveryMethod_buttonGroup_edit {
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarksArea {
  margin-bottom: min(3.75rem, 16vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarksArea .opcRemarksDataBind .opcRemarks_remarkLabel_edit {
  margin-top: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarksArea .opcRemarksDataBind .opcRemarks_remarkDescription_edit {
  margin-left: 0;
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressHeaderGroup {
  margin-bottom: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressHeaderGroup .opcDeliveryAddressHeader {
  display: block;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem {
  border-bottom: 1px solid #707070;
  padding: 0 0 min(1.25rem, 5.3333333333vw) 0;
  margin: 0 0 min(1.25rem, 5.3333333333vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup {
  gap: 0 min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_itemImageGroup {
  width: min(7.5rem, 32vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary {
  width: calc(100% - min(8.75rem, 37.3333333333vw));
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_itemNameGroup {
  font-weight: 700;
  line-height: 1.5;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_itemNumAndPricesAndLabelGroup .opcItem_itemSubTotalPricesAndLabelGroup {
  font-weight: 700;
  border-bottom: 1px solid #c2c2c2;
  padding: 0 0 min(0.3125rem, 1.3333333333vw) 0;
  margin: 0 0 min(0.3125rem, 1.3333333333vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_itemRetailPricesAndLabelGroup,
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_itemSummary .opcItem_subTotalNumAndLabelGroup {
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_deliveryAddressItemGroup_edit {
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_deliveryAddressItemGroup_edit .opcItem_messageCardDescriptionGroup_edit {
  margin: min(0.625rem, 2.6666666667vw) 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressItemArea .opcItem .opcItem_itemAndLabelGroup .opcItem_deliveryAddressItemGroup_edit .opcItem_messageCardDescriptionGroup_edit a {
  text-decoration: underline;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit {
  border: none;
  padding: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_checkedValueTitleLabel_edit {
  display: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_freeAreaGroup_edit {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_checkedValueLabelGroup_edit {
  display: flex;
  margin-bottom: min(1.875rem, 8vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit {
  margin-bottom: min(1.875rem, 8vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit {
  display: flex;
  flex-wrap: wrap;
  gap: min(1.5625rem, 6.6666666667vw) min(0.9375rem, 4vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit {
  display: flex;
  flex-direction: column-reverse;
  flex-shrink: 0;
  width: calc(20% - min(3.75rem, 16vw) / 5);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit .opcSocialGiftLetter_letterImageLabelGroup_edit .opcSocialGiftLetter_letterImageIdAndUrlLabelGroup_edit {
  margin: 0;
  cursor: pointer;
  position: relative;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit .opcSocialGiftLetter_letterImageLabelGroup_edit .opcSocialGiftLetter_letterImageIdAndUrlLabelGroup_edit::after {
  content: "";
  display: block;
  width: 100%;
  height: 100%;
  border: 1px solid #c2c2c2;
  position: absolute;
  top: 0;
  left: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit .opcSocialGiftLetter_letterImageLabelGroup_edit .opcSocialGiftLetter_letterImageIdAndUrlLabelGroup_edit .opcSocialGiftLetter_letterImageId_edit {
  display: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit .opcSocialGiftLetter_letterImageLabelGroup_edit .opcSocialGiftLetter_letterImageIdAndUrlLabelGroup_edit .opcSocialGiftLetter_letterImageIdTitle_edit {
  display: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit .opcSocialGiftLetter_letterImageLabelGroup_edit .opcSocialGiftLetter_letterImageIdAndUrlLabelGroup_edit:has(input:checked)::after {
  border: 1px solid #333333;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit .opcSocialGiftLetter_imageTitleGroup_edit .opcSocialGiftLetter_imageTitle_edit {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  text-align: center;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_messageTitleAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit {
  border: none;
  background-color: #eeeeee;
  padding: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_messageTitleAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewGroup_edit {
  max-width: min(31.25rem, 133.3333333333vw);
  margin-inline: auto;
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_messageTitleAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewGroup_edit .opcSocialGiftLetter_letterImagePreview_edit {
  width: 100%;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup {
  border: none;
  padding: 0;
  margin: 0;
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup .opcSocialGiftLetter_detailGroup .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit {
  display: flex;
  gap: min(1.25rem, 5.3333333333vw);
  border: none;
  padding: 0;
  margin-top: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup .opcSocialGiftLetter_detailGroup .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewGroup {
  width: min(7.5rem, 32vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup .opcSocialGiftLetter_detailGroup .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_messageGroup {
  width: calc(100% - min(8.75rem, 37.3333333333vw));
}
.sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup .opcSocialGiftLetter_detailGroup .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_messageGroup .opcSocialGiftLetter_message {
  white-space: normal;
}
.sysOpcBody #sysWrap #sysMain #sysOpc #openPointAndCouponEditDialog .opcItemPoint_itemListGroup_edit .opcItemPoint_itemGroup_edit {
  display: flex;
  flex-wrap: wrap;
  padding: min(0.625rem, 2.6666666667vw);
}
.sysOpcBody #sysWrap #sysMain #sysOpc #openPointAndCouponEditDialog .opcItemPoint_itemListGroup_edit .opcItemPoint_itemGroup_edit .opcItemPoint_itemNameGroup_edit {
  float: none;
  border-right: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc #openPointAndCouponEditDialog .opcItemPoint_itemListGroup_edit .opcItemPoint_itemGroup_edit .opcItemPoint_itemQuantityGroup_edit {
  float: none;
}
.sysOpcBody #sysWrap #sysMain #sysOpc #openPointAndCouponEditDialog .opcItemPoint_itemListGroup_edit .opcItemPoint_itemGroup_edit .opcItemPoint_clearfix_edit {
  display: none;
}

.modaal-wrapper .opcPointAndCouponDialog {
  min-width: min(25rem, 106.6666666667vw);
}
.modaal-wrapper .opcPointTitle,
.modaal-wrapper .opcCouponCodeTitle,
.modaal-wrapper .opcCouponTitle {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.modaal-wrapper .opcDeliveryAddressEditDialog_directChangeLabel,
.modaal-wrapper .opcDeliveryAddressEditDialog_customerDeliveryAddressLabel,
.modaal-wrapper .opcPoint_usablePointLabel_edit,
.modaal-wrapper .opcPoint_usePointLabel_edit,
.modaal-wrapper .opcCouponCode_couponCodeLabel_edit,
.modaal-wrapper .opcCouponCode_useCouponCodeListLabel_edit,
.modaal-wrapper .opcPoint_itemListLabel_edit {
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 700;
  line-height: inherit;
  border-left: none;
  padding-left: 0;
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.modaal-wrapper .opcPoint_usePoint_edit,
.modaal-wrapper .opcCouponCode_couponCode_edit {
  margin: 0;
}
.modaal-wrapper .opcPoint_edit,
.modaal-wrapper .opcItemPoint_edit,
.modaal-wrapper .opcCouponCode_edit,
.modaal-wrapper .opcCoupon_edit {
  padding: min(0.625rem, 2.6666666667vw);
}
.modaal-wrapper .opcPoint_usablePoint_edit {
  margin-left: 0;
}
.modaal-wrapper .opcItemPoint_itemListGroup_edit {
  margin-left: 0;
}
.modaal-wrapper .opcItemPoint_itemNameGroup_edit {
  border: none;
}
.modaal-wrapper .opcItemPoint_itemGroup_edit {
  padding: min(0.625rem, 2.6666666667vw);
}
.modaal-wrapper .opcPointAndCouponDialog_buttonGroup_edit {
  text-align: center;
}
.modaal-wrapper .opcPoint_usePointUnitLabel_edit {
  display: block;
  text-align: right;
}

/*! ========================================================
フォームページ設定
========================================================= */
#sysFormConfirm .sysButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysFormIndex .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysFormIndex .sysNextSubmit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysFormConfirm .sysNextSubmit {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysFormConfirm .sysNextSubmit .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysFormIndex #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysFormIndex #sysWrap #sysMain > h2 {
  display: none;
}
#sysFormIndex #sysWrap #sysMain > p {
  margin-bottom: min(1.875rem, 8vw);
}
#sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField > p {
  width: 100%;
  font-size: min(0.875rem, 3.7333333333vw);
}
#sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField > p a {
  text-decoration: underline;
}
#sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField > br {
  display: none;
}
#sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField .sysItemNameByFreeform {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField .sysItemThumnailByFreeform {
  max-width: min(18.75rem, 80vw);
}
#sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField:not(:has(input[type=radio])) > p {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField:has(input[type=radio]) {
  display: flex;
  flex-wrap: wrap;
  gap: min(0.625rem, 2.6666666667vw) 0;
}

#sysFormConfirm #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysFormConfirm #sysWrap #sysMain > h2 {
  display: none;
}
#sysFormConfirm #sysWrap #sysMain form .sysForm .sysFormItem {
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.5rem, 2.1333333333vw);
}

#sysFormThanks #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysFormThanks #sysWrap #sysMain > h2 {
  display: none;
}
#sysFormThanks #sysWrap #sysMain > p {
  text-align: center;
}

/*! ========================================================
レビューページ設定
========================================================= */
#sysItemReviewIndex #sysMain input[value=確認画面に進む] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysItemReviewIndex #sysMain input[value=確認画面に進む] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysItemReviewIndex #sysMain input[value=商品詳細] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysItemReviewIndex #sysMain input[value=並び替え] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: 0;
}

#sysItemReviewIndex #sysMain input[value=不適切なレビューの報告] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin-top: min(0.625rem, 2.6666666667vw);
}

#sysItemReviewConfirm #sysMain input[value=投稿する] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysItemReviewConfirm #sysMain input[value=投稿する] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysItemReviewConfirm #sysMain input[value=入力画面に戻る] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysItemReviewThanks #sysMain input[value=戻る] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysItemReviewIndex #sysMain input[value=確認] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysItemReviewIndex #sysMain input[value=確認] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysItemReviewIndex #sysMain input[value=戻る] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: min(0.125rem, 0.5333333333vw) solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}

#sysItemReviewIndex #sysMain input[value=報告] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
#sysItemReviewIndex #sysMain input[value=報告] .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

#sysItemReviewIndex #sysMain .sysReviewItemName a[href*="/ir/"] {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) auto 0 0;
}

#sysItemReviewIndex #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysItemReviewIndex #sysWrap #sysAside {
  display: none !important;
}
#sysItemReviewIndex #sysWrap #sysMain > h2 {
  max-width: min(25rem, 106.6666666667vw);
  font-size: min(1.25rem, 5.3333333333vw);
  margin-inline: auto;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysItemReviewIndex #sysWrap #sysMain > div {
  max-width: min(25rem, 106.6666666667vw);
  margin-inline: auto;
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysItemReviewIndex #sysWrap #sysMain > h3 {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
  margin-top: min(2.5rem, 10.6666666667vw);
}
#sysItemReviewIndex #sysWrap #sysMain .SysImproperReviewTitle {
  max-width: 100%;
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysItemReviewIndex #sysWrap #sysMain .SysImproperReviewContent {
  max-width: 100%;
}
#sysItemReviewIndex #sysWrap #sysMain .SysImpropalReviewDone {
  max-width: 100%;
  margin-bottom: min(3.75rem, 16vw);
}
#sysItemReviewIndex #sysWrap #sysMain form .sysEvaluation .sysFormField label {
  color: #e69b05;
}
#sysItemReviewIndex #sysWrap #sysMain form .sysEvaluation .sysFormField br {
  display: none;
}
#sysItemReviewIndex #sysWrap #sysMain form .SysImproperReviewForm {
  margin-bottom: min(3.75rem, 16vw);
}
#sysItemReviewIndex #sysWrap #sysMain form .SysImproperReviewForm li .SysImpropalReviewTextareaTitle {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 500;
  line-height: 1.5;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemReviewIndex #sysWrap #sysMain form .SysImproperReviewForm li:has(.SysImpropalReviewTextareaTitle) + li:not(:has(.SysImproperReviewFormTextarea)) {
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemReviewIndex #sysWrap #sysMain form:has(input[value=商品詳細]) {
  margin-bottom: min(3.75rem, 16vw);
}
#sysItemReviewIndex #sysWrap #sysMain form:has(select[name=sort]) {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: flex-end;
  gap: min(0.625rem, 2.6666666667vw);
}
#sysItemReviewIndex #sysWrap #sysMain form:has(select[name=sort]) select {
  height: min(2.5rem, 10.6666666667vw);
  width: -moz-fit-content;
  width: fit-content;
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewItemList {
  max-width: 100%;
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
  background-color: #eeeeee;
  padding: min(3.125rem, 13.3333333333vw) min(3.125rem, 13.3333333333vw);
  margin-top: min(1.25rem, 5.3333333333vw);
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0 min(0.9375rem, 4vw);
  width: 100%;
  border: none;
  border-radius: min(0.625rem, 2.6666666667vw);
  background-color: #ffffff;
  padding: min(1.875rem, 8vw) min(1.875rem, 8vw) min(4.125rem, 17.6vw);
  position: relative;
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysThumbnailImage,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysThumbnailImage {
  float: none;
  width: min(5rem, 21.3333333333vw);
  margin-right: 0;
  margin-bottom: min(0.9375rem, 4vw);
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysReviewItemName,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysReviewItemName {
  width: calc(100% - min(5.9375rem, 25.3333333333vw));
  margin-bottom: min(0.9375rem, 4vw);
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysNickname,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysNickname {
  max-width: calc(100% - min(6.25rem, 26.6666666667vw));
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  padding-left: min(2.8125rem, 12vw);
  position: relative;
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysNickname::before,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysNickname::before {
  content: "";
  display: block;
  width: min(1.875rem, 8vw);
  height: min(1.875rem, 8vw);
  background-image: url(../img/layout/common/icon_user.png);
  background-size: 100% 100%;
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysEvaluation,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysEvaluation {
  flex-shrink: 0;
  font-size: min(1.0625rem, 4.5333333333vw);
  line-height: 1.5;
  color: #e69b05;
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysReviewText,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysReviewText {
  width: 100%;
  font-size: min(1rem, 4.2666666667vw);
  line-height: 1.7;
  margin-top: min(0.9375rem, 4vw);
}
#sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysReviewDatetime,
#sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysReviewDatetime {
  display: block;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.5;
  position: absolute;
  bottom: min(1.875rem, 8vw);
  right: min(1.875rem, 8vw);
}

#sysItemReviewConfirm #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysItemReviewConfirm #sysWrap #sysAside {
  display: none !important;
}
#sysItemReviewConfirm #sysWrap #sysMain > h2 {
  max-width: min(25rem, 106.6666666667vw);
  font-size: min(1.25rem, 5.3333333333vw);
  margin-inline: auto;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysItemReviewConfirm #sysWrap #sysMain > div:not(.sysForm) {
  max-width: min(25rem, 106.6666666667vw);
  margin-inline: auto;
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
#sysItemReviewConfirm #sysWrap #sysMain > h3 {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
  margin-top: min(2.5rem, 10.6666666667vw);
}
#sysItemReviewConfirm #sysWrap #sysMain .sysForm .sysFormItem {
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.5rem, 2.1333333333vw);
}
#sysItemReviewConfirm #sysWrap #sysMain .sysForm .sysFormItem.sysEvaluation .sysFormField {
  color: #e69b05;
}

#sysItemReviewThanks #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysItemReviewThanks #sysWrap #sysAside {
  display: none !important;
}
#sysItemReviewThanks #sysWrap #sysMain > div {
  text-align: center;
  margin-bottom: min(3.75rem, 16vw);
}

/*! ========================================================
テキストページ設定
========================================================= */
#sysWrap:has(.text-page) {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box {
  margin-bottom: min(3.75rem, 16vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box .txt-contents-ttl-sub {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.5;
  margin-bottom: min(0.9375rem, 4vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box li {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table {
  width: 100%;
  border-collapse: collapse;
  border-spacing: 0;
  background-color: #ffffff;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table thead th {
  border: 1px solid #707070;
  background-color: #eeeeee;
  padding: min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table thead .shopping-guide-table-ttl-list {
  display: none;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table tbody th {
  font-weight: 400;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table tbody td {
  text-align: center;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table tbody th,
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table tbody td {
  line-height: 1.5;
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw);
  box-sizing: border-box;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table tbody span {
  display: inline;
  font-weight: 700;
  color: #d12e2e;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .trade-law-container .trade-law-container-box dl {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  border-bottom: 1px solid #707070;
  border-left: 1px solid #707070;
  border-right: 1px solid #707070;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .trade-law-container .trade-law-container-box dt {
  flex-basis: 35%;
  font-weight: 700;
  border-top: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  background-color: #eeeeee;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .trade-law-container .trade-law-container-box dd {
  flex-basis: 65%;
  border-top: 1px solid #707070;
  background-color: #ffffff;
  padding: min(1.25rem, 5.3333333333vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .trade-law-container .trade-law-container-box ul {
  display: flex;
  flex-direction: column;
  gap: min(0.625rem, 2.6666666667vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .privacy-policy-container p {
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .privacy-policy-container .center-txt {
  text-align: center;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .privacy-policy-container ol {
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .privacy-policy-container .privacy-policy-prohibitions-ol {
  margin-top: min(0.625rem, 2.6666666667vw);
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .company-container dl {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  border-bottom: 1px solid #707070;
  border-left: 1px solid #707070;
  border-right: 1px solid #707070;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .company-container dt {
  flex-basis: 25%;
  font-weight: 700;
  border-top: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  background-color: #eeeeee;
}
#sysWrap:has(.text-page) #sysMain .text-page .sysContent .company-container dd {
  flex-basis: 75%;
  border-top: 1px solid #707070;
  background-color: #ffffff;
  padding: min(1.25rem, 5.3333333333vw);
}

/*! ========================================================
ソーシャルギフト設定
========================================================= */
.sysSocialGiftBody .sysSocialGiftReceiveButton,
.sysSocialGiftBody .sysSocialGiftNextButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.sysSocialGiftBody .sysSocialGiftReceiveButton .fa,
.sysSocialGiftBody .sysSocialGiftNextButton .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}

.sysSocialGiftReceiveDeliveryAddressTitle_editButton,
.sysSocialGiftReceiveItemsTitle_editButton {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: auto;
  max-width: -moz-fit-content;
  max-width: fit-content;
  min-height: min(2.125rem, 9.0666666667vw);
  font-size: min(0.875rem, 3.7333333333vw);
  font-weight: 500;
  line-height: 1.5;
  color: #333333;
  white-space: initial;
  background: #ffffff;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.375rem, 1.6vw) min(1.25rem, 5.3333333333vw);
  margin: min(0.9375rem, 4vw) auto 0;
  margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
}

.sysSocialGiftBody #sysWrap {
  width: 100%;
  max-width: min(53.75rem, 229.3333333333vw);
  padding-inline: min(1.875rem, 8vw);
  margin-inline: auto;
  padding-top: min(1.25rem, 5.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .title-small-underline {
  margin-top: min(3.125rem, 13.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain form[action*="/product/"] .sysSocialGiftReceiveItemsTitle,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsTitle {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(3.125rem, 13.3333333333vw);
  margin-top: min(3.125rem, 13.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsTitle,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressTitle {
  font-size: min(1.25rem, 5.3333333333vw);
  font-weight: 700;
  margin-bottom: min(0.625rem, 2.6666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveTopPageContent,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItems_assortmentParentName,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryMethodTitle {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: inherit;
  border-left: none;
  padding-left: 0;
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain span:has(+ .sysRequired) {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  position: relative;
}
.sysSocialGiftBody #sysWrap #sysMain span:has(+ .sysRequired)::after {
  content: "必須";
  display: inline-block;
  font-size: min(0.6875rem, 2.9333333333vw);
  line-height: 1.5;
  color: #ffffff;
  border-radius: min(0.1875rem, 0.8vw);
  background-color: #d12e2e;
  padding: min(0.0625rem, 0.2666666667vw) min(0.5rem, 2.1333333333vw) min(0.125rem, 0.5333333333vw);
  margin-left: min(0.75rem, 3.2vw);
}
.sysSocialGiftBody #sysWrap #sysMain span:has(+ .sysRequired) + .sysRequired {
  display: none;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveButtonArea,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftButtonGroup {
  margin-top: min(3.75rem, 16vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveTopPageContent {
  text-align: center;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea {
  width: 100%;
  max-width: min(33.75rem, 144vw);
  background-color: #eeeeee;
  padding: min(1.25rem, 5.3333333333vw);
  margin-inline: auto;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea .sysSocialGiftReceiveGiftLetterImageGroup {
  max-width: min(31.25rem, 133.3333333333vw);
  margin-inline: auto;
  margin-bottom: min(0.9375rem, 4vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea .sysSocialGiftReceiveGiftLetterImageGroup img {
  width: 100%;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea .sysSocialGiftReceiveGiftLetterMessageGroup {
  border-radius: min(0.3125rem, 1.3333333333vw);
  background-color: #ffffff;
  padding: min(1.25rem, 5.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea .sysSocialGiftReceiveGiftLetterMessageGroup .sysSocialGiftReceiveGiftLetterMessage {
  white-space: normal;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveLimitDate {
  font-weight: 700;
  text-align: center;
  margin-top: min(2.5rem, 10.6666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemListGroup {
  border: none;
  padding: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItem {
  border: none;
  padding: 0;
  margin: 0;
  margin-bottom: min(3.125rem, 13.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup {
  display: flex;
  gap: min(1.25rem, 5.3333333333vw);
  border-bottom: 1px solid #707070;
  padding: 0;
  padding-bottom: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemImageGroup {
  width: min(7.5rem, 32vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary {
  width: calc(100% - min(8.75rem, 37.3333333333vw));
  padding: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItems_itemNameGroup {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  border-bottom: 1px solid #c2c2c2;
  padding-bottom: min(0.3125rem, 1.3333333333vw);
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItem_subTotalNumAndLabelGroup {
  font-size: min(1rem, 4.2666666667vw);
  margin: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup {
  border: none;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection {
  display: flex;
  flex-wrap: wrap;
  gap: min(3.125rem, 13.3333333333vw) min(2.8125rem, 12vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup {
  width: calc(50% - min(2.8125rem, 12vw) / 2);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup {
  cursor: pointer;
  margin: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary {
  margin: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildImageGroup {
  border: 1px solid #c2c2c2;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildImageGroup .sysSocialGiftReceiveItems_assortmentChildImage {
  width: 100%;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildNameGroup {
  margin-bottom: min(0.1875rem, 0.8vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildNameGroup .sysSocialGiftReceiveItems_assortmentChildName {
  font-weight: 700;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary:has(input:checked) .sysSocialGiftReceiveItems_assortmentChildImageGroup {
  border: 1px solid #333333;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup {
  border: none;
  padding: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup {
  border: none;
  padding: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem {
  border: none;
  padding: 0;
  margin: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup {
  display: flex;
  gap: min(1.25rem, 5.3333333333vw);
  border-bottom: 1px solid #707070;
  padding: 0;
  padding-bottom: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemImageGroup {
  width: min(7.5rem, 32vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary {
  width: calc(100% - min(8.75rem, 37.3333333333vw));
  padding: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItems_itemNameGroup {
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  border-bottom: 1px solid #c2c2c2;
  padding-bottom: min(0.3125rem, 1.3333333333vw);
  margin-bottom: min(0.3125rem, 1.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItem_subTotalNumAndLabelGroup,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItems_variationNameGroup {
  font-size: min(1rem, 4.2666666667vw);
  margin: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup {
  border: none;
  border-bottom: 1px solid #707070;
  padding-bottom: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(1.25rem, 5.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: min(23.5625rem, 100.5333333333vw);
  margin: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildImageGroup {
  order: 1;
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildImageGroup img {
  width: 100%;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildName {
  order: 2;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  margin-bottom: min(0.1875rem, 0.8vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildDescription {
  order: 3;
  font-size: min(1rem, 4.2666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveDeliveryMethodArea .sysSelectDelivery {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveDeliveryMethodArea .sysSelectHopeDelivery > div:first-of-type {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveDeliveryMethodArea .sysSelectHopeDelivery > div label {
  display: block;
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: inherit;
  border-left: none;
  padding-left: 0;
  margin-top: min(1.25rem, 5.3333333333vw);
  margin-bottom: min(0.5rem, 2.1333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveDeliveryMethodArea .sysSelectHopeDelivery > div label:has(+ select[style="display: none;"]) {
  display: none;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryAddressHeaderGroup,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveItemHeaderGroup {
  display: flex;
  align-items: center;
  justify-content: space-between;
  border-bottom: 1px solid #707070;
  padding-bottom: min(0.625rem, 2.6666666667vw);
  margin-bottom: min(0.9375rem, 4vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryAddressHeaderGroup .sysSocialGiftReceiveDeliveryAddressTitle,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryAddressHeaderGroup .sysSocialGiftReceiveItemsTitle,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveItemHeaderGroup .sysSocialGiftReceiveDeliveryAddressTitle,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveItemHeaderGroup .sysSocialGiftReceiveItemsTitle {
  margin-bottom: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryAddressHeaderGroup input,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveItemHeaderGroup input {
  margin: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryMethodArea {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryAddress_deliveryAddressGroup,
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryMethod_deliveryMethodGroup {
  font-size: min(1rem, 4.2666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) {
  padding-top: min(6.875rem, 29.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) {
  display: flex;
  flex-direction: column;
  margin-bottom: min(3.75rem, 16vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) > div {
  text-align: center;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) {
  border: 1px solid #707070;
  padding: min(1.25rem, 5.3333333333vw);
  margin-block: min(3.75rem, 16vw) min(1.25rem, 5.3333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) .sysOrderNumber {
  font-size: min(1.5625rem, 6.6666666667vw);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.04em;
  margin-top: min(0.5rem, 2.1333333333vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) .sysCartNote {
  order: 1;
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  letter-spacing: 0.04em;
  color: #333333;
  text-align: left;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysSocialGiftReceiveThanksPageFreeAreaBottom .campaign-ttl {
  padding-top: 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysSocialGiftReceiveThanksPageFreeAreaBottom .campaign-btn {
  margin-bottom: min(2.5rem, 10.6666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysSocialGiftReceiveThanksPageFreeAreaBottom .campaign-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: min(21.5625rem, 92vw);
  min-height: min(3.75rem, 16vw);
  font-size: min(1rem, 4.2666666667vw);
  font-weight: 700;
  line-height: 1.5;
  color: #ffffff;
  white-space: initial;
  background: #333333;
  border: 1px solid #333333;
  border-radius: min(6.25rem, 26.6666666667vw);
  padding: min(0.625rem, 2.6666666667vw) min(2.5rem, 10.6666666667vw);
  margin: min(0.625rem, 2.6666666667vw) auto 0;
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysSocialGiftReceiveThanksPageFreeAreaBottom .campaign-btn a .fa {
  margin-left: min(0.625rem, 2.6666666667vw);
}
.sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysSocialGiftReceiveThanksPageFreeAreaBottom .campaign-txt {
  font-size: min(0.875rem, 3.7333333333vw);
  line-height: 1.7;
  letter-spacing: 0.04em;
  color: #333333;
}
@media (max-width: 46.875em) {
  html {
    scroll-padding-top: 0;
  }
  body {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .pc_only {
    display: none !important;
  }
  .tb_only {
    display: none !important;
  }
  .sp_only {
    display: block !important;
  }
  .title-large {
    font-size: min(1.3125rem, 5.6vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  .title-medium {
    font-size: min(1.0625rem, 4.5333333333vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  .title-medium.left {
    margin-bottom: min(0.9375rem, 4vw);
  }
  .title-medium-underline {
    font-size: min(1.0625rem, 4.5333333333vw);
    padding-bottom: min(0.9375rem, 4vw);
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .title-medium-sub {
    font-size: min(1.25rem, 5.3333333333vw);
    padding-top: min(1.25rem, 5.3333333333vw);
    margin-bottom: min(1.5625rem, 6.6666666667vw);
  }
  .title-medium-sub span {
    font-size: min(0.625rem, 2.6666666667vw);
    padding-top: min(0.125rem, 0.5333333333vw);
  }
  .title-small-underline {
    font-size: min(0.9375rem, 4vw);
    margin-bottom: min(1.875rem, 8vw);
  }
  .sysFuncItemBlock .sysCartButton {
    box-sizing: border-box;
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  .shop-calender {
    width: 100%;
    padding-inline: min(0.9375rem, 4vw);
  }
  .shop-calender #calendar {
    width: min(19.5rem, 83.2vw);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock {
    margin-bottom: min(1.875rem, 8vw);
  }
   #top #sysMain .sysFuncItemBlock .sysItemBlock {
    margin-bottom: 0;
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul {
    gap: min(1.875rem, 8vw) min(0.9375rem, 4vw);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul li {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul li .sysIconRank {
    width: min(1.875rem, 8vw);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemName a {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: 0;
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemPrice {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMain .sysFuncItemBlock.item-block-col6 .sysItemBlock ul, #sysMain .sysFuncItemBlock.item-block-col5 .sysItemBlock ul, #sysMain .sysFuncItemBlock.item-block-col4 .sysItemBlock ul, #sysMain .sysFuncItemBlock.item-block-col3 .sysItemBlock ul {
    gap: min(1.875rem, 8vw) min(0.9375rem, 4vw);
  }
  #sysMain .sysFuncItemBlock.item-block-col6 .sysItemBlock ul li, #sysMain .sysFuncItemBlock.item-block-col5 .sysItemBlock ul li, #sysMain .sysFuncItemBlock.item-block-col4 .sysItemBlock ul li, #sysMain .sysFuncItemBlock.item-block-col3 .sysItemBlock ul li {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  .sysCategoryPankuzu,
  .sysItemCategoryPankuzu {
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  .sysCategoryPankuzu > a,
  .sysCategoryPankuzu > span,
  .sysItemCategoryPankuzu > a,
  .sysItemCategoryPankuzu > span {
    font-size: min(0.625rem, 2.6666666667vw);
  }
  .sysCategoryPankuzu > a::after,
  .sysItemCategoryPankuzu > a::after {
    width: min(0.4375rem, 1.8666666667vw);
    height: min(0.9375rem, 4vw);
    margin-inline: min(0.375rem, 1.6vw);
  }
  #sysAll #sysMain input[type=text],
  #sysAll #sysMain input[type=email],
  #sysAll #sysMain input[type=search],
  #sysAll #sysMain input[type=password],
  #sysAll #sysMain input[type=tel],
  #sysAll #sysMain input[type=number],
  #sysAll #sysMain select {
    height: min(2.625rem, 11.2vw);
  }
  #sysAll #sysMain input[type=text],
  #sysAll #sysMain input[type=email],
  #sysAll #sysMain input[type=search],
  #sysAll #sysMain input[type=password],
  #sysAll #sysMain input[type=tel],
  #sysAll #sysMain input[type=number],
  #sysAll #sysMain select {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysAll #sysMain textarea {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysAll #sysMain label:has(input[type=radio]),
  #sysAll #sysMain label:has(input[type=checkbox]) {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysAll #sysMain .sysFormItem {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysAll #sysMain .sysFormLabel {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysAll #sysMain .sysAutoLoginField {
    gap: 0 min(0.25rem, 1.0666666667vw);
  }
  #sysAll #sysMain .sysAutoLoginField .sysAutoLoginLabel {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysOpcBody input[type=text],
  .sysOpcBody input[type=email],
  .sysOpcBody input[type=search],
  .sysOpcBody input[type=password],
  .sysOpcBody input[type=tel],
  .sysOpcBody input[type=number],
  .sysOpcBody select {
    height: min(2.625rem, 11.2vw);
  }
  .sysOpcBody input[type=text],
  .sysOpcBody input[type=email],
  .sysOpcBody input[type=search],
  .sysOpcBody input[type=password],
  .sysOpcBody input[type=tel],
  .sysOpcBody input[type=number],
  .sysOpcBody select {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysHeader .header-content .header-top {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysHeader .header-content .header-bottom {
    width: 100%;
    /*padding-inline: min(0.9375rem, 4vw);*/
  }
  #sysHeader .header-content .header-top {
    padding-block: min(0.625rem, 0.5vw);
  }
  #sysHeader .header-content .header-top .header-top-left {
    gap: min(0.9375rem, 4vw);
  }
  #sysHeader .header-content .header-bottom {
    /* display: none; */
  }
  #sysHeader .header-banner ul li {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysHeader .header-banner ul {
    padding: min(0.3125rem, 1.3333333333vw);
  }
  #sysHeader .header-banner ul li a {
    font-size: min(0.625rem, 2.6666666667vw);
  }

  #sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .header-drawer-menu__top {
    margin-bottom: min(0.75rem, 3.2vw);
  }
  #sysHeader .header-drawer-menu > .sysContent .header-drawer-menu__content .sysFuncItemCategory .sysHeadline {
    font-size: min(0.9375rem, 4vw);
  }
  #sysHeader .header-logo {
    width: min(9rem, 40vw);
  }
  #sysHeader .header-search {
    width: 100%;
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysHeader .header-search form {
    width: 100%;
    margin-right: 0;
  }
  #sysFooter .shop-info-content {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysFooter .shop-info-content {
    padding-inline: 0;
    margin-top: min(2.5rem, 10.6666666667vw);
  }
  #sysFooter .shop-info-content .shop-info-container {
    margin-bottom: min(3.125rem, 13.3333333333vw);
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer {
    display: block;
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-img {
    width: 100%;
    max-width: 100%;
    margin-bottom: min(3.125rem, 13.3333333333vw);
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-img ul {
    flex-direction: row;
    justify-content: center;
    gap: 0;
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-img ul li {
    width: 50%;
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-info {
    max-width: 100%;
    min-width: 0;
    padding-inline: min(0.9375rem, 4vw);
    margin-top: 0;
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-info p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-info p .small {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-calender {
    margin-top: 0;
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #sysFooter .footer-content .footer-container {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysFooter .footer-content {
    margin-top: min(3.125rem, 13.3333333333vw);
  }
  #sysFooter .footer-content .footer-container {
    flex-wrap: wrap;
    gap: min(1.25rem, 5.3333333333vw);
    padding-block: min(1.875rem, 8vw) min(1.25rem, 5.3333333333vw);
  }
  #sysFooter .footer-content .footer-container > div {
    width: 100%;
  }
  #sysFooter .footer-content .footer-container .footer-logo {
    padding-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysFooter .footer-content .footer-container .footer-logo > .sysContent {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  #sysFooter .footer-content .footer-container .footer-logo > .sysContent > ul {
    max-width: min(7.875rem, 33.6vw);
    margin-bottom: 0;
  }
  #sysFooter .footer-content .footer-container .footer-sns {
    width: -moz-fit-content;
    width: fit-content;
  }
  #sysFooter .footer-content .footer-container .sysFuncItemCategory .sysHeadline {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysFooter .footer-content .footer-container .sysFuncItemCategory ul {
    gap: min(0.5rem, 2.1333333333vw);
  }
  #sysFooter .footer-content .footer-container .sysFuncItemCategory ul li a {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysFooter .footer-content .footer-container .sysFuncListNav ul {
    gap: min(0.5rem, 2.1333333333vw);
  }
  #sysFooter .footer-content .footer-container .sysFuncListNav ul li a {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysFooter .footer-shop-menu .sysContent {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysFooter .footer-shop-menu .sysContent ul li a {
    font-size: min(0.75rem, 3.2vw);
    padding-inline: min(0.625rem, 2.6666666667vw);
  }
  #sysFooter .footer-copyright .sysContent {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysFooter .footer-copyright .sysContent p {
    font-size: min(0.6875rem, 2.9333333333vw);
  }
  #top .top-mv .top-mv__content {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap {
    padding-bottom: 0rem;
  }
  .top-mv__content .swiper-pagination {
    margin-top: 0px !important;
}
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block {
    gap: min(0.625rem, 2.6666666667vw);
    width: min(14.6875rem, 62.6666666667vw);
    padding: min(0.625rem, 2.6666666667vw) min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw) min(0.625rem, 2.6666666667vw);
    bottom: -1.875rem;
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-img {
    width: min(4.375rem, 18.6666666667vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info {
    width: min(7.8125rem, 33.3333333333vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-name {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.1875rem, 0.8vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-price {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-button {
    width: min(0.25rem, 1.0666666667vw);
    height: min(0.5rem, 2.1333333333vw);
    font-size: 0;
    line-height: 0;
    padding-right: 0;
    margin-top: 0;
    position: absolute;
    top: 50%;
    right: min(0.625rem, 2.6666666667vw);
    transform: translateY(-50%);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-button::after {
    width: 100%;
    height: 100%;
    position: static;
    transform: translateY(0);
  }
  #top .top-banner ul {
    padding-inline: min(0.9375rem, 4vw);
  }
  #top .top-banner ul {
    flex-direction: column;
    justify-content: flex-start;
    gap: min(1.25rem, 5.3333333333vw);
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .top-banner ul li {
    width: 100%;
    max-width: min(22.5rem, 96vw);
    margin-inline: auto;
  }
  #top .top-ranking {
    padding-block: min(0rem, 8vw);
    padding-bottom: 20px !important;
  }
  #top .top-ranking .sysItemBlock {
    padding-inline: 0;
  }
  #top .top-ranking .sysItemBlock ul {
    flex-wrap: nowrap;
    gap: 0 !important;
    overflow-x: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  #top .top-ranking .sysItemBlock ul::-webkit-scrollbar {
    display: none;
  }
  #top .top-ranking .sysItemBlock ul::before, #top .top-ranking .sysItemBlock ul::after {
    content: "";
    flex-shrink: 0;
    display: block;
    width: min(0.9375rem, 4vw);
    height: 1px;
  }
  #top .top-ranking .sysItemBlock ul li {
    flex-shrink: 0;
    width: min(10rem, 42.6666666667vw) !important;
    margin-right: min(0.625rem, 2.6666666667vw);
  }
  #top .top-ranking .sysItemBlock ul li:last-of-type {
    margin-right: 0;
  }
  #top .top-category-img > .sysHeadline {
    padding-inline: min(0.9375rem, 4vw);
  }
  #top .top-category-img {
    margin-bottom: min(1.875rem, 8vw);
  }
  #top .top-category-img .img-block {
    height: auto;
  }
  #top .top-category-img .img-block picture,
  #top .top-category-img .img-block img {
    height: auto;
    -o-object-fit: initial;
       object-fit: initial;
    -o-object-position: initial;
       object-position: initial;
  }
  #top .top-category-img .top-category-item {
    max-width: 100%;
    padding-inline: min(0.9375rem, 4vw);
    position: static;
    transform: translateY(0);
    margin-top: -5.8125rem;
  }
  #top .top-category-img .top-category-item .sysItemBlock {
    padding: 0;
    margin-bottom: 0;
  }
  #top .top-category-img .top-category-item .sysItemBlock ul {
    flex-direction: column;
  }
  #top .top-category-img .top-category-item .sysItemBlock ul li {
    width: 100%;
    max-width: min(16.5625rem, 70.6666666667vw);
    padding: min(0.9375rem, 4vw);
    margin-inline: auto;
  }
  #top .top-category-btn {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .top-category-list-item .sysContent {
    padding-inline: min(0.9375rem, 4vw);
  }
  #top .top-category-list-item {
    padding-block: min(1.875rem, 8vw);
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .top-category-list-item .sysContent ul {
    gap: min(0.8125rem, 3.4666666667vw);
  }
  #top .top-category-list-item .sysContent ul li {
    width: calc(50% - min(0.8125rem, 3.4666666667vw) / 2);
  }
  #top .top-category-list-item .sysContent ul li a {
    padding: min(0.5rem, 2.1333333333vw) min(0.5rem, 2.1333333333vw) min(0.3125rem, 1.3333333333vw);
  }
  #top .top-category-list-item .sysContent ul li a p {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(0.3125rem, 1.3333333333vw);
  }
  #top .top_item-pickup .sysHeadline {
    padding-inline: min(0.9375rem, 4vw);
  }
  #top .top_item-pickup {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .top_item-pickup .sysItemBlock ul li {
    display: flex;
    flex-direction: column;
    width: 100%;
  }
  #top .top_item-pickup .sysItemBlock ul li .sysItemImage {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #top .top_item-pickup .sysItemBlock ul li .sysItemName {
    margin-bottom: min(0.3125rem, 1.3333333333vw);
  }
  #top .top_item-pickup .sysItemBlock ul li .sysItemName a {
    font-size: min(1.125rem, 4.8vw);
  }
  #top .top_item-pickup .sysItemBlock ul li .sysItemPrice {
    font-size: min(1.0625rem, 4.5333333333vw);
    padding-bottom: min(0.9375rem, 4vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  #top .top_item-pickup .sysItemBlock ul li .sysItemPrArea {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #top .top_item-pickup .sysItemBlock ul li #sysDescriptionPc,
  #top .top_item-pickup .sysItemBlock ul li #sysDescriptionMobile {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #top .top-review {
    padding: min(1.875rem, 8vw) min(0.9375rem, 4vw) min(1.5625rem, 6.6666666667vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li {
    align-items: flex-start;
    gap: 0 min(0.9375rem, 4vw);
    padding: min(0.9375rem, 4vw) min(0.9375rem, 4vw) min(3.3125rem, 14.1333333333vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysThumbnailImage {
    width: min(4.375rem, 18.6666666667vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .review-info {
    width: calc(100% - min(5.3125rem, 22.6666666667vw));
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .review-info .review-info-inner {
    gap: min(0.5rem, 2.1333333333vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewItemName a:nth-of-type(1) {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.4375rem, 1.8666666667vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewItemName a:nth-of-type(2) {
    font-size: min(0.625rem, 2.6666666667vw);
    padding-left: min(0.75rem, 3.2vw);
    bottom: min(1.125rem, 4.8vw);
    left: min(0.9375rem, 4vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysNickname {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    padding-left: min(1.875rem, 8vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysNickname::before {
    width: min(1.375rem, 5.8666666667vw);
    height: min(1.375rem, 5.8666666667vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewText {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .sysReviewDatetime {
    font-size: min(0.75rem, 3.2vw);
    bottom: min(0.9375rem, 4vw);
    right: min(0.9375rem, 4vw);
  }
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li form,
  #top .top-review .sysContent .sysReviewItemList .sysReviewList li .both {
    display: none;
  }
  #top .top-review-btn {
    padding-inline: min(0.9375rem, 4vw);
    padding-bottom: min(1.875rem, 8vw);
  }
  #top .top-scene {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .top-scene .top-scene__content .img-block {
    height: auto;
    margin-bottom: min(1.5625rem, 6.6666666667vw);
  }
  #top .top-scene .top-scene__content .img-block picture,
  #top .top-scene .top-scene__content .img-block img {
    height: auto;
    -o-object-fit: initial;
       object-fit: initial;
    -o-object-position: initial;
       object-position: initial;
  }
  #top .top-scene .top-scene__content .text-block {
    max-width: 100%;
    padding-inline: min(0.9375rem, 4vw);
    position: static;
    transform: translateY(0);
  }
  #top .top-scene .top-scene__content .text-block p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #top .top-scene .top-scene__content .text-block .btn-common {
    margin-left: auto;
  }
  #top .category-list .sysContent {
    padding-inline: min(0.9375rem, 4vw);
  }
  #top .category-list {
    padding-block: min(1.875rem, 8vw);
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .category-list .sysContent ul {
    gap: min(0.8125rem, 3.4666666667vw);
  }
  #top .category-list .sysContent ul li {
    width: calc(50% - min(0.8125rem, 3.4666666667vw) / 2) !important;
  }
  #top .category-list .sysContent ul li a {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.75rem, 3.2vw);
  }
  #top .top-topic {
    padding-inline: min(0.9375rem, 4vw);
  }
  #top .top-topic {
    padding-inline: 0;
  }
  #top .top-topic .top-topic__content {
    display: block;
  }
  #top .top-topic .top-topic__content .img-block {
    max-width: min(18.75rem, 80vw);
    margin-left: auto;
  }
  #top .top-topic .top-topic__content .text-block {
    max-width: min(20rem, 85.3333333333vw);
    padding: min(1.5625rem, 6.6666666667vw);
    margin-right: 0;
    margin-left: min(0.9375rem, 4vw);
    margin-top: -1.25rem;
  }
  #top .top-topic .top-topic__content .text-block p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #top .top-banner-large {
    padding-inline: min(0.9375rem, 4vw);
  }
  #top .top-banner-large {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .top-news {
    padding: min(1.875rem, 8vw) min(0.9375rem, 4vw);
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #top .top-news nav ul li a {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.75rem, 3.2vw) min(2.125rem, 9.0666666667vw) min(0.75rem, 3.2vw) min(0.9375rem, 4vw);
  }
  #top .top-news nav ul li a::after {
    right: min(0.9375rem, 4vw);
  }
  #sysItemDetail #sysWrap {
    padding-inline: 0;
  }
  #sysItemDetail #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemDetail article .item-container {
    flex-direction: column;
    align-items: center;
    gap: min(1.25rem, 5.3333333333vw);
    margin-bottom: 0;
  }
  #sysItemDetail article #test-left {
    max-width: min(34.6875rem, 148vw);
    padding-top: 0;
  }
  #sysItemDetail article .item-container .sysItemImages .sysMainImage {
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysItemDetail article .item-container .sysItemImages .sysImageList {
    gap: min(0.625rem, 2.6666666667vw);
  }
  #sysItemDetail article .item-container .sysItemImages .sysImageList li {
    width: 40px;
  }
  #sysItemDetail article .item-container .item-info-container {
  width: 100%;
  max-width: 100%;
}
  #sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateSelectPrefStateArea #prefStateId {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div input[type=text] {
    height: min(2.625rem, 11.2vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysNumber {
    width: 100%;
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysNumber select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysItemName {
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysItemName h1 {
    font-size: min(1.125rem, 4.8vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysRetailPrice {
    margin-bottom: 0;
  }
  #sysItemDetail article .item-container .item-info-container .sysRetailPrice span {
    font-size: 26px;
  }
  #sysItemDetail article .item-container .item-info-container .sysPr {
    margin-bottom: 0;
  }
  #sysItemDetail article .item-container .item-info-container .sysDescription {
    padding-block: 0;
    margin-bottom: 0;
  }
  #sysItemDetail article .item-container .item-info-container .sysDescription p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysItemId {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysShippingCost {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysStockQuantity {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateViewName {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm {
    padding: min(0.8125rem, 3.4666666667vw) min(0.625rem, 2.6666666667vw) min(0.875rem, 3.7333333333vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateSelectPrefStateArea .sysDeliveryDateSelectPrefStateLabel {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea > div {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea .sysDeliveryDateAppendComment,
  #sysItemDetail article .item-container .item-info-container .sysDeliveryDate .sysDeliveryDateForm .sysDeliveryDateArea .sysDeliveryDateNoAvailableDatesMessage {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysVariation > div {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable th {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.5rem, 2.1333333333vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable td {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    padding: min(0.5rem, 2.1333333333vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysVariation .sysFormVariationTable td input[type=radio] {
    margin-bottom: min(0.1875rem, 0.8vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections {
    margin-bottom: min(1.5625rem, 6.6666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div:has(input[type=radio])::before {
    height: min(0.375rem, 1.6vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div select {
    margin-top: min(0.375rem, 1.6vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSelections > div input[type=text] {
    margin-top: min(0.375rem, 1.6vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules {
    margin-bottom: min(1.5625rem, 6.6666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar th {
    height: min(3.75rem, 16vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalSchedulesCalendarArea .sysRentalSchedulesCalendars .sysRentalSchedulesCalendarDatesArea .sysRentalSchedulesCalendar td {
    height: min(3.75rem, 16vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalScheduleInfo {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysForm .sysRentalSchedules .sysRentalScheduleInfo > div:not(.sysRentalScheduleNotice) {
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysGetPoint {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    margin-bottom: min(1.5625rem, 6.6666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysNumber .sysNumArea {
    gap: min(0.5rem, 2.1333333333vw);
    margin-left: min(0.5rem, 4vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysNumber .sysNumArea button {
    width: min(2.125rem, 9.0666666667vw);
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysSubtotal {
    margin-bottom: min(0.9375rem, 4vw);
    font-size: 28px !important;
    width: 100%;
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysWishSum {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysItemDetail article .item-container .item-info-container .sysForm #sysWishSum span {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
  }
  #sysItemDetail article .item-container .item-info-container .sysFreeForm {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysItemDetail article .sysExplanation {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #sysItemDetail article .sysExplanation p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemDetail article .sysReview {
    display: flex;
    flex-direction: column;
    width: calc(100% + min(1.875rem, 8vw));
    padding: min(1.875rem, 8vw) min(0.9375rem, 4vw) min(1.5625rem, 6.6666666667vw);
    margin-left: max(-0.9375rem, -4vw);
    margin-bottom: min(3.125rem, 13.3333333333vw);
  }
  #sysItemDetail article .sysReview > span {
    order: 1;
    font-size: min(1.3125rem, 5.6vw);
    margin-bottom: 0;
  }
  #sysItemDetail article .sysReview .sysReviewHistoryList {
    order: 3;
    display: flex;
    flex-direction: column;
    gap: min(0.625rem, 2.6666666667vw);
  }
  #sysItemDetail article .sysReview .sysReviewHistoryList li {
    gap: 0 min(0.5rem, 2.1333333333vw);
    padding: min(0.9375rem, 4vw) min(0.9375rem, 4vw) min(2.6875rem, 11.4666666667vw);
  }
  #sysItemDetail article .sysReview .sysReviewHistoryList li .sysNickname {
    max-width: calc(100% - min(5.8125rem, 24.8vw));
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    padding-left: min(1.875rem, 8vw);
  }
  #sysItemDetail article .sysReview .sysReviewHistoryList li .sysNickname::before {
    width: min(1.375rem, 5.8666666667vw);
    height: min(1.375rem, 5.8666666667vw);
  }
  #sysItemDetail article .sysReview .sysReviewHistoryList li .sysReviewText {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemDetail article .sysReview .sysReviewHistoryList li .sysReviewDatetime {
    font-size: min(0.75rem, 3.2vw);
    bottom: min(0.9375rem, 4vw);
    right: min(0.9375rem, 4vw);
  }
  #sysItemDetail article .sysReview form {
    order: 2;
    margin-bottom: min(0.9375rem, 4vw);
  }
  #sysItemDetail article .sysReview form input[type=submit] {
    font-size: min(0.8125rem, 3.4666666667vw);
    position: static;
    margin-left: auto;
  }
  #sysItemDetail .related-item .sysItemBlock {
    padding-inline: 0;
    margin-bottom: min(3.125rem, 13.3333333333vw);
  }
  #sysItemCategory #sysWrap,
  #sysItemSearch #sysWrap {
    padding-inline: 0;
  }
  #sysItemCategory #sysWrap,
  #sysItemSearch #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemCategory .sysItemCategoryForm {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysItemCategory .sysItemCategoryForm .sysItemCategoryCtl {
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    padding-block: min(0.9375rem, 4vw) min(0.625rem, 2.6666666667vw);
    width: 94%;
    margin: 0 auto !important;
  }
  #sysItemCategory .sysItemCategoryForm .sysItemCategoryCtl a {
    display: inline-block;
    padding: min(0.25rem, 1.0666666667vw) min(0.625rem, 2.6666666667vw) min(0.3125rem, 1.3333333333vw);
  }
  #sysItemSearch #sysMain > h2 {
    font-size: min(1.0625rem, 4.5333333333vw);
    margin-bottom: min(0.9375rem, 4vw);
    margin-top: 20px;
  }

  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormSort select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormLimit select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput input[type=submit] {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemSearch .sysItemSearchForm {
    width: 100%;
    margin: 0 auto;
    box-sizing: border-box;
  }

  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput {
    padding: min(1.25rem, 5.3333333333vw) min(0.9375rem, 4vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormWord {
    margin-bottom: min(0.1875rem, 0.8vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchAndOr {
    gap: min(0.9375rem, 4vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchAndOr label {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormRange {
    width: -moz-fit-content;
    width: fit-content;
    margin-right: 0;
    margin-bottom: min(0.9375rem, 4vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormRange input[type=text] {
    margin-inline: min(0.125rem, 0.5333333333vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormCategory {
    display: block;
    width: 100%;
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormCategory select {
    height: min(2.5rem, 10.6666666667vw);
    margin-top: min(0.3125rem, 1.3333333333vw);
    margin-left: 0;
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups {
    margin-top: min(0.9375rem, 4vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups .sysItemSearchFormItemCategoryGroupsTitle {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] span[class*=itemCategoryGroupTitle] {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] ul {
    gap: min(0.4375rem, 1.8666666667vw) min(0.9375rem, 4vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] ul li input[type=checkbox] {
    margin-right: min(0.25rem, 1.0666666667vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormItemCategoryGroups > div[class*=itemCategoryGroup] ul li label {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormSort {
    width: -moz-fit-content;
    width: fit-content;
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormLimit {
    width: -moz-fit-content;
    width: fit-content;
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput input[type=submit] {
    width: 100%;
    max-width: 100%;
    margin-top: min(0.9375rem, 4vw);
  }


  #sysItemCategory .sysItemListDisp,
  #sysItemSearch .sysItemListDisp {
    margin-block: min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw);
  }
  #sysItemCategory .sysItemListDisp {
    width: 94%;
  }
  #sysItemCategory .sysItemListDisp #displayCount,
  #sysItemSearch .sysItemListDisp #displayCount {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemListDisp .sysItemListViewType,
  #sysItemSearch .sysItemListDisp .sysItemListViewType {
    gap: min(0.9375rem, 4vw);
  }
  #sysItemCategory .sysItemListDisp .sysItemListViewType label,
  #sysItemSearch .sysItemListDisp .sysItemListViewType label {
    font-size: min(0.75rem, 3.2vw) !important;
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div select,
  #sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div input[type=text],
  #sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div input[type=text] {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddVariation select,
  #sysItemSearch .sysItemList ul.sysList li .sysAddVariation select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail,
  #sysItemSearch .sysItemList ul.sysThumbnail {
    gap: min(1.5625rem, 6.6666666667vw) min(0.9375rem, 4vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li,
  #sysItemSearch .sysItemList ul.sysThumbnail li {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li .sysItemName a,
  #sysItemSearch .sysItemList ul.sysThumbnail li .sysItemName a {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.125rem, 0.5333333333vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li #sysDescriptionPc,
  #sysItemCategory .sysItemList ul.sysThumbnail li #sysDescriptionMobile,
  #sysItemSearch .sysItemList ul.sysThumbnail li #sysDescriptionPc,
  #sysItemSearch .sysItemList ul.sysThumbnail li #sysDescriptionMobile {
    font-size: min(0.625rem, 2.6666666667vw);
    margin-bottom: min(0.125rem, 0.5333333333vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li .sysRetailPrice,
  #sysItemSearch .sysItemList ul.sysThumbnail li .sysRetailPrice {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li > form input[type=submit],
  #sysItemSearch .sysItemList ul.sysThumbnail li > form input[type=submit] {
    box-sizing: border-box;
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button,
  #sysItemSearch .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button {
    box-sizing: border-box;
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.625rem, 2.6666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li,
  #sysItemSearch .sysItemList ul.sysList li {
    gap: 0 min(0.9375rem, 4vw);
    padding-block: min(0.9375rem, 4vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysThumbnailImage,
  #sysItemSearch .sysItemList ul.sysList li .sysThumbnailImage {
    width: min(6.25rem, 26.6666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > div:not([class]),
  #sysItemSearch .sysItemList ul.sysList li > div:not([class]) {
    width: calc(100% - min(7.1875rem, 30.6666666667vw));
  }
  #sysItemCategory .sysItemList ul.sysList li > div:not([class]) .sysItemName a,
  #sysItemSearch .sysItemList ul.sysList li > div:not([class]) .sysItemName a {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.125rem, 0.5333333333vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > div:not([class]) #sysDescriptionPc,
  #sysItemCategory .sysItemList ul.sysList li > div:not([class]) #sysDescriptionMobile,
  #sysItemSearch .sysItemList ul.sysList li > div:not([class]) #sysDescriptionPc,
  #sysItemSearch .sysItemList ul.sysList li > div:not([class]) #sysDescriptionMobile {
    font-size: min(0.625rem, 2.6666666667vw);
    line-height: 1.5;
    margin-bottom: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > div:not([class]) .sysRetailPrice,
  #sysItemSearch .sysItemList ul.sysList li > div:not([class]) .sysRetailPrice {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > form,
  #sysItemSearch .sysItemList ul.sysList li > form {
    padding-left: min(7.1875rem, 30.6666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > form input[type=submit],
  #sysItemSearch .sysItemList ul.sysList li > form input[type=submit] {
    max-width: 100%;
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysWishListButtonFormAjax,
  #sysItemSearch .sysItemList ul.sysList li .sysWishListButtonFormAjax {
    padding-left: min(7.1875rem, 30.6666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysWishListButtonFormAjax button,
  #sysItemSearch .sysItemList ul.sysList li .sysWishListButtonFormAjax button {
    max-width: 100%;
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.625rem, 2.6666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div,
  #sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div {
    font-size: min(0.75rem, 3.2vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div select,
  #sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div select {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div label,
  #sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div label {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddSelection > div input[type=text],
  #sysItemSearch .sysItemList ul.sysList li .sysAddSelection > div input[type=text] {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddVariation .sysVariationSelects,
  #sysItemSearch .sysItemList ul.sysList li .sysAddVariation .sysVariationSelects {
    font-size: min(0.75rem, 3.2vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysAddVariation select,
  #sysItemSearch .sysItemList ul.sysList li .sysAddVariation select {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemCategory .sysPagination,
  #sysItemSearch .sysPagination {
    padding-block: min(2.5rem, 10.6666666667vw) min(3.125rem, 13.3333333333vw);
  }
  #sysItemCategory .sysItemCategoryInfo {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysItemCategory .sysItemCategoryInfo .sysCategoryDescription .img {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysItemCategory .sysItemCategoryInfo .sysCategoryDescription p {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: 0;
  }
  #sysBasket #sysMain .sysDeleteArea .sysDeleteArea {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysBasket #sysMain .sysDeleteArea .sysDeleteArea {
    margin: min(0.3125rem, 1.3333333333vw) 0 0 auto;
  }
  #sysBasket #sysMain #sysInputCouponCode .sysButton {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysBasket #sysMain #sysInputCouponCode .sysButton {
    margin-left: 0;
  }
  #sysBasket #sysMain .sysConfirmCoupon input[type=button] {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysBasket #sysMain .sysConfirmCoupon input[type=button] {
    margin: min(0.625rem, 2.6666666667vw) 0 0 auto;
  }
  .basketCouponEditDialog_buttonGroup .basketCouponDialog_applyButton {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .basketCouponEditDialog_buttonGroup .basketCouponDialog_cancelButton {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .sysCart #sysMain .sysSocialGiftReceiveUrlCopyButton {
    margin-top: min(0.9375rem, 4vw);
  }
  .sysCart #sysMain .sysSocialGiftReceiveUrlSendLineButton {
    margin-bottom: min(0.9375rem, 4vw);
  }
  #sysBasket #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysBasket #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysBasket #sysWrap #sysMain {
    font-size: small;
  }
  #sysBasket #sysWrap #sysMain .sysNextSubmitAreaForUseAmazon {
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysBasket #sysWrap #sysMain div:not(#sysInputCouponCode) .sysBox {
    padding: min(0.9375rem, 4vw);
  }
  #sysBasket #sysWrap #sysMain .sysTotal {
    margin-block: min(1.875rem, 8vw) min(0.9375rem, 4vw);
  }
  #sysBasket #sysWrap #sysMain .sysTotal .sysBox > div {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysBasket #sysWrap #sysMain .sysTotal .sysBox > div .sysCartAttention {
    font-size: min(1rem, 4.2666666667vw);
  }
  #sysBasket #sysWrap #sysMain .sysInputCouponCode .sysBox input[type=text] {
    margin-top: min(0.375rem, 1.6vw);
  }
  #sysBasket #sysWrap #sysMain .sysCartTitle {
    font-size: min(0.9375rem, 4vw);
  }
  #sysBasket #sysWrap #sysMain .sysCartItemAreaMessage {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea {
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox {
    gap: 0 min(0.625rem, 2.6666666667vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > a {
    width: min(5rem, 21.3333333333vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysProduct {
    width: calc(100% - min(5.625rem, 24vw));
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysProduct .sysItemName {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.3125rem, 1.3333333333vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysProduct > div:not(.sysItemName) {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) {
    font-size: min(0.75rem, 3.2vw);
    padding-top: min(0.9375rem, 4vw);
    margin-bottom: min(0.3125rem, 1.3333333333vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) .sysNumArea {
    gap: min(0.5rem, 2.1333333333vw);
    margin-left: min(0.9375rem, 4vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox > div:not([class]):has(+ .sysSubTotalArea) .sysNumArea button {
    width: min(2.125rem, 9.0666666667vw);
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea .sysCartInForm {
    margin-bottom: min(0.3125rem, 1.3333333333vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea select {
    margin-top: min(0.125rem, 0.5333333333vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea input[type=text] {
    margin-top: min(0.125rem, 0.5333333333vw);
  }
  #sysBasket #sysWrap #sysMain .sysItemListArea .sysBox .sysSubTotalArea > .sysCartAttention {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(0.3125rem, 1.3333333333vw);
  }
  #sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container {
    padding: min(0.9375rem, 4vw);
  }
  #sysBasket #sysWrap #sysMain .modaal-wrapper .modaal-container .basketCouponEditDialog .basketCouponEdit .basketCouponTitle {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.25rem, 1.0666666667vw);
  }
  #sysRegi #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysRegi #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysRegi #sysWrap #sysMain .sysCartTitle {
    font-size: min(0.9375rem, 4vw);
    padding-top: min(1.25rem, 5.3333333333vw);
  }
  #sysRegi #sysWrap #sysMain .sysBox > p {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysThanks #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox > div:has(.sysMemberAgreementFormLabel) {
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox > div:has(.sysMemberAgreementFormLabel) .sysMemberAgreementFormLabel {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox > div:has(.sysMemberAgreementFormLabel) .sysMemberAgreement {
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.9375rem, 4vw);
  }
  #sysThanks #sysWrap {
    padding-top: min(3.75rem, 16vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) {
    padding: min(0.9375rem, 4vw);
    margin-block: min(2.8125rem, 12vw) min(0.9375rem, 4vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) .sysOrderNumber {
    font-size: min(1.0625rem, 4.5333333333vw);
    margin-top: min(0.5rem, 2.1333333333vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox:has(.sysCartNote) .sysCartNote {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysThanks #sysWrap #sysMain .sysBox:has(.sysForm) {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysMypage .sysOrder input[value=再注文する] {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .sysMypage .sysOrder input[value=再注文する] {
    margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
  }
  #sysMypageRepeat #sysRepeatOrderDetail table td a {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysMypageRepeat #sysRepeatOrderDetail table td a {
    margin: min(0.625rem, 2.6666666667vw) auto 0 0;
  }
  #sysMypageRepeat #sysMain form:first-of-type input[value=登録する],
  #sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysMain form:first-of-type input[value=登録する] {
    margin-top: min(1.875rem, 8vw);
  }
  #sysMypageRepeat #sysMain .sysRepeatOrderNextOrderAttachedItemRequest input[value=商品を追加する] {
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageRepeat .sysRepeatOrderAttachedItemDialogClose {
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageIndex:has(form[action*="skip/done"]) #sysMain form:first-of-type input[value=スキップする],
  #sysMypageRepeatCancelConfirm input[value=キャンセルする] {
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  .sysCallOrderHistoryDetail button {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .sysCallOrderHistoryDetail button {
    margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
  }
  #sysMypageIndex .sysItemReviewLink a,
  #sysMypageOrderHistory .sysItemReviewLink a {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysMypageIndex .sysItemReviewLink a,
  #sysMypageOrderHistory .sysItemReviewLink a {
    margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
  }
  #sysMypageIndex .sysItemReviewLink span,
  #sysMypageOrderHistory .sysItemReviewArea > span {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysMypageIndex .sysItemReviewLink span,
  #sysMypageOrderHistory .sysItemReviewArea > span {
    margin: min(0.625rem, 2.6666666667vw) auto min(0.625rem, 2.6666666667vw) 0;
  }
  #sysMypageWithdrawalConfirm form:first-of-type .sysButton {
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  .sysMypage #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  .sysMypage #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysMypageMinorHeadLine {
    font-size: min(0.9375rem, 4vw);
  }
  .sysMypage #sysWrap #sysMain .sysMypageNav {
    flex-direction: column;
    margin-top: min(1.875rem, 8vw);
  }
  .sysMypage #sysWrap #sysMain .sysMypageNav form {
    width: 100%;
  }
  .sysMypage #sysWrap #sysMain .sysOrderHistory > div {
    font-size: min(0.75rem, 3.2vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList:has(.sysOrderHeader) .sysOrders {
    padding: min(0.9375rem, 4vw);
    margin: 0 0 min(0.625rem, 2.6666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderHistory .sysOrderList:not(:has(.sysOrderHeader)) .sysOrder {
    padding: min(0.9375rem, 4vw);
    margin: 0 0 min(0.625rem, 2.6666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderNumberArea {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderDetailArea {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin: 0 0 min(0.625rem, 2.6666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderDetailArea .sysOrderDatatimeGroup {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysOrderHistoryDetailHeader {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin: min(1.0625rem, 4.5333333333vw) 0 min(0.5625rem, 2.4vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.9375rem, 4vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemGroup {
    gap: min(0.625rem, 2.6666666667vw);
    border: none;
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemGroup .sysItemImageGroup {
    width: min(5rem, 21.3333333333vw);
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemGroup .sysItemSummaryGroup {
    width: calc(100% - min(5.625rem, 24vw));
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysDeliveryList .sysDelivery .sysItemArea .sysItem .sysItemReviewArea {
    padding: min(0.625rem, 2.6666666667vw) 0 0;
  }
  .sysMypage #sysWrap #sysMain .sysOrderDetail #sysMypageOrderHistoryDetail .sysCartOption_RemarkArea {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) 0 min(1.875rem, 8vw);
  }
  #sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword h3 {
    font-size: min(0.9375rem, 4vw);
  }
  #sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword h4 {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword .sysMemberPasswordDescription {
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword .sysMemberPasswordDescription small {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword .sysLengthMessageText,
  #sysMypageEditMember #sysWrap #sysMain form .sysForm .sysMemberPassword .sysFormCaution {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageEditConfirm #sysWrap #sysMain > div {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageEditConfirm #sysWrap #sysMain .sysForm .sysFormItem {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding-bottom: min(0.375rem, 1.6vw);
  }
  #sysMypageEditSave #sysWrap #sysMain > p,
  #sysMypageEditSavedelivery #sysWrap #sysMain > p {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysMypageEditDelivery #sysWrap #sysMain .sysSelectAddress button {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.9375rem, 4vw);
  }
  #sysMypageEditDelivery #sysWrap #sysMain > form > p {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysMypagePoint #sysAll #sysMain .sysMyPoint {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageReview #sysAll #sysMain .sysCoupon {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.9375rem, 4vw);
  }
  #sysMypageReview #sysAll #sysMain .sysCoupon .sysCouponDiscount {
    padding-bottom: min(0.9375rem, 4vw);
  }
  #sysMypageAshiato #sysAll #sysMain .sysItemListDisp {
    margin-block: min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw);
  }
  #sysMypageAshiato #sysAll #sysMain .sysItemListDisp .sysItemListViewType {
    gap: min(0.9375rem, 4vw);
  }
  #sysMypageAshiato #sysAll #sysMain .sysItemListDisp .sysItemListViewType label {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysMypageAshiato #sysAll #sysMain .sysItemList div {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageReview #sysAll #sysMain .sysItemListDisp {
    font-size: min(0.75rem, 3.2vw);
    margin-block: min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw);
  }
  #sysMypageReview #sysAll #sysMain .sysItemListDisp .sysItemListViewType {
    gap: min(0.9375rem, 4vw);
  }
  #sysMypageReview #sysAll #sysMain .sysItemListDisp .sysItemListViewType label {
    font-size: min(0.75rem, 3.2vw) !important;
  }
  #sysMypageRestockRequest #sysAll #sysMain .sysItemListDisp {
    margin-block: min(1.25rem, 5.3333333333vw) min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRestockRequest #sysAll #sysMain .sysItemListDisp .sysItemListViewType {
    gap: min(0.9375rem, 4vw);
  }
  #sysMypageRestockRequest #sysAll #sysMain .sysItemListDisp .sysItemListViewType label {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysMypageAshiato .sysItemList ul.sysThumbnail,
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail,
  #sysMypageRestockRequest .sysItemList ul.sysThumbnail {
    gap: min(1.5625rem, 6.6666666667vw) min(0.9375rem, 4vw);
  }
  #sysMypageAshiato .sysItemList ul.sysThumbnail li,
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li,
  #sysMypageRestockRequest .sysItemList ul.sysThumbnail li {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  #sysMypageAshiato .sysItemList ul.sysThumbnail li > div:not([class]),
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li > div:not([class]),
  #sysMypageRestockRequest .sysItemList ul.sysThumbnail li > div:not([class]) {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageAshiato .sysItemList ul.sysThumbnail li form input[type=submit],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li form input[type=submit],
  #sysMypageRestockRequest .sysItemList ul.sysThumbnail li form input[type=submit] {
    box-sizing: border-box;
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  #sysMypageAshiato .sysItemList ul.sysThumbnail li form input[type=submit][value=お気に入りから削除する],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li form input[type=submit][value=お気に入りから削除する],
  #sysMypageRestockRequest .sysItemList ul.sysThumbnail li form input[type=submit][value=お気に入りから削除する] {
    margin-top: min(0.3125rem, 1.3333333333vw);
  }
  #sysMypageAshiato .sysItemList ul.sysThumbnail li form input[type=submit][value=再入荷リクエストを解除する],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li form input[type=submit][value=再入荷リクエストを解除する],
  #sysMypageRestockRequest .sysItemList ul.sysThumbnail li form input[type=submit][value=再入荷リクエストを解除する] {
    font-size: min(0.6875rem, 2.9333333333vw);
    margin-top: min(0.3125rem, 1.3333333333vw);
  }
  #sysMypageAshiato .sysItemList ul.sysList li,
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li,
  #sysMypageRestockRequest .sysItemList ul.sysList li {
    gap: 0 min(0.9375rem, 4vw);
    padding-block: min(0.9375rem, 4vw);
  }
  #sysMypageAshiato .sysItemList ul.sysList li .sysThumbnailImage,
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li .sysThumbnailImage,
  #sysMypageRestockRequest .sysItemList ul.sysList li .sysThumbnailImage {
    width: min(6.25rem, 26.6666666667vw);
  }
  #sysMypageAshiato .sysItemList ul.sysList li > div:not([class]),
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li > div:not([class]),
  #sysMypageRestockRequest .sysItemList ul.sysList li > div:not([class]) {
    width: calc(100% - min(7.1875rem, 30.6666666667vw));
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageAshiato .sysItemList ul.sysList li form input[type=submit],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form input[type=submit],
  #sysMypageRestockRequest .sysItemList ul.sysList li form input[type=submit] {
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  #sysMypageAshiato .sysItemList ul.sysList li form input[type=submit][value=お気に入りから削除する],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form input[type=submit][value=お気に入りから削除する],
  #sysMypageRestockRequest .sysItemList ul.sysList li form input[type=submit][value=お気に入りから削除する] {
    margin-top: min(0.3125rem, 1.3333333333vw);
    margin-left: min(7.1875rem, 30.6666666667vw);
  }
  #sysMypageAshiato .sysItemList ul.sysList li form input[type=submit][value=再入荷リクエストを解除する],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form input[type=submit][value=再入荷リクエストを解除する],
  #sysMypageRestockRequest .sysItemList ul.sysList li form input[type=submit][value=再入荷リクエストを解除する] {
    margin-top: min(0.3125rem, 1.3333333333vw);
    margin-left: min(7.1875rem, 30.6666666667vw);
  }
  #sysMypageReview #sysWrap #sysMain .sysMyReviewList {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageReview #sysWrap #sysMain .sysMyReviewList .sysItemName {
    padding-top: min(1.25rem, 5.3333333333vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  #sysMypageReview #sysWrap #sysMain .sysMyReviewList .sysReview {
    padding-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo {
    margin-top: min(0.625rem, 2.6666666667vw);
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderList .sysRepeatOrder .sysRepeatOrderInfo td {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail h2 {
    font-size: min(0.9375rem, 4vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder h4,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext h4 {
    font-size: min(0.9375rem, 4vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysChangedRepeatOrderMessage,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysChangedRepeatOrderNextMessage,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysChangedRepeatOrderMessage,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysChangedRepeatOrderNextMessage {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo {
    margin-top: min(0.5rem, 2.1333333333vw);
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo td,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo td {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderInfo th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderInfo th {
    width: 34%;
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr td,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr td {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrder .sysRepeatOrderAttachedItem tr th:nth-of-type(3),
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderDetail .sysRepeatOrderNext .sysRepeatOrderAttachedItem tr th:nth-of-type(3) {
    width: 15%;
  }
  #sysMypageRepeat #sysWrap #sysMain > p,
  #sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > p,
  #sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > p,
  #sysMypageRepeatCancelConfirm #sysWrap #sysMain > p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div,
  #sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div,
  #sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div,
  #sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2),
  #sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2),
  #sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2),
  #sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div:nth-of-type(2) {
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain > form:first-of-type > div:has(input, select),
  #sysMypageIndex:has(form[action*="editNextOrder/addressSave"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select),
  #sysMypageIndex:has(form[action*="skip/done"]) #sysWrap #sysMain > form:first-of-type > div:has(input, select),
  #sysMypageRepeatCancelConfirm #sysWrap #sysMain > form:first-of-type > div:has(input, select) {
    margin-top: min(0.375rem, 1.6vw);
  }
  #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderSummary {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.9375rem, 4vw);
  }
  #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest .sysRepeatOrderNextOrderAttachedItemRequestTitle {
    font-size: min(0.9375rem, 4vw);
  }
  #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th,
  #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr td {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th:first-of-type {
    width: 40%;
  }
  #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th:nth-of-type(2), #sysMypageRepeat #sysWrap #sysMain .sysRepeatOrderNextOrderAttachedItemRequest #sysRepeatOrderNextOrderAttachedItemRequestList tr th:last-of-type {
    width: 30%;
  }
  #sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container {
    padding: min(0.9375rem, 4vw);
  }
  #sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysRepeatOrderAttachedItemListBlock .sysRepeatOrderAttachedItemList {
    gap: min(0.9375rem, 4vw);
  }
  #sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysRepeatOrderAttachedItemListBlock .sysRepeatOrderAttachedItemList .sysRepeatOrderAttachedItemListItem {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  #sysMypageRepeat .sysRepeatOrderAttachedItemDialogWrapper .modaal-outer-wrapper .modaal-inner-wrapper .modaal-container .modaal-content .modaal-content-container .sysRepeatOrderAttachedItemListBlock .sysRepeatOrderAttachedItemList .sysRepeatOrderAttachedItemListItem input[type=button] {
    max-width: 100%;
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw);
    margin-top: min(0.75rem, 3.2vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory h2 {
    font-size: min(0.9375rem, 4vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder h4 {
    font-size: min(0.9375rem, 4vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysChangedRepeatOrderNextMessage {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo {
    margin-top: min(0.5rem, 2.1333333333vw);
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo td {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderInfo th {
    width: 34%;
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr th,
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr td {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageRepeat #sysWrap #sysMain #sysRepeatOrderHistory .sysRepeatOrder .sysRepeatOrderAttachedItem tr th:nth-of-type(3) {
    width: 15%;
  }
  #sysMypageWithdrawalConfirm #sysWrap #sysMain .sysWithdrawal > p,
  #sysMypageWithdrawalDone #sysWrap #sysMain .sysWithdrawal > p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageLogin #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysMypageLogin #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageLogin #sysWrap #sysMain .sysIsUseAutoLogin {
    margin-block: min(1.875rem, 8vw);
  }
  #sysMypageLogout #sysAll #sysMain > p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMypageReminder #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysMypageReminder #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysMypageReminder #sysWrap #sysMain .sysMypageMinorHeadLine {
    font-size: min(0.9375rem, 4vw);
    margin-top: min(1.25rem, 5.3333333333vw);
    margin-bottom: min(0.75rem, 3.2vw);
  }
  #sysMypageReminder #sysWrap #sysMain .sysFormField {
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysMypageReminder #sysWrap #sysMain div {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  button[name=searchAddress] {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  button[name=searchAddress] {
    margin: 0 auto 0 0;
  }
  #sysMemberRegisterIndex #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysMemberRegisterIndex #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysMemberRegisterIndex #sysWrap #sysMain > div .sysMemberAgreementFormLabel {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysMemberRegisterIndex #sysWrap #sysMain > div .sysMemberAgreement {
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.9375rem, 4vw);
  }
  #sysMemberRegisterIndex #sysWrap #sysMain #form_main .sysForm > label {
    margin-top: min(0.375rem, 1.6vw);
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysMemberRegisterIndex #sysWrap #sysMain #form_main .sysForm .sysFormCaution {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysMemberRegisterIndex #sysWrap #sysMain #form_main .sysForm > input[type=submit] {
    margin-top: min(1.875rem, 8vw);
  }
  #sysMemberRegisterConfirm #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysMemberRegisterConfirm #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysMemberRegisterConfirm #sysWrap #sysMain > div {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysMemberRegisterConfirm #sysWrap #sysMain #sysDone .sysForm .sysFormItem {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding-bottom: min(0.375rem, 1.6vw);
  }
  #sysMemberRegisterRegister #sysWrap #sysMain > p {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: 0;
  }
  .opcOrderSummary_usePointAndCoupon {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .opcOrderSummary_usePointAndCoupon {
    margin: min(0.3125rem, 1.3333333333vw) 0 0 auto;
  }
  .opcBillingAddress_zipCodeSearchButton_edit,
  .opcClient_zipCodeSearchButton_edit,
  .opcDeliveryAddress_zipCodeSearchButton_edit {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .opcBillingAddress_zipCodeSearchButton_edit,
  .opcClient_zipCodeSearchButton_edit,
  .opcDeliveryAddress_zipCodeSearchButton_edit {
    margin: min(0.3125rem, 1.3333333333vw) 0 0 auto;
  }
  .opcBillingAddress_editButton,
  .opcPaymentMethod_editButton {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .opcBillingAddress_editButton,
  .opcPaymentMethod_editButton {
    margin: min(0.3125rem, 1.3333333333vw) 0 0 auto;
  }
  .opcClient_editButton,
  .opcDeliveryAddress_editButton,
  .opcDeliveryMethod_editButton,
  .opcDeliveryAddressItemTitle_editButton {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .opcClient_editButton,
  .opcDeliveryAddress_editButton,
  .opcDeliveryMethod_editButton,
  .opcDeliveryAddressItemTitle_editButton {
    margin: 0 0 0 auto;
  }
  .opcCompletedDeliveryAddressList_changeItems_edit {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .opcDeliveryAddressTitle_deleteButton,
  .opcDeliveryAddressList_addButton {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .opcDeliveryAddressTitle_deleteButton,
  .opcDeliveryAddressList_addButton {
    margin: 0 0 0 auto;
  }
  .opcCouponCode_useButton_edit {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .opcCouponCode_useButton_edit {
    margin: min(0.3125rem, 1.3333333333vw) 0 0 auto;
  }
  .sysOpcBody #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcCommonEditModeBlock,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddress,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcClient,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressSummary,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethod,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarks_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSubstituteOrderMemo_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcPoint_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemPoint_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcCouponCode_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcCoupon_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMember_memberAgreementDescription_edit {
    padding: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcBillingAddressTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcClientTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarksTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSubstituteOrderMemoTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcPointTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcCouponCodeTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcCouponTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMemberTitle,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcDeliveryAddressHeaderGroup .opcDeliveryAddressHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGiftLetterTitle {
    font-size: min(0.9375rem, 4vw);
    margin-top: min(1.25rem, 5.3333333333vw);
    margin-bottom: min(0.75rem, 3.2vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeader {
    font-size: min(0.9375rem, 4vw);
    margin-top: min(0.625rem, 2.6666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcDeliveryAddressHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcDeliveryMethodHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcDeliveryAddressItemHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup .opcSocialGiftLetter_letterImageTitleLabel_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcDeliveryAddressHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcDeliveryMethodHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcDeliveryAddressItemHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup .opcSocialGiftLetter_letterImageTitleLabel_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcDeliveryAddressHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcDeliveryMethodHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcDeliveryAddressItemHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup .opcSocialGiftLetter_letterImageTitleLabel_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryAddressHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryMethodHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryAddressItemHeader,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcSocialGiftLetter_letterImageTitleLabel_edit {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcCommonEditLabel {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(0.625rem, 2.6666666667vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalPricesAndLabelGroup,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalPricesGroup,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalAmount,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummary_totalPoint {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcCommonButtonGroupEdit {
    margin-top: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressHeaderGroup,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodHeaderGroup,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressItemHeaderGroup {
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressGroup,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodGroup {
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_purposeAnditemCommonOptionGroup_edit .opcItem_purposeAndLabelGroup_edit {
    margin-top: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcRequestOrderArea:has(form[name=order_form_top]) {
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcRequestOrderArea:has(form[name=order_form_bottom]) {
    margin-top: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSelectDeliveries_edit {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList {
    padding: 0;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcPaymentMethodList .opcPaymentMethod_edit {
    padding: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit {
    padding: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_totalPricesAndLabelGroup {
    padding: 0 0 min(0.5rem, 2.1333333333vw) 0;
    margin: 0 0 min(0.5rem, 2.1333333333vw) 0;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_priceBreakDownGroup .opcOrderSummary_feeAndLabelGroup {
    padding: 0 0 min(0.5rem, 2.1333333333vw) 0;
    margin: 0 0 min(0.5rem, 2.1333333333vw) 0;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcOrderSummaryArea .opcOrderSummary .opcOrderSummary_priceBreakDownGroup .opcOrderSummary_usePointPriceAndLabelGroup {
    padding: 0 0 min(0.5rem, 2.1333333333vw) 0;
    margin: 0 0 min(0.5rem, 2.1333333333vw) 0;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_purposeAndLabelGroup_edit select,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_purposeAndLabelGroup_edit select {
    height: min(2.125rem, 9.0666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_purposeAndLabelGroup_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_purposeAndLabelGroup_edit {
    margin-bottom: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionTitleAndOptionNameGroup_edit {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit {
    margin-bottom: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit:last-of-type,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit:last-of-type {
    margin-bottom: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit {
    gap: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionOptionLabel_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailGroup_edit .opcItem_itemCommonOptionOptionGroup_edit .opcItem_itemCommonOptionOptionLabel_edit .opcItem_itemCommonOptionOptionBlock_edit .opcItem_itemCommonOptionOptionLabel_edit {
    font-size: min(0.75rem, 3.2vw);
    margin-bottom: min(0.5625rem, 2.4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItemCommonOptionsArea .opcItem_itemCommonOptionDetailAndLabelGroup_edit,
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit .opcItem_itemCommonOptionDetailAndLabelGroup_edit {
    margin-top: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcItem_itemCommonOptionGroup_edit {
    margin-top: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcDeliveryAddressHeader {
    margin-bottom: min(0.375rem, 1.6vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcDeliveryAddressAndItemsGroup_edit .opcItem_numAndLabelGroup_edit .opcItem_num_edit {
    height: min(2.625rem, 11.2vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit li > div > div select {
    height: min(2.125rem, 9.0666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit li > div {
    gap: min(0.3125rem, 1.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit > div > div select {
    height: min(2.125rem, 9.0666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit {
    margin-top: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit {
    padding: min(0.9375rem, 4vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit:last-of-type {
    margin-bottom: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryAddressSummary {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit {
    margin-bottom: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcMultiDelivery .opcDeliveryMethodsArea .opcDeliveryMethodListDataBind .opcDeliveryMethodListArea .opcDeliveryMethodListGroup_edit .opcDeliveryMethodGroup_edit .opcDeliveryMethod_edit .opcDeliveryMethod_deliveryMethodListGroup_edit .opcDeliveryMethod_deliveryMethodAndLabelGroup_edit > div {
    gap: min(0.3125rem, 1.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcRemarksArea {
    margin-bottom: min(1.875rem, 8vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_checkedValueLabelGroup_edit {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit {
    flex-wrap: nowrap;
    gap: 0;
    width: calc(100% + min(1.875rem, 8vw));
    margin-left: max(-0.9375rem, -4vw);
    overflow-x: scroll;
    -ms-overflow-style: none;
    scrollbar-width: none;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit::-webkit-scrollbar {
    display: none;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit::before, .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit::after {
    content: "";
    flex-shrink: 0;
    display: block;
    width: min(0.9375rem, 4vw);
    height: 1px;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit {
    width: min(10rem, 42.6666666667vw);
    margin-right: min(0.625rem, 2.6666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit:last-of-type {
    margin-right: 0;
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_letterImageTitleAndImageGroup_edit .opcSocialGiftLetter_letterImageGroup_edit .opcSocialGiftLetter_letterImageAndTitleGroup_edit .opcSocialGiftLetter_imageTitleGroup_edit .opcSocialGiftLetter_imageTitle_edit {
    font-size: min(0.75rem, 3.2vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_messageTitleAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit {
    padding: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter_edit .opcSocialGiftLetterContentsGroup_edit .opcSocialGiftLetter_detailGroup_edit .opcSocialGiftLetter_messageTitleAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewGroup_edit {
    margin-bottom: min(0.9375rem, 4vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup .opcSocialGiftLetter_detailGroup .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit {
    gap: min(0.625rem, 2.6666666667vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup .opcSocialGiftLetter_detailGroup .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_letterImagePreviewGroup {
    width: min(5rem, 21.3333333333vw);
  }
  .sysOpcBody #sysWrap #sysMain #sysOpc .opcSocialGift .opcSocialGiftLetter .opcSocialGiftLetterContentsGroup .opcSocialGiftLetter_detailGroup .opcSocialGiftLetter_letterImagePreviewAndMessageGroup_edit .opcSocialGiftLetter_messageGroup {
    width: calc(100% - min(5.625rem, 24vw));
  }
  .modaal-wrapper .opcPointAndCouponDialog {
    min-width: 0;
  }
  #sysFormIndex #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysFormIndex #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysFormIndex #sysWrap #sysMain > p {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  #sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField > p {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField:not(:has(input[type=radio])) > p {
    margin-bottom: min(0.3125rem, 1.3333333333vw);
  }
  #sysFormIndex #sysWrap #sysMain form .sysForm .sysFormItem .sysFormField:has(input[type=radio]) {
    gap: min(0.3125rem, 1.3333333333vw) 0;
  }
  #sysFormConfirm #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysFormConfirm #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysFormConfirm #sysWrap #sysMain form .sysForm .sysFormItem {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding-bottom: min(0.375rem, 1.6vw);
  }
  #sysFormThanks #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysFormThanks #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysFormThanks #sysWrap #sysMain > p {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemReviewIndex #sysMain input[value=並び替え] {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysItemReviewIndex #sysMain input[value=並び替え] {
    margin: 0;
  }
  #sysItemReviewIndex #sysMain input[value=不適切なレビューの報告] {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysItemReviewIndex #sysMain input[value=不適切なレビューの報告] {
    margin-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemReviewIndex #sysMain .sysReviewItemName a[href*="/ir/"] {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  #sysItemReviewIndex #sysMain .sysReviewItemName a[href*="/ir/"] {
    margin: min(0.625rem, 2.6666666667vw) auto 0 0;
  }
  #sysItemReviewIndex #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysItemReviewIndex #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain > h2 {
    font-size: min(0.9375rem, 4vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain > div {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain > h3 {
    font-size: min(0.9375rem, 4vw);
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .SysImproperReviewTitle {
    font-size: min(0.9375rem, 4vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .SysImproperReviewContent {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .SysImpropalReviewDone {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain form .SysImproperReviewForm {
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain form .SysImproperReviewForm li .SysImpropalReviewTextareaTitle {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.375rem, 1.6vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain form .SysImproperReviewForm li:has(.SysImpropalReviewTextareaTitle) + li:not(:has(.SysImproperReviewFormTextarea)) {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding-bottom: min(0.375rem, 1.6vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain form:has(input[value=商品詳細]) {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain form:has(select[name=sort]) select {
    height: min(2.125rem, 9.0666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList {
    display: flex;
    flex-direction: column;
    gap: min(0.625rem, 2.6666666667vw);
    width: calc(100% + min(1.875rem, 8vw));
    background-color: #eeeeee;
    padding: min(1.875rem, 8vw) min(0.9375rem, 4vw) min(1.5625rem, 6.6666666667vw);
    margin-left: max(-0.9375rem, -4vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li {
    gap: 0 min(0.5rem, 2.1333333333vw);
    padding: min(0.9375rem, 4vw) min(0.9375rem, 4vw) min(2.6875rem, 11.4666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysThumbnailImage,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysThumbnailImage {
    width: min(3.75rem, 16vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysReviewItemName,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysReviewItemName {
    width: calc(100% - min(4.6875rem, 20vw));
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysNickname,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysNickname {
    max-width: calc(100% - min(5.8125rem, 24.8vw));
    font-size: min(0.75rem, 3.2vw);
    line-height: 1.5;
    padding-left: min(1.875rem, 8vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysNickname::before,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysNickname::before {
    width: min(1.375rem, 5.8666666667vw);
    height: min(1.375rem, 5.8666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysReviewText,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysReviewText {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemReviewIndex #sysWrap #sysMain .sysReviewHistoryList li .sysReviewDatetime,
  #sysItemReviewIndex #sysWrap #sysMain .sysAllReviewHistoryList li .sysReviewDatetime {
    font-size: min(0.75rem, 3.2vw);
    bottom: min(0.9375rem, 4vw);
    right: min(0.9375rem, 4vw);
  }
  #sysItemReviewConfirm #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysItemReviewConfirm #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemReviewConfirm #sysWrap #sysMain > h2 {
    font-size: min(0.9375rem, 4vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  #sysItemReviewConfirm #sysWrap #sysMain > div:not(.sysForm) {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  #sysItemReviewConfirm #sysWrap #sysMain > h3 {
    font-size: min(0.9375rem, 4vw);
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  #sysItemReviewConfirm #sysWrap #sysMain .sysForm .sysFormItem {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding-bottom: min(0.375rem, 1.6vw);
  }
  #sysItemReviewThanks #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysItemReviewThanks #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysItemReviewThanks #sysWrap #sysMain > div {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(1.875rem, 8vw);
  }
  #sysWrap:has(.text-page) {
    padding-inline: min(0.9375rem, 4vw);
  }
  #sysWrap:has(.text-page) {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box .txt-contents-ttl-sub {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table thead th {
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table tbody th,
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .txt-container .txt-container-box table tbody td {
    padding: min(0.9375rem, 4vw) min(0.625rem, 2.6666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .trade-law-container .trade-law-container-box dl {
    flex-flow: column;
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .trade-law-container .trade-law-container-box dt {
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .trade-law-container .trade-law-container-box dd {
    padding: min(0.9375rem, 4vw) min(0.625rem, 2.6666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .company-container dl {
    flex-flow: column;
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .company-container dt {
    padding: min(0.625rem, 2.6666666667vw);
  }
  #sysWrap:has(.text-page) #sysMain .text-page .sysContent .company-container dd {
    padding: min(0.9375rem, 4vw) min(0.625rem, 2.6666666667vw);
  }
  .sysSocialGiftReceiveDeliveryAddressTitle_editButton,
  .sysSocialGiftReceiveItemsTitle_editButton {
    min-height: min(2rem, 8.5333333333vw);
    font-size: min(0.75rem, 3.2vw);
    padding: min(0.375rem, 1.6vw) min(0.9375rem, 4vw);
    margin: min(0.625rem, 2.6666666667vw) auto 0;
  }
  .sysSocialGiftReceiveDeliveryAddressTitle_editButton,
  .sysSocialGiftReceiveItemsTitle_editButton {
    margin: min(0.3125rem, 1.3333333333vw) 0 0 auto;
  }
  .sysSocialGiftBody #sysWrap {
    padding-inline: min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap {
    padding-top: min(0.625rem, 2.6666666667vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .title-small-underline {
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain form[action*="/product/"] .sysSocialGiftReceiveItemsTitle,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsTitle {
    font-size: min(0.9375rem, 4vw);
    margin-bottom: min(1.875rem, 8vw);
    margin-top: min(1.25rem, 5.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsTitle,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressTitle {
    font-size: min(0.9375rem, 4vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveTopPageContent,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItems_assortmentParentName,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryMethodTitle {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(0.625rem, 2.6666666667vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveButtonArea,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftButtonGroup {
    margin-top: min(1.875rem, 8vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea {
    padding: min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea .sysSocialGiftReceiveGiftLetterImageGroup {
    margin-bottom: min(0.625rem, 2.6666666667vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveGiftLetterArea .sysSocialGiftReceiveGiftLetterMessageGroup {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding: min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveLimitDate {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(1.875rem, 8vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItem {
    margin-bottom: min(1.875rem, 8vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup {
    gap: min(0.625rem, 2.6666666667vw);
    padding-bottom: min(0.9375rem, 4vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemImageGroup {
    width: min(5rem, 21.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItems_itemNameGroup {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding-bottom: min(0.5rem, 2.1333333333vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItem_subTotalNumAndLabelGroup {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary {
    width: calc(100% - min(5.625rem, 24vw));
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection {
    gap: min(1.875rem, 8vw) min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveItemsAreaGroup .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup {
    width: calc(50% - min(0.9375rem, 4vw) / 2);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup {
    gap: min(0.625rem, 2.6666666667vw);
    padding-bottom: min(0.9375rem, 4vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemImageGroup {
    width: min(5rem, 21.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItems_itemNameGroup {
    font-size: min(0.8125rem, 3.4666666667vw);
    padding-bottom: min(0.5rem, 2.1333333333vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItem_subTotalNumAndLabelGroup,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary .sysSocialGiftReceiveItems_variationNameGroup {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_itemAndLabelGroup .sysSocialGiftReceiveItems_itemSummary {
    width: calc(100% - min(5.625rem, 24vw));
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup {
    padding-bottom: min(0.9375rem, 4vw);
    margin-bottom: min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildName {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-bottom: min(0.125rem, 0.5333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveItemsArea .sysSocialGiftReceiveItems_itemListGroup .sysSocialGiftReceiveItem .sysSocialGiftReceiveItems_assortmentParentGroup .sysSocialGiftReceiveItems_assortmentParent .sysSocialGiftReceiveItems_assortmentChildSection .sysSocialGiftReceiveItems_assortmentChildGroup .sysSocialGiftReceiveItems_assortmentChildLabelGroup .sysSocialGiftReceiveItems_assortmentChildSummary .sysSocialGiftReceiveItems_assortmentChildDescription {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveDeliveryMethodArea .sysSelectDelivery {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveDeliveryMethodArea .sysSelectHopeDelivery > div:first-of-type {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceiveDeliveryAddressAndItemsAreaGroup .sysSocialGiftReceiveDeliveryMethodArea .sysSelectHopeDelivery > div label {
    font-size: min(0.8125rem, 3.4666666667vw);
    margin-top: min(0.625rem, 2.6666666667vw);
    margin-bottom: min(0.5rem, 2.1333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryAddressHeaderGroup,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveItemHeaderGroup {
    padding-bottom: min(0.5rem, 2.1333333333vw);
    margin-bottom: min(0.75rem, 3.2vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryMethodArea {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryAddress_deliveryAddressGroup,
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(form[action*="/giftReceive/save"]) .sysSocialGiftReceiveDeliveryMethod_deliveryMethodGroup {
    font-size: min(0.8125rem, 3.4666666667vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) {
    padding-top: min(3.125rem, 13.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) {
    margin-bottom: min(2.5rem, 10.6666666667vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) {
    padding: min(0.9375rem, 4vw);
    margin-block: min(2.8125rem, 12vw) min(0.9375rem, 4vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) > div:has(.sysOrderNumber) .sysOrderNumber {
    font-size: min(1.0625rem, 4.5333333333vw);
    margin-top: min(0.5rem, 2.1333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysBox:has(.sysCartNote) .sysCartNote {
    font-size: min(0.75rem, 3.2vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysSocialGiftReceiveThanksPageFreeAreaBottom .campaign-btn {
    margin-bottom: min(1.25rem, 5.3333333333vw);
  }
  .sysSocialGiftBody #sysWrap #sysMain .sysSocialGiftReceive:has(.sysSocialGiftReceiveThanksPageContent) .sysSocialGiftReceiveThanksPageFreeAreaBottom .campaign-txt {
    font-size: min(0.75rem, 3.2vw);
  }
.sysPrintDeliveryNote button, .sysCallPrintReceipt button{
    color: #000000;
}
}
@media (min-width: 46.9375em) and (max-width: 60em) {
  body {
    font-size: min(1rem, 4.2666666667vw);
  }
  .pc_only {
    display: none !important;
  }
  .sp_only {
    display: none !important;
  }
  .tb_only {
    display: block !important;
  }
  .sysFuncItemBlock .sysCartButton {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul li .sysIconRank {
    width: min(1.875rem, 8vw);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemName a {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysMain .sysFuncItemBlock .sysItemBlock ul li .sysItemPrice {
    font-size: min(0.875rem, 3.7333333333vw);
  }

  #sysHeader .header-logo {
    width: min(9.5625rem, 40.8vw);
  }
  #sysHeader .header-search form {
    width: min(15.3125rem, 65.3333333333vw);
  }
  #sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysHeadline {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysContent nav {
    padding: 1.25rem min(1.875rem, 8vw);
  }
  #sysHeader .header-bottom .sysFuncItemCategory.header-content-bottom-left .sysContent nav ul li a {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysHeader .header-bottom .sysFuncListNav.header-content-bottom-left ul {
    gap: min(1.25rem, 5.3333333333vw);
  }
  #sysHeader .header-bottom .sysFuncListNav.header-content-bottom-left ul li a {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysHeader .header-bottom .header-shop-info ul {
    gap: min(1.25rem, 5.3333333333vw);
  }
  #sysHeader .header-bottom .header-shop-info ul li a {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysHeader .header-bottom .header-shop-info ul li a .icon {
    width: min(1.25rem, 5.3333333333vw);
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer {
    flex-wrap: wrap;
    max-width: min(42.125rem, 179.7333333333vw);
    margin-inline: auto;
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-img {
    max-width: 100%;
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-img ul {
    flex-direction: row;
    justify-content: center;
    gap: 0;
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-img ul li {
    width: 50%;
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-info {
    max-width: min(19.5rem, 83.2vw);
    margin-top: 0;
  }
  #sysFooter .shop-info-content .shop-info-container .shop-info-horizontal-conainer .shop-calender {
    margin-top: 0;
  }
  #sysFooter .footer-content .footer-container {
    flex-wrap: wrap;
    gap: min(1.875rem, 8vw);
    padding-block: min(1.875rem, 8vw);
  }
  #sysFooter .footer-content .footer-container > div {
    width: calc(33.3333333333% - min(3.75rem, 16vw) / 3);
  }
  #sysFooter .footer-content .footer-container .footer-logo {
    width: 100%;
  }
  #sysFooter .footer-content .footer-container .footer-logo > .sysContent {
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  #sysFooter .footer-content .footer-container .footer-logo > .sysContent > ul {
    max-width: min(7.875rem, 33.6vw);
    margin-bottom: 0;
  }
  #sysFooter .footer-content .footer-container .footer-sns {
    width: -moz-fit-content;
    width: fit-content;
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block {
    gap: min(0.9375rem, 4vw);
    width: min(16.25rem, 69.3333333333vw);
    padding: min(0.9375rem, 4vw);
    bottom: min(0.9375rem, 4vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-img {
    width: min(6.875rem, 29.3333333333vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info {
    width: min(8.4375rem, 36vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-name {
    font-size: min(0.875rem, 3.7333333333vw);
    margin-bottom: min(0.25rem, 1.0666666667vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-price {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #top .top-mv .top-mv__content .top-mv__wrap .top-mv__block a .item-block .item-info .item-button {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #top .top-banner ul {
    gap: min(1.875rem, 8vw);
  }
  #top .top-banner ul li {
    width: calc(33.3333333333% - min(3.75rem, 16vw) / 3);
  }
  #top .top-category-list-item .sysContent ul {
    gap: min(0.9375rem, 4vw);
  }
  #top .top-category-list-item .sysContent ul li {
    width: calc(25% - min(2.8125rem, 12vw) / 4);
  }
  #top .top-category-list-item .sysContent ul li a {
    padding: min(0.5rem, 2.1333333333vw) min(0.5rem, 2.1333333333vw) min(0.625rem, 2.6666666667vw);
  }
  #top .top-category-list-item .sysContent ul li a p {
    font-size: min(0.875rem, 3.7333333333vw);
    margin-top: min(0.625rem, 2.6666666667vw);
  }
  #top .category-list .sysContent ul {
    gap: min(0.9375rem, 4vw);
  }
  #top .category-list .sysContent ul li {
    width: calc(33.3333333333% - min(1.875rem, 8vw) / 3) !important;
  }
  #top .category-list .sysContent ul li a {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #top .top-topic .top-topic__content {
    align-items: flex-start;
  }
  #top .top-topic .top-topic__content .text-block {
    padding: min(1.875rem, 8vw);
    margin-top: 4.375rem;
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li .sysItemName a,
  #sysItemSearch .sysItemList ul.sysThumbnail li .sysItemName a {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li #sysDescriptionPc,
  #sysItemCategory .sysItemList ul.sysThumbnail li #sysDescriptionMobile,
  #sysItemSearch .sysItemList ul.sysThumbnail li #sysDescriptionPc,
  #sysItemSearch .sysItemList ul.sysThumbnail li #sysDescriptionMobile {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li .sysRetailPrice,
  #sysItemSearch .sysItemList ul.sysThumbnail li .sysRetailPrice {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li > form input[type=submit],
  #sysItemSearch .sysItemList ul.sysThumbnail li > form input[type=submit] {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button,
  #sysItemSearch .sysItemList ul.sysThumbnail li .sysWishListButtonFormAjax button {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > div:not([class]) .sysItemName a,
  #sysItemSearch .sysItemList ul.sysList li > div:not([class]) .sysItemName a {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > div:not([class]) .sysRetailPrice,
  #sysItemSearch .sysItemList ul.sysList li > div:not([class]) .sysRetailPrice {
    font-size: min(0.875rem, 3.7333333333vw);
  }
  #sysItemCategory .sysItemList ul.sysList li > form input[type=submit],
  #sysItemSearch .sysItemList ul.sysList li > form input[type=submit] {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysItemCategory .sysItemList ul.sysList li .sysWishListButtonFormAjax button,
  #sysItemSearch .sysItemList ul.sysList li .sysWishListButtonFormAjax button {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysMypageAshiato .sysItemList ul.sysThumbnail li form input[type=submit],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysThumbnail li form input[type=submit],
  #sysMypageRestockRequest .sysItemList ul.sysThumbnail li form input[type=submit] {
    font-size: min(0.75rem, 3.2vw);
  }
  #sysMypageAshiato .sysItemList ul.sysList li form input[type=submit],
  #sysMypageReview:has(.sysItemList) .sysItemList ul.sysList li form input[type=submit],
  #sysMypageRestockRequest .sysItemList ul.sysList li form input[type=submit] {
    font-size: min(0.75rem, 3.2vw);
  }
}
@media (min-width: 60.0625em) {
  a[href*="tel:"] {
    pointer-events: none;
    cursor: default;
  }
  .tb_only {
    display: none !important;
  }
  .sp_only {
    display: none !important;
  }
  .pc_only {
    display: block !important;
  }
}
@media (max-width: 60em) {
  .sysPr span,
  .sysItemPrArea span {
    font-size: min(0.625rem, 2.6666666667vw);
  }
  #sysWrap #sysAside {
    display: none;
  }
  #sysItemCategory #sysWrap,
  #sysItemSearch #sysWrap {
    display: block;
  }
  #sysItemCategory #sysWrap #sysMain {
    width: 100%;
    margin: 0 auto;
  }
  #sysItemSearch #sysWrap #sysMain {
    width: 94%;
    margin: 0 auto;
  }
}
@media (prefers-reduced-motion: reduce), print {
  .animate__animated {
    animation-duration: 1ms !important;
    transition-duration: 1ms !important;
    animation-iteration-count: 1 !important;
  }
  .animate__animated[class*=Out] {
    opacity: 0;
  }
}
@media screen and (max-width: 1260px) {
  #top .top-category-img .top-category-item {
    right: 0;
  }
}
@media screen and (min-width: 751px) and (max-width: 1200px) {
  #top .top-review {
    padding: min(3.125rem, 13.3333333333vw) min(1.875rem, 8vw) min(1.875rem, 8vw);
  }
  #top .top-news {
    padding: min(3.125rem, 13.3333333333vw) min(1.875rem, 8vw);
  }
  #sysItemDetail article .sysReview {
    padding: min(3.125rem, 13.3333333333vw) min(1.875rem, 8vw);
  }
  #sysItemDetail article .sysReview form input[type=submit] {
    right: min(1.875rem, 8vw);
  }
}
@media screen and (min-width: 751px) and (max-width: 1000px) {
  #sysItemDetail article .item-container {
    flex-direction: column;
    align-items: center;
    gap: min(1.875rem, 8vw);
  }
  #sysItemDetail article .item-container .sysItemImages {
  flex: 0 0 calc(55% - 30px); /* 60pxの半分を引く */
  max-width: calc(55% - 30px);
  }
}
@media (min-width: 46.9375em) and (max-width: 75em) {
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormRange {
    margin-right: 0;
    margin-bottom: min(0.9375rem, 4vw);
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormCategory {
    display: block;
    width: 100%;
  }
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormCategory select {
    width: 100%;
    margin-top: min(0.3125rem, 1.3333333333vw);
    margin-left: 0;
  }
}
@media (max-width: 46.875em) and (max-width: 46.875em) {
  #sysItemSearch .sysItemSearchForm .sysItemSearchFormInput .sysItemSearchFormCategory select {
    height: min(2.125rem, 9.0666666667vw);
  }
}
@media (min-width: 60.0625em) and (max-width: 75em) {
  #sysItemCategory .sysItemList ul.sysThumbnail li,
  #sysItemSearch .sysItemList ul.sysThumbnail li {
    width: calc(33.3333333333% - min(3.25rem, 13.8666666667vw) / 3);
  }
}
/*# sourceMappingURL=user.css.map */


#sysHeader{
position: fixed;
z-index: 9999;
background-color: #ffffff; 
}

/* 配送・店舗受取選択のレイアウト */
/* ラジオボタンは非表示 */
.sysReceiveOptionRadioGroup input[type="radio"] {
  display: none;
}

/* 選択肢の共通スタイル */
.sysReceiveOptionTabLabel {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 2px solid #ccc;
  border-radius: 8px;
  padding: 10px 16px;
  cursor: pointer;
  margin-right: 10px;
  font-size: 14px;
  transition: all 0.2s ease;
}

/* 選択時の装飾 */
.sysReceiveOptionRadioGroup input[type="radio"]:checked + label.sysReceiveOptionTabLabel {
  border-color: #007aff;
  background-color: #b3d4fc;
  color: #007aff;
  font-weight: bold;
}

.sysReceiveAtStoreContent .sysReceiveStore,.sysReceiveAtStoreContent .sysReceiveDate,.sysReceiveOptionRadioGroup{
    margin-bottom: min(.625rem, 2.6666666667vw);
}


/*amazonpay非利用時のボタン位置の調整*/
#sysBasket .sysNextSubmitArea{
  display: block;
  margin-bottom: min(2.5rem, 10.6666666667vw);
  padding: 0;
  width: 100%;
}

@media (max-width: 46.875em) {
  #sysBasket .sysNextSubmitArea{
      margin-bottom: min(1.875rem, 8vw);
  }
}

/*在庫数表示の強調*/
#sysItemDetail article .item-container .item-info-container .sysStockQuantity{
  font-weight:600;
}
@media screen and (max-width:750px){

}
@media screen and (min-width:751px) and (max-width:960px){

}
@media screen and (min-width:961px){

}
/* #END_OF_RESOURCE_FILE */
