/* ##############################################################################

    DEFAULT

############################################################################## */
  html {
    font-size: max(9px, min(0.8333333333vw, 1rem));
    height: 100%;
    overflow-y: scroll;
    overflow-x: hidden;
  }
  @media screen and (min-width: 768px) and (max-width: 1080px) {
    html {
      font-size: 0.875rem;
      overflow-y: auto;
      overflow-x: auto;
    }
  }
  @media screen and (min-width: 768px) and (max-width: 880px) {
    html > body {
      min-width: 67.5rem;
    }
  }
  @media screen and (max-width: 767px) {
    html {
      font-size: min(3.3816425121vw, 0.875rem);
    }
  }
  body {
    position: relative;
    font-family: 'Shuei KakuGo Gin L', YuGothic, 'Yu Gothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic ProN', sans-serif;
    color: #3B3D52;
    background-position: top left;
    background-image: url(../images/common/ptn-bg.jpg);
    font-weight: 500;
    font-feature-settings: "palt";
    line-height: 1.7;
    word-break: break-word;
    padding-top: 7rem;
  }
  *,
  *:after,
  *::before {
    letter-spacing: .05em;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    box-sizing: border-box;
  }
  ul,
  ol { list-style: none; }
  small,.txt-sm { font-size: 86%; line-height: 1.5; }
  .txt-lg { font-size: 115%; }
  a {
    color: #3B3D52;
    text-decoration: none;
    transition: all .4s ease-out;
    outline : none;
  }
  a:hover {
    opacity: .7;
    text-decoration: none;
  }
  img,
  svg {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
    transition: all .4s ease-out;
  }
  iframe {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
    vertical-align: bottom;
  }
  address { font-style: normal; }

  @media screen and (min-width: 768px) {
    a { 
      -webkit-tap-highlight-color:rgba(0, 0, 0, 0); 
    }

    @-moz-document url-prefix() {
      * { font-feature-settings: "palt"; }
    }
    @media screen and (-webkit-min-device-pixel-ratio:0) {
      * { font-feature-settings: "palt"; }
    }
  }
  @media print, screen and (min-width: 768px) {
    body {
      font-size: max(14.1666666667px, min(0.8333333333vw, 1rem));
    }
  }
  @media screen and (max-width: 1080px) {
    body {
      padding-top: 4.5rem;
      -webkit-text-size-adjust: none;
      word-break: break-all;
    }
  }


/* ##############################################################################

    COMMON

############################################################################## */

/* layout
**************************************** */

  /* --- inner --- */
  .inner {
    width: 90%;
    max-width: 67.5rem; /* 1080px */
    margin: 0 auto;
  }
  .inner-sm {
    max-width: 50rem;
  }
  .inner-lg {
    max-width: 95rem; /* 1520px */
  }

  /* --- section_pdg --- */
  .section_pdg,
  .section_pdg-top,
  .section_pdg-btm {
    font-size: 1rem;
  }
  .section_pdg {
    padding-top: 5rem;
    padding-bottom: 5rem;
  }
  .section_pdg-top {
    padding-top: 5rem;
  }
  .section_pdg-btm {
    padding-bottom: 5rem;
  }
  .section_deco,
  .section_deco2 {
    position: relative;
    z-index: 10;
  }
  .section_deco::before {
    content: "";
    position: absolute;
    top: -6rem;
    left: 0;
    right: 0;
    height: fit-content;
    aspect-ratio: 1560 / 324;
    background-image: url(../images/common/section-border_s.png);
    background-size: cover;
  }
  .section_deco2::before {
    content: "";
    position: absolute;
    top: -4rem;
    left: 0;
    right: 0;
    height: fit-content;
    aspect-ratio: 1560 / 274;
    background-image: url(../images/common/section-border_s2.png);
    background-size: cover;
    background-repeat: no-repeat;
  }

  /* --- float --- */
  .flt-rgt { float: right; }
  .flt-lft { float: left; }

  /* --- position --- */
  .pos_rel {
    position: relative;
    z-index: 1;
  }
  .pos_ab {
    position: absolute;
    z-index: 0;
  }

  /* --- margin --- */
  .mgn-btm4 { margin-bottom: .25rem; }
  .mgn-btm8 { margin-bottom: .5rem; }
  .mgn-btm12 { margin-bottom: .75rem; }
  .mgn-btm16 { margin-bottom: 1rem; }
  .mgn-btm24 { margin-bottom: 1.5rem; }
  .mgn-btm32 { margin-bottom: 2rem; }
  .mgn-btm40 { margin-bottom: 2.5rem; }
  .mgn-btm48 { margin-bottom: 3rem; }
  .mgn-btm56 { margin-bottom: 3.5rem; }
  .mgn-btm64 { margin-bottom: 4rem; }
  .mgn-btm72 { margin-bottom: 4.5rem; }
  .mgn-btm80 { margin-bottom: 5rem; }
  .mgn-btm120 { margin-bottom: 7.5rem; }
  .mgn-btm160 { margin-bottom: 10rem; }
  .mgn-auto { width: fit-content; margin-left: auto; margin-right: auto; }

  /* --- pc or sp --- */
  .pc-none,
  .pc-none-inline,
  .pc-none-table,
  .pc-none-flex { display: none; }
  .sp-none { display: block; }
  .sp-none-inline { display: inline; }
  .sp-none-table { display: table; }
  .sp-none-flex {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .section_pdg,
    .section_pdg-top,
    .section_pdg-btm {
      font-size: 1.125rem; /* 18px */
    }
  }
  @media screen and  (max-width: 767px) {
    .inner-sm { width: 86%; }

    /* --- section_pdg --- */
    .section_pdg {
      padding-top: 3rem;
      padding-bottom: 3rem;
    }
    .section_pdg-top {
      padding-top: 3rem;
    }
    .section_pdg-btm {
      padding-bottom: 3rem;
    }
    .section_deco::before {
      top: -3rem;
    }
    .section_deco2::before {
      top: -2rem;
    }

    /* --- margin --- */
    .mgn-btm12 { margin-bottom: .5rem; }
    .mgn-btm16 { margin-bottom: .5rem; }
    .mgn-btm24 { margin-bottom: 1rem; }
    .mgn-btm32 { margin-bottom: 1.5rem; }
    .mgn-btm40 { margin-bottom: 1.75rem; }
    .mgn-btm48 { margin-bottom: 2rem; }
    .mgn-btm56 { margin-bottom: 2rem; }
    .mgn-btm64 { margin-bottom: 2rem; }
    .mgn-btm72 { margin-bottom: 2.5rem; }
    .mgn-btm80 { margin-bottom: 2.5rem; }
    .mgn-btm120 { margin-bottom: 4rem; }
    .mgn-btm160 { margin-bottom: 5rem; }
    .sp-none,
    .sp-none-inline,
    .sp-none-table,
    .sp-none-flex { display: none !important; }
    .pc-none { display: block; }
    .pc-none-inline { display: inline; }
    .pc-none-table { display: table; }
    .pc-none-flex {
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
    }
  }

