@charset "euc-jp";
/* --------------------- */
/* 共通スタイル -------- */
/* --------------------- */
/*!
 * ress.css &#8226; v1.2.2
 * MIT License
 * github.com/filipelinhares/ress */
/* # ==================
 * # Global selectors
 * # ================== */
html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  overflow-y: scroll;
  /* All browsers without overlaying scrollbars */
  -webkit-text-size-adjust: 100%;
  /* iOS 8+ */ }

*, ::before, ::after {
  background-repeat: no-repeat;
  -webkit-box-sizing: inherit;
  box-sizing: inherit; }

::before, ::after {
  text-decoration: inherit;
  vertical-align: inherit; }

* {
  padding: 0;
  margin: 0; }

/* # ========================
 * # General elements
 * # ======================== */
/* Add the correct display in iOS 4-7. */
audio:not([controls]) {
  display: none;
  height: 0; }

hr {
  overflow: visible;
  /* Show the overflow in Edge and IE */ }

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

summary {
  display: block;
  display: list-item;
  /* Add the correct display in all browsers */ }

small {
  font-size: 80%;
  /* Set font-size to 80% in `small` elements */ }

[hidden], template {
  display: none;
  /* Add the correct display in IE */ }

abbr[title] {
  border-bottom: 1px dotted;
  /* Add a bordered underline effect in all browsers */
  text-decoration: none;
  /* Remove text decoration in Firefox 40+ */ }

a {
  background-color: transparent;
  /* Remove the gray background on active links in IE 10 */
  -webkit-text-decoration-skip: objects;
  /* Remove gaps in links underline in iOS 8+ and Safari 8+ */ }
  a:active, a:hover {
    outline-width: 0;
    /* Remove the outline when hovering in all browsers */ }

code, kbd, pre, samp {
  font-family: monospace, monospace;
  /* Specify the font family of code elements */ }

b, strong {
  font-weight: bolder;
  /* Correct style set to `bold` in Edge 12+, Safari 6.2+, and Chrome 18+ */ }

dfn {
  font-style: italic;
  /* Address styling not present in Safari and Chrome */ }

/* Address styling not present in IE 8/9 */
mark {
  background-color: #ff0;
  color: #000; }

/* https://gist.github.com/unruthless/413930 */
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sub {
  bottom: -0.25em; }

sup {
  top: -0.5em; }

ul, ol {
  list-style-type: none; }

/* # ================
 * # Forms
 * # ================ */
input {
  border-radius: 0; }
button, [type="button"], [type="reset"], [type="submit"], [role="button"] {
  cursor: pointer; }
[disabled] {
  cursor: default; }
[type="number"] {
  width: auto; }
[type="search"] {
  -webkit-appearance: textfield; }
  [type="search"]::-webkit-search-cancel-button, [type="search"]::-webkit-search-decoration {
    -webkit-appearance: none; }

textarea {
  overflow: auto;
  resize: vertical;
}

button, input, optgroup, select, textarea {
  font: inherit;
 }

optgroup {
  font-weight: bold;
}

button {
  overflow: visible;
}
  button::-moz-focus-inner {
    border-style: 0;
    padding: 0; }

/* Remove inner padding and border in Firefox 4+ */
[type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
  border-style: 0;
  padding: 0; }

/* Replace focus style removed in the border reset above */
button:-moz-focusring, [type="button"]::-moz-focus-inner, [type="reset"]::-moz-focus-inner, [type="submit"]::-moz-focus-inner {
  outline: 1px dotted ButtonText; }

button, html [type="button"], [type="reset"], [type="submit"] {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS */ }

button, select {
  text-transform: none;
  /* Firefox 40+, Internet Explorer 11- */ }

/* Remove the default button styling in all browsers */
button, input, select, textarea {
  background-color: transparent;
  border-style: none;
  color: inherit; }

/* Style select like a standard input */
select {
  -moz-appearance: none;
  /* Firefox 36+ */
  -webkit-appearance: none;
  /* Chrome 41+ */ }
  select::-ms-expand {
    display: none;
    /* Internet Explorer 11+ */ }
  select::-ms-value {
    color: currentColor;
    /* Internet Explorer 11+ */ }

legend {
  border: 0;
  /* Correct `color` not being inherited in IE 8/9/10/11 */
  color: inherit;
  /* Correct the color inheritance from `fieldset` elements in IE */
  display: table;
  /* Correct the text wrapping in Edge and IE */
  max-width: 100%;
  /* Correct the text wrapping in Edge and IE */
  white-space: normal;
  /* Correct the text wrapping in Edge and IE */ }

::-webkit-file-upload-button {
  -webkit-appearance: button;
  /* Correct the inability to style clickable types in iOS and Safari */
  font: inherit;
  /* Change font properties to `inherit` in Chrome and Safari */ }

[type="search"] {
  -webkit-appearance: textfield;
  /* Correct the odd appearance in Chrome and Safari */
  outline-offset: -2px;
  /* Correct the outline style in Safari */ }

input[type="text"], input[type="password"] {
  outline: none; }

textarea, select {
  outline: none; }

/* # =======
 * # Specify media element style
 * # ======= */
img {
  border-style: none;
  /* Remove border when inside `a` element in IE 8/9/10 */ }

/* Add the correct vertical alignment in Chrome, Firefox, and Opera */
progress {
  vertical-align: baseline; }

svg:not(:root) {
  overflow: hidden;
  /* Internet Explorer 11- */ }

audio, canvas, progress, video {
  display: inline-block;
  /* Internet Explorer 11+, Windows Phone 8.1+ */ }

/* # ======
 * # Accessibility
 * # ====== */
/* Hide content from screens but not screenreaders */
@media screen {
  [hidden~="screen"] {
    display: inherit; }
    [hidden~="screen"]:not(:active):not(:focus):not(:target) {
      position: absolute !important;
      clip: rect(0 0 0 0) !important; } }

/* Specify the progress cursor of updating elements */
[aria-busy="true"] {
  cursor: progress; }

/* Specify the pointer cursor of trigger elements */
[aria-controls] {
  cursor: pointer; }

/* Specify the unstyled cursor of disabled, not-editable, or otherwise inoperable elements */
[aria-disabled] {
  cursor: default; }

/* # =======
 * # Selection
 * # ======= */
/* Specify text selection background color and omit drop shadow */
::-moz-selection, ::-moz-selection {
  background-color: #efefef;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }
::-moz-selection, ::selection {
  background-color: #efefef;
  /* Required when declaring ::selection */
  color: #000;
  text-shadow: none; }

/* Clearfix */
.cl:before {
  content: " ";
  display: table; }

.cl:after {
  content: " ";
  display: table;
  clear: both; }

/* --------------------- */
/* 基本構造     -------- */
/* --------------------- */
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box; }

html {
  font-size: 10px; }

body {
  position: relative;
  width: 100%;
  height: 100%;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  color: #222222;
  overflow: visible;
  height: auto;
  overflow: auto;
  font-size: 1.6rem; }

_:-ms-lang(x)::-ms-backdrop, body {
  z-index: 1; }

/* テキスト ----------------------*/
h1 {
  line-height: 1.4;
  font-weight: normal; }

h2 {
  line-height: 1.4;
  font-weight: normal;
  margin: 0 0 50px 0; }

h3 {
  line-height: 1.4;
  font-weight: normal;
  margin: 0 0 30px 0; }

p {
  line-height: 1.6; }

p, li, dt, dd, a {
  line-height: 1.6; }

ul, li {
  list-style: none;
  text-decoration: none; }

ul, ol {
  padding: 0;
  margin: 0; }

button {
  outline: none; }

/* リンク ----------------------*/
a {
  -webkit-transition: all 0.25s;
  -o-transition: all 0.25s;
  transition: all 0.25s;
  text-decoration: none;
  color: #222222;
  cursor: pointer; }

a:hover {
  opacity: 0.7;
  color: #222222; }

a:hover {
  -webkit-transition: all 0.25s;
  -o-transition: all 0.25s;
  transition: all 0.25s;
  text-decoration: none; }

/* 画像 ----------------------*/
.page_wrapper img {
  width: 100%;
  max-width: 100%; }

input {
  outline: none; }

input::-ms-clear {
  visibility: hidden; }

button {
  cursor: pointer; }

/* メディアクエリ ----------------------*/
.pc_only {
  display: block; }

.pc_tb_only {
  display: block; }

.sp_tb_only {
  display: none; }

.sp_only {
  display: none; }

@media screen and (max-width: 768px) {
  .pc_only {
    display: none; }
  .pc_tb_only {
    display: block; }
  .sp_tb_only {
    display: block; }
  .sp_only {
    display: none; } }

@media screen and (max-width: 480px) {
  .pc_tb_only {
    display: none; }
  .sp_only {
    display: block; }
  .sp_only.sp_480 {
    display: block; }
  .sp_only.sp_320 {
    display: none; } }

@media screen and (max-width: 320px) {
  .sp_only.sp_480 {
    display: none; }
  .sp_only.sp_320 {
    display: block; } }

/* メディアクエリ 改行 ----------------------*/
.br_pc {
  display: inline-block; }

.br_pc_tb {
  display: inline-block; }

.br_tb {
  display: none; }

.br_sp_tb {
  display: none; }

.br_sp {
  display: none; }

@media screen and (max-width: 768px) {
  .br_pc {
    display: none; }
  .br_tb {
    display: inline-block; }
  .br_sp_tb {
    display: inline-block; }
  .br_sp {
    display: none; } }

@media screen and (max-width: 480px) {
  .br_pc_tb {
    display: none; }
  .br_sp_tb {
    display: none; }
  .br_tb {
    display: none; }
  .br_sp {
    display: inline-block; }
  .br_sp.sp_320 {
    display: none; } }

@media screen and (max-width: 320px) {
  .br_sp.sp_320 {
    display: inline-block; }
  .br_sp.not_sp_320 {
    display: none; } }

/* --------------------- */
/* テキスト ------------ */
/* --------------------- */
/* フォントファミリー */
.gothic_mix {
  font-family: "Open Sans", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }

.gothic_en {
  font-family: "Open Sans", sans-serif; }

.mincyo_jn {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif; }

/* カラー */
.text_white {
  color: #fff; }

.text_highlight {
  color: #098642;
  font-weight: bold; }

/* font デコレーション */
.text_c {
  text-align: center; }

.text_l {
  text-align: left; }

.text_r {
  text-align: right; }

.text_prm {
  color: #098642; }

.text_b {
  font-weight: bold; }

.text_underline {
  text-decoration: underline; }

.text_borderbottom {
  border-bottom: 1px solid #098642; }

/* fontサイズ */
.font_12 {
  font-size: 1.2rem !important; }

.font_13 {
  font-size: 1.3rem !important; }

.font_14 {
  font-size: 1.4rem !important; }

.font_15 {
  font-size: 1.5rem !important; }

.font_16 {
  font-size: 1.6rem !important; }

.font_17 {
  font-size: 1.7rem !important; }

.font_18 {
  font-size: 1.8rem !important; }

.font_20 {
  font-size: 2rem !important; }

.font_22 {
  font-size: 2.2rem !important; }

.font_23 {
  font-size: 2.3rem !important; }

@media screen and (max-width: 768px) {
  .font_12_tb {
    font-size: 1.2rem !important; }
  .font_13_tb {
    font-size: 1.3rem !important; }
  .font_14_tb {
    font-size: 1.4rem !important; }
  .font_15_tb {
    font-size: 1.5rem !important; }
  .font_16_tb {
    font-size: 1.6rem !important; }
  .font_17_tb {
    font-size: 1.7rem !important; }
  .font_18_tb {
    font-size: 1.8rem !important; }
  .font_20_tb {
    font-size: 2rem !important; }
  .font_22_tb {
    font-size: 2.2rem !important; }
  .font_23_tb {
    font-size: 2.3rem !important; } }

@media screen and (max-width: 480px) {
  .font_12_sp {
    font-size: 1.2rem !important; }
  .font_13_sp {
    font-size: 1.3rem !important; }
  .font_14_sp {
    font-size: 1.4rem !important; }
  .font_15_sp {
    font-size: 1.5rem !important; }
  .font_16_sp {
    font-size: 1.6rem !important; }
  .font_17_sp {
    font-size: 1.7rem !important; }
  .font_18_sp {
    font-size: 1.8rem !important; }
  .font_20_sp {
    font-size: 2rem !important; }
  .font_22_sp {
    font-size: 2.2rem !important; }
  .font_23_sp {
    font-size: 2.3rem !important; } }

/* インデント */
.text_indent {
  padding-left: 1.2rem;
  text-indent: -1.5rem; }

/* --------------------- */
/* 外枠レイアウト ------ */
/* --------------------- */
#wrapper {
  margin: 0;
  padding: 0; }

.wrapper {
  position: relative; }

@media screen and (max-width: 768px) {
  .wrapper.no_scroll {
    position: fixed;
    width: 100%;
    height: 100%; } }

@media screen and (max-width: 768px) {
  header.open + .wrapper:after {
    content: "";
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.5);
    z-index: 100;
    pointer-events: none; } }

/* 背景色スタイル ----------------------*/
.bg_white {
  background-color: #fff; }

.bg_beige {
  background-color: #E6E4DE; }

/* flex ----------------------*/
.flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: normal;
  -ms-flex-direction: row;
  flex-direction: row;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start; }

.flex.no_wrap {
  -ms-flex-wrap: nowrap !important;
  flex-wrap: nowrap !important;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between; }

/* 位置指定 ----------------------*/
.fixed {
  position: fixed; }

/* ボックス ----------------------*/
.block {
  display: block; }

/* フロート ----------------------*/
.f_l {
  float: left; }

.f_r {
  float: right; }

/* cleaffix ----------------------*/
/* For modern browsers */
.cf:before,
.cf:after {
  content: "";
  display: table; }

.cf:after {
  clear: both; }

/* For IE 6/7 (trigger hasLayout) */
.cf {
  zoom: 1; }

/* 画像枠 ----------------------*/
.img_wrap {
  font-size: 0; }
  .img_wrap img {
    width: 100%; }
  .img_wrap picture {
    width: 100%; }

/* object-fit ----------------------*/
.obj-cover {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  font-family: 'object-fit: cover;';
  -o-object-position: center center;
  object-position: center center; }

/* マージン ----------------------*/
.mb_0 {
  margin-bottom: 0px !important; }

.mb_8 {
  margin-bottom: 8px !important; }

.mb_12 {
  margin-bottom: 12px !important; }

.mb_16 {
  margin-bottom: 16px !important; }

.mb_20 {
  margin-bottom: 20px !important; }

.mb_24 {
  margin-bottom: 24px !important; }

.mb_30 {
  margin-bottom: 30px !important; }

.mb_36 {
  margin-bottom: 36px !important; }

.mb_40 {
  margin-bottom: 40px !important; }

.mb_50 {
  margin-bottom: 50px !important; }

.mb_60 {
  margin-bottom: 60px !important; }

.mt_0 {
  margin-top: 0px !important; }

.mt_8 {
  margin-top: 8px !important; }

.mt_12 {
  margin-top: 12px !important; }

.mt_16 {
  margin-top: 16px !important; }

.mt_20 {
  margin-top: 20px !important; }

.mt_24 {
  margin-top: 24px !important; }

.mt_30 {
  margin-top: 30px !important; }

.mt_36 {
  margin-top: 36px !important; }

.mt_40 {
  margin-top: 40px !important; }

.mt_50 {
  margin-top: 50px !important; }

.mt_60 {
  margin-top: 60px !important; }

/* --------------------- */
/* 部品         -------- */
/* --------------------- */
.bg_sns_facebook {
  background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_facebook.svg") no-repeat center center;
  background-size: contain; }
  .bg_sns_facebook:hover {
    background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_facebook_on.svg") no-repeat center center;
    background-size: contain; }

.bg_sns_twitter {
  background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_twitter.svg") no-repeat center center;
  background-size: contain; }
  .bg_sns_twitter:hover {
    background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_twitter_on.svg") no-repeat center center;
    background-size: contain; }

.bg_sns_instagram {
  background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_instagram.svg") no-repeat center center;
  background-size: contain; }
  .bg_sns_instagram:hover {
    background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_instagram_on.svg") no-repeat center center;
    background-size: contain; }
.link_page {
  position: relative;
  padding: 10px 44px 10px 24px !important;
  font-size: 1.5rem;
  letter-spacing: 0.07em;
  display: inline-block;
}
  .link_arrow:after {
    content: "";
    position: absolute;
    top: calc(50% - 6px);
    right: 20px;
    width: 10px;
    height: 13px;
    background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_arrow_blk.svg") no-repeat center center;
    background-size: 100% auto; }

.link_arrow.arrow_down:after {
  -webkit-transform: rotate(90deg);
  -ms-transform: rotate(90deg);
  transform: rotate(90deg); }

.link_arrow.arrow_top:after {
  -webkit-transform: rotate(-90deg);
  -ms-transform: rotate(-90deg);
  transform: rotate(-90deg); }

.box_border {
  border: 1px solid #222222;
  border-radius: 5px;
  padding: 8px 16px; }

.box_border.gray {
  border: 1px solid #777777;
  border-radius: 5px; }

.box_bg {
  background-color: #222222;
  padding: 8px 16px;
  color: #fff; }

.box_bg.link_arrow {
  padding: 8px 32px 8px 16px; }
  .box_bg.link_arrow:after {
    background: url("https://file002.shop-pro.jp/PA01361/349/img/common/icon_arrow_white.svg") no-repeat center center;
    background-size: 100% auto;
    right: 10px; }

.box_bg.gray {
  background-color: #777777;
  border-radius: 5px; }

.news_body {
  font-size: 13px;
  line-height: 1.5em;
  letter-spacing: -0.05em;
  color: #060505;
  padding: 0;
  margin: 0;
  word-wrap: break-word;
  text-align: justify;
  font-family: Verdana,"游ゴシック",YuGothic,"ヒラギノ角ゴ ProN W3","Hiragino Kaku Gothic ProN","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,sans-serif;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%; }
  .news_body ul {
    margin: 0;
    padding: 0;
    border-top-style: none;
    border-right-style: none;
    border-bottom-style: none;
    border-left-style: none;
    display: block; }
    .news_body ul li {
      list-style-type: none;
      margin: 0;
      padding: 0;
      border-top-style: none;
      border-right-style: none;
      border-bottom-style: none;
      border-left-style: none;
      display: list-item;
      text-align: -webkit-match-parent; }
      .news_body ul li > a {
        display: block;
        overflow: hidden;
        padding: 5px 0;
        letter-spacing: 0.05em;
        text-decoration: none;
        color: #060505;
        -webkit-transition: all 0.3s;
        -moz-transition: all 0.3s;
        -ms-transition: all 0.3s;
        -o-transition: all 0.3s;
        transition: all 0.3s; }
        .news_body ul li > a:hover {
          color: #7d7d7d;
          text-decoration: none;
          opacity: 1 !important;
          filter: alpha(opacity=100) !important;
          zoom: 1 !important; }
        .news_body ul li > a > h4 {
          padding: 0;
          border-top-style: none;
          border-right-style: none;
          border-bottom-style: none;
          border-left-style: none;
          float: left;
          margin: 0 20px 0 0;
          font-size: 115%;
          font-weight: normal; }
        .news_body ul li > a > h3 {
          margin: 0;
          padding: 0;
          border-top-style: none;
          border-right-style: none;
          border-bottom-style: none;
          border-left-style: none;
          float: left;
          font-size: 115%;
          font-weight: bold; }
          .news_body ul li > a > h3:not(:target) {
            padding-top: 0.2em\9; }

.news_body ul {
  list-style: none;
  margin: -10px 0 0 0; }
  .news_body ul li > a {
    padding: 10px 0 14px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex; }
    .news_body ul li > a > h4 {
      float: none;
      width: 11rem;
      font-size: 1.3rem;
      font-family: "Open Sans", sans-serif;
      letter-spacing: 0; }
    .news_body ul li > a > h3 {
      float: none;
      font-size: 1.5rem;
      font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
      font-weight: normal;
      width: calc( 100% - 11rem); }

@media screen and (max-width: 768px) {
  .news_body ul li > a > h4 {
    width: 8rem; }
  .news_body ul li > a > h3 {
    width: calc( 100% - 8rem); } }

@media screen and (max-width: 480px) {
  .news_body ul li > a {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column; }
    .news_body ul li > a > h4 {
      width: 100%;
      margin-bottom: 12px; }
    .news_body ul li > a > h3 {
      width: 100%;
      font-size: 1.4rem;
      line-height: 1.6; } }

/* --------------------- */
/* animation    -------- */
/* --------------------- */
/* scroll effect  ------- anime_scroll_abc_ill */
.anime_scroll_abc_ill_effct {
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 0.6s;
  animation-duration: 0.6s;
  -webkit-animation-name: anime_scroll_abc_ill_effct;
  animation-name: anime_scroll_abc_ill_effct;
  visibility: visible !important; }

@-webkit-keyframes anime_scroll_abc_ill_effct {
  0% {
    opacity: 0;
    -webkit-transform: translate(120%, -50px);
    transform: translate(120%, -50px); }
  100% {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0); } }

@keyframes anime_scroll_abc_ill_effct {
  0% {
    opacity: 0;
    -webkit-transform: translate(120%, -50px);
    transform: translate(120%, -50px); }
  100% {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0); } }

/* scroll effect  ------- scaleup fadein */
.anime_scroll_fadein_scaleUp_effct {
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-name: anime_scroll_fadein_scaleUp_effct;
  animation-name: anime_scroll_fadein_scaleUp_effct;
  visibility: visible !important; }

@-webkit-keyframes anime_scroll_fadein_scaleUp_effct {
  0% {
    opacity: 0;
    -webkit-transform: matrix(1, 0, 0, 1, 0, 50);
    transform: matrix(1, 0, 0, 1, 0, 50);
    -webkit-transform: scale(0.5);
    transform: scale(0.5); }
  100% {
    opacity: 1;
    -webkit-transform: matrix(1, 0, 0, 1, 0, 0);
    transform: matrix(1, 0, 0, 1, 0, 0);
    -webkit-transform-origin: 50% 50% 0px;
    transform-origin: 50% 50% 0px;
    -webkit-transform: scale(1);
    transform: scale(1); } }

@keyframes anime_scroll_fadein_scaleUp_effct {
  0% {
    opacity: 0;
    -webkit-transform: matrix(1, 0, 0, 1, 0, 50);
    transform: matrix(1, 0, 0, 1, 0, 50);
    -webkit-transform: scale(0.5);
    transform: scale(0.5); }
  100% {
    opacity: 1;
    -webkit-transform: matrix(1, 0, 0, 1, 0, 0);
    transform: matrix(1, 0, 0, 1, 0, 0);
    -webkit-transform-origin: 50% 50% 0px;
    transform-origin: 50% 50% 0px;
    -webkit-transform: scale(1);
    transform: scale(1); } }

/* scroll effect  ------- scaleup fadein quick */
.anime_scroll_fadein_quick_effct {
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 0.4s;
  animation-duration: 0.4s;
  -webkit-animation-name: anime_scroll_fadein_quick_effct;
  animation-name: anime_scroll_fadein_quick_effct;
  visibility: visible !important; }

@-webkit-keyframes anime_scroll_fadein_quick_effct {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-4%);
    transform: translateY(-4%); }
  100% {
    opacity: 1;
    -webkit-animation: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
    animation: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) both; } }

@keyframes anime_scroll_fadein_quick_effct {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-4%);
    transform: translateY(-4%); }
  100% {
    opacity: 1;
    -webkit-animation: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) both;
    animation: 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275) both; } }