/* flex
**************************************** */
  
  /* --- ブロック要素 --- */
  .flex {
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
  }
  .flex-pc-none {
    display: none;
  }

  /* --- インライン要素 --- */
  .flex-inline {
    display: -webkit-inline-flex;
    display: -ms-inline-flexbox;
    display: inline-flex;
  }

  /* --- 逆向き --- */
  .flex-reverse {
    -webkit-flex-direction: row-reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
  }
  
  /* --- 縦並び --- */
  .flex-column {
    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
  }

  /* --- 水平方向揃え --- */
  .flex-j-start {
    -webkit-justify-content: flex-start;
    -ms-flex-pack: start;
    justify-content: flex-start;
  }
  .flex-j-end {
    -webkit-justify-content: flex-end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
  .flex-j-ctr {
    -webkit-justify-content: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
  .flex-j-between {
    -webkit-justify-content: space-between;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
  .flex-j-around {
    -webkit-justify-content: space-around;
    -ms-flex-pack: distribute;
    justify-content: space-around;
  }

  /* --- 垂直方向揃え --- */
  .flex-a-start {
    -webkit-align-items: flex-start;
    -ms-flex-align: start;
    align-items: flex-start;
  }
  .flex-a-end {
    -webkit-align-items: flex-end;
    -ms-flex-align: end;
    align-items: flex-end;
  }
  .flex-a-ctr {
    -webkit-align-items: center;
    -ms-flex-align: center;
    align-items: center;
  }
  .flex-a-baseline {
    -webkit-align-items: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
  }
  .flex-a-stretch {
    -webkit-align-items: stretch;
    -ms-flex-align: stretch;
    align-items: stretch;
  }

  /* --- 子要素の折り返し設定 --- */
  .flex-c-nowrap {
    -webkit-flex-wrap: nowrap;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
  }
  .flex-c-wrap {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
  }

  /* --- 子要素の複数行設定 --- */
  .flex-c-reverse {
    -webkit-flex-wrap: wrap-reverse;
    -ms-flex-wrap: wrap-reverse;
    flex-wrap: wrap-reverse;
  }
  .flex-c-start {
    -webkit-align-content: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
  }
  .flex-c-start {
    -webkit-align-items: flex-start;
    -ms-flex-line-pack: start;
    align-content: flex-start;
  }
  .flex-c-end {
    -webkit-align-content: flex-end;
    -ms-flex-line-pack: end;
    align-content: flex-end;
  }
  .flex-c-ctr {
    -webkit-align-content: center;
    -ms-flex-line-pack: center;
    align-content: center;
  }
  .flex-c-baseline {
    -webkit-align-content: baseline;
    -ms-flex-line-pack: baseline;
    align-content: baseline;
  }
  .flex-c-stretch {
    -webkit-align-content: stretch;
    -ms-flex-line-pack: stretch;
    align-content: stretch;
  }
  
  /* --- gridレイアウト --- */
  .grid-col2,
  .grid-col3,
  .grid-col4 {
    display: grid;
    gap: 4rem 2rem;
    grid-auto-flow: row;
  }
  .grid-col2 {
    grid-template-columns: repeat(2, 1fr);
    gap: 4rem 3rem;
  }
  .grid-col3 {
    grid-template-columns: repeat(3, 1fr);
  }
  .grid-col4 {
    grid-template-columns: repeat(4, 1fr);
  }
  .subgrid2 {
    display: grid;
    grid-template-rows: subgrid; 
    grid-row: span 2;
    gap: 0;
  }

  @media screen and (max-width: 768px) {

    .flex-pc-none {
      display: -webkit-flex;
      display: -ms-flexbox;
      display: flex;
    }

    /* --- 縦並び - sp --- */
    .flex-sp-block {
      -webkit-flex-direction: column;
      -ms-flex-direction: column;
      flex-direction: column;
    }
    .flex-sp-block.flex-col2 > *,
    .flex-sp-block.flex-col2-lg > *,
    .flex-sp-block.flex-col3 > *,
    .flex-sp-block.flex-col3-lg > * {
      width: 100%;
      margin-right: 0;
      margin-bottom: 10%;
    }
    .flex-sp-block.flex-col2 > *:last-child,
    .flex-sp-block.flex-col2-lg > *:last-child,
    .flex-sp-block.flex-col3 > *:last-child,
    .flex-sp-block.flex-col3-lg > *:last-child {
      margin-bottom: 0;
    }

    /* --- 並び順変更 - sp --- */
    .flex-sp-reverse {
      -webkit-flex-direction: column-reverse;
      -ms-flex-direction: column-reverse;
      flex-direction: column-reverse;
    }

    /* --- ざっくりflexレイアウト - sp --- */
    .flex-sp-col2 > *,
    .flex-sp-col2.flex-col3 > *:nth-child(3n+3),
    .flex-sp-col2.flex-col3-lg > *:nth-child(3n+3) {
      width: 48.5%;
      margin-right: 3%;
      margin-bottom: 3%;
    }
    .flex-sp-col2 > *:nth-child(even) { margin-right: 0; }
    .flex-sp-col3 > *,
    .flex-sp-col3.flex-col4 > *:nth-child(4n+4) {
      width: 31.33%;
      margin-right: 3%;
      margin-bottom: 3%;
    }
    .flex-sp-col3 > *:nth-child(3n+3) { margin-right: 0; }

    /* --- gridレイアウト --- */
    .grid-sp-block.grid-col2 {
      grid-template-columns: repeat(1, 1fr);
    }
    .grid-sp-block.grid-col3,
    .grid-sp-block.grid-col4 {
      gap: 1rem;
      grid-template-columns: repeat(1, 1fr);
    }
    .grid-sp-block-lg.grid-col3,
    .grid-sp-block-lg.grid-col4 {
      gap: 3rem;
    }
  }

/* ttl
**************************************** */
  /* --- page_ttl --- */
  .page_ttl {
    position: relative;
    height: 16rem;
  }

  /* --- breadcrumbs --- */
  .breadcrumbs {
    position: absolute;
    top: .5rem;
    left: 1rem;
    z-index: 100;
    padding: .5em 0;
    font-size: .813rem; /* 13px */
    color: #ffffff6f;
  }
  .breadcrumbs a {
    color: #fff;
  }
  .breadcrumbs a::after {
    content: "";
    display: inline-block;
    width: .45em;
    aspect-ratio: 1 / 1;
    margin: 0 .75em;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    transform: translateY(-.1em) rotate(45deg);
    transition: all .4s ease-out;
  }

  /* --- ttl-01 --- */
  .ttl-01 {
    position: relative;
    width: fit-content;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
    line-height: 1.3;
  }
  .ttl-01:not([class*=mgn-btm]) {
    margin-bottom: 1.5rem;
  }
  .ttl-01::before,
  .ttl-01::after {
    content: "";
    position: absolute;
    top: 0;
    display: inline-block;
    width: .5625rem;
    height: 5.5rem;
    background-image: url(../images/common/ttl-deco_l.svg);
    background-size: contain;
    background-repeat: no-repeat;
  }
  .ttl-01::before {
    left: -3rem;
  }
  .ttl-01::after {
    right: -3rem;
    transform: rotate(180deg);
  }
  .ttl-01 .catch {
    display: block;
    font-size: 1.25rem; /* 20px */
    letter-spacing: .05em;
  }
  .ttl-01 .jp {
    display: block;
    font-size: 2.5rem; /* 40px */
    letter-spacing: .05em;
  }
  .ttl-01 .en {
    display: block;
    color: var(--clr-yl);
    font-size: 1rem;
    letter-spacing: .05em;
  }

  .ttl-01.txt-wh::before,
  .ttl-01.txt-wh::after {
    background-image: url(../images/common/ttl-deco_l-wh.svg);
  }
  .ttl-01.txt-wh .en {
    color: #fff;
  }
  
  .ttl-01.rl {
    -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
            writing-mode: vertical-rl;
    -webkit-font-feature-settings: 'pkna';
            font-feature-settings: 'pkna';
            text-align: left;
    margin-left: 0;
    margin-right: 0;
  }
  .ttl-01.rl * {
    font-feature-settings: normal;
  }
  .ttl-01.rl .en {
    margin-left: .5rem;
  }
  .ttl-01.rl .jp {
    padding-top: 1em;
    text-indent: -1em;
    letter-spacing: 0em;
  }
  .ttl-01.rl::before,
  .ttl-01.rl::after {
    left: 0;
    right: 0;
    width: 8.0625rem;
    height: .5625rem;
    background-image: url(../images/common/ttl-deco_u.svg);
  }
  .ttl-01.rl.txt-wh::before,
  .ttl-01.rl.txt-wh::after {
    background-image: url(../images/common/ttl-deco_u-wh.svg);
  }
  .ttl-01.rl::before {
    top: -2.5rem;
  }
  .ttl-01.rl::after {
    top: auto;
    bottom: -2.5rem;
    transform: rotate(180deg);
  }

  /* --- ttl-02 --- */
  .ttl-02 {
    margin-bottom: .75rem;
    font-size: 2rem; /* 32px */
    line-height: 1.5;
    color: var(--clr-yl);
  }

  /* --- ttl-03 --- */
  .ttl-03 {
    margin-bottom: .5rem;
    font-size: 1.5rem; /* 24px */
    line-height: 1.5;
    color: var(--clr-yl);
  }

  /* --- ttl-04 --- */
  .ttl-04 {
    margin-bottom: 1rem;
    font-size: 2rem; /* 32px */
    line-height: 1.5;
  }
  .ttl-04 .en {
    display: block;
    margin-bottom: .5rem;
    font-size: 1rem;
    line-height: 1.5;
  }

  /* --- ttl-05 --- */
  .ttl-05 {
    margin-bottom: .75rem;
    font-size: 1.75rem; /* 28px */
    line-height: 1.3;
    color: var(--clr-yl);
    text-align: center;
  }
  .ttl-05 span {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 1.75em;
    border-radius: 50%;
    aspect-ratio: 1 / 1;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: .75rem;
    color: #fff;
    background-color: var(--clr-yl);
    font-size: 1.5rem; /* 24px */
  }

  @media screen and (max-width: 767px) {
    /* --- page_ttl --- */
    .page_ttl {
      height: 8rem;
    }

    /* --- breadcrumbs --- */
    .breadcrumbs {
      top: 0;
      left: .75rem;
      font-size: .786rem; /* 11px */
    }

    /* --- ttl-01 --- */
    .ttl-01::before,
    .ttl-01::after {
      transform: scale(.8,.8);
      transform-origin: top center;
    }
    .ttl-01 .catch {
      font-size: .929rem; /* 13px */
    }
    .ttl-01 .jp {
      font-size: 2rem;
    }
    .ttl-01 .en {
      font-size: .857rem; /* 12px */
    }
  
    .ttl-01.rl::before,
    .ttl-01.rl::after {
      right: -.75rem;
    }
    .ttl-01.rl::after {
      transform: scale(.8,.8) rotate(180deg);
    }
  
    /* --- ttl-02 --- */
    .ttl-02 {
      font-size: 1.5rem;
    }
  
    /* --- ttl-03 --- */
    .ttl-03 {
      font-size: 1.429rem; /* 20px */
    }
  
    /* --- ttl-04 --- */
    .ttl-04 {
      font-size: 1.5rem;
    }
    .ttl-04 .en {
      margin-bottom: .25rem;
      font-size: .857rem; /* 12px */
    }
  
    /* --- ttl-05 --- */
    .ttl-05 {
      font-size: 1.5rem;
    }
    .ttl-05 span {
      font-size: 1.25rem; /* 24px */
    }
  }

/* .color
*************************************************** */
  :root {
    --clr-bk: #3B3D52;
    --clr-yl: #BF962D;
    --clr-og: #EF4E3C;
    --clr-gy: #C4C4CB;
    --clr-gr: #76B2A2;
    --clr-br: #825602;
  }

/* bg
**************************************** */
  .bg-wh { background-color: #fff !important; }
  .bg-bk { background-color: var(--clr-bk); }
  .bg-yl { background-color: var(--clr-yl); }
  .bg-og { background-color: var(--clr-og); }
  .bg-gy { background-color: var(--clr-gy); }
  .bg-gr { background-color: var(--clr-gr); }
  .bg-br { background-color: var(--clr-br); }
  .bg-bg { background-image: url(../images/common/ptn-bg.jpg); }
  .bg-wh { background-image: url(../images/common/ptn-wh.jpg); }
  .deco_r,
  .deco_l {
    top: 0;
    bottom: 0;
    margin: auto;
    width: 18.125rem;
  }
  .deco_r {
    right: 2.5rem;
  }
  .deco_l {
    left: 2.5rem;
  }
  @media screen and (max-width: 767px) {
    .deco_r,
    .deco_l {
      width: 9rem;
    }
    .deco_r {
      right: .5rem;
    }
    .deco_l {
      left: .5rem;
    }
  }

/* txt
**************************************** */
  .txt-wh { color: #fff; }
  .txt-yl { color: var(--clr-yl); }
  .txt-og { color: var(--clr-og); }
  .txt-gy { color: var(--clr-gy); }
  .txt-gr { color: var(--clr-gr); }
  .txt-br { color: var(--clr-br); }
  .txt-bk { color: var(--clr-bk); }
  .txt-ctr,
  .txt-ctr-pc  { text-align: center; }
  .txt-rgt  { text-align: right; }
  .txt-link {
    position: relative;
    display: inline-flex;
    align-items: center;
    text-decoration: underline;
  }
  .txt-link::after {
    content: "";
    display: block;
    width: .45rem;
    aspect-ratio: 1 / 1;
    margin-left: .25em;
    border-top: solid 1px;
    border-right: solid 1px;
    transform: rotate(45deg);
    transition: all .4s ease-out;
  }
  .txt-link:hover {
    color: var(--clr-main);
  }
  .txt-link:hover::after {
    border-top-color: var(--clr-main);
    border-right-color: var(--clr-main);
  }
  .txt-attention {
    display: block;
    margin-top: .5em;
    padding-left: 1em;
    text-indent: -1em;
    line-height: 1.8;
    font-size: .875rem; /* 14px */
    font-weight: 500;
  }

  @media screen and (max-width: 767px) {
    .txt-ctr-pc  { text-align: left; }
  }

/* font
**************************************** */
  .bold,
  strong,
  .ec-font-bold,
  .ec-cartRow__unitPrice,
  .ec-cartRow__sutbtotal {
    font-family: "Shuei KakuGo Gin B";
    font-weight: normal;
  }
  .font-jp {
    font-family: "Kasumi Seiran Light";
    font-weight: normal;
  }
  .font-en {
    font-family: 'EB Garamond', serif;
    font-weight: 500;
  }

/* btn
********************************************** */
  /* --- btn --- */
  .btn > * {
    position: relative;
    z-index: 1;
    display: flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
    min-width: 20rem; /* 320px */
    margin-left: auto;
    margin-right: auto;
    padding: 1.5rem 5rem;
    font-family: "Kasumi Seiran Light";
    border: none;
    border-top: solid 1px;
    border-bottom: solid 1px;
    transition: all .4s ease-out;
    font-size: 1.25rem; /* 20px */
    cursor: pointer;
  }
  .btn > *::before,
  .btn > *::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    display: block;
    height: fit-content;
    aspect-ratio: 1 / 1;
    transition: all .4s ease-out;
  }
  .btn > *::before {
    right: 1.5rem;
    width: 2rem;
    background-color: var(--clr-og);
    border-radius: 50%;
  }
  .btn > *::after {
    right: 2.35rem;
    width:  .45rem;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    transform: rotate(45deg);
  }
  .btn > a[href^="#"]::after {
    transform: rotate(135deg);
  }
  .btn > *:hover,
  a:hover .btn span {
    background-color :#3b3d5210;
    opacity: 1;
  }

  .btn-02 > * {
    min-width: 0;
    padding-top: 0;
    padding-bottom: 0;
    border: none;
  }
  .btn-02 > *:hover,
  a:hover .btn-02 span {
    background-color :transparent;
  }
  .btn-02 > *:hover::before,
  a:hover .btn-02 span::before,
  .btn-03 > *:hover::before,
  a:hover .btn-03 span::before {
    transform: translateX(.125rem);
  }
  .btn-02 > *:hover::after,
  a:hover .btn-02 span::after,
  .btn-03 > *:hover::after,
  a:hover .btn-03 span::after {
    transform: translateX(.125rem) rotate(45deg);
  }

  .btn-03 > * {
    min-width: 15rem; /* 240px */
    padding: 1rem 4rem 1rem 2rem;
    font-family: 'Shuei KakuGo Gin B', YuGothic, 'Yu Gothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic ProN', sans-serif;
    font-weight: bold;
    background-color: var(--clr-yl);
    border-radius: 0;
    color: #fff;
    font-size: 1rem;
  }
  .btn-03 > *::before {
    right: 1.5rem;
    width: 1.5rem;
    background-color: #fff;
    border-radius: 50%;
  }
  .btn-03 > *::after {
    right: 2.1rem;
    width:  .45rem;
    border-top: solid 2px var(--clr-yl);
    border-right: solid 2px var(--clr-yl);
  }
  .btn-03 > *:hover,
  a:hover .btn-03 span {
    background-color: var(--clr-yl);
  }

  .btn-sm > * {
    position: relative;
    padding: .4rem 1rem .4rem 2rem;
    font-size: .813rem; /* 13px */
    line-height: 1;
    background-color: var(--clr-bk);
    color: #fff;
    border-radius: 9999px;
    border: none;
    cursor: pointer;
    white-space: nowrap;
  }
  .btn-sm > *::before,
  .btn-sm > *::after {
    content: "";
    position: absolute;
    top: 0;
    bottom: 0;
    margin: auto;
    height: fit-content;
    aspect-ratio: 1 / 1;
    transition: all .2s ease-out;
  }
  .btn-sm > *::before {
    left: .6875rem; /* 11px */
    width:  .875rem; /* 14px */
    background-color: #fff;
    border-radius: 9999px;
  }
  .btn-sm > *::after {
    left: .9rem;
    width:  .25rem; /* 14px */
    border-top: solid 1px var(--clr-bk);
    border-right: solid 1px var(--clr-bk);
    transform: rotate(45deg);
  }
  .btn-sm > *:hover {
    opacity: 1;
  }
  .btn-sm > *:hover::before,
  a:hover .btn-sm span::before {
    transform: translateX(.125em);
  }
  .btn-sm > *:hover::after,
  a:hover .btn-sm span::after {
    transform: translateX(.125em) rotate(45deg);
  }
  .btn-sm-wh > * {
    background-color: #fff;
    color: var(--clr-bk);
  }
  .btn-sm-wh > *::before {
    background-color: var(--clr-bk);
  }
  .btn-sm-wh > *::after {
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
  }
  .btn-sm-og > * {
    background-color: var(--clr-og);
  }
  .btn-sm-og > *::after {
    border-top: solid 1px var(--clr-og);
    border-right: solid 1px var(--clr-og);
  }

  .btn_list {
    width: fit-content;
    display: grid;
    gap: 2rem;
    grid-template-columns: repeat(3, 1fr);
  }
  .btn_list.col2 {
    grid-template-columns: repeat(2, 1fr);
  }
  .other_page .btn_list:not(.no-mgn) {
    margin-left: auto;
    margin-right: auto;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .btn-sm > * {
      font-size: 1rem; /* 16px */
    }
  }
  @media screen and (max-width: 767px) {
    /* --- btn --- */
    .btn > * {
      min-width: 15rem;
      padding: 1.25rem 5rem;
      font-size: 1.125rem
    }
    .btn > *::before {
      right: .5rem;
      width: 1.5rem;
    }
    .btn > *::after {
      right: 1.125rem;
      width:  .4rem;
    }
    .btn > a[href^="#"]::after {
      right: 1.05rem;
    }

    .btn-03 > * {
      padding: 1rem 3rem 1rem 2rem;
      font-size: .929rem; /* 13px */
    }
    .btn-03 > *::before {
      right: 1.5rem;
      width: 1.25rem;
    }
    .btn-03 > *::after {
      right: 1.95rem;
      width:  .45rem;
    }

    .btn-sm > * {
      font-size: .929rem; /* 13px */
    }

    .btn_list,
    .btn_list.col2 {
      gap: 1.5rem;
      grid-template-columns: repeat(1, 1fr);
    }
    .btn_list .btn > *,
    .btn_list.col2 .btn > * {
      width: 100%;
    }
  }

/* img
********************************************** */
  .img-cover {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .img-contain {
    object-fit: contain;
  }


/* ##############################################################################

    HEADER

############################################################################## */
  .header {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    height: 7rem;
    border-top: .5rem var(--clr-bk) solid;
    background-position: top left;
    background-image: url(../images/common/ptn-bg.jpg);
    z-index: 1000000000;
  }
  .header_wrap {
    width: 100%;
  }

  @media screen and (max-width: 1080px) {
    .header {
      height: 4.5rem;
      border-top-width: .25rem;
    }
  }

/* header--logo
**************************************** */
  .header--logo {
    position: fixed;
    top: 3.5rem;
    left: 3rem;
    width: 16.5rem;
    z-index: 10001;
    transition: all .4s ease-out;
  }
  .header-sm .header--logo {
    top: 1rem;
    width: 10rem;
  }

  @media screen and (max-width: 1080px) {
    .front_page .header--logo {
      top: .25rem;
      left: 0;
      width: 12.5rem;
      padding: .75rem 1.25rem;
      background-image: url(../images/common/ptn-bg.jpg);
      border-radius: 0 0 .25rem 0;
    }
    body:not(.front_page) .header--logo,
    .header-sm .header--logo {
      top: .4rem;
      left: 0;
      width: 8rem;
      padding: 0 .75rem;
    }
  }

/* header--nav
**************************************** */
  /* --- gnav--menu --- */
  .gnav--menu {
    margin-top: .75rem;
  }
  .gnav--menu li {
    margin-left: 2.5rem;
  }
  .gnav--menu .gnav--link {
    position: relative;
    padding-right: 1rem;
    font-size: 1.25rem; /* 20px */
  }
  .gnav--menu .gnav--link::after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    margin: auto;
    display: inline-block;
    width: .3em;
    height: fit-content;
    aspect-ratio: 1 / 1;
    border-top: solid 1px;
    border-right: solid 1px;
    transform: rotate(135deg);
  }

  /* --- gnav--submenu --- */
  .gnav--submenu {
    margin-right: 2rem;
  }
  .gnav--submenu li {
    margin-left: .75rem;
  }
  .gnav--submenu svg {
    width: 1.25rem; /* 20px */
  }
  .gnav--submenu path {
    fill: #3B3D52;
  }

  /* --- gnav_cta --- */
  .gnav_cta {
    margin-left: 2.5rem;
  }
  .gnav--login a,
  .gnav--favorite a,
  .gnav--cart a {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    width: 7rem;
    aspect-ratio: 112 / 104;
    color: #fff;
  }
  .gnav--login a:hover,
  .gnav--favorite a:hover,
  .gnav--cart a:hover {
    opacity: 1;
  }
  .gnav--login .txt,
  .gnav--favorite .txt,
  .gnav--cart .txt {
    display: inline-block;
    margin-top: 1em;
    font-size: .813rem; /* 13px */
    line-height: 1;
    letter-spacing: .05em;
  }
  .gnav--login a {
    background-color: #B4B4C2;
  }
  .gnav--favorite a {
    background-color: var(--clr-yl);
  }
  .gnav--cart a {
    background-color: var(--clr-og);
  }
  .gnav--login img,
  .gnav--favorite img,
  .gnav--cart img {
    max-width: 1.5rem;
  }
  .cart_num {
    position: absolute;
    top: calc(50% - 2.25rem);
    right: calc(50% - 2rem);
    display: flex;
    justify-content: center;
    align-items: center;
    width: 1rem;
    height: fit-content;
    aspect-ratio: 1 / 1;
    font-size: .75rem; /* 12px */
    line-height: 1;
    border-radius: 50%;
    color: var(--clr-og);
    background-color: #fff;
    white-space: nowrap;
    letter-spacing: normal;
  }

  @media screen and (min-width: 1081px) {
    .gnav_btn {
      display: none;
    }
  }
  @media screen and (max-width: 1080px) {
    /*  --- gnav --- */
    .gnav {
      display: none;
    }

    /* --- gnav_cta --- */
    .gnav_cta {
      margin-left: 0;
      margin-right: 4.25rem;
    }
    .gnav--login a,
    .gnav--favorite a,
    .gnav--cart a {
      width: 4.25rem;
      aspect-ratio: 1 / 1;
    }
    .gnav--login .txt,
    .gnav--favorite .txt,
    .gnav--cart .txt {
      margin-top: .75em;
      font-size: .714rem; /* 10px */
    }
    .gnav--login img,
    .gnav--favorite img,
    .gnav--cart img {
      max-width: 1.5rem;
    }
    .cart_num {
      transform: scale(.75,.75);
      transform-origin: left bottom;
    }

    /*  --- gnav_btn --- */
    .gnav_btn {
      position: absolute;
      top: 0;
      right: 0;
      width: 4.25rem;
      height: fit-content;
      aspect-ratio: 1 / 1;
      z-index: 99999999;
      background-color: var(--clr-bk);
    }
    .gnav_btn--lines {
      position: relative;
      width: 1.5rem;
      height: 1.25rem;
      margin-top: .2rem;
    }
    .gnav_btn--lines span {
      transition: all .4s;
      box-sizing: border-box;
    }
    .gnav_btn--lines span {
      position: absolute;
      left: 0;
      width: 100%;
      height: 2px;
      background-color: #fff;
    }
    .gnav_btn--lines span:nth-of-type(1) {
      top: 0;
    }
    .gnav_btn--lines span:nth-of-type(2) {
      top: 50%;
      transform: translateY(-50%);
    }
    .gnav_btn--lines span:nth-of-type(3) {
      bottom: 0;
    }
    .active .gnav_btn--lines span:nth-of-type(1) {
      -webkit-transform: translateY(.55rem) rotate(-40deg);
      transform: translateY(.55rem) rotate(-40deg);
    }
    .active .gnav_btn--lines span:nth-of-type(2) {
      opacity: 0;
    }
    .active .gnav_btn--lines span:nth-of-type(3) {
      -webkit-transform: translateY(-.55rem) rotate(40deg);
      transform: translateY(-.55rem) rotate(40deg);
    }
    .gnav_btn--txt {
      margin-top: 1em;
      font-size: .714rem; /* 10px */
      line-height: 1;
      letter-spacing: .05em;
      color: #fff;
    }
    .gnav_btn--txt span:nth-of-type(2) { display: block; }
    .gnav_btn--txt span:nth-of-type(2) { display: none; }
    .active .gnav_btn--txt span:nth-of-type(1) { display: none; }
    .active .gnav_btn--txt span:nth-of-type(2) { display: block; }
  }


/* ##############################################################################

    FOOTER

############################################################################## */

  /* footer_guide
  **************************************** */
  .footer_guide {
    position: relative;
    padding-top: 2rem;
    padding-bottom: 5rem;
    background: linear-gradient(180deg, #76B2A2 72.92%, #fff 100%);
  }
  .footer_guide::before {
    content: "";
    position: absolute;
    top: -12rem;
    left: 0;
    right: 0;
    height: fit-content;
    aspect-ratio: 1920 / 398;
    background-image: url(../images/common/section-border_l.png);
    background-size: cover;
  }
  .footer_guide .inner {
    max-width: 74rem;
  }
  .footer_guide .txt_slider {
    position: relative;
    z-index: 10;
    transform: translateY(-100%);
  }
  .footer_guide .deco_l {
    top: 5rem;
    left: 2.5em;
    margin: 0;
    opacity: .6;
    mix-blend-mode: color-dodge;
  }
  .footer_guide .deco_r {
    top: 40%;
    right: 2.5em;
    margin: 0;
    opacity: .6;
    mix-blend-mode: color-dodge;
  }

  /* --- guide_contents --- */
  .guide_contents {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1.5rem;
    margin-bottom: 5rem;
  }
  .guide_contents .content {
    padding: 1.5rem 2.5rem 2rem;
    background-color: #fff;
    border-radius: .5rem;
    font-size: .938rem; /* 15px */
  }

  /* --- shopping_flow --- */
  .shopping_flow {
    position: relative;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 2rem;
  }
  .shopping_flow4 {
    grid-template-columns: repeat(4, 1fr);
  }
  .shopping_flow::before {
    content: "";
    position: absolute;
    top: 1rem;
    right: 0;
    left: 0;
    border-top: 1px solid;
  }
  .shopping_flow .step {
    position: relative;
    z-index: 10;
  }
  .shopping_flow .num {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2rem;
    aspect-ratio: 1 / 1;
    margin-bottom: 1.5rem;
    border-radius: 50%;
    font-size: 1.25rem; /* 20px */
    line-height: 1;
    color: #fff;
    background-color: var(--clr-bk);
  }
  .shopping_flow .is-complete .num {
    background-color: var(--clr-yl);
  }
  .shopping_flow .ttl {
    margin-bottom: .5rem;
    font-size: 1.25rem; /* 20px */
    line-height: 1;
    color: var(--clr-yl);
  }
  .shopping_flow .txt {
    font-size: .938rem; /* 15px */
    line-height: 1.7;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .shopping_flow .ttl {
      font-size: 1.375rem; /* 22px */
    }
    .guide_contents .content,
    .shopping_flow .txt {
      font-size: 1.125rem; /* 18px */
    }
  }
  @media screen and (min-width: 768px) {
    .guide_contents .content:first-child { grid-area: 1 / 1 / 2 / 3; }
    .guide_contents .content:last-child  { grid-area: 4 / 1 / 5 / 3; }
  }
  @media screen and (max-width: 767px) {
    .footer_guide {
      padding-top: 1rem;
      padding-bottom: 2.5rem;
    }
    .footer_guide .inner {
      width: 95%;
    }
    .footer_guide::before {
      top: -4.25rem;
    }
    .footer_guide .deco_l {
      top: 2.5rem;
      left: .5em;
    }
    .footer_guide .deco_r {
      right: .25em;
    }
  
    /* --- guide_contents --- */
    .guide_contents {
      grid-template-columns: repeat(1, 1fr);
      gap: .5rem;
      margin-bottom: 2.5rem;
    }
    .guide_contents .content {
      padding: 1.5rem 1.5rem 2rem;
      border-radius: .25rem;
    }
  
    /* --- shopping_flow --- */
    .shopping_flow {
      gap: .5rem;
    }
    .shopping_flow::before {
      top: .75rem;
    }
    .shopping_flow .num {
      width: 1.5rem;
      margin-bottom: .5rem;
      font-size: 1rem;
    }
    .shopping_flow .ttl {
      font-size: .786rem; /* 11px */
      letter-spacing: normal;
      white-space: nowrap;
    }
    .footer .shopping_flow .ttl {
      font-size: 1rem;
    }
    .shopping_flow .txt {
      font-size: .714rem; /* 10px */
    }
    .shopping_flow .txt br {
      display: none;
    }
  }

  /* footer_main
  **************************************** */
  .footer_main {
    padding-top: 4.5rem;
    padding-bottom: 4.5rem;
    color: #fff;
    background-color: var(--clr-bk);
  }

  /* --- footer_about --- */
  .footer_about--logoarea {
    padding: 1rem 3rem 1rem 0;
    margin-right: 3rem;
    border-right: solid 1px;
  }
  .footer--logo {
    max-width: 16.5rem;
    margin-bottom: 2rem;
    filter: brightness(0) invert(1);
  }
  .sns_area {
    gap: 2rem;
  }
  .sns_area img {
    max-width: 2rem;
  }
  .footer_about .name {
    margin-bottom: 1.5rem;
    font-size: 1.25rem; /* 20px */
    line-height: 1;
  }
  .footer_about .address {
    margin-bottom: 1.5rem;
    font-size: .938rem; /* 15px */
    line-height: 1.7;
  }

  /* --- footer_nav --- */
  .fnav {
    margin-bottom: 3rem;
  }
  .fnav--menu {
    column-count: 2;
  }
  .fnav--menu li {
    margin-left: 2rem;
    margin-bottom: 1.5rem;
  }
  .fnav--menu a {
    position: relative;
    padding-left: 1rem;
    font-size: 1.25rem; /* 20px */
    line-height: 1;
    color: #fff;
  }
  .fnav--menu a::before {
    content: "";
    position: absolute;
    top: .4em;
    left: 0;
    aspect-ratio: 1 / 1;
    width: .3em;
    height: fit-content;
    border-top: solid 1px;
    border-right: solid 1px;
    transform: rotate(45deg);
    transition: all .2s ease-out;
  }
  .fnav--submenu li:not(:last-child) {
    border-right: solid 1px var(--clr-gy);
  }
  .fnav--submenu a {
    display: block;
    padding: 0 1rem;
    font-size: .813rem; /* 13px */
    line-height: 1;
    color: var(--clr-gy);
  }
  .fnav--submenu li:first-child a {
    padding-left: 0;
  }
  .fnav--submenu li:last-child a {
    padding-right: 0;
  }
  
  @media screen and (max-width: 767px) {
    .footer_main {
      padding-top: 1.5rem;
      padding-bottom: 3rem;
    }
  
    /* --- footer_about --- */
    .footer_about {
      text-align: center;
      margin-left: auto;
      margin-right: auto;
      margin-bottom: 3rem;
    }
    .footer_about--logoarea {
      padding: .75rem 0;
      margin-right: 0;
      border-right: none;
      margin-bottom: 1.5rem;
    }
    .footer--logo {
      max-width: 12rem;
      margin-bottom: 1rem;
    }
    .sns_area {
      gap: 1.5rem;
    }
    .sns_area img {
      max-width: 1.5rem;
    }
  
    /* --- footer_nav --- */
    .footer_nav {
      width: 97%;
      margin-left: auto;
      margin-right: auto;
    }
    .fnav--menu {
      margin-bottom: 2rem;
      column-count: 2;
    }
    .fnav--menu li {
      margin-left: 0;
      margin-bottom: 1rem;
    }
    .fnav--menu a {
      font-size: 1.125rem;
    }
    .fnav--submenu {
      justify-content: center;
    }
    .fnav--submenu a {
      padding: 0 .75rem;
      font-size: .786rem; /* 11px */
    }
  }

/* footer_copyright
**************************************** */
  .footer_copyright {
    padding: 1rem;
    text-align: center;
    background-color: var(--clr-gy);
  }
  .footer_copyright small {
    font-size: .75rem; /* 12px */
    line-height: 1;
  }
  @media screen and (max-width: 767px) {
    .footer_copyright {
      padding: .75rem;
    }
  }


  /* ##############################################################################
  
      SIDE
  
  ############################################################################## */
  
  /* .layout
  *************************************************** */
  .side_column-wrap {
    padding: 3rem;
    padding-bottom: 8rem;
    background-image: url(../images/common/ptn-wh.jpg);
    overflow-x: hidden;
  }
  .side_column-wrap::-webkit-scrollbar {
    width: 4px
  }
  .side_column-wrap::-webkit-scrollbar-track {
    background-color: var(--clr-gy);
    border-radius: 4px;
    border: none
  }
  .side_column-wrap::-webkit-scrollbar-thumb {
    background-color: var(--clr-bk);
    border-radius: 4px;
    box-shadow: none
  }
  
  .side_section:not([class*=mgn-btm]) {
    margin-bottom: 1.5rem;
  }
  .side--ttl {
    display: flex;
    align-items: center;
    padding-bottom: .25rem;
    margin-bottom: .75rem;
    font-size: 1.25rem; /* 20px */
    color: var(--clr-br);
    border-bottom: dashed 1px var(--clr-gy);
  }
  .side--ttl .icn {
    width: 1rem;
    margin-right: 0.5rem;
  }
  .side--list_ttl {
    font-size: 1rem; /* 16px */
    color: var(--clr-br);
  }
  .side--list + .side--list_ttl {
    margin-top: 1rem;
  }
  .side--list {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: .125rem;
    margin-left: .5rem;
  }
  .side--list a {
    position: relative;
    display: inline-block;
    padding-left: 1.4rem;
    font-size: .938rem; /* 15px */
    line-height: 1.5;
    letter-spacing: .05em;
  }
  .side--list a::before,
  .side--list a::after {
    content: "";
    position: absolute;
    display: block;
    height: fit-content;
    aspect-ratio: 1 / 1;
    transition: all .4s ease-out;
  }
  .side--list a::before {
    top: .2rem;
    left: 0;
    width: .875rem; /* 14px */
    background-color: var(--clr-bk);
    border: solid 1px var(--clr-bk);
    border-radius: 50%;
  }
  .side--list a::after {
    top: .5rem;
    left: .25rem;
    width: .3rem;
    border-top: solid 1px #fff;
    border-right: solid 1px #fff;
    transform: rotate(45deg);
  }
  .side--list a:hover {
    color: var(--clr-gy);
  }
  .side--list a:hover::before {
    background-color: transparent;
  }
  .side--list a:hover::after {
    border-top-color: var(--clr-bk);
    border-right-color: var(--clr-bk);
  }
  .side--bnr > div > div > div {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: .5rem;
    text-align: center;
  }
  .side--bnr div {
    margin-bottom: 0 !important;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .side--list_ttl {
      font-size: 1.25rem; /* 20px */
    }
    .side--list a {
      font-size: 1.125rem; /* 18px */
    }
  }
  @media screen and (min-width: 1081px) {
    .side_column-wrap {
      position: sticky;
      top: 7rem;
      height: calc(100vh - 7rem);
    }
  }
  @media screen and (max-width: 1080px) {
    .side_column-wrap .pc-none {
      display: block;
    }
  }
  @media screen and (max-width: 767px) {
    .side_column-wrap {
      padding: 2.5rem 2rem;
    }
    .side_column-wrap::-webkit-scrollbar {
      width: 2px
    }
    
    .side_section:not([class*=mgn-btm]) {
      margin-bottom: 2.5rem;
    }
    .side--ttl {
      padding-bottom: .5rem;
      margin-bottom: 1rem;
      font-size: 1.429rem; /* 20px */
    }
    .side--ttl .icn {
      width: 1.25rem;
      margin-right: 0.5rem;
    }
    .side--list_ttl {
      margin-bottom: .5rem;
      font-size: 1.286rem; /* 18px */
    }
    .side--list + .side--list_ttl {
      margin-top: 2rem;
    }
    .side--list {
      gap: .75rem;
    }
    .side--list a {
      padding-left: 1.8rem;
      font-size: 1.143rem; /* 16px */
    }
    .side--list a::before {
      top: .35rem;
      width: 1.143rem; /* 16px */
    }
    .side--list a::after {
      top: .7rem;
      width: .4rem;
    }
    .side--bnr {
      padding-top: 2rem;
    }
    .side--bnr > div > div > div {
      gap: .75rem;
    }
  }


/* ##############################################################################

    INDEX

############################################################################## */

/* .layout
*************************************************** */
  .main_column {
    position: relative;
    width: calc(100% - 22.5rem);
  }
  .side_column {
    position: relative;
    width: 22.5rem; /* 360px */
    border-right: solid 1px var(--clr-gy);
    margin-top: 11.5rem;
    background-image: url(../images/common/ptn-wh.jpg);
  }
  .side_column::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: fit-content;
    aspect-ratio: 360 / 37;
    background-image: url(../images/common/bg-border.svg);
    transform: translateY(-100%);
    background-size: contain;
  }

  @media screen and (max-width: 1080px) {
    .main_column {
      width: 100%;
      overflow: hidden;
    }
    .side_column {
      position: fixed;
      top: 4.5rem;
      right: 0;
      z-index: 9999999;
      width: 30rem;
      height: calc(100% - 4.5rem);
      margin: 0;
      padding: 0;
      overflow: scroll;
      pointer-events: none;
      transform: translateX(100%);
      transition: .3s ease-out;
      -webkit-overflow-scrolling: touch;
    }
    .side_column.active {
      pointer-events: auto;
      transform: translateX(0);
    }
    .side_column::before {
      display: none;
    }
  }
  @media screen and (max-width: 767px) {
    .side_column {
      width: 100%;
    }
  }

/* hero
*************************************************** */
  .hero {
    position: relative;
    z-index: 10;
    margin-bottom: 5rem;
  }
  .hero--deco {
    position: absolute;
    left: 0;
    right: 0;
    bottom: -1px;
    margin: auto;
    max-width: 40rem;
    pointer-events: none;
  }
  .hero--catch {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 100;
    color: #fff;    
    font-size: 3.5rem; /* 56px */
    text-align: center;
    pointer-events: none;
  }
  .hero--txt {
    margin-top: 3rem;
    margin-bottom: 3rem;
    font-size: 1.25rem; /* 20px */
    text-align: center;
  }
  .hero .deco_r {
    top: 10%;
    z-index: 100;
  }

  /* --- hero--slider --- */
	.hero--slider .slide-animation {
    animation: fadezoom 8s 0s forwards;
  }
  @keyframes fadezoom {
    0%   { transform: scale(1); }
    100% { transform: scale(1.05); }
  }
  .slick-dots {
    position: absolute;
    left: 3rem;
    bottom: 2rem;
    display: flex;
    align-items: center;
  }
  .slick-dots li:not(:last-child) { margin-right: 1.5rem; }
  .slick-dots li:only-child { display: none; }
  .slick-dots button {
    position: relative;
    width: .5rem;
    aspect-ratio: 1 / 1;
    padding: 0;
    border: none;
    background-color: #fff;
    font-size: 0;
    border-radius: 50%;
    cursor: pointer;
    outline: none;
  }
  .slick-dots button::before {
    content: "";
    position: absolute;
    inset: -.25rem;
    background-color: #fff;
    border-radius: 50%;
    opacity: 0;
  }
  .slick-dots .slick-active button::before { opacity: .3; }

  /* --- gallery_slider --- */
  .gallery_slider {
    width: 100%;
    height: 12.5rem;
    background-repeat: repeat-x;
    background-position: center;
    animation: slide 60s linear infinite;
    background-size: auto 100%;
  }
  .gallery_slider01 { background-image: url(../images/common/slide-img01.png); }
  .gallery_slider02 { background-image: url(../images/common/slide-img02.png); }
  .gallery_slider03 { background-image: url(../images/common/slide-img03.png); }
  @keyframes slide {
    0%   { background-position: 0 0; }
    100% { background-position: -138.75rem 0; }
  }

  /* --- txt_slider --- */
  .txt_slider {
    width: 100%;
    height: 5.875rem;
    background-repeat: repeat-x;
    background-position: center;
    animation: slide 60s linear infinite;
    background-image: url(../images/common/slide-txt.svg);
    background-size: auto 100%;
  }
  @keyframes slide {
    0%   { background-position: 0 0; }
    100% { background-position: -81.4375rem 0; }
  }

  @media screen and (max-width: 767px) {
    .hero {
      margin-bottom: 3rem;
    }
    .hero--deco {
      max-width: 15rem;
    }
    .hero--catch {    
      font-size: 1.5rem;
    }
    .hero--txt {
      margin-top: 2rem;
      margin-bottom: 2rem;
      font-size: 1rem;
    }
    .hero .deco_r {
      top: 5%;
    }

    /* --- hero--slider --- */
    .hero--slider li {
      aspect-ratio: 1 / .6;
    }
    .hero--slider img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .slick-dots {
      left: 1.5rem;
      bottom: 1rem;
    }
    .slick-dots li:not(:last-child) { margin-right: 1rem; }
    .slick-dots button::before {
      inset: -.125rem;
    }

    /* --- gallery_slider --- */
    .gallery_slider {
      height: calc(12.5rem / 2);
    }
    @keyframes slide {
      0%   { background-position: 0 0; }
      100% { background-position: calc(-138.75rem / 2) 0; }
    }

    /* --- txt_slider --- */
    .txt_slider {
      height: calc(5.875rem / 2);
    }
    @keyframes slide {
      0%   { background-position: 0 0; }
      100% { background-position: calc(-81.4375rem / 2) 0; }
    }
  }

/* home_search
*************************************************** */
  .home_search {
    position: relative;
    z-index: 1;
    padding-bottom: 6rem;
  }
  .home_search::before {
    content: "";
    position: absolute;
    top: calc(-5rem - 110px);
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url(../images/common/ptn-wh.jpg);
  }

  /* --- hot_words --- */
  .hot_words,
  .ec-shelfRole__tags {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: .5rem;
  }
  .hot_words {
    margin-bottom: 1.5rem;
  }
  .ec-shelfRole__tags {
    justify-content: flex-start;
    gap: .4rem;
    margin-top: 1rem;
  }
  .hot_words a,
  .ec-shelfRole__tags a {
    display: block;
    padding: .25rem .5rem;
    font-size: .938rem; /* 15px */
    line-height: 1;
    letter-spacing: .05em;
    border: solid 1px var(--clr-yl) !important;
    color: var(--clr-br) !important;
    background-color: #fff !important;
    border-radius: .25rem;
  }
  .ec-shelfRole__tags a {
    font-size: .875rem; /* 14px */
  }
  .hot_words a:hover,
  .ec-shelfRole__tags a:hover {
    color: #fff;
    background-color: var(--clr-yl);
  }

  /* --- search_form --- */
  .search_form {
    position: relative;
  }
  .search_form--txt {
    display: block;
    width: 100%;
    border: solid 1px var(--clr-gy);
    border-radius: .25em;
    padding: 1.125rem 3rem 1.125rem 1.5rem;
    line-height: 1;
    font-size: 1rem; /* 16px */
    box-sizing: border-box !important;
    font-family: 'Shuei KakuGo Gin L', YuGothic, 'Yu Gothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic ProN', sans-serif;
  }
  .search_form-sm .search_form--txt {
    padding: .7rem 2.5rem .7rem 1rem;
    font-size: .938rem; /* 15px */
    width: calc(100% - .5rem);
    margin-left: .5rem;
  }
  .search_form--btn {
    position: absolute;
    top: 0;
    right: 1rem;
    bottom: 0;
    z-index: 10;
    margin: auto;
    display: block;
    width: 1.5rem;
    height: fit-content;
    aspect-ratio: 1 / 1;
    padding: 0;
    background-image: url(../images/common/icon-search-bk.svg);
    background-position: center;
    background-size: contain;
    background-color: transparent;
    background-repeat: no-repeat;
    border: none;
    cursor: pointer;
  }
  .search_form-sm .search_form--btn {
    width: 1rem;    
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .search_form--txt,
    .search_form-sm .search_form--txt {
      font-size: 1.125rem; /* 18px */
    }
    .hot_words a,
    .ec-shelfRole__tags a {
      font-size: 1.063rem; /* 17px */
    }
  }
  @media screen and (max-width: 767px) {
    .home_search::before {
      top: calc(-3rem - 55px);
    }
  
    /* --- search_form --- */
    .search_form--txt,
    .search_form-sm .search_form--txt {
      padding: 1rem 3rem 1rem 1rem;
      letter-spacing: .05em;
    }
    .iphone .search_form--txt,
    .search_form-sm .search_form--txt {
      font-size: 16px;
    }
    .search_form--btn,
    .search_form-sm .search_form--btn {
      width: 1.25rem;
    }
  }

/* home_ranking / home_recommend / home_giftset / home_seasonal
*************************************************** */
  /* --- home_ranking --- */
  .home_ranking .deco {
    top: 1.4rem;
    right: 11.625rem;
    max-width: 15.25rem;
  }

  /* --- home_recommend --- */
  .home_recommend .deco {
    bottom: 0;
    left: 5rem;
    z-index: 10;
    max-width: 13.3125rem;
  }

  /* --- home_giftset --- */
  .home_giftset .deco {
    bottom: 0;
    right: 7.5rem;
    z-index: 10;
    max-width: 12.9375rem;
  }

  /* --- home_seasonal --- */
  .home_seasonal {
    padding-bottom: 12rem;
  }
  .home_seasonal .deco {
    bottom: 0;
    left: 4.375rem;
    z-index: 10;
    max-width: 19.1875rem;
  }

  /* --- animation --- */
  .animation {
    opacity: 0;
    transform: translate(0, 1.5rem);
    transition: all .4s cubic-bezier(.2,-2,.8,2)
  }
  .animation.active {
    opacity: 1;
    transform: translate(0,0)
  }

  /* --- item_list --- */
  .item_list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 2rem;
  }
  .item_list.slider {
    padding: 0 15rem 2.75rem;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    grid-template-columns: repeat(10, 20.81rem);
  }
  .item_list.slider::-webkit-scrollbar {
    width: 1rem;
    height: .5rem;
    border-radius: 1rem;
    cursor: pointer;
  }
  .item_list.slider::-webkit-scrollbar-track {
    width: calc(100% - 70rem);
    margin-right: 15rem;
    margin-left: 15rem;
    background-color: #f6f6f6;
    border-radius: 1rem;
  }
  .item_list.slider::-webkit-scrollbar-thumb {
    background-color: #C4C4CB;
    border-radius: 1rem;
  }
  .item_list li {
    position: relative;
    counter-increment: number;
  }
  .item_list .link {
    position: relative;
    display: block;
    padding-top: 1.75rem;
  }
  .item_list .link:hover {
    opacity: 1;
  }
  .item_list.ranking .link {
    position: relative;
    display: block;
    padding-top: 1.75rem;
  }
  .item_list.ranking .link::before {
    content: counter(number);
    position: absolute;
    top: 0;
    left: -1.75rem;
    z-index: 10;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 3.5rem; /* 56px */
    height: fit-content;
    aspect-ratio: 1 / 1;
    font-size: 2rem;
    line-height: 1;
    font-family: 'EB Garamond', serif;
    font-weight: 500;
    color: #fff;
    background-color: var(--clr-bk);
    border-radius: 50%;
  }
  .item_list.ranking .link::after {
    content: "";
    position: absolute;
    top: .25rem;
    left: calc(-1.75rem + .25rem);
    z-index: 10;
    width: calc(3.5rem - .5rem);
    height: fit-content;
    aspect-ratio: 1 / 1;
    border: dashed 1px #fff;
    border-radius: 50%;
  }
  .item_list.ranking li:nth-child(1) .link::before { background-color: var(--clr-yl); }
  .item_list.ranking li:nth-child(2) .link::before { background-color: #B4B4C2; }
  .item_list.ranking li:nth-child(3) .link::before { background-color: #A48A64; }
  .item_list .imgarea {
    position: relative;
    display: block;
    aspect-ratio: 1/ 1;
    height: fit-content;
    margin-bottom: .75rem;
    filter: drop-shadow(0 0 1.25rem rgba(59, 61, 82, .20));
  }
  .item_list .imgarea::before {
    content: "View more";
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: 'EB Garamond', serif;
    font-weight: 500;
    color: #fff;
    background-color: #3b3d5267;
    background-image: url(../images/home/hover-deco_sashiko_l.svg), url(../images/home/hover-deco_sashiko_r.svg);
    background-position: top left, bottom right;
    background-repeat: no-repeat;
    background-size: 40% auto;
    opacity: 0;
    transition: all .4s ease-out;
  }
  .item_list .link:hover .imgarea::before {
    opacity: 1;
  }
  .item_list .imgarea .img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: all .4s ease-out;
  }
  .item_list .name {
    margin-bottom: .5rem;
    font-size: .938rem; /* 15px */
    line-height: 1.77;
    transition: all .4s ease-out;
  }
  .item_list .link:hover .name,
  .item_list .link:hover .price {
    color: var(--clr-yl);
  }
  .item_list .price {
    font-size: 1rem; /* 16px */
    text-align: right;
    color: var(--clr-og);
    font-family: "Shuei KakuGo Gin B";
    transition: all .4s ease-out;
    letter-spacing: normal;
  }
  .item_list .price::after {
    content: "\FF08\7A0E\8FBC\FF09";
    font-size: 75%;
    letter-spacing: .05em;
    font-family: "Shuei KakuGo Gin B";
    margin-left: -.25em;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .item_list .name {
      font-size: 1.125rem; /* 18px */
    }
    .item_list .price {
      font-size: 1.1875rem; /* 19px */
    }
  }
  @media screen and (max-width: 1080px) {
    .item_list.slider {
      padding: 0 10% 1.5rem;
      grid-template-columns: repeat(10, 15rem);
    }
    .item_list.slider::-webkit-scrollbar-track {
      margin-right: 2rem;
      margin-left: 2rem;
    }
    /* --- home_ranking --- */
    .home_ranking .deco {
      right: .5rem;
    }
  }
  @media screen and (max-width: 767px) {
    /* --- home_ranking --- */
    .home_ranking .deco {
      top: 2.05rem;
      max-width: calc(15.25rem / 1.75);
    }
  
    /* --- home_recommend --- */
    .home_recommend .deco {
      left: .5rem;
      max-width: calc(13.3125rem / 1.75);
    }
  
    /* --- home_giftset --- */
    .home_giftset .deco {
      right: .5rem;
      max-width: calc(12.9375rem / 1.75);
    }
  
    /* --- home_seasonal --- */
    .home_seasonal {
      padding-bottom: 6rem;
    }
    .home_seasonal .deco {
      left: 1rem;
      bottom: 1rem;
      max-width: calc(19.1875rem / 1.75);
    }
  
    /* --- item_list --- */
    .item_list {
      grid-template-columns: repeat(2, 1fr);
      gap: 1rem 1.5rem;
    }
    .item_list .link,
    .item_list.ranking .link {
      padding-top: 1rem;
    }
    .item_list.ranking .link::before,
    .item_list.ranking .link::after {
      transform: scale(.75,.75);
      transform-origin: center;
    }
    .item_list .imgarea {
      filter: drop-shadow(0 0 .5rem rgba(59, 61, 82, .20));
    }
    .item_list .link:hover .imgarea::before {
      opacity: 0;
    }
  }

/* home_locality / home_producer
*************************************************** */  
  /* --- home_locality --- */
  .home_locality {
    padding-top: 7rem;
  }
  .home_locality .txt_slider {
    transform: translateY(-100%);
  }
  
  /* --- img_txt --- */
  .img_txt {
    position: relative;
  }
  .img_txt::after {
    content: "";
    position: absolute;
    top: 30rem;
    left: 0;
    right: 0;
    bottom: 0;
    background-image: url(../images/common/ptn-bg.jpg);
  }
  .img_txt-reverse::after {
    background-image: url(../images/common/ptn-wh.jpg);
  }
  .img_txt .ttlarea {
    position: relative;
    z-index: 10;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    padding-left: 9rem;
  }
  .img_txt-reverse .ttlarea {
    flex-direction: row-reverse;
    padding-left: 0;
    padding-right: 9rem;
  }
  .img_txt .imgarea {
    width: 72.5rem;
  }
  .img_txt .txtarea {
    position: relative;
    z-index: 20;
    margin-top: -19rem;
    padding-top: 11.25em;
    padding-left: 9rem;
    padding-bottom: 5rem;
    background-image: url(../images/home/locality-deco.png);
    background-position: top left;
    background-repeat: no-repeat;
  }
  .img_txt-reverse .txtarea {
    padding-left: 0;
    padding-right: 9rem;
    background-image: url(../images/home/producer-deco.png);
    background-position: top right;
  }
  .img_txt .txtarea .txt {
    width: 30rem;
    margin-bottom: 2.5rem;
    font-size: 1rem;
  }
  .img_txt .txtarea .txt-lg {
    width: 45rem;
    font-size: 1rem;
  }
  .img_txt-reverse .txtarea .txt,
  .img_txt-reverse .txtarea .btn_list {
    margin-left: auto;
    margin-right: 0;
  }
  #food .img_txt-reverse .txtarea .btn_list {
    direction: rtl;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .img_txt .txtarea .txt,
    .img_txt .txtarea .txt-lg {
      font-size: 1.125rem; /* 18px */
    }
  }
  @media screen and (min-width: 1921px) {
    .img_txt .ttlarea {
      max-width: 1600px;
      margin-left: auto;
      margin-right: auto;
    }
  }
  @media screen and (max-width: 1080px) and (min-width: 768px) {
    .img_txt .imgarea {
      width: calc(100% - 10rem);
    }
    .img_txt .ttlarea {
      padding-left: 5%;
    }
    .img_txt-reverse .ttlarea {
      padding-right: 5%;
      padding-left: 0;
    }
    .img_txt .txtarea {
      padding-left: 5%;
      padding-right: 5%;
      padding-bottom: 4rem;
      background-size: 100% auto;
      background-position: top 20% left 0;
    }
    .front_page .img_txt .txtarea {
      background-position: top 35% left 0;
    }
    .img_txt-reverse .txtarea {
      padding-left: 5%;
      padding-right: 5%;
    }
    .home_producer .btn_list {
      grid-template-columns: repeat(1, 1fr);
    }
    .home_producer .btn_list .btn.sp-none {
      display: none;
    }
  }
  @media screen and (max-width: 767px) {
    .home_locality {
      padding-top: 3.5rem;
    }
    .home_locality .txt_slider {
      transform: translateY(-150%);
    }
    
    /* --- img_txt --- */
    .img_txt::after {
      top: 25rem;
    }
    .img_txt .ttlarea {
      padding-left: 2.5%;
    }
    .img_txt-reverse .ttlarea {
      padding-right: 2.5%;
      padding-left: 0;
    }
    .img_txt .imgarea {
      width: calc(100% - 8.5rem);
    }
    .img_txt .imgarea li {
      aspect-ratio: 2 / 2.75;
    }
    .img_txt .imgarea li img {
      width: 100%;
      height: 100%;
      object-fit: cover;
    }
    .img_txt .txtarea {
      margin-top: -9rem;
      padding-top: 6em;
      padding-left: 5%;
      padding-right: 5%;
      padding-bottom: 4rem;
      background-size: 250% auto;
    }
    .img_txt-reverse .txtarea {
      padding-left: 5%;
      padding-right: 5%;
    }
    .img_txt .txtarea .txt,
    .img_txt .txtarea .txt-lg {
      width: 100%;
      margin-bottom: 1.5rem;
    }
  }

/* home_content
*************************************************** */
  .home_content {
    padding-top: 8rem;
    padding-bottom: 8rem;
  }
  .home_content .inner {
    max-width: 78rem;
  }

  /* --- contnet_list --- */
  .contnet_list {
    display: grid;
    gap: 1rem;
    grid-template-columns: repeat(2, 1fr);
  }
  .contnet_list .link {
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    aspect-ratio: 628 / 400;
    text-align: center;
    color: #fff;
    overflow: hidden;
  }
  .contnet_list .link:hover {
    opacity: 1;
  }
  .contnet_list .link::before {
    content: "";
    position: absolute;
    inset: 0;
    z-index: 10;
    display: block;
    background-image: url(../images/home/hover-deco_sashiko_l.svg), url(../images/home/hover-deco_sashiko_r.svg);
    background-position: top left, bottom right;
    background-repeat: no-repeat;
    background-size: 25% auto;
    opacity: 0;
    transition: all .4s ease-out;
    pointer-events: none;
  }
  .contnet_list .link:hover::before {
    opacity: 1;
  }
  .contnet_list .imgarea {
    position: absolute;
    inset: 0;
  }
  .contnet_list .link:hover .imgarea img {
    filter: blur(.125rem);
  }
  .contnet_list .txtarea {
    position: relative;
    z-index: 10;
  }
  .contnet_list .txt {
    max-width: 26.25rem;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 1rem;
    text-align: left;
    font-size: 1rem;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .contnet_list .txt {
      font-size: 1.125rem; /* 18px */
    }
  }
  @media screen and (max-width: 767px) {
    .home_content {
      padding-top: 4rem;
      padding-bottom: 4rem;
    }
    .home_content .inner {
      width: 100%;
    }
  
    /* --- contnet_list --- */
    .contnet_list {
      gap: .5rem;
      grid-template-columns: repeat(1, 1fr);
    }
    .contnet_list .link:hover::before {
      opacity: 0;
    }
    .contnet_list .link:hover .imgarea img {
      filter: blur(0);
    }
    .contnet_list .txt {
      max-width: 83%;
      margin-bottom: 0;
      font-size: .929rem; /* 13px */
    }
  }

/* home_topics
*************************************************** */
  .home_topics {
    padding-top: 2.5rem;
  }
  .home_topics,
  .main_column > .section_pdg:last-child {
    padding-bottom: 18rem;
  }

  /* --- posts-topics --- */
  .post {
    position: relative;
  }
  .post--date {
    margin-right: 1.5rem;
    font-size: 1rem;
    letter-spacing: .05em;
    line-height: 1;
    color: var(--clr-yl);
    font-family: 'EB Garamond', serif;
    font-weight: 500;
    white-space: nowrap;
  }
  .post--link:hover {
    opacity: 1;
  }
  .post--link::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    cursor: pointer;
  }
  .posts-topics .post {
    display: flex;
    align-items: center;
    padding: 2.5rem;
    padding-right: 5rem;
    border-bottom: solid 1px;
    transition: all .4s ease-out;
  }
  .posts-topics .post::before {
    content: "";
    position: absolute;
    top: 0;
    right: 2.5rem;
    bottom: 0;
    margin: auto;
    display: block;
    width:  .5rem;
    height: fit-content;
    aspect-ratio: 1 / 1;
    border-top: solid 2px var(--clr-yl);
    border-right: solid 2px var(--clr-yl);
    transform: rotate(45deg);
  }
  .posts-topics .post:first-child {
    border-top: solid 1px;
  }
  .posts-topics .post--ttl {
    flex: 1;
    font-size: 1.25rem; /* 20px */
    line-height: 1.5;
  }

  @media screen and (max-width: 1650px) and (min-width: 768px) {
    .post--date {
      font-size: 1.125rem; /* 18px */
    }
    .posts-topics .post--ttl {
      font-size: 1.375rem; /* 22px */
    }
  }
  @media screen and (min-width: 768px) {
    .posts-topics .post:hover {
      background-color: #3B3D5210;
    }
  }
  @media screen and (max-width: 767px) {  
    .home_topics {
      padding-top: 1.5rem;
    }
    .home_topics,
    .main_column > .section_pdg:last-child {
      padding-bottom: 9rem;
    }
  
    /* --- posts-topics --- */
    .post--date {
      margin-bottom: .75rem;
    }
    .posts-topics .post {
      display: block;
      padding: 1.5rem 1.5rem 1.25rem 1.25rem;
    }
    .posts-topics .post::before {
      right: .75rem;
      border-top: solid 1px var(--clr-yl);
      border-right: solid 1px var(--clr-yl);
    }
    .posts-topics .post--ttl {
      font-size: 1.125rem;
    }
  }


/* ##############################################################################

    SUBPAGE

############################################################################## */

/* .box
*************************************************** */
  .box {
    position: relative;
    z-index: 10;
    padding: 2rem 3.5rem 2.5rem;
  }
  .box-sm {
    padding: 1rem;
  }
  .box .ttl {
    margin-bottom: 1.5rem;
    font-size: 2rem; /* 32px */
    line-height: 1.25;
    text-align: center;
  }
  .box .flex .imgarea {
    width: 16%;
    margin-right: 1.5rem;
  }
  .box .flex .txtarea {
    flex: 1;
  }

  @media screen and (max-width: 767px) {
    .box {
      padding: 1.5rem 1.5rem 2rem;
    }
    .box .ttl {
      margin-bottom: 1rem;
      font-size: 1.5rem;
    }
    .box .flex .imgarea {
      width: 30%;
      margin-right: auto;
      margin-left: auto;
      margin-bottom: 1rem;
    }
  }

/* .list
*************************************************** */
  .list li {
    position: relative;
    padding-left: 1.25rem;
  }
  .list li:not(:last-child),
  ol li:not(:last-child) {
    margin-bottom: .5em;
  }
  .list li::before {
    content: "";
    top: .65em;
    left: 0;
    position: absolute;
    width: .5rem;
    height: fit-content;
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    background-color: var(--clr-bk);
  }
  ol {
    list-style-type: decimal;
    padding-left: 1.5rem;
  }
  ol li::marker {
    font-weight: 600;
  }
  ol ol {
    margin-top: .5em;
    margin-bottom: 1.5em;
  }

  .sakaya_list {
    gap: 0;
  }
  .sakaya_list a {
    text-decoration: underline;
  }

  .features_list section {
    padding: 2rem 2.5rem;
    background-color: #fff;
    border-radius: 0.5rem;
  }

  @media screen and (max-width: 767px) {
    .features_list section {
      padding: 1.5rem 2rem;
      border-radius: .25rem;
    }
  }

/* table
**************************************** */
  /* --- table-01 --- */
  .table-01 {
    width: 100%;
    border: 1px solid var(--clr-gy);
    background-color: #fff;
  }
  .table-01 th,
  .table-01 td {
    padding: 1em 1.5em;
    letter-spacing: normal;
    line-height: 1.6;
    border: 1px solid var(--clr-gy);
    vertical-align: middle;
  }
  .table-01 th {
    background-image: url(../images/common/ptn-bg.jpg);
    letter-spacing: .1em;
  }

  /* --- table-02 --- */
  .table-02 th,
  .table-02 td {
    position: relative;
    border: 0;
    padding: 1em 1.5em;
    vertical-align: middle;
  }
  .table-02 th::before,
  .table-02 td::before {
    content: '';
    position: absolute;
    bottom: 0;
    width: calc(100% - .1875rem);
  }
  .table-02 th {
    color: var(--clr-br);
    white-space: nowrap;
  }
  .table-02 th::before {
    left: 0;
    height: 1px;
    background-color: var(--clr-yl);
  }
  .table-02 td::before {
    right: 0;
    height: 1px;
    background-color: var(--clr-gy);
  }

  .table-txt {
    display: block;
    width: fit-content;
    margin: .25rem auto 0;
    font-size: .75rem; /* 12px */;
    color: var(--clr-br);
    line-height: 1.5;
    text-align: left;
  }

  @media screen and (max-width: 767px) {
    .table-02 {
      font-size: .929rem; /* 13px */
    }
    .table-02 th,
    .table-02 td {
      padding: 1em 1em;
    }

    .sp-scroll {
      overflow-x: scroll;
      margin-bottom: 2.5em;
      -webkit-overflow-scrolling: touch;
    }
    .sp-scroll::-webkit-scrollbar {
      height: 4px
    }
    .sp-scroll::-webkit-scrollbar-track {
      background-color: var(--clr-gy);
      border-radius: 4px;
      border: none
    }
    .sp-scroll::-webkit-scrollbar-thumb {
      background-color: var(--clr-bk);
      border-radius: 4px;
      box-shadow: none
    }
    .sp-scroll table {
      width: 75rem;
    }
  }

/* cta_tel
**************************************** */
  .cta_tel {
    text-align: center;
    padding-top: 1em;
    padding-bottom: 1em;
    background-color: #00000007;
  }
  .cta_tel .tel {
    display: block;
    font-size: 1.25rem;
    letter-spacing: .01em;
    line-height: 1.2;
  }
  .cta_tel .num {
    font-size: 175%;
    letter-spacing: -.01em;
  }

  @media screen and (max-width: 767px) {
    .cta_tel .num {
      font-size: 150%;
    }
  }

/* shop
**************************************** */
.c-tab-nav {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  padding: 0;
  text-align: center;
  margin-bottom: 1rem;
}
.c-tab-nav__anchor {
  padding: .5em;
  border-bottom: solid 1px;
  font-size: 1.25rem;
  background-color: #3b3d5210;
}
.c-tab-nav__anchor.is-active {
  border-radius: .25em .25em 0 0;
  border: solid 1px;
  border-bottom: none;
  background-color: transparent;
}

@media screen and (max-width: 767px) {
  .c-tab-nav__anchor {
    font-size: 1.125rem;
  }
}

/* mypage
**************************************** */
.ec-input input,
.ec-halfInput input,
.ec-numberInput input,
.ec-zipInput input,
.ec-telInput input,
.ec-select input,
.ec-birth input,
.c-profile__form__choice input {
  display: block;
  width: 100%;
  padding: .75rem 1rem;
  margin-bottom: .75rem;
  font-size: 1rem;
  line-height: 1.42857;
  color: var(--clr-bk);
  background-color: #fff;
  background-image: none;
  border: 1px solid var(--clr-gy);
  border-radius: .25rem;
  font-family: "Shuei KakuGo Gin L", YuGothic, "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", sans-serif;
  -webkit-appearance: none;
  box-shadow: none;
}
.ec-input textarea,
.ec-halfInput textarea,
.ec-numberInput textarea,
.ec-zipInput textarea,
.ec-telInput textarea,
.ec-select textarea,
.ec-birth textarea,
.c-profile__form__choice textarea {
  display: block;
  width: 100%;
  height: 7em;
  padding: .75rem 1rem;
  font-size: 1rem;
  line-height: 1.42857;
  color: #555555;
  background-color: #fff;
  background-image: none;
  border: 1px solid #ccc;
  border-radius: .25rem;
  font-family: "Shuei KakuGo Gin L", YuGothic, "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", sans-serif;
  -webkit-appearance: none;
  box-shadow: none;
}
::placeholder{
  color: var(--clr-gy);
}
.form-check {
  cursor: pointer;
}
.ec-label {
  font-family: "Shuei KakuGo Gin B";
}
.ec-required {
  display: inline-block;
  margin-left: .5em;
  padding: .25em .5em;
  border-radius: .25em;
  background-color: var(--clr-og);
  color: #fff;
  font-size: .6875rem; /* 11px */
  line-height: 1;
  transform: translateY(-.125em);
}
.ec-borderedDefs dl {
  margin-bottom: 1.5rem;
}
.ec-zipInput {
  display: flex;
  align-items: center;
}
.ec-zipInput input {
  width: fit-content;
  max-width: 100%;
  margin-left: 0.5rem;
}
.ec-zipInputHelp {
  display: none;
}
.ec-select select,
.ec-birth select,
.c-profile__form__choice select,
.ks_select_quantity select {
  display: inline-block;
  width: fit-content;
  max-width: 100%;
  height: 3rem;
  padding: .5rem 1rem;
  margin-bottom: .75rem;
  font-size: 1rem;
  line-height: 1.42857;
  color: #555555;
  background-color: #fff;
  background-image: none;
  border: 1px solid var(--clr-gy);
  border-radius: .25rem;
  font-family: "Shuei KakuGo Gin L", YuGothic, "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", sans-serif;
  box-shadow: none;
}
.ec-select select {
  margin-bottom: 0;
}
.disp-number {
  display: none !important;
}
.c-profile__form__choice select {
  display: block;
  width: 100%;
}
input[type="radio"] {
  margin-top: -2px;
}
.ec-registerRole__actions {
  border-top: solid 1px;
  padding-top: 2rem;
  margin-top: 3rem;
}
.ec-errorMessage {
  color: var(--clr-og);
  font-family: "Shuei KakuGo Gin B", YuGothic, "Yu Gothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: bold;
}

.ec-navlistRole__navlist {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
}
.ec-addressList .ec-addressList__item {
  display: table;
  width: 100%;
  position: relative;
  background-color: #fff;
  margin-bottom: .5rem;
}
.ec-addressList .ec-addressList__remove {
  vertical-align: middle;
  padding: 1rem;
  text-align: center;
}
.ec-addressList .ec-addressList__remove .ec-icon img {
  width: 1em;
  height: 1em;
}
.ec-addressList .ec-addressList__address {
  display: table-cell;
  vertical-align: middle;
  padding: 1rem;
  margin-right: 4em;
  width: 70%;
}
.ec-addressList .ec-addressList__action {
  position: relative;
  vertical-align: middle;
  text-align: right;
  top: 1.5rem;
  padding-right: .75rem;
}

.ec-closeBtn--circle {
  display: flex;
  justify-content: center;
  align-items: center;
  border: 0 none;
  padding: 0;
  margin: 0;
  text-shadow: none;
  box-shadow: none;
  border-radius: 50%;
  background: var(--clr-gy);
  cursor: pointer;
  width: 1.5rem;
  height: 1.5rem;
  line-height: 1;
  vertical-align: middle;
  position: relative;
  text-align: center;
}
.ec-favoriteRole .ec-favoriteRole__item .ec-closeBtn--circle {
  position: absolute;
  right: -.5rem;
  top: 1rem;
  z-index: 100;
}
.ec-favoriteRole .ec-favoriteRole__item .ec-closeBtn--circle img {
  width: .75rem;
  height: .75rem;
}

.ec-orderMail__link a {
  text-decoration: underline;
  cursor: pointer;
}
.ec-orderMail__body {
  display: none;
}
.ec-definitions,
.ec-definitions--soft {
  display: flex;
  margin-top: .5rem;
}
.ec-historyListHeader .ec-definitions {
  margin-top: 0;
}
.ec-definitions dd,
.ec-definitions--soft dd {
  margin-left: .5rem;
}

.ec-orderSpecial {
  margin-bottom: 2.5rem;
}
@media screen and (max-width: 767px) {
  .ec-orderSpecial  { margin-bottom: 1.75rem; }
  .ec-addressList .ec-addressList__remove {
    padding: 2rem;
  }
  .ec-welcomeMsg {
    margin-top: 1rem;
  }
  .ec-navlistRole__navlist {
    gap: .75rem;
  }
  .iphone .ec-input input,
  .iphone .ec-halfInput input,
  .iphone .ec-numberInput input,
  .iphone .ec-zipInput input,
  .iphone .ec-telInput input,
  .iphone .ec-select input,
  .iphone .ec-birth input,
  .iphone .c-profile__form__choice input,
  .iphone .ec-input textarea,
  .iphone .ec-halfInput textarea,
  .iphone .ec-numberInput textarea,
  .iphone .ec-zipInput textarea,
  .iphone .ec-telInput textarea,
  .iphone .ec-select textarea,
  .iphone .ec-birth textarea,
  .iphone .c-profile__form__choice textarea {
    font-size: 16px;
  }
}

/* topics
**************************************** */
#news_readmore {
  margin-top: 2rem;
  text-align: center;
}
.wp-content a {
  color: #2271b1;
}

/* products
**************************************** */
.ec-searchnavRole__infos {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.ec-pager {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1rem;
}
.ec-pager {
  margin-top: 4rem;
}
.ec-pager a {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2rem;
  aspect-ratio: 1 / 1;
}
.ec-pager li:not(.ec-pager__item-prev):not(.ec-pager__item-next) a {
  border-radius: 50%;
  border: solid 1px;
  color: var(--clr-bk);
  background-color: #fff;
}
.ec-pager .ec-pager__item--active a {
  color: #fff !important;
  background-color: var(--clr-bk) !important;
}

.detail_wrap {
  display: flex;
  justify-content: space-between;
}
.detail_wrap .ec-grid2__cell {
  width: 48%;
}
.item_visual .slide-item a,
.item_visual .slide-item span {
  display: flex;
  justify-content: center;
  width: 100%;
  text-align: center;
  aspect-ratio: 1 / 1;
  cursor: pointer;
  background-color: #fff;
}
.item_nav {
  display: grid;
  grid-template-columns: repeat(8, 1fr);
  gap: .5rem;
  margin-top: 1rem;
}
.item_nav .slideThumb {
  aspect-ratio: 1 / 1;
  cursor: pointer;
  transition: all .4s ease-out;
}
.item_nav .slideThumb:hover {
  opacity: .5;
}
.c-profile__form__price {
  font-size: 1.5rem;
  color: var(--clr-og);
  font-family: "Shuei KakuGo Gin B";
  transition: all .4s ease-out;
  letter-spacing: normal;
}
.c-profile__form__price::after {
  content: "\FF08\7A0E\8FBC\FF09";
  font-size: 75%;
  letter-spacing: .05em;
  font-family: "Shuei KakuGo Gin B";
  margin-left: -.25em;
}
.c-profile__categories {
  padding-top: 1.5rem;
  border-top: dashed 1px var(--clr-gy);
}
.c-profile__categories__row {
  display: flex;
  font-size: .875rem; /* 14px */
  margin-bottom: .25rem;
}
.c-profile__categories__row a:not(:last-child):after {
  content: "";
  display: inline-block;
  width: .45em;
  aspect-ratio: 1 / 1;
  margin: 0 .5em;
  border-top: solid 1px;
  border-right: solid 1px;
  transform: translateY(-.1em) rotate(45deg);
  transition: all .4s ease-out;
}
.ec-productRole__btn.btn-03 > *  {
  min-width: 20rem;
  font-size: 1.125rem; /* 18px */
  margin-left: 0;
  background-color: var(--clr-og);
  border-radius: .25rem;
}
.ec-productRole__btn.btn-03 > *[disabled] {
  background-color: var(--clr-gy);
  cursor: default;
}
.ec-productRole__btn.btn-03 > *[disabled]::before,
.ec-productRole__btn.btn-03 > *[disabled]::after {
  display: none;
}
.ec-productRole__btn.btn-03 > *::after {
  border-top: solid 2px var(--clr-og);
  border-right: solid 2px var(--clr-og);
}
.p-product_detail__favorite {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: .3em .8em;
  color: var(--clr-yl);
  background-color: #fff;
  border: solid 1px;
  border-radius: .25em;
  cursor: pointer;
  font-family: 'Shuei KakuGo Gin L', YuGothic, 'Yu Gothic', 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic ProN', sans-serif;
}
.p-product_detail__favorite svg {
  fill: var(--clr-yl);
  width: 1.25em;
  margin-right: .3em;
}
.p-product_detail__favorite.disabled {
  opacity: .5;
}
.c-profile__form__choice label {
  font-family: 'Shuei KakuGo Gin B';
}
.c-profile__form__button {
  display: inline-block;
  height: 2rem;
  aspect-ratio: 1 / 1;
  background-color: #fff;
  border: solid 1px #fff;
  border-radius: 50%;
  font-size: 1.125rem; /* 18px */
  cursor: pointer;
}
.c-profile__form__field {
  height: 2rem;
  background-color: #fff;
  border: solid 1px var(--clr-gy);
  text-align: center;
  font-size: 1rem; /* 16px */
}
@media screen and (max-width: 767px) {
  .section_pdg.p-shop_detail,
  .section_pdg.p-product {
    padding-top: 0;
  }
  .detail_wrap {
    display: block;
  }
  .detail_wrap .ec-grid2__cell {
    width: 100%;
    margin-bottom: 3rem;
  }
  .detail_wrap .ec-grid2__cell {
    margin-bottom: 2rem;
  }
  .p-shop_detail .detail_wrap .ec-grid2__cell:last-child {
    margin-bottom: 4rem;
  }
}

/* --- ec-modal --- */
.ec-modal {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99999;
  width: 100%;
  height: 100%;
  &.small {
    width: 30%;
  }
  &.full {
    width: 100%;
    height: 100%;
  }
  .ec-modal-overlay {
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: rgba(0, 0, 0, 0.3);
    width: 100%;
    height: 100%;
  }
  .ec-modal-wrap {
    position: relative;
    border-radius: 2px;
    border: 1px solid #333;
    background-color: #fff;
    width: 90%;
    margin: 20px;
    padding: 40px 5px;
    @include media_desktop {
      padding: 40px 10px;
      width: 50%;
      margin: 20px auto;
    }
  }
  .ec-modal-close {
    cursor: pointer;
    position: absolute;
    right: 20px;
    top: 10px;
    font-size: 20px;
    height: 30px;
    width: 20px;
    &:hover {
      color: #4b5361;
    }
  }
  .ec-modal-box {
    text-align: center;
  }
  .ec-role {
    margin-top: 20px;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    .btn-sm > * {
      font-size: 1rem;
    }
  }
}

/* --- lity --- */
.lity {
  z-index: 99999999990;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  white-space: nowrap;
  background: #0b0b0b;
  background: rgba(0,0,0,0.9);
  outline: none !important;
  opacity: 0;
  -webkit-transition: opacity .3s ease;
  -o-transition: opacity .3s ease;
  transition: opacity .3s ease
}
.lity.lity-opened {
  opacity: 1
}
.lity.lity-closed {
  opacity: 0
}
.lity * {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box
}
.lity-wrap {
  z-index: 99999999990;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  text-align: center;
  outline: none !important
}
.lity-wrap:before {
  content: '';
  display: inline-block;
  height: 100%;
  vertical-align: middle;
  margin-right: -0.25em
}
.lity-loader {
  z-index: 99999999991;
  color: #fff;
  position: absolute;
  top: 50%;
  margin-top: -0.8em;
  width: 100%;
  text-align: center;
  font-size: 14px;
  font-family: Arial,Helvetica,sans-serif;
  opacity: 0;
  -webkit-transition: opacity .3s ease;
  -o-transition: opacity .3s ease;
  transition: opacity .3s ease
}
.lity-loading .lity-loader {
  opacity: 1
}
.lity-container {
  z-index: 99999999992;
  position: relative;
  text-align: left;
  vertical-align: middle;
  display: inline-block;
  white-space: normal;
  max-width: 100%;
  max-height: 100%;
  outline: none !important
}
.lity-content {
  z-index: 99999999993;
  width: 100%;
  -webkit-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
  -webkit-transition: -webkit-transform .3s ease;
  transition: -webkit-transform .3s ease;
  -o-transition: -o-transform .3s ease;
  transition: transform .3s ease;
  transition: transform .3s ease, -webkit-transform .3s ease, -o-transform .3s ease
}
.lity-loading .lity-content,.lity-closed .lity-content {
  -webkit-transform: scale(.8);
  -ms-transform: scale(.8);
  -o-transform: scale(.8);
  transform: scale(.8)
}
.lity-content:after {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  display: block;
  right: 0;
  width: auto;
  height: auto;
  z-index: -1;
  -webkit-box-shadow: 0 0 8px rgba(0,0,0,0.6);
  box-shadow: 0 0 8px rgba(0,0,0,0.6)
}
.lity-close {
  z-index: 99999999994;
  width: 35px;
  height: 35px;
  position: fixed;
  right: 0;
  top: 0;
  -webkit-appearance: none;
  cursor: pointer;
  text-decoration: none;
  text-align: center;
  padding: 0;
  color: #fff;
  font-style: normal;
  font-size: 35px;
  font-family: Arial,Baskerville,monospace;
  line-height: 35px;
  text-shadow: 0 1px 2px rgba(0,0,0,0.6);
  border: 0;
  background: none;
  outline: none;
  -webkit-box-shadow: none;
  box-shadow: none
}
.lity-close::-moz-focus-inner {
  border: 0;
  padding: 0
}
.lity-close:hover,.lity-close:focus,.lity-close:active,.lity-close:visited {
  text-decoration: none;
  text-align: center;
  padding: 0;
  color: #fff;
  font-style: normal;
  font-size: 35px;
  font-family: Arial,Baskerville,monospace;
  line-height: 35px;
  text-shadow: 0 1px 2px rgba(0,0,0,0.6);
  border: 0;
  background: none;
  outline: none;
  -webkit-box-shadow: none;
  box-shadow: none
}
.lity-close:active {
  top: 1px
}
.lity-image img {
  max-width: 100%;
  display: block;
  line-height: 0;
  border: 0
}
.lity-iframe .lity-container,.lity-youtube .lity-container,.lity-vimeo .lity-container,.lity-facebookvideo .lity-container,.lity-googlemaps .lity-container {
  width: 100%;
  max-width: 964px
}
.lity-iframe-container {
  width: 100%;
  height: 0;
  padding-top: 56.25%;
  overflow: auto;
  pointer-events: auto;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
  -webkit-overflow-scrolling: touch
}
.lity-iframe-container iframe {
  position: absolute;
  display: block;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-box-shadow: 0 0 8px rgba(0,0,0,0.6);
  box-shadow: 0 0 8px rgba(0,0,0,0.6);
  background: #000
}
.lity-hide {
  display: none
}

/* cart
**************************************** */
.ec-cartTable{
  display: table;
  width: 100%;
}
.ec-cartHeader {
  display: none;
  width: 100%;
  background: #F4F3F0;
}
.ec-cartHeader .ec-cartHeader__label{
  display: table-cell;
  padding: .5rem 1rem;
  font-size: 1.125rem;
  background: var(--clr-bk);
  color: #fff;
  overflow-x: hidden;
}
.ec-cartRow {
  display: table-row;
}
.ec-cartRow .ec-cartRow__delColumn {
  border-top: dashed 1px var(--clr-gy);
  text-align: center;
  display: table-cell;
  width: 14%;
  vertical-align: middle;
}
.ec-cartRow .ec-cartRow__contentColumn {
  border-top: dashed 1px var(--clr-gy);
  padding: 1rem 0;
  display: table;
}
.ec-cartRow .ec-cartRow__delColumn .ec-icon img {
  width: 1.5em;
  height: 1.5em;
}
.ec-cartRow .ec-cartRow__img {
  display: table-cell;
  width: 20%;
  vertical-align: middle;
  padding-right: 5%;
}
.ec-cartRow .ec-cartRow__summary {
  display: table-cell;
  font-weight: bold;
  vertical-align: middle;
  width: 75%;
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__name {
  word-break: break-all;
  margin-bottom: .5rem;
  font-size: .875rem; /* 14px */
  line-height: 1.8;
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__name a {
  display: inline-block;
  margin-bottom: .5rem;
  font-size: 1rem; /* 16px */
  line-height: 1.5;
  color: #337ab7;
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
}
.ec-cartRow__unitPrice,
.ec-cartRow__sutbtotal {
  font-size: 1rem;
  color: var(--clr-og);
}
.ec-cartRow .ec-cartRow__summary .ec-cartRow__sutbtotalSP {
  display: block;
  font-weight: normal;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amount {
  display: none;
  margin-bottom: .75rem;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountSP {
  display: block;
  margin-bottom: .75rem;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountUpDown {
  display: flex;
  justify-content: center;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountDownButton,
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountDownButtonDisabled,
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountUpButton {
  margin: 0 2px;
  display: inline-block;
  border: 1px solid var(--clr-gy);
  border-radius: 50%;
  width: 2rem;
  height: 2rem;
  cursor: pointer;
  line-height: 1;
  vertical-align: middle;
  position: relative;
  text-align: center;
  background: #fff;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountDownButtonDisabled {
  cursor: default;
}
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountDownButton .ec-cartRow__amountDownButton__icon img,
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountDownButtonDisabled .ec-cartRow__amountDownButton__icon img,
.ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountUpButton .ec-cartRow__amountUpButton__icon img {
  display: block;
  margin-left: -0.4em;
  width: 0.8em;
  height: 0.8em;
  position: absolute;
  top: 28%;
  left: 50%;
}
.ec-cartRow .ec-cartRow__amountColumn {
  display: table-cell;
  border-top: dashed 1px var(--clr-gy);
  vertical-align: middle;
  text-align: center;
  width: 20%;
}
.ec-cartRow .ec-cartRow__subtotalColumn {
  display: none;
  border-top: dashed 1px var(--clr-gy);
  text-align: right;
  width: 16.66666667%;
  padding: 1rem;
}
.ec-cartRole .ec-cartRole__actions {
  text-align: right;
  width: 100%;
  margin-bottom: 5rem;
}
.ec-cartRole .ec-cartRole__actions .btn a {
  margin-right: 0;
}
.ec-cartRole .ec-cartRole__totalAmount {
  margin-left: .5rem;
  color: var(--clr-og);
  font-size: 16px;
  letter-spacing: .02em;
}
.ec-cartRole .ec-cartRole__total {
  padding: 1rem 0;
  font-weight: bold;
  font-size: 1rem;
}
.weight_size_wrap {
  text-align: left !important;
}
.weight_size {
  margin-bottom: 1px !important;
  border: none !important;
  padding: 0.5rem 1rem !important;
  font-size: 1.125rem !important;
  background: var(--clr-bk) !important;
  color: #fff !important;
  font-family: "Kasumi Seiran Light";
  font-weight: normal;
}

@media screen and (min-width: 768px) {
  .ec-cartTable{
    border-top: none;
  }
  .ec-cartHeader{
    display: table-row;
  }
  .ec-cartRow .ec-cartRow__delColumn {
    width: 8.3333333%;
  }
  .ec-cartRow .ec-cartRow__contentColumn,
  .ec-cartRow .ec-cartRow__subtotalColumn {
    display: table-cell;
  }
  .ec-cartRow .ec-cartRow__amountColumn {
    width: 16.66666667%;
  }
  .ec-cartRow .ec-cartRow__delColumn .ec-icon img {
    width: 1em;
    height: 1em;
  }
  .ec-cartRow .ec-cartRow__img {
    display: inline-block;
  }
  .ec-cartRow .ec-cartRow__summary {
    display: inline-block;
    vertical-align: middle;
  }
  .ec-cartRow .ec-cartRow__summary .ec-cartRow__sutbtotalSP {
    display: none;
  }
  .ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amount {
    display: block;
  }
  .ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountSP {
    display: none;
  }
  .ec-cartRow .ec-cartRow__amountColumn .ec-cartRow__amountUpDown {
    display: block;
  }
  .ec-cartRole .ec-cartRole__totalAmount {
    font-size: 150%;
  }
}
@media screen and (max-width: 767px) {
  .ec-cartRole .ec-cartRole__actions {
    margin-bottom: 3rem;
  }
  .weight_size {
    padding: .25rem .5rem !important;
    font-size: 1rem !important;
  }
  .ec-cartRow .ec-cartRow__delColumn {
    width: 9%;
  }
  .ec-cartRow .ec-cartRow__delColumn .ec-icon img {
    width: 1em;
    height: 1em;
  }
  .ec-cartRow .ec-cartRow__summary .ec-cartRow__name {
    margin-bottom: 0;
  }
  .ec-cartRow .ec-cartRow__img {
    width: 30%;
  }
}

/* shopping
**************************************** */
.ec-orderRole {
  margin: 0 auto;
  box-sizing: border-box;
  line-height: 1.4;
  -webkit-text-size-adjust: 100%;
  width: 100%;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.ec-orderRole .ec-orderRole__detail {
  padding: 0;
  width: 100%;
}
.ec-orderRole .ec-orderRole__summary {
  width: 100%;
}
.ec-totalBox {
  padding: 1.5rem;
  margin-bottom: 1rem;
}
.ec-totalBox .ec-totalBox__spec {
  display: flex;
  justify-content: space-between;
  -ms-flex-pack: space-between;
  margin-bottom: .5rem;
}
.ec-totalBox .ec-totalBox__spec dt {
  text-align: left;
}
.ec-totalBox .ec-totalBox__taxRate dt::before {
  content: "[ ";
}
.ec-totalBox .ec-totalBox__spec dd {
  text-align: right;
}
.ec-totalBox .ec-totalBox__taxRate dd::after {
  content: " ]";
}
.ec-totalBox .ec-totalBox__total {
  margin-top: 1rem;
  border-top: dashed 1px var(--clr-gy);
  padding: 1rem 0 .5em;
  text-align: right;
  font-size: .875rem; /* 14px */
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
}
.ec-totalBox .ec-totalBox__price {
  margin-left: .5rem;
  font-size: 150%;
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
  letter-spacing: normal;
}
.ec-totalBox .ec-totalBox__paymentTotal {
  padding: .5rem 0;
  text-align: right;
  font-size: .875rem; /* 14px */
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
}
.ec-totalBox .ec-totalBox__taxRate {
  display: flex;
  justify-content: flex-end;
  margin-bottom: .5rem;
  font-size: .75rem; /* 12px */
}
.ec-totalBox .ec-totalBox__taxLabel {
  font-size: .875rem; /* 14px */
}
.ec-totalBox .ec-totalBox__paymentTotal .ec-totalBox__price,
.ec-totalBox .ec-totalBox__paymentTotal .ec-totalBox__taxLabel {
  color: var(--clr-og);
}
.ec-totalBox .btn-03 > * {
  margin-top: .5rem;
  width: 100%;
}

.ec-rectHeading h1,
.ec-rectHeading h2,
.ec-rectHeading h3,
.ec-rectHeading h4,
.ec-rectHeading h5,
.ec-rectHeading h6 {
  margin-bottom: 1rem;
  color: #fff;
  background: var(--clr-bk);
  padding: .5em;
  font-size: 1.125rem;
  font-family: "Kasumi Seiran Light";
  font-weight: normal;
}
.ec-orderDelivery .ec-orderDelivery__title {
  padding: 0 0 1rem;
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
  font-size: 1.125rem; /* 18px */
  position: relative;
}
.ec-orderAccount .ec-orderAccount__change,
.ec-orderDelivery .ec-orderDelivery__change {
  display: inline-block;
  position: absolute;
  right: 0;
  top: 0;
}
.ec-imageGrid {
  display: table;
  width: 100%;
  border-top: dashed 1px var(--clr-gy);
}
.ec-orderRole .ec-borderedList {
  margin-bottom: 20px;
  border-bottom: dashed 1px var(--clr-gy);
}
.ec-imageGrid .ec-imageGrid__img {
  display: table-cell;
  padding: 1rem;
  width: 20%;
}
.ec-imageGrid .ec-imageGrid__img img {
  width: 100%;
}
.ec-imageGrid .ec-imageGrid__content {
  vertical-align: middle;
  display: table-cell;
  padding: 1rem;
}
.ec-selects {
  padding-bottom: 1rem;
  margin-bottom: 1rem;
  border-bottom: dashed 1px var(--clr-gy);
}
.ec-select label {
  margin-right: .25rem;
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
}
#zeus_payment_input {
  margin-top: .5rem;
  margin-bottom: .5rem;
  border: 1px solid var(--clr-gy) !important;
  padding: 1rem !important;
}
.alert-info {
  color: #31708f;
  background-color: #d9edf7;
  border-color: #bce8f1;
}
.alert {
  padding: 1rem;
  margin-bottom: 1rem;
  border: 1px solid transparent;
  border-radius: 4px;
}
.text-danger {
  color: var(--clr-og);
}
.ec-select {
  margin-bottom: 1rem;
}
.ec-alert-warning__icon {
  display: none;
}

.ec-AddAddress .ec-AddAddress__item {
  display: table;
  padding: 1rem;
  margin-bottom: 1rem;
}
.ec-AddAddress .ec-AddAddress__itemThumb {
  display: table-cell;
  width: 20%;
}
.ec-AddAddress .ec-AddAddress__itemThumb img {
  width: 100%;
}
.ec-AddAddress .ec-AddAddress__itemtContent {
  display: table-cell;
  vertical-align: middle;
  padding-left: 1rem;
  font-size: 1rem;
}
.ec-AddAddress .ec-AddAddress__itemtTitle {
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
  margin-bottom: 1rem;
}
.ec-AddAddress .ec-AddAddress__selectAddress {
  display: inline-block;
  max-width: 100%;
}
.ec-AddAddress .ec-AddAddress__selectNumber {
  display: inline-block;
  margin-left: 2rem;
}
.ec-AddAddress .ec-AddAddress__selectNumber label {
  font-size: 1rem;
  font-family: "Shuei KakuGo Gin B";
  font-weight: normal;
}
.ec-AddAddress .ec-AddAddress__selectNumber input {
  display: inline-block;
  margin-left: .5rem;
  width: 5rem;
}

@media screen and (min-width: 768px) {
  .ec-orderRole {
    margin-top: 1.5rem;
    flex-direction: row;
  }
  .ec-orderRole .ec-orderRole__detail {
    width: 60.66666%;
  }
  .ec-orderRole .ec-orderRole__summary {
    width: 33.33333%;
  }
  .ec-select__delivery,
  .ec-select__time {
    display: inline-block;
    margin-right: 1rem;
  }
}
@media screen and (max-width: 767px) {
  .ec-orderDelivery .ec-orderDelivery__title {
    font-size: 1rem;
  }
  .ec-imageGrid .ec-imageGrid__img {
    padding: 1rem 0;
    width: 25%;
  }
}