/* scroll effect  ------- right - left */
.anime_scroll_r_l_effct {
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-name: anime_scroll_r_l_effct;
  animation-name: anime_scroll_r_l_effct;
  visibility: visible !important; }

@-webkit-keyframes anime_scroll_r_l_effct {
  0% {
    opacity: 0;
    -webkit-transform: translateX(300px);
    -ms-transform: translateX(300px);
    transform: translateX(300px); }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0); } }

@keyframes anime_scroll_r_l_effct {
  0% {
    opacity: 0;
    -webkit-transform: translateX(300px);
    -ms-transform: translateX(300px);
    transform: translateX(300px); }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0); } }

/* scroll effect  ------- top - bottom */
.anime_scroll_t_b_effct {
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 0.5s;
  animation-duration: 0.5s;
  -webkit-animation-name: anime_scroll_t_b_effct;
  animation-name: anime_scroll_t_b_effct;
  visibility: visible !important; }

@-webkit-keyframes anime_scroll_t_b_effct {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-300px);
    -ms-transform: translateY(-300px);
    transform: translateY(-300px); }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); } }

@keyframes anime_scroll_t_b_effct {
  0% {
    opacity: 0;
    -webkit-transform: translateY(-300px);
    -ms-transform: translateY(-300px);
    transform: translateY(-300px); }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); } }

/* --------------------- */
/* modal   ------------- */
/* --------------------- */
.openModal {
  outline: none; }

.modalArea {
  display: none;
  position: fixed;
  z-index: 1010;
  color: #222222;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%; }

.modalBg {
  width: 100%;
  height: 100%;
  background-color: rgba(29, 29, 29, 0.8); }

.modalWrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 70%;
  max-width: 500px;
  padding: 30px 30px;
  background-color: #fff; }

.closeModal {
  position: absolute;
  display: block;
  width: 40px;
  height: 40px;
  top: 30px;
  right: 40px;
  cursor: pointer; }
  .closeModal:before, .closeModal:after {
    position: absolute;
    content: "";
    display: block;
    top: 17px;
    left: 10px;
    width: 20px;
    height: 3px;
    background-color: #000;
    opacity: 0.7; }
  .closeModal:before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg); }
  .closeModal:after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg); }

@media screen and (max-width: 768px) {
  .modalWrapper {
    width: 90%; } }

@media screen and (max-width: 480px) {
  .closeModal {
    top: -200%;
    right: 0; } }

/* --------------------- */
/* header       -------- */
/* --------------------- */
#header_wrapper {
  margin: 0;
  padding: 0;
  position: relative;
  height: 65px;
  width: 100%;
  background-color: #222222;
  z-index: 100; }
  #header_wrapper ul li a {
    text-decoration: none; }
  #header_wrapper .inner_contents {
    height: 100%; }

.gnav_logo {
  width: 161px;
  height: 100%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center; }

.gnav_menu_first {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  height: 100%; }
  .gnav_menu_first > li {
    height: 100%;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
    padding: 0; }
    .gnav_menu_first > li:not(:last-of-type) > a {
      padding: 0 1.3vw; }
    .gnav_menu_first > li > a {
      display: inline-block;
      height: 100%;
      line-height: 70px;
      position: relative;
      font-size: 1.4rem;
      color: #fff;
      padding: 0; }
      .gnav_menu_first > li > a:hover {
        opacity: 0.75; }
  .gnav_menu_first > li:not(.view_cart) > a:hover:after {
    position: absolute;
    content: "";
    display: inline-block;
    width: 30px;
    height: 2px;
    top: 50px;
    left: calc( 50% - 15px);
    background-color: #fff; }
  .gnav_menu_first .is_active a:after {
    position: absolute;
    content: "";
    display: inline-block;
    width: 30px;
    height: 2px;
    top: 50px;
    left: calc( 50% - 15px);
    background-color: #fff; }

a:hover + .gnav_menu_secound,
.gnav_menu_secound:hover {
  display: block; }
  a:hover + .gnav_menu_secound:before,
  .gnav_menu_secound:hover:before {
    content: "";
    display: block;
    position: absolute;
    width: 100vw;
    height: 15px;
    top: -15px;
    left: 0; }

.gnav_menu_secound {
  display: none;
  background-color: #fff;
  position: absolute;
  top: 100%;
  left: 0;
  width: 100%;
  margin-top: -5px;
  padding: 24px 25%;
  text-align: center; }
  .gnav_menu_secound > li {
    margin: 0;
    padding: 0;
    line-height: 1;
    display: inline-block;
    font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }
    .gnav_menu_secound > li:not(:last-of-type) {
      margin-right: 3px; }
    .gnav_menu_secound > li a {
      display: inline-block;
      padding: 6px 12px;
      font-size: 1.4rem;
      line-height: 1.6; }

.view_cart {
  margin-left: 25px; }
  .view_cart a {
    font-family: "Open Sans", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
    font-size: 1.3rem !important;
    font-weight: bold; }
  .view_cart .view_cart_icon_part {
    position: relative;
    display: inline-block;
    top: 5px;
    width: 23px;
    height: 23px;
    margin: 0px 12px 0 0; }
  .view_cart .icon-cart {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: url(https://file002.shop-pro.jp/PA01361/349/img/common/icon_cart.svg) no-repeat center center;
    background-size: 21px auto; }
  .view_cart .num_cart {
    position: absolute;
    display: inline-block;
    top: -7px;
    right: -11px;
    width: 17px;
    height: 17px;
    text-align: center;
    line-height: 17px;
    letter-spacing: 0;
    font-size: 1rem;
    font-weight: normal;
    background-color: #D58061;
    border-radius: 50%; }
  .view_cart .tax {
    font-size: 0.9rem; }

#header_wrapper.fixed {
  position: fixed;
  top: 0;
  left: 0;
  background-color: rgba(34, 34, 34, 0.9); }

@media screen and (max-width: 1280px) {
  .gnav_menu_secound {
    padding: 24px 18%; } }

@media screen and (max-width: 1040px) {
  #header_wrapper .inner_contents {
    width: 100%;
    padding: 0 4%; }
  .gnav_menu_first > li {
    height: 100%;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
    padding: 0; }
    .gnav_menu_first > li:not(:last-of-type) > a {
      padding: 0 1.05vw; }
  .view_cart {
    margin-left: 0; } }

@media screen and (max-width: 960px) {
  #header_wrapper .inner_contents {
    padding: 0 3%; } }

@media screen and (max-width: 940px) {
  .gnav_logo {
    width: 140px; }
  .gnav_menu_first > li > a {
    font-size: 1.2rem; }
  .view_cart {
    margin-left: 0; }
    .view_cart .view_cart_icon_part {
      margin: 0px 10px 0 0; }
  .amount_cart {
    font-size: 1.2rem; } }

@media screen and (max-width: 820px) {
  #header_wrapper .inner_contents {
    padding: 0 2% 0 2.5%; }
  .gnav_menu_first > li:not(:last-of-type) > a {
    padding: 0 0.7vw; }
  .gnav_menu_secound {
    padding: 24px 8%; }
  .view_cart .view_cart_icon_part {
    width: 20px;
    height: 20px;
    margin: 0px 8px 0 0; }
  .view_cart .num_cart {
    right: -9px; }
  .view_cart .icon-cart {
    background-size: 15px auto; } }

@media screen and (max-width: 768px) {
  #header_wrapper {
    width: 768px; } }

/* --------------------- */
/* フッター     -------- */
/* --------------------- */
#footer_category {
  padding: 60px 0 23px;
  background-color: #E6E4DE; }
  #footer_category .inner_contents {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap; }
  #footer_category .content_ttl {
    display: inline-block;
    position: relative;
    width: 260px;
    margin: 0;
    text-align: left;
    line-height: 1.8;
    font-weight: normal;
    font-size: 1.4rem; }
    #footer_category .content_ttl:after {
      position: absolute;
      width: 100%;
      height: 1px;
      top: 26px;
      bottom: inherit;
      margin: 0;
      left: 0;
      -webkit-transform: none;
      -ms-transform: none;
      transform: none; }
    #footer_category .content_ttl .img_wrap {
      display: inline-block;
      height: 23px;
      font-size: inherit; }
      #footer_category .content_ttl .img_wrap img {
        height: 100%;
        width: auto; }
    #footer_category .content_ttl span {
      display: inline-block !important;
      margin: 0 0 0 15px;
      vertical-align: middle;
      font-size: 1.4rem;
      font-weight: normal; }
  #footer_category .list_category {
    width: calc( 100% - 260px);
    margin: 0 0 96px 0;
    padding: 0 0 0 20%; }
    #footer_category .list_category li {
      width: 33.3%; }
      #footer_category .list_category li:not(:last-of-type) {
        margin-bottom: 9px; }
      #footer_category .list_category li:before {
        content: "- "; }
      #footer_category .list_category li a {
        padding: 10px 0;
        font-size: 1.4rem; }
  @media screen and (max-width: 1024px) {
    #footer_category .content_ttl {
      width: 230px; }
      #footer_category .content_ttl span {
        margin: 0 0 0 10px;
        font-size: 1.1rem; }
    #footer_category .list_category {
      width: calc( 100% - 230px);
      padding: 0 0 0 5%; }
      #footer_category .list_category li {
        width: 33%; } }
  @media screen and (max-width: 768px) {
    #footer_category .inner_contents.middle {
      width: 100%; } }

#pagetop_part {
  text-align: center; }
  #pagetop_part a {
    display: inline-block;
    width: calc( 40px * 2);
    height: 32px; }
    #pagetop_part a img {
      width: 50%;
      height: auto;
      margin: 0 auto; }

#footer_body {
  padding: 70px 0 20px;
  background-color: #222222;
  color: #fff;
  letter-spacing: 0.05em; }
  #footer_body .inner_contents {
    position: relative;
    padding-bottom: 95px; }
  #footer_body ul li a {
    color: #fff; }
  #footer_body .footer_menu_wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    width: 78%;
    margin: 0 auto; }
  #footer_body .foote_logo {
    width: 194px;
    margin: 0 auto 40px; }
  @media screen and (max-width: 1160px) {
    #footer_body .footer_menu_wrap {
      width: 90%; } }
  @media screen and (max-width: 768px) {
    #footer_body > .inner_contents {
      padding: 0 8%; }
    #footer_body .footer_menu_wrap {
      width: 100%; } }
  #footer_body .list_footerMenu_main {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 50%;
    margin: -7px 0 21px 0;
    font-size: 1.4rem; }
    #footer_body .list_footerMenu_main li {
      width: 50%;
      line-height: 1; }
      #footer_body .list_footerMenu_main li:not(:last-of-type) {
        margin-bottom: 5px; }
      #footer_body .list_footerMenu_main li a {
        display: inline-block;
        padding: 7px 5px 7px 0; }
  #footer_body .foooter_menu_products {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1; }
  #footer_body .foooter_menu_about {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3; }
  #footer_body .foooter_menu_recipe {
    -webkit-box-ordinal-group: 6;
    -ms-flex-order: 5;
    order: 5; }
  #footer_body .foooter_menu_news {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2; }
  #footer_body .foooter_menu_shop {
    -webkit-box-ordinal-group: 5;
    -ms-flex-order: 4;
    order: 4; }
  #footer_body .foooter_menu_website {
    -webkit-box-ordinal-group: 7;
    -ms-flex-order: 6;
    order: 6; }
  #footer_body .foooter_menu_logout {
    -webkit-box-ordinal-group: 8;
    -ms-flex-order: 7;
    order: 7; }
  #footer_body .footer_contact_part {
    width: 50%;
    margin-top: 5px;
    padding-left: 17%;
    font-size: 1.4rem; }
    #footer_body .footer_contact_part p {
      width: 300px;
      margin-bottom: 10px; }
    #footer_body .footer_contact_part a {
      display: block; }
    #footer_body .footer_contact_part a:hover {
      opacity: 0.75; }
    #footer_body .footer_contact_part .part_ttl {
      width: 276px;
      padding: 7px;
      margin-bottom: 20px;
      text-align: center;
      letter-spacing: 0.3em;
      font-size: 1.5rem;
      border: 1px solid #fff;
      border-radius: 5px;
      color: #fff; }
    #footer_body .footer_contact_part .tel_num {
      width: 154px;
      margin-bottom: 10px; }
    #footer_body .footer_contact_part .footer_contact_part {
      padding-left: 10%; }
    @media screen and (max-width: 768px) {
      #footer_body .footer_contact_part {
        padding-left: 7%; } }
  #footer_body .list_footerMenu_bottom {
    margin: 0 auto;
    position: absolute;
    bottom: 32px;
    left: 0;
    right: 0;
    justify-content: center;
}
    #footer_body .list_footerMenu_bottom li:not(:last-of-type) {
      margin-right: 10px; }
    #footer_body .list_footerMenu_bottom li a {
      padding: 5px;
      font-size: 1.2rem; }
    @media screen and (max-width: 768px) {
      #footer_body .list_footerMenu_bottom {
        right: 7%; } }
  #footer_body .footer_copyright_area {
    position: absolute;
    margin: 0 auto;
    padding: 0;
    bottom: 3px;
    left: 0;
    right: 0;
    width: 356px;
    height: 14px;
    font-size: 0; }
    #footer_body .footer_copyright_area img {
      height: 100%;
      width: auto; }
    @media screen and (max-width: 768px) {
      #footer_body .footer_copyright_area {
        left: 4%; } }
  @media screen and (max-width: 1024px) {
    #footer_body .inner_contents {
      padding-bottom: 115px; }
    #footer_body .list_footerMenu_bottom {
      bottom: 30px; } }

_:-ms-lang(x)::-ms-backdrop, #footer_body .footer_contact_part .part_ttl {
  padding: 10px 7px 7px; }

.page_wrapper {
  background-color: #F4F2EF; }

.container {
  width: 100%;
  max-width: inherit;
  height: 100%; }

.contentsArea {
  margin: 0 auto;
  padding: 100px 0 0; }

.contentsArea_fill {
  width: 100%;
  padding: 100px 0; }

.inner_contents {
  width: 90%;
  max-width: 1160px;
  margin: 0 auto;
  padding: 0; }

.inner_contents.middle {
  width: 91.379%;
  max-width: 1060px;
  margin: 0 auto; }

.inner_contents.middle_l {
  width: 93%;
  max-width: 1060px;
  margin: 0 auto; }

@media screen and (max-width: 768px) {
  .page_wrapper {
    width: 768px; }
  .contentsArea > .inner_contents {
    padding: 0 4%; }
  .contentsArea_fill > .inner_contents {
    padding: 0 4%; }
  .inner_contents {
    width: 100%; }
  .inner_contents.middle {
    width: 96%;
    margin: 0 auto; }
  .inner_contents.middle_l {
    width: 98%;
    margin: 0 auto; } }

.flex.colomn_4_pc {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
  .flex.colomn_4_pc > .flex_item {
    width: calc( ( 99.9% - 81px ) / 4); }
    .flex.colomn_4_pc > .flex_item:not(:nth-of-type(4n)) {
      margin-right: 27px; }

.flex.colomn_3_pc {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
  .flex.colomn_3_pc > .flex_item {
    width: calc( ( 99.9% - 6% ) / 3);
    margin-right: 0 !important; }
    .flex.colomn_3_pc > .flex_item:not(:nth-of-type(3n)) {
      margin-right: 3% !important; }

.flex.colomn_2_pc {
  -ms-flex-wrap: wrap;
  flex-wrap: wrap; }
  .flex.colomn_2_pc > .flex_item {
    width: calc( ( 99.9% - 5% ) / 2); }
    .flex.colomn_2_pc > .flex_item:not(:nth-of-type(2n)) {
      margin-right: 5%; }

.flex.colomn_1_pc {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column; }
  .flex.colomn_1_pc > .flex_item {
    width: 100%;
    margin: 0;
    padding: 0; }

@media screen and (max-width: 768px) {
  .flex.colomn_2_tb > .flex_item {
    width: calc( ( 99.9% - 3% ) / 2);
    margin-right: 0 !important; }
    .flex.colomn_2_tb > .flex_item:not(:nth-of-type(2n)) {
      margin-right: 3% !important; }
  .flex.colomn_1_tb {
    -webkit-box-orient: vertical !important;
    -webkit-box-direction: normal !important;
    -ms-flex-direction: column !important;
    flex-direction: column !important; }
    .flex.colomn_1_tb > .flex_item {
      width: 100% !important;
      margin-right: 0 !important; } }

.part_breadcrumb {
  background-color: #F4F2EF; }

.list_breadcrumb li {
  display: inline-block;
  padding: 6px 0 5px;
  font-size: 1.2rem; }
  .list_breadcrumb li:not(:last-of-type):after {
    content: ">";
    margin-left: 5px; }
  .list_breadcrumb li a {
    padding: 3px 3px 3px 0;
    font-size: 1.2rem; }
  .list_breadcrumb li:last-of-type a {
    pointer-events: none; }

@media screen and (max-width: 1024px) {
  .part_breadcrumb .inner_contents {
    width: 100%;
    padding: 0 4%; } }

@media screen and (max-width: 768px) {
  .part_breadcrumb .inner_contents {
    padding: 0 3%; } }

#space_category {
  padding: 63px 0 100px; }
  #space_category .img_part_column {
    -ms-flex-flow: nowrap;
    flex-flow: nowrap;
    margin-top: 40px; }
    #space_category .img_part_column .img_wrap {
      width: calc( ( 99.9% - 7% ) / 3); }
      #space_category .img_part_column .img_wrap:not(:nth-of-type(3n)) {
        margin-right: 3.5%; }
  #space_category a {
    display: block; }

#space_bannerArea {
  padding: 100px 0 70px !important; }
  #space_bannerArea .img_part_column {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap; }
    #space_bannerArea .img_part_column .img_wrap {
      width: calc( ( 99.9% - 4% ) / 3);
      margin-bottom: 30px; }
      #space_bannerArea .img_part_column .img_wrap:not(:nth-of-type(3n)) {
        margin-right: 2%; }

#space_recommended_recipe {
  padding: 80px 0 70px; }
  #space_recommended_recipe .content_ttl {
    text-align: center;
    font-size: 2.5rem;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
    font-weight: 900; }
  #space_recommended_recipe .product_list {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start; }
    #space_recommended_recipe .product_list li {
      margin-bottom: 0; }
  #space_recommended_recipe .recipe_category {
    color: #777777;
    font-size: 1.5rem;
    font-weight: bold; }

#space_sns {
  padding: 100px 0 0; }
  #space_sns .box_line {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
    width: 80%;
    max-width: 800px;
    margin: 0 auto;
    padding: 34px 5% 29px 8%;
    z-index: 2; }
    #space_sns .box_line:before, #space_sns .box_line:after {
      content: "";
      position: absolute;
      display: block;
      width: calc( 100% - 5px);
      height: calc( 100% - 5px);
      top: 0;
      left: 0;
      border: 1px solid #777777;
      pointer-events: none; }
    #space_sns .box_line:before {
      top: 0;
      left: 0; }
    #space_sns .box_line:after {
      top: 5px;
      left: 5px; }
  #space_sns .ttl {
    margin-bottom: 0;
    padding-right: 15px;
    font-size: 1.8rem;
    font-weight: 500;
    background-color: #F4F2EF; }
    #space_sns .ttl:before {
      content: "";
      position: absolute;
      width: calc( 100% - ( 5% + 8% + 204px + 286px ));
      width: 70%;
      height: 1px;
      top: 52%;
      left: calc( 50% + 204px);
      left: 50%;
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
      transform: translateX(-50%);
      background-color: #777777;
      z-index: -1; }
  #space_sns .list_sns {
    padding-left: 15px;
    line-height: 1;
    background-color: #F4F2EF; }
    #space_sns .list_sns li {
      display: inline-block;
      line-height: 1; }
    #space_sns .list_sns .sns_facebook {
      position: relative;
      top: 1px;
      width: 92px; }
  @media screen and (max-width: 900px) {
    #space_sns .box_line {
      width: 90%;
      max-width: inherit; }
    #space_sns .ttl {
      font-size: 1.7rem; } }

#space_recommended_products .content_ttl {
  text-align: center;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  font-size: 2.5rem;
  font-weight: 900; }

#space_recommended_products .product_list {
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start; }
  #space_recommended_products .product_list li {
    margin-bottom: 0; }
  #space_recommended_products .product_list .prd_name {
    margin-bottom: 16px; }
  #space_recommended_products .product_list .prd_des {
    margin-bottom: 7px; }
  #space_recommended_products .product_list .prd_price {
    font-size: 1.4rem; }

.l_r_box,
.r_l_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: nowrap;
  flex-wrap: nowrap;
  text-align: left; }
.l_r_box .box_l,
.r_l_box .box_l {
  -webkit-box-ordinal-group: 2;
  -ms-flex-order: 1;
  order: 1; }
.l_r_box .box_r,
.r_l_box .box_r {
  -webkit-box-ordinal-group: 3;
  -ms-flex-order: 2;
  order: 2; }

.ttl_border {
  position: relative;
  margin-bottom: 90px;
  font-weight: bold; }
  .ttl_border span {
    display: block;
    font-size: 1.6rem; }
  .ttl_border:after {
    position: absolute;
    content: "";
    display: inline-block;
    bottom: -30px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    width: 40px;
    height: 2px;
    background-color: #777777; }

.product_list li {
  width: calc( ( 99.9% - 15% ) / 4);
  margin-bottom: 70px;
  font-size: 1.6rem; }
  .product_list li:not(:nth-of-type(4n)) {
    margin-right: 5%; }

.product_list .prd_link {
  display: block; }

.product_list .prd_img {
  display: block;
  width: 100%;
  margin-bottom: 17px; }

.product_list .prd_name {
  display: block;
  font-weight: bold;
  margin-bottom: 12px;
  letter-spacing: 0.05em; }

.product_list .prd_des {
  display: block;
  margin-bottom: 13px;
  font-size: 1.4rem;
  min-height: 4.3rem; }

.product_list .prd_price {
  font-family: "Open Sans", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  font-size: 1.4rem; }

@media screen and (max-width: 1023px) {
  .product_list li {
    width: calc( ( 99.9% - 10% ) / 3); }
    .product_list li:nth-of-type(3n) {
      margin-right: 0; }
    .product_list li:not(:nth-of-type(3n)) {
      margin-right: 5%; } }

.cartjs_box {
  margin-top: 25px;
  position: relative;
  font-family: "Open Sans", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif; }
  .cartjs_box table {
    width: 100%; }
  .cartjs_box tbody {
    width: 100%; }
  .cartjs_box td {
    padding: 0 !important; }

.cartjs_option {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 15px; }
  .cartjs_option th {
    font-size: 1.4rem;
    font-weight: normal; }
  .cartjs_option td {
    position: relative;
    display: inline-block;
    width: calc( 100% - (50px + 20px));
    font-size: 1.5rem;
    font-weight: bold; }
    .cartjs_option td:after {
      position: absolute;
      content: "";
      display: inline-block;
      width: 11px;
      height: 11px;
      top: 11px;
      right: 14px;
      border-right: 2px solid #222222;
      border-bottom: 2px solid #222222;
      -webkit-transform: rotate(45deg);
      -ms-transform: rotate(45deg);
      transform: rotate(45deg);
      pointer-events: none; }
    .cartjs_option td select {
      -webkit-appearance: none;
      -moz-appearance: none;
      appearance: none;
      padding: 5px 10px;
      height: 36px;
      border: 1px solid #E2E2E2;
      background-color: #fff;
      border: 1px solid #777777;
      font-weight: bold;
      outline: none; }

.cartjs_product_num {
  position: absolute;
  bottom: 0;
  left: 0; }
  .cartjs_product_num th {
    display: none; }

.cartjs_product_input_txt {
  display: inline-block;
  width: 50px;
  height: 45px;
  text-align: center;
  border: 1px solid #777777 !important;
  color: #222222;
  font-size: 1.6rem;
  background-color: #fff; }

.cartjs_cart_in {
  text-align: right; }
  .cartjs_cart_in input {
    width: calc( 100% - (50px + 20px));
    height: 45px;
    background-color: #D58061;
    padding: 10px;
    color: #fff;
    font-size: 1.5rem;
    font-weight: bold;
    -webkit-transition: all 0.25s;
    -o-transition: all 0.25s;
    transition: all 0.25s; }
    .cartjs_cart_in input:hover {
      background-color: #DD6541;
      -webkit-transition: all 0.25s;
      -o-transition: all 0.25s;
      transition: all 0.25s; }

_:-ms-lang(x)::-ms-backdrop, .cartjs_cart_in input {
  padding: 13px 10px 10px; }

.pagenation {
  position: relative;
  width: 80%;
  margin: 20px auto 20px;
  text-align: center;
  font-size: 1.6rem; }
  .pagenation .disabled {
    color: #777777;
    opacity: 0.8; }

.pagenation_pos {
  font-size: 1.5rem; }

.pagenation_prev,
.pagenation_next {
  position: absolute; }

.pagenation_prev {
  left: 0; }

.pagenation_next {
  right: 0; }

.product_list .tax, .list_ranking product_list .tax, .recommend-items .tax {
  font-size: 1.25rem; }

.about_page #about_content {
  margin: 0;
  padding: 0; }
  .about_page #about_content > .inner_contents {
    width: 100%;
    max-width: inherit; }

.about_page .cover_area {
  position: relative;
  margin: 0 0 80px 0; }

.about_page .cover_ttl {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%); }
  .about_page .cover_ttl .img_wrap {
    width: 440px; }

.about_page .lead {
  margin: 0 0 140px 0;
  text-align: center;
  font-size: 1.7rem;
  line-height: 2.8;
  letter-spacing: 0.15em; }

.about_page .side_l {
  padding-right: calc( ( 100% - 1160px) / 2); }

.about_page .side_r {
  padding-left: calc( ( 100% - 1160px) / 2); }

.about_page .l_r_box {
  position: relative;
  margin: 0 0 180px 0; }

.about_page .text_box {
  width: calc( 100% - 53.2%);
  padding-top: 70px; }
  .about_page .text_box .des {
    font-size: 1.5rem;
    letter-spacing: 0.05em;
    line-height: 2.19; }

.about_page .img_box {
  width: 53.2%; }

.about_page .heading_ttl {
  position: absolute;
  top: -60px;
  margin: 0;
  padding: 47px 45px 48px;
  background: url(https://file002.shop-pro.jp/PA01361/349/img/about/bg_ttl_about_01.svg) no-repeat left top, url(https://file002.shop-pro.jp/PA01361/349/img/about/bg_ttl_about_02.svg) no-repeat right calc( 100% - 1px);
  background-size: 51px 51px; }
  .about_page .heading_ttl .img_wrap {
    width: 26px; }

.about_page .box_l.text_box {
  padding-left: 20%;
  padding-right: 3%; }
  .about_page .box_l.text_box .heading_ttl {
    left: calc( ( 100% - 1200px )/ 2); }

.about_page .box_r.text_box {
  padding-right: 19%;
  padding-left: 3%; }
  .about_page .box_r.text_box .heading_ttl {
    right: calc( ( 100% - 1200px )/ 2); }

.about_page .l_r_box:nth-of-type(3) .box_r.text_box {
  padding-right: 16.5%;
  padding-left: 3%; }

@media screen and (max-width: 1400px) {
  .about_page .box_l.text_box .heading_ttl {
    left: 8%; }
  .about_page .box_r.text_box .heading_ttl {
    right: 8%; } }

@media screen and (max-width: 1160px) {
  .about_page .side_l {
    padding-right: 0; }
  .about_page .side_r {
    padding-left: 0; }
  .about_page .box_l.text_box {
    padding-left: 200px;
    padding-right: 3%; }
    .about_page .box_l.text_box .heading_ttl {
      left: 50px; }
  .about_page .box_r.text_box {
    padding-right: 180px !important;
    padding-left: 3% !important; }
    .about_page .box_r.text_box .heading_ttl {
      right: 50px; } }

@media screen and (max-width: 768px) {
  .about_page .inner_contents {
    padding: 0 !important; }
  .about_page .cover_ttl .img_wrap {
    width: 330px; }
  .about_page .l_r_box {
    margin: 0 0 100px 0; }
  .about_page .side_l {
    padding-right: 0; }
  .about_page .side_r {
    padding-left: 0; }
  .about_page .text_box {
    width: calc( 100% - 38%);
    padding-top: 0px; }
    .about_page .text_box .heading_ttl {
      padding: 32px 30px; }
    .about_page .text_box .des {
      font-size: 1.4rem;
      letter-spacing: 0.05em;
      line-height: 2.1; }
  .about_page .img_box {
    width: 38%; }
  .about_page .box_l.text_box {
    padding-left: 145px;
    padding-right: 3.8% !important; }
    .about_page .box_l.text_box .heading_ttl {
      left: 30px; }
  .about_page .box_r.text_box {
    padding-right: 123px !important;
    padding-left: 3.8% !important; }
    .about_page .box_r.text_box .heading_ttl {
      right: 30px; }
  .about_page .heading_ttl {
    top: -60px;
    padding: 37px 35px;
    background: url(https://file002.shop-pro.jp/PA01361/349/img/about/bg_ttl_about_01.svg) no-repeat left top, url(https://file002.shop-pro.jp/PA01361/349/img/about/bg_ttl_about_02.svg) no-repeat right bottom;
    background-size: 45px 45px; }
    .about_page .heading_ttl .img_wrap {
      width: 22px; } }

.about_page .enjoy_shopping {
  width: 80%;
  max-width: 800px;
  margin: -50px auto 0; }
  .about_page .enjoy_shopping * {
    letter-spacing: 0.05em; }
  .about_page .enjoy_shopping h3 {
    font-size: 2rem;
    margin: 0 0 37px 0;
    padding: 0 0 15px 0;
    border-bottom: 1px solid #B9B9B9; }
  .about_page .enjoy_shopping dl,
  .about_page .enjoy_shopping p {
    font-size: 1.5rem; }
  .about_page .enjoy_shopping dt {
    margin: 0 0 8px 0;
    font-weight: bold; }
  .about_page .enjoy_shopping dd {
    margin: 0 0 25px 0; }
  .about_page .enjoy_shopping p {
    margin: 0 0 30px 0; }
  @media screen and (max-width: 768px) {
    .about_page .enjoy_shopping {
      margin: 0 auto 0; }
      .about_page .enjoy_shopping dl,
      .about_page .enjoy_shopping p {
        font-size: 1.4rem; } }

.about_page #about_company {
  width: 80%;
  max-width: 800px;
  margin: 0 auto 110px;
  padding: 100px 0 0 0; }
  .about_page #about_company * {
    letter-spacing: 0.05em; }
  .about_page #about_company .ttl {
    font-size: 2rem;
    margin: 0 0 20px 0;
    letter-spacing: 0.05em; }
  .about_page #about_company table {
    width: 100%;
    margin: 0 auto;
    font-size: 1.5rem; }
  .about_page #about_company table, .about_page #about_company td, .about_page #about_company th {
    border: 1px solid #595959;
    border-collapse: collapse;
    vertical-align: baseline; }
  .about_page #about_company td, .about_page #about_company th {
    padding: 12px 10px 12px 12px;
    text-align: left;
    letter-spacing: 0;
    line-height: 1.5; }
  .about_page #about_company th {
    font-weight: normal;
    min-width: 5rem; }
  @media screen and (max-width: 768px) {
    .about_page #about_company {
      margin-top: -50px; } }

.about_page #space_category {
  padding: 50px 0;
  background-color: #E6E4DE; }

.single_page > .contentsArea > .inner_contents {
  width: 80%;
  max-width: 800px; }

@media screen and (max-width: 768px) {
  .single_page > .contentsArea > .inner_contents {
    width: 90%;
    max-width: inherit; } }

.single_page .section {
  margin: 0 0 60px 0; }

.single_page .pagetitle {
  text-align: center;
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  font-size: 2.6rem;
  letter-spacing: 0.1em;
  margin: 0 0 60px 0; }

.single_page .sectitle {
  font-weight: bold;
  font-size: 2rem;
  margin-bottom: 20px;
  letter-spacing: 0.05em; }

.single_page li,
.single_page p {
  font-size: 1.5rem;
  letter-spacing: 0.03em; }

.single_page ul li {
  margin: 0 0 26px 0; }
  .single_page ul li > h4 {
    margin: 0 0 12px 0; }

.single_page p {
  line-height: 1.8;
  margin: 0 0 20px 0; }

.single_page table th, .single_page table td {
  padding: 3px 16px; }

#page_shoppingGide #secnav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  margin: 0 0 50px 0; }
  #page_shoppingGide #secnav li {
    width: calc( (100% - 4%) / 3);
    margin-bottom: 10px; }
    #page_shoppingGide #secnav li:not(:nth-of-type(3n)) {
      margin-right: 2%; }
    #page_shoppingGide #secnav li a {
      display: inline-block;
      width: 100%;
      padding: 18px 0;
      background-color: #E2E2E2;
      text-align: center;
      font-weight: bold;
      font-size: 1.5rem; }

@media screen and (max-width: 1024px) {
  #page_shoppingGide #secnav li a {
    font-size: 1.4rem; } }

#page_shoppingGide .sectitle {
  margin-top: -100px;
  padding-top: 100px; }

#page_shoppingGide #sec02 img {
  width: 180px; }

#page_shoppingGide #bannerlistwp {
  margin: 80px 0 0 0; }
  #page_shoppingGide #bannerlistwp ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: nowrap;
    flex-wrap: nowrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0 auto; }
    #page_shoppingGide #bannerlistwp ul li {
      margin-bottom: 0; }
      #page_shoppingGide #bannerlistwp ul li:first-of-type {
        margin-right: 20px; }

#space_category .img_part_column2 {
  -ms-flex-flow: nowrap;
  flex-flow: nowrap;
}
#space_category .img_part_column2 .img_wrap {
  width: calc( ( 99.9% - 3.5% ) / 2); 
}
#space_category .img_part_column2 .img_wrap:not(:nth-of-type(2n)) {
  margin-right: 3.5%;
}

#footer_category .searchbox {
  width: calc( 100% - 260px);
  margin: 0 0 40px 0;
  padding: 0 0 0 20%;
}
#footer_category .searchbox .input_keyword{
   width: calc(100% - 240px);
   height: 40px;
   margin-right: 12px;
   padding: 0 20px;
   background-color: #fff;
   border-radius: 0;
}
#footer_category .searchbox .input_search_btn {
  width: 180px;
  height: 40px;
  color: #fff;
  background-color: #222222;
}
@media screen and (max-width: 1024px) {
  #footer_category .searchbox {
    width: calc( 100% - 230px);
    padding: 0 0 0 5%;
  }
}

.footer_freeshipping {
  background-color: #222222;
  text-align: center;
  padding: 4px 0;
  color: #ffffff;
  letter-spacing: 0.1em;
  font-size: 1.3rem;
}
.footer_freeshipping img {
  display: inline-block;
  width: 24px;
  height: 24px;
  margin-right: 8px;
  vertical-align: middle;
}
.footer_freeshipping span {
  padding-left: 4px;
  font-weight: bold;
  font-size: 1.4rem;
}

/* About Karuizawa */
.about_page #about_karuizawa {
  width: 80%;
  max-width: 800px;
  margin: 0 auto 110px;
  padding: 100px 0 0 0;
} 
.about_page #about_karuizawa h2 {
  font-size: 2rem;
  margin: 0 0 37px 0;
  padding: 0 0 15px 0;
  border-bottom: 1px solid #B9B9B9;
}
.about_page #about_karuizawa h3 {
  margin-bottom: 12px;
  font-size: 1.6rem;
  font-weight: bold;
}
.about_page #about_karuizawa .pic {
  margin-bottom: 40px;
}
.about_page #about_karuizawa p {
  margin-bottom: 28px;
  font-size: 1.5rem;
}
.about_page #about_karuizawa .access span {
  display: block;
  text-decoration: underline;
}
.about_page #about_karuizawa .map {
  margin-bottom: 60px;
}
.about_page #about_karuizawa .list_recommend {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.about_page #about_karuizawa .list_recommend li {
  width: calc( ( 99.9% - 12% ) / 4);
  margin-bottom: 60px;
  font-size: 1.4rem;
  margin-right: 0;
}
.about_page #about_karuizawa .list_recommend li:not(:nth-of-type(4n)) {
  margin-right: 4%;
}
.about_page #about_karuizawa .list_recommend .prd_name {
  padding-bottom: 12px;
  border-bottom: 1px solid #222222;
}

/* Free Page */
.page_free h3 {
  margin-bottom: 8px;
  font-size: 1.5rem;
  font-weight: bold;
}
.page_free img {
  display: block;
  width: 100%;
  margin-bottom: 20px;
}
.page_free .list_2col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
}
.page_free .list_2col li {
  width: calc( ( 99.9% - 4% ) / 2);
  margin-bottom: 60px;
  font-size: 1.5rem;
  margin-right: 0;
}
.page_free .list_2col li:not(:nth-of-type(2n)) {
  margin-right: 4%;
}
.page_free .list_2col li .name {
  display: block;
  padding-bottom: 12px;
  font-weight: bold;
}
.page_free .btn_contact {
  padding: 16px;
  background-color: #D58061;
  letter-spacing: 0.1em;
  font-size: 2rem;
  font-weight: bold;
  color: #fff;
}

/* a */
.des a, .p_box a { text-decoration: underline; }
/* mailmag */
.mailmag {
    max-width: 736px;
    margin: 40px auto 0;
    border: 3px double #fff;
    padding: 12px 0 12px 24px;
}
.mailmag:hover{
    opacity: 0.9
}
.mailmag .ttl {
    width: 128px;
    margin-right: 16px;
}
.mailmag .icon {
    width: 28px;
    margin-right: 16px;
}
.mailmag .txt {
    font-size: 13px;
    color: #fff;
}
/* instagram */
footer .logo_instagram {
  margin-bottom: 40px;
  text-align: center;
}
footer .logo_instagram  img {
  width: 32px;
  height: 32px:
}