@charset "UTF-8";
/*!
Theme Name: トーエー食品
Theme URI:
Author: 西濃印刷
Author URI: https://www.seinou.co.jp
Description: てすとだよ
Version: 1.0
License: 
License URI:
Tags:

◆00：基本設定
◆10：レイアウト設定
 ◆11 ボディー 
 ◆12 ヘッダー 
 ◆13 グローバルナビ 
 ◆14 サイドバー 
 ◆15 コンテンツ 
 ◆16 トピックパス 
 ◆17 キービジュアル
 ◆18 サブコンテンツ
 ◆19 フッター 
 ◆20 サイドバーメニュー 
◆40：各コンテンツ
◆70：WordPress専用
◆80：絶対表記
◆90：プリント用

! de-style.css v1.0.5 | MIT License | https://github.com/nicolas-cusan/destyle.css
*/
/*==============================================
◆1-0：CSSリセット・フォントの読み込み
==============================================*/
/*! Yaku Han JP v3.3.1 (OFL-1.1 AND MIT) by Qrac */
/*! Type: YakuHanJP - Based on Noto Sans CJK JP */
@font-face {
  font-family: YakuHanJP;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(./fonts/YakuHanJP/YakuHanJP-Regular.eot);
  src: url(./fonts/YakuHanJP/YakuHanJP-Regular.woff2) format("woff2"), url(./fonts/YakuHanJP/YakuHanJP-Regular.woff) format("woff");
  unicode-range: U+3001-3002, U+3008-3011, U+3014-3015, U+30fb, U+ff01,U+ff08-ff09, U+ff1a-ff1b, U+ff1f, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}

@font-face {
  font-family: YakuHanJP;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(./fonts/YakuHanJP/YakuHanJP-Bold.eot);
  src: url(./fonts/YakuHanJP/YakuHanJP-Bold.woff2) format("woff2"), url(./fonts/YakuHanJP/YakuHanJP-Bold.woff) format("woff");
  unicode-range: U+3001-3002, U+3008-3011, U+3014-3015, U+30fb, U+ff01,U+ff08-ff09, U+ff1a-ff1b, U+ff1f, U+ff3b, U+ff3d, U+ff5b, U+ff5d;
}

@font-face {
  font-family: notoSans;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  /*src: url(./fonts/YakuHanJP/YakuHanJP-Black.eot);*/
  src: url(./fonts/notoSans/NotoSansCJKjp-Regular.woff2) format("woff2"), url(./fonts/notoSans/NotoSansCJKjp-Regular.woff) format("woff");
}

@font-face {
  font-family: notoSans;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  /*src: url(./fonts/YakuHanJP/YakuHanJP-Black.eot);*/
  src: url(./fonts/notoSans/NotoSansCJKjp-Bold.woff2) format("woff2"), url(./fonts/notoSans/NotoSansCJKjp-Bold.woff) format("woff");
}

/*! Yaku Han JP v3.3.1 (OFL-1.1 AND MIT) by Qrac */
/*! Type: YakuHanRP - Based on Rounded M+ 1c */
@font-face {
  font-family: YakuHanRP;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(./fonts/YakuHanRP/YakuHanRP-Regular.eot);
  src: url(./fonts/YakuHanRP/YakuHanRP-Regular.woff2) format("woff2"), url(./fonts/YakuHanRP/YakuHanRP-Regular.woff) format("woff");
  unicode-range: U+3001-3002,U+3008-3011,U+3014-3015,U+30fb,U+ff01,U+ff08-ff09,U+ff1a-ff1b,U+ff1f,U+ff3b,U+ff3d,U+ff5b,U+ff5d;
}

@font-face {
  font-family: YakuHanRP;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(./fonts/YakuHanRP/YakuHanRP-Bold.eot);
  src: url(./fonts/YakuHanRP/YakuHanRP-Bold.woff2) format("woff2"), url(./fonts/YakuHanRP/YakuHanRP-Bold.woff) format("woff");
  unicode-range: U+3001-3002,U+3008-3011,U+3014-3015,U+30fb,U+ff01,U+ff08-ff09,U+ff1a-ff1b,U+ff1f,U+ff3b,U+ff3d,U+ff5b,U+ff5d;
}

@font-face {
  font-family: roudedMplus;
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url(./fonts/roundedMplus/rounded-mplus-1c-regular.eot);
  src: url(./fonts/roundedMplus/rounded-mplus-1c-regular.woff2) format("woff2"), url(./fonts/roundedMplus/rounded-mplus-1c-regular.woff) format("woff");
}

@font-face {
  font-family: roudedMplus;
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url(./fonts/roundedMplus/rounded-mplus-1c-bold.eot);
  src: url(./fonts/roundedMplus/rounded-mplus-1c-bold.woff2) format("woff2"), url(./fonts/roundedMplus/rounded-mplus-1c-bold.woff) format("woff");
}

* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}

::before,
::after {
  box-sizing: border-box;
}

body {
  margin: 0;
}

main {
  display: block;
}

section {
  margin-bottom: 3em;
}

p,
table,
blockquote,
pre,
iframe,
form,
figure,
dl {
  margin: 0 0 2em;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
  line-height: 1.2em;
  font-feature-settings: "palt" 1;
  text-align: left;
  font-family: "YakuHanMP", "roudedMplus", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
}

h1 {
  font-size: 3em;
  margin: 1.2em auto;
}

@media screen and (max-width: 88em) {
  h1 {
    margin: 0.86em auto;
  }
}

@media screen and (max-width: 42em) {
  h1 {
    font-size: 2em;
  }
}

h2 {
  font-size: 2em;
  margin: 1.2em auto;
}

@media screen and (max-width: 88em) {
  h2 {
    margin: 0.86em auto;
  }
}

@media screen and (max-width: 42em) {
  h2 {
    font-size: 2em;
  }
}

h3 {
  font-size: 2em;
  margin: 1.2em auto;
}

@media screen and (max-width: 88em) {
  h3 {
    margin: 1em auto;
  }
}

@media screen and (max-width: 42em) {
  h3 {
    font-size: 1.5em;
  }
}

h4 {
  font-size: 1.5em;
  margin: 1.2em auto;
}

@media screen and (max-width: 88em) {
  h4 {
    margin: 1em auto;
  }
}

@media screen and (max-width: 42em) {
  h4 {
    font-size: 1.2em;
  }
}

h5 {
  font-size: 1.5em;
  margin: 1em auto;
}

@media screen and (max-width: 42em) {
  h5 {
    font-size: 1.2em;
  }
}

h6 {
  font-size: 1.2em;
  margin: 1em auto;
}

* + h1,
* + h2,
* + h3,
* + h4,
* + h5,
* + h6 {
  margin-top: 2em;
}

ul,
ol {
  padding: 0;
  list-style: none;
  margin: 0 auto 1.5em;
}

li {
  line-height: 1.2em;
}

li:not(:last-child) {
  margin-bottom: 1em;
}

ul > li > ul,
ul > li ol,
ol > li > ul,
ol > li ol {
  padding: 1.2em 0 0;
}

/*
ol>li {
  > ul,ol {
    padding: $size-m 0 0;
    margin-left: $size-l;
  }
}

ul {
  > li {
    position: relative;
    padding-left: 1em;

    &::before {
      content: "";
      display: inline-block;
      position: absolute;
      top: 0.5em;
      left: 0.375em;
      height: 0.25em;
      width: 0.25em;
      background: $primary-color*$jump-smaller;
    }
  }
}

ol {
  counter-reset: number 0;

  > li {
    &::before {
      counter-increment: number 1;
      content: counters(number, "-", decimal-leading-zero)".";
      padding-right: 0.5em;
      color: $primary-color*$jump-smaller;
    }
  }
}*/
dt {
  font-weight: normal;
}

dd {
  margin-left: 0;
}

hr {
  box-sizing: content-box;
  height: 0;
  overflow: visible;
  border: 0;
  clear: both;
  border-top: 1px solid #aaa;
  margin: 3em auto;
}

pre {
  font-size: inherit;
  font-family: inherit;
  font-size: 0.86em;
  background: white;
  padding: 1em;
}

address {
  font-style: inherit;
}

a {
  background-color: transparent;
  text-decoration: none;
  color: #751535;
  transition: all 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

a:hover {
  color: #B25;
  transition: all 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

a * {
  transition: all 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

b,
strong,
em {
  font-weight: 400;
}

mark {
  color: inherit;
  background: rgba(187, 34, 85, 0.4);
}

code,
kbd,
samp {
  font-size: inherit;
  font-family: inherit;
  word-break: normal;
}

q,
i {
  font-style: italic;
}

small {
  font-size: 0.75em;
}

sub,
sup {
  font-size: 0.86em;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

rt {
  margin-bottom: -0.25em;
}

figure {
  overflow: hidden;
  overflow-x: scroll;
  -ms-overflow-style: none;
  /* IE, Edge 対応 */
  scrollbar-width: none;
  /* Firefox 対応 */
}

figure::-webkit-scrollbar {
  /* Chrome, Safari 対応 */
  display: none;
}

figcaption {
  font-size: 0.86em;
  line-height: 1.2em;
}

img,
svg {
  border-style: none;
  vertical-align: bottom;
  width: 100%;
  height: auto;
  object-fit: cover;
}

embed,
object,
iframe {
  border: 0;
  vertical-align: bottom;
}

button,
input,
optgroup,
select,
textarea {
  vertical-align: middle;
  color: inherit;
  font: inherit;
  outline: 0;
  border: 1px solid #aaa;
  background: #fff;
  line-height: 1.2em;
  margin: 0 0.86em;
  padding: 0.3em;
}

@media screen and (max-width: 42em) {
  button,
  input,
  optgroup,
  select,
  textarea {
    display: block;
    margin: 0;
  }
}

select {
  -webkit-appearance: none;
  appearance: none;
  border-radius: 0;
}

button,
input {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type="button"],
[type="reset"],
[type="submit"] {
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
}

button[disabled],
[type="button"][disabled],
[type="reset"][disabled],
[type="submit"][disabled] {
  cursor: default;
}

button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 0;
  min-width: 0;
}

legend {
  color: inherit;
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal;
}

progress {
  vertical-align: baseline;
}

textarea {
  overflow: auto;
}

[type="checkbox"],
[type="radio"] {
  box-sizing: border-box;
  padding: 0;
}

[type="number"]::-webkit-inner-spin-button,
[type="number"]::-webkit-outer-spin-button {
  height: auto;
}

[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit;
}

::-webkit-input-placeholder {
  font: inherit;
}

:-ms-input-placeholder {
  font: inherit;
}

::-ms-input-placeholder {
  font: inherit;
}

::placeholder {
  font: inherit;
}

label[for] {
  cursor: pointer;
}

details {
  display: block;
}

summary {
  display: list-item;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
  margin: 0 auto 2em;
}

@media screen and (max-width: 42em) {
  table {
    width: 100%;
    overflow-x: scroll;
  }
}

caption {
  text-align: left;
  margin-bottom: 0.75em;
}

td,
th {
  vertical-align: middle;
  padding: 0.6em 0.3em;
  border-bottom: 1px solid #aaa;
  min-width: 6em;
  /* @include break-point(2) {
    display: block;
  }*/
}

@media screen and (max-width: 42em) {
  td,
  th {
    font-size: 0.86em;
  }
}

th {
  text-align: left;
  font-weight: normal;
  /*@include break-point(2) {
    background: $gray * $jump;
  }*/
}

template {
  display: none;
}

[hidden] {
  display: none;
}

::selection {
  background: rgba(187, 34, 85, 0.4);
}

::-moz-selection {
  background: rgba(187, 34, 85, 0.4);
}

#header {
  position: relative;
  z-index: 20;
}

#header--inner {
  width: 70em;
  margin: 0 auto;
  padding: 0 1em;
}

@media screen and (max-width: 88em) {
  #header--inner {
    width: 92vw;
  }
}

#header--inner--flex {
  width: 70em;
  margin: 0 auto;
  padding: 0 1em;
  display: flex;
  justify-content: space-between;
  align-items: center;
}

@media screen and (max-width: 88em) {
  #header--inner--flex {
    width: 92vw;
  }
}

#header--inner--flex__fixed {
  width: 70em;
  margin: 0 auto;
  padding: 0 1em;
  display: flex;
  justify-content: space-between;
  align-items: center;
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  position: fixed;
  transform: translateX(-50%);
  left: 50%;
  top: 1.2em;
  z-index: 1;
  padding: 1em 1.5em;
  background: #fff;
  border-radius: 1em;
}

@media screen and (max-width: 88em) {
  #header--inner--flex__fixed {
    width: 92vw;
  }
}

@media screen and (max-width: 42em) {
  #header--inner--flex__fixed {
    width: 100vw;
    position: relative;
    display: block;
    box-shadow: none;
    transform: none;
    top: 0;
    left: auto;
    border-radius: 0;
  }
}

#header-4sides {
  position: relative;
}

@media screen and (max-width: 42em) {
  #header-4sides {
    display: none;
  }
}

#header-4sides--top {
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  top: 0;
  left: 0;
  width: 100vw;
  padding: 1em;
}

#header-4sides--bottom {
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  bottom: 0;
  left: 0;
  width: 100vw;
  padding: 1em;
}

#header-4sides--left {
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  top: 0;
  left: 0;
  height: 100vh;
  padding: 0.75em;
}

#header-4sides--right {
  position: fixed;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  top: 0;
  right: 0;
  height: 100vh;
  padding: 0.75em;
}

#footer {
  background: -moz-linear-gradient(top, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.75) 10%, white 100%);
  background: -webkit-linear-gradient(top, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.75) 10%, white 100%);
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0), rgba(255, 255, 255, 0.75) 10%, white 100%);
  margin: 0 auto;
  padding: 6em 0;
}

.navi--item {
  margin: 0.6em 0;
  line-height: 1.2em;
}

.navi--item:not(:first-child) {
  margin-left: 0.86em;
}

@media screen and (max-width: 42em) {
  .navi--item:not(:first-child) {
    margin-left: auto;
  }
}

.navi--main {
  display: contents;
}

.navi--main__block {
  display: block;
  text-align: right;
}

@media screen and (max-width: 42em) {
  .navi--main__block {
    position: absolute;
    top: 0;
    left: 0;
    height: 0;
    width: 0;
  }
}

.navi--icon {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  font-size: 0.86em;
  padding: 0.625em 0.75em;
  border-radius: 1.5em;
  background: #fff;
  color: #B25;
  line-height: 1.2em;
  border: 1px solid #efefef;
}

.navi--icon:not(:first-child) {
  margin-left: 0.86em;
}

@media screen and (max-width: 42em) {
  .navi--icon:not(:first-child) {
    margin-left: auto;
  }
}

@media screen and (max-width: 42em) {
  .navi--icon {
    background: #B25;
    color: #fff;
    border: none;
  }
}

.navi--icon:hover {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  transform: translateY(-0.125em);
}

.navi--icon > svg {
  width: 1.5em;
  fill: #B25;
}

@media screen and (max-width: 42em) {
  .navi--icon > svg {
    fill: #fff;
  }
}

.navi--inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  padding: 0.3em 0;
}

@media screen and (max-width: 42em) {
  .navi--inner {
    position: fixed;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    background: #fff;
    height: 100vh;
    width: 100vw;
    top: 0;
    left: 0;
  }
  .navi--inner > * {
    display: block;
    margin: 0 auto 1.2em;
    font-size: 1.2em;
  }
  .navi--inner > *:first-child::before {
    content: "MENU";
    display: block;
    text-align: center;
    border-bottom: 1px solid #aaa;
    padding-bottom: 0.86em;
    margin-bottom: 1em;
    color: #aaa;
  }
}

.navi--inner__visible {
  display: flex;
  justify-content: flex-end;
  padding: 0.3em 0;
}

@media screen and (max-width: 42em) {
  .navi--inner__visible {
    position: fixed;
    right: 2em;
    top: 50%;
    transform: translateY(-50%);
    flex-direction: column;
  }
  .navi--inner__visible > * {
    box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
    margin: 0 auto 1.2em;
  }
}

.navi--footer {
  width: 70em;
  margin: 0 auto 2em;
  font-size: 0.86em;
}

@media screen and (max-width: 88em) {
  .navi--footer {
    width: 92vw;
  }
}

@media screen and (max-width: 42em) {
  .navi--footer {
    font-size: initial;
  }
}

.navi--footer--lst {
  display: flex;
  justify-content: center;
}

@media screen and (max-width: 42em) {
  .navi--footer--lst {
    display: block;
  }
}

.navi--footer--child {
  display: flex;
  padding-left: 1.2em;
}

.navi--footer--child:not(:first-child) {
  border-left: 1px solid #aaa;
}

@media screen and (max-width: 42em) {
  .navi--footer--child {
    margin: 1.5em auto 0;
    padding: 1.2em 0;
    justify-content: center;
  }
  .navi--footer--child:not(:first-child) {
    border-left: none;
    border-top: 1px solid #aaa;
  }
}

.navi--footer--child--link-main {
  flex: 0 0 auto;
  font-weight: 700;
}

@media screen and (max-width: 42em) {
  .navi--footer--child--link-main {
    flex: 0 0 40%;
    text-align: center;
  }
}

.navi--footer--child--inner {
  padding: 0;
}

@media screen and (max-width: 42em) {
  .navi--footer--child--inner {
    flex: 0 0 60%;
  }
}

.navi--footer--child--link-sub {
  flex: 0 0 auto;
  font-size: 0.86em;
  padding: 0 1.2em;
  margin-bottom: 1em;
}

.navi--footer--child--contact {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  background: #fff;
  padding: 2em 1.5em;
  margin-left: 1.5em;
  border-radius: 1.2em;
  flex: 0 0 48%;
  color: #701433;
}

@media screen and (max-width: 88em) {
  .navi--footer--child--contact {
    flex: 0 0 36%;
  }
}

@media screen and (max-width: 42em) {
  .navi--footer--child--contact {
    margin-left: 0;
  }
}

.navi--footer--child--contact--title {
  font-size: 1.2em;
}

.navi--footer--child--contact--inner {
  display: flex;
  justify-content: space-around;
  flex-wrap: wrap;
}

.navi--footer--child--contact--inner > *:not(:last-child) {
  margin-right: 0.86em;
}

@media screen and (max-width: 88em) {
  .navi--footer--child--contact--inner {
    justify-content: flex-start;
  }
}

.navi--footer--child--contact--tel, .navi--footer--child--contact--address, .navi--footer--child--contact--mail {
  display: flex;
  align-items: center;
  margin-bottom: 0.86em;
}

.navi--footer--child--contact--tel > *:not(:last-child), .navi--footer--child--contact--address > *:not(:last-child), .navi--footer--child--contact--mail > *:not(:last-child) {
  margin-right: 0.86em;
}

.navi--footer--child--contact--icon {
  padding: 0.86em;
  background: #B25;
  border-radius: 1em;
}

.navi--footer--child--contact--icon > svg,
.navi--footer--child--contact--icon img {
  height: 1em;
  width: 1em;
  fill: #fff;
}

@media screen and (max-width: 42em) {
  .navi--footer--child--contact--icon > svg,
  .navi--footer--child--contact--icon img {
    height: 1.2em;
    width: 1.2em;
  }
}

.drawer-menu {
  display: none;
}

.drawer-menu--bar {
  display: block;
  width: 1.36em;
  height: 1px;
  background: #fff;
  z-index: 100;
  transition: all 0.5s;
  position: relative;
  left: 1.32em;
  top: 50%;
  transform: translateY(-50%);
}

.drawer-menu--bar::before {
  content: "";
  display: block;
  width: 1.36em;
  height: 1px;
  background: #fff;
  z-index: 100;
  transition: all 0.5s;
  position: absolute;
  transform-origin: left top;
  top: -0.68em;
}

.drawer-menu--bar::after {
  content: "";
  display: block;
  width: 1.36em;
  height: 1px;
  background: #fff;
  z-index: 100;
  transition: all 0.5s;
  position: absolute;
  transform-origin: left bottom;
  bottom: -0.68em;
}

@media screen and (max-width: 42em) {
  .drawer-menu--navi {
    transition: all 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
    z-index: -100;
    opacity: 0;
    pointer-events: none;
  }
}

.drawer-menu--navi__dd--child {
  transition: all 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  position: absolute;
  width: auto;
  padding: 0.86em 1.2em;
  min-height: 3em;
  bottom: -2em;
  right: 1em;
  border-radius: 1.2em;
  transform: scaleY(0);
  transform-origin: right top;
  background: #fff;
}

.drawer-menu--navi__dd--child > *:not(:last-child) {
  padding-right: 1em;
  border-right: 1px solid #aaa;
}

@media screen and (max-width: 42em) {
  .drawer-menu--navi__dd--child > *:not(:last-child) {
    border: none;
    padding: 0;
  }
}

@media screen and (max-width: 42em) {
  .drawer-menu--navi__dd--child {
    position: static;
    height: auto;
    bottom: auto;
    right: auto;
    transform: none;
    background: none;
    width: 100%;
    text-align: center;
    padding: 0;
  }
  .drawer-menu--navi__dd--child > * {
    width: 100%;
    display: block;
    margin: 0 auto 1.2em;
  }
}

.drawer-menu--btn {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  width: 4em;
  height: 4em;
  background: #B25;
  margin-left: 1.2em;
}

.drawer-menu--btn__fixed {
  width: 4em;
  height: 4em;
  background: #B25;
  z-index: 200;
  position: fixed;
  bottom: 2em;
  left: 50%;
  transform: translateX(-50%);
}

.drawer-menu:checked ~ .drawer-menu--btn .drawer-menu--bar {
  background: #B25;
}

.drawer-menu:checked ~ .drawer-menu--btn .drawer-menu--bar::before {
  transform: rotate(45deg) scaleX(1.414);
}

.drawer-menu:checked ~ .drawer-menu--btn .drawer-menu--bar::after {
  transform: rotate(-45deg) scaleX(1.414);
}

.drawer-menu:checked ~ .drawer-menu--navi {
  transition: all 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  z-index: 100;
  opacity: 1;
  pointer-events: auto;
}

.drawer-menu:checked ~ .drawer-menu--navi__dd {
  z-index: 100;
  opacity: 1;
}

.drawer-menu:checked ~ .drawer-menu--navi__dd > .drawer-menu--navi__dd--child {
  transition: all 0.5s cubic-bezier(0.190, 1.000, 0.220, 1.000);
  transform: scaleY(1);
}

.drawer-menu:checked ~ .drawer-menu--btn__fixed .drawer-menu--bar {
  background: #B25;
}

.drawer-menu:checked ~ .drawer-menu--btn__fixed .drawer-menu--bar::before {
  transform: rotate(45deg) scaleX(1.414);
}

.drawer-menu:checked ~ .drawer-menu--btn__fixed .drawer-menu--bar::after {
  transform: rotate(-45deg) scaleX(1.414);
}

#btn-back-to-top {
  position: fixed;
  z-index: 9999;
  bottom: 12em;
  right: 4em;
}

#btn-back-to-top a {
  display: block;
  width: 4em;
  height: 4em;
  position: relative;
  font-size: 0.8em;
  line-height: 1;
  background: #B25;
  border-radius: 100%;
  color: #fff;
}

#btn-back-to-top a::before {
  content: ">";
  display: block;
  transform: translate(-50%, -50%) rotate(-90deg) scaleX(0.8);
  position: absolute;
  top: 50%;
  left: 50%;
}

#copy-right {
  font-size: 0.86em;
  text-align: center;
}

#identity--header {
  margin: 0;
  font-size: 1em;
  text-align: center;
}

#identity--header--img {
  width: 100%;
  height: auto;
}

#identity--flex {
  display: flex;
}

#identity--flex--child {
  flex: 0 0 1em;
}

#identity--flex--child__to {
  flex: 0 0 0.75em;
}

#logo-mark {
  width: 12em;
  fill: #B25;
  display: block;
  padding: 0.3em;
  margin: 0 auto;
}

#logo-type {
  width: 10em;
  fill: #444;
  display: block;
  padding: 0.3em;
  margin: 0 auto;
  border-top: 1px #aaa solid;
}

.news--top {
  display: flex;
}

@media screen and (max-width: 42em) {
  .news--top {
    display: block;
  }
}

.news--top--heading {
  flex: 0 0 15%;
  font-size: 1.2em;
  margin: 0;
}

.news--top--inner {
  flex: 0 0 85%;
}

.news--child {
  display: flex;
  margin-bottom: 1.5em;
}

@media screen and (max-width: 42em) {
  .news--child {
    display: block;
    padding-left: 1em;
  }
}

.news--date {
  margin-right: 1.2em;
  padding: 0 1.2em;
  border-right: 1px solid #aaa;
}

@media screen and (max-width: 42em) {
  .news--date {
    margin-right: 0;
    margin-bottom: 0.75em;
    padding: 0 0 0.75em 0;
    display: block;
    border-right: none;
    border-bottom: 1px solid gray;
  }
}

.main-visual {
  margin: 0 auto 1em;
}

.main-visual--img {
  width: 70em;
  height: 35em;
  margin: 0 auto;
  background: #fff;
  overflow: hidden;
}

@media screen and (max-width: 88em) {
  .main-visual--img {
    width: 92vw;
  }
}

.main-visual__shrink {
  width: 70em;
  height: 17.5em;
  margin: 0 auto;
  background: #fff;
}

@media screen and (max-width: 88em) {
  .main-visual__shrink {
    width: 92vw;
  }
}

.main-visual__bytext {
  width: 70em;
  height: 28em;
  margin: 0 auto;
  display: flex;
  flex-direction: row-reverse;
}

@media screen and (max-width: 88em) {
  .main-visual__bytext {
    width: 92vw;
  }
}

.main-visual__bytext--img {
  flex: 0 0 62.5%;
  overflow: hidden;
}

.main-visual__bytext--img__flex {
  flex: 0 0 62.5%;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.main-visual__bytext--text {
  flex: 0 0 37.5%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: row-reverse;
  padding: 2em 1.2em;
}

@media screen and (max-width: 88em) {
  .main-visual__bytext {
    height: 38vmin;
  }
}

@media screen and (max-width: 42em) {
  .main-visual__bytext {
    width: 100%;
    height: auto;
    min-height: initial;
    display: block;
    margin-bottom: 2em;
  }
}

.main-visual--contents {
  width: 100%;
  margin: 0 auto 2em;
}

.main-visual--contents--img {
  height: 17.5em;
  margin: 0 auto;
  background: #fff;
}

.main-visual--full {
  width: 100vw;
  height: 80vmin;
  background: #fff;
  overflow: hidden;
  display: flex;
  position: relative;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width: 42em) {
  .main-visual--full img {
    height: 150%;
    width: auto;
  }
}

.main-visual--full--sub-img {
  position: absolute;
  right: 20%;
  bottom: 22%;
  width: 20%;
  height: auto;
}

@media screen and (max-width: 42em) {
  .main-visual--full--sub-img {
    right: 5%;
    bottom: 50%;
    transform: translateY(50%);
    width: 37.5%;
  }
}

.main-text {
  margin-bottom: 1.2em;
}

.main-text--inner {
  width: 70em;
  margin: 0 auto;
  padding: 1em 1.2em;
}

@media screen and (max-width: 88em) {
  .main-text--inner {
    width: 92vw;
  }
}

.image {
  margin: 0 auto 2em;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

.image--inner {
  margin: 0 auto 2em;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 67em;
  height: 26.8em;
}

@media screen and (max-width: 88em) {
  .image--inner {
    width: 92vw;
    height: auto;
  }
}

.image-text {
  display: block;
}

.image-text--inner {
  display: block;
}

.image-text--title {
  font-size: 1.5em;
  margin-bottom: 0.6em;
  line-height: 1.2em;
}

.image-text--text {
  margin-bottom: 1.2em;
  line-height: initial;
}

.image-text--fee {
  margin-bottom: 1.2em;
  line-height: initial;
}

.image-text--fee > span {
  font-size: 1.2em;
}

.image-text--right {
  display: flex;
  align-items: center;
}

.image-text--right--img {
  flex: 0 0 6.94444em;
  width: 6.94444em;
  height: 6.94444em;
  background: #fff;
  overflow: hidden;
}

.image-text--right--inner {
  padding-left: 1.2em;
}

.image-text--img {
  flex: 0 0 6.94444em;
  width: 6.94444em;
  height: 6.94444em;
  background: #fff;
  margin: 0 auto 1.5em;
  overflow: hidden;
}

.image-text--img__link {
  flex: 0 0 6.94444em;
  width: 6.94444em;
  height: 6.94444em;
  margin: 0 auto 1.5em;
  position: relative;
}

.image-text--img__link--inner {
  width: 6.94444em;
  height: 6.94444em;
  background: #fff;
  border-radius: 50%;
  overflow: hidden;
}

.image-text--img__link::after {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  content: ">";
  display: block;
  position: absolute;
  line-height: 0;
  padding: 1em 0.8em;
  background: #fff;
  bottom: -0.86em;
  right: -0.86em;
  border-radius: 50%;
  color: #aaa;
  transform: scaleX(0.9);
}

.image-text--difference--child {
  display: flex;
  align-items: flex-end;
  margin-bottom: 4.5em;
}

@media screen and (max-width: 42em) {
  .image-text--difference--child {
    display: block;
  }
}

.image-text--difference--child:nth-child(odd) {
  flex-direction: row;
}

.image-text--difference--child:nth-child(odd) .image-text--difference--box {
  margin-left: -3em;
}

@media screen and (max-width: 88em) {
  .image-text--difference--child:nth-child(odd) .image-text--difference--box {
    margin-left: -6vw;
  }
}

@media screen and (max-width: 42em) {
  .image-text--difference--child:nth-child(odd) .image-text--difference--box {
    margin-left: 0;
  }
}

.image-text--difference--child:nth-child(even) {
  flex-direction: row-reverse;
}

.image-text--difference--child:nth-child(even) .image-text--difference--box {
  margin-right: -3em;
}

@media screen and (max-width: 88em) {
  .image-text--difference--child:nth-child(even) .image-text--difference--box {
    margin-right: -6vw;
  }
}

@media screen and (max-width: 42em) {
  .image-text--difference--child:nth-child(even) .image-text--difference--box {
    margin-right: 0;
  }
}

.image-text--difference--img {
  flex: 0 0 40.2em;
  width: 40.2em;
  height: 24.12em;
  background: #fff;
  overflow: hidden;
  display: flex;
  align-items: center;
  justify-content: center;
}

@media screen and (max-width: 88em) {
  .image-text--difference--img {
    flex: 0 0 55.2vw;
    width: 55.2vw;
    height: 33.12vw;
  }
}

@media screen and (max-width: 42em) {
  .image-text--difference--img {
    width: 92vw;
    height: 55.2vw;
    margin-bottom: 1.5em;
  }
}

.image-text--difference--box {
  flex: 0 0 29.8em;
  margin-bottom: 1em;
  padding: 2em 2em;
  height: 100%;
  background: #efefef;
  z-index: 10;
}

@media screen and (max-width: 88em) {
  .image-text--difference--box {
    flex: 0 0 42.8vw;
    width: 42.8vw;
    height: auto;
  }
}

@media screen and (max-width: 42em) {
  .image-text--difference--box {
    width: 100%;
    margin-bottom: 0;
  }
}

#contents-area {
  margin: 0 auto 6em;
}

@media screen and (max-width: 88em) {
  #contents-area {
    margin-bottom: 2em;
  }
}

.contents-area--inner {
  width: 70em;
  margin-right: auto;
  margin-left: auto;
  padding: 3em 1.5em 0;
}

@media screen and (max-width: 88em) {
  .contents-area--inner {
    width: 92vw;
  }
}

@media screen and (max-width: 88em) {
  .contents-area--inner {
    padding: 1.5em 0;
  }
}

.contents-area--inner__detail {
  width: 70em;
  margin-right: auto;
  margin-left: auto;
  padding: 3em 1em 0;
}

@media screen and (max-width: 88em) {
  .contents-area--inner__detail {
    width: 92vw;
  }
}

.contents-area--inner-min {
  width: 42em;
  margin-right: auto;
  margin-left: auto;
  padding: 3em 1.5em 0;
}

@media screen and (max-width: 88em) {
  .contents-area--inner-min {
    width: 92vw;
  }
}

@media screen and (max-width: 88em) {
  .contents-area--inner-min {
    padding: 1.5em 0;
  }
}

.flex--triple {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin-left: -1em;
}

.flex--triple__center {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

@media screen and (max-width: 88em) {
  .flex--triple {
    margin-left: 0;
  }
}

.flex--triple--child {
  flex: 0 0 calc(100% / 3);
  padding-left: 1em;
  margin-bottom: 1.5em;
}

@media screen and (max-width: 88em) {
  .flex--triple--child {
    flex: 0 0 100%;
    padding: 0;
  }
}

.flex--triple--child__split {
  flex: 0 0 calc(100% / 3);
  padding-left: 1em;
  margin-bottom: 1.5em;
}

@media screen and (max-width: 88em) {
  .flex--triple--child__split {
    flex: 0 0 calc(100% / 3);
  }
}

@media screen and (max-width: 42em) {
  .flex--triple--child__split {
    flex: 0 0 100%;
    padding: 0;
  }
}

.flex--quadruple {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin-left: -1em;
}

@media screen and (max-width: 88em) {
  .flex--quadruple {
    margin-left: 0;
  }
}

.flex--quadruple--child {
  flex: 0 0 calc(100% / 4);
  padding-left: 1em;
  margin-bottom: 1.5em;
}

@media screen and (max-width: 42em) {
  .flex--quadruple--child {
    flex: 0 0 48%;
    padding: 0;
  }
  .flex--quadruple--child:nth-child(even) {
    margin-left: 4%;
  }
}

.block-lst {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.block-lst--child {
  width: 22.33333em;
  height: 22.33333em;
  padding: 1.2em;
  overflow: hidden;
}

.block-lst--child--inner {
  width: 100%;
  height: 100%;
  padding: 1.2em;
  background: #efefef;
  overflow: hidden;
}

.block-lst--img {
  width: 11.16667em;
  height: 11.16667em;
  background: #fff;
  margin: 0 auto;
}

.item-lst {
  margin: 0 auto 3em;
}

.item-lst--child {
  display: flex;
  align-items: flex-start;
  flex-wrap: wrap;
  justify-content: center;
  padding: 1.5em 0;
  border-bottom: 1px solid #dddddd;
}

.item-lst--child__add-detail {
  margin-bottom: 6em;
}

.item-lst--child:last-child {
  border-bottom: none;
}

@media screen and (max-width: 88em) {
  .item-lst--child {
    justify-content: center;
    align-items: center;
  }
}

@media screen and (max-width: 42em) {
  .item-lst--child {
    flex-direction: column;
  }
}

.item-lst--img {
  flex: 0 0 13.4em;
  width: 13.4em;
  background: #fff;
  overflow: hidden;
}

@media screen and (max-width: 88em) {
  .item-lst--img {
    flex: 0 0 34vmin;
    width: 34vmin;
    margin: 1.5em;
  }
}

@media screen and (max-width: 42em) {
  .item-lst--img {
    flex: 0 0 auto;
    width: 92vw;
    margin-bottom: 1.5em;
  }
}

.item-lst--img__attention {
  color: #fff;
  background: #B25;
  padding: 0.86em;
  text-align: center;
  font-size: 0.75em;
}

.item-lst--text {
  flex: 0 0 26.8em;
  padding-left: 1.5em;
}

@media screen and (max-width: 42em) {
  .item-lst--text {
    flex: 0 0 auto;
    width: 100%;
    padding: 0;
    margin-bottom: 1em;
  }
}

.item-lst--fee span {
  font-size: 1.5em;
  font-weight: 700;
}

.item-lst--icon {
  display: flex;
  flex-wrap: wrap;
}

.item-lst--icon--child {
  flex: 0 0 auto;
  font-size: 0.75em;
  margin: 0 1em 0 0;
  padding: 0.6em 1.2em;
  background: #B25;
  color: #fff;
}

.item-lst--title {
  margin-top: 0;
  font-size: 1.2em;
  font-weight: 700;
}

.item-lst--component {
  flex: 0 0 26.8em;
  font-size: 0.86em;
  padding-left: 2em;
}

@media screen and (max-width: 88em) {
  .item-lst--component {
    flex: 0 0 100%;
    padding: 0;
  }
}

@media screen and (max-width: 42em) {
  .item-lst--component {
    width: 92vw;
    font-size: 1em;
  }
}

.item-lst--component table {
  width: 100%;
  max-width: 40rem;
}

.item-lst--component--allergy {
  font-size: 0.6em;
}

.item-lst--component--allergy > th,
.item-lst--component--allergy td {
  line-height: 1.2em;
  padding: 0.6em;
  border: 1px solid #aaa;
  padding: 0.5em 0.125em;
  min-width: 8em;
  text-align: center;
}

@media screen and (max-width: 88em) {
  .item-lst--component--allergy {
    font-size: 0.86em;
    max-width: 40rem;
    margin: 0 auto;
  }
}

.item-lst--component--allergy--lst {
  border-top: 1px solid #aaa;
  border-left: 1px solid #aaa;
  display: flex;
  flex-wrap: wrap;
}

.item-lst--component--allergy--lst > li {
  border-right: 1px solid #aaa;
  border-bottom: 1px solid #aaa;
  flex: 0 0 auto;
  width: calc(100% / 6);
  padding: 0.5em 0.125em;
  margin: 0;
  display: flex;
  justify-content: center;
  align-items: center;
}

@media screen and (max-width: 42em) {
  .item-lst--component--allergy--lst > li {
    width: calc(100% / 4);
  }
}

.allergen {
  background-color: #666666;
  color: #fff;
}

.item-lst--conversion {
  flex: 0 0 40.2em;
  margin: 1.2em 0;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 1.5em 1em;
}

.item-lst--conversion--input {
  display: block;
  margin-right: 1.2em;
  flex: 0 1 auto;
}

.item-lst--conversion--input > input {
  width: 3em;
  margin: 0;
}

@media screen and (max-width: 42em) {
  .item-lst--conversion {
    flex: 0 0 auto;
    width: 92vw;
    margin: 1em auto;
    padding: 0.86em;
  }
}

.item-lst__relation {
  font-size: 0.6em;
  margin-left: -0.5em;
}

.item-lst__relation > a {
  display: inline-block;
  padding: 0.4em 0.8em;
  background-color: #fff;
  border-radius: 0.5em;
  margin-bottom: 0.5em;
  margin-left: 0.5em;
}

.multi-col__3 {
  column-count: 3;
}

.piling-text--2 {
  width: 42em;
  writing-mode: vertical-rl;
  column-count: 2;
  column-rule: solid 1px #aaa;
  column-gap: 1.5em;
  margin: 0 auto 2em;
  overflow: scroll;
}

@media screen and (max-width: 88em) {
  .piling-text--2 {
    width: 92vw;
  }
}

#index-lst {
  margin: 0 auto 3em;
  display: inline-block;
  padding: 1.2em 2em;
  background: rgba(187, 34, 85, 0.125);
}

.time-line {
  padding: 3em;
  background: #efefef;
}

.time-line--child {
  display: flex;
  margin: 0;
  border-bottom: 1px solid #fff;
}

.time-line--time {
  flex: 0 0 15%;
  padding-right: 1.5em;
  margin-top: 1.2em;
  color: #B25;
  text-align: right;
  position: relative;
  height: 100%;
}

.time-line--time::after {
  content: "";
  display: block;
  background-color: #B25;
  height: 1px;
  width: 1.2em;
  position: absolute;
  right: -0.6em;
  top: 50%;
  transform: translateY(-50%);
}

.time-line--event {
  flex: 0 0 auto;
  display: flex;
  border-left: 2px solid #bfbfbf;
  padding-left: 1.5em;
}

.time-line--event--child {
  width: 14em;
  padding: 1.5em;
  margin-right: 2em;
  background: #fff;
}

.time-line--event--child__start {
  width: 14em;
  padding: 1.5em;
  margin-right: 2em;
  border-radius: 2em 2em 0 0;
  margin-top: 1.5em;
  background: #fff;
}

.time-line--event--child__end {
  width: 14em;
  padding: 1.5em;
  margin-right: 2em;
  border-radius: 0 0 2em 2em;
  margin-bottom: 1.5em;
  background: #fff;
}

.time-line--event--child__empty {
  width: 14em;
  padding: 1.5em;
  margin-right: 2em;
}

.time-line--event--title {
  writing-mode: vertical-rl;
  font-feature-settings: normal;
  display: block;
}

.time-line--event--explanation {
  display: block;
  font-size: 0.86em;
}

ol.c-orderd-lst {
  counter-reset: number 0;
}

ol.c-orderd-lst li::before {
  counter-increment: number 1;
  content: counters(number, "-", decimal-leading-zero) ".";
  padding-right: 0.5em;
  color: #701433;
}

small.c-smaller {
  font-size: 0.36em;
}

.c-align--center {
  text-align: center;
}

.c-vertical-writing {
  writing-mode: vertical-rl;
  font-feature-settings: normal;
  margin: 0 0 0 1.5em;
  letter-spacing: 0.05em;
}

.c-size--xxl {
  font-size: 6em;
}

.c-size--xl {
  font-size: 3em;
}

.c-size--l {
  font-size: 2em;
}

.c-size--sl {
  font-size: 1.5em;
}

.c-size--m {
  font-size: 1.2em;
}

.c-size--sm {
  font-size: 1em;
}

.c-size--s {
  font-size: 0.75em;
}

.c-mb--xxl {
  margin-bottom: 6em;
}

.c-mb--xl {
  margin-bottom: 3em;
}

.c-mb--l {
  margin-bottom: 2em;
}

.c-mb--sl {
  margin-bottom: 1.5em;
}

.c-mb--m {
  margin-bottom: 1.2em;
}

.c-mb--sm {
  margin-bottom: 1em;
}

.c-mb--s {
  margin-bottom: 0.75em;
}

.c-mb--xs {
  margin-bottom: 0.6em;
}

.c-mb--none {
  margin-bottom: 0;
}

.c-mt--xxl {
  margin-top: 6em;
}

.c-mt--xl {
  margin-top: 3em;
}

.c-mt--l {
  margin-top: 2em;
}

.c-mt--sl {
  margin-top: 1.5em;
}

.c-mt--m {
  margin-top: 1.2em;
}

.c-mt--sm {
  margin-top: 1em;
}

.c-mt--s {
  margin-top: 0.75em;
}

.c-mt--xs {
  margin-top: 0.6em;
}

.c-mt--none {
  margin-top: 0;
}

.c-mv--none {
  margin-top: 0;
  margin-bottom: 0;
}

.c-c--white {
  color: #fff;
}

.c-scall-x--75 {
  transform: scaleX(0.75);
}

.c-folding {
  margin-bottom: 1.5em;
}

@media screen and (max-width: 42em) {
  .c-folding {
    margin-bottom: 0;
  }
}

.c-folding > input {
  display: none;
}

.c-folding > label {
  display: block;
  cursor: pointer;
  margin-bottom: 1em;
}

.c-folding--icon {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  margin: 0 0.3em;
  display: inline-block;
  width: 1em;
  height: 1em;
  position: relative;
  border-radius: 50%;
  background-color: #fff;
}

.c-folding--icon::after {
  content: "+";
  font-size: 0.86em;
  display: inline-block;
  color: #f83;
  position: absolute;
  line-height: 0;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.c-folding--contents {
  display: block;
  height: 0;
  overflow: hidden;
}

.c-folding > input:checked ~ label .c-folding--icon::after {
  content: "-";
}

.c-folding > input:checked ~ .c-folding--contents {
  height: auto;
  min-height: 3em;
}

.c-folding--bp1 > input {
  display: none;
}

.c-folding--bp1 > label {
  display: none;
}

@media screen and (max-width: 42em) {
  .c-folding--bp1 > label {
    display: block;
    cursor: pointer;
    margin-bottom: 1em;
  }
}

.c-folding--bp1 > label--icon {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  margin: 0 0.3em;
  display: inline-block;
  width: 1em;
  height: 1em;
  position: relative;
  border-radius: 50%;
  background-color: #fff;
}

.c-folding--bp1 > label--icon::after {
  content: "+";
  font-size: 0.86em;
  display: inline-block;
  color: #f83;
  position: absolute;
  line-height: 0;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 42em) {
  .c-folding--bp1--contents {
    display: block;
    height: 0;
    overflow: hidden;
  }
}

.c-folding--bp1 > input:checked ~ label .c-folding--icon::after {
  content: "-";
}

@media screen and (max-width: 42em) {
  .c-folding--bp1 > input:checked ~ .c-folding--bp1--contents {
    height: 100%;
    transform: scaleY(1);
  }
}

.c-btn--main {
  display: inline-block;
  padding: 1em 2em;
  background: #B25;
  color: #fff;
  border-radius: 0.75em;
}

.c-btn--main:hover {
  color: #fff;
  background: #f32c6f;
}

.c-btn--main::after {
  content: ">";
  margin-left: 0.5em;
  transform: scaleX(0.5);
  margin-right: 0.25em;
}

.c-btn--main__cov {
  display: inline-block;
  padding: 1.5em 1.2em;
  background: #f83;
  color: #fff;
  border-radius: 0.75em;
}

.c-btn--main__cov::before {
  content: "";
  display: inline-block;
  width: 1em;
  height: 1em;
  margin-right: 0.6em;
  background: url("./images/_icon/cart.png") no-repeat center center/100%;
}

.c-btn--main__cov:hover {
  background: #ffb142;
  color: #fff;
}

.c-btn--add-img {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  position: relative;
  display: flex;
  align-items: center;
  background: #fff;
  border-radius: 1.5em;
  font-size: 1.2em;
  padding: 0.6em 3em 0.6em 1.5em;
}

.c-btn--add-img:hover {
  transform: translateY(-0.25em);
}

.c-btn--add-img--img {
  display: block;
  height: 3em;
  flex: 0 0 3em;
  width: 3em;
  border-radius: 50%;
  margin-right: 1em;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}

.c-btn--add-img--text {
  color: #B25;
}

.c-btn--add-img::after {
  content: ">";
  transform: scaleX(0.8) translateY(-50%);
  position: absolute;
  right: 1em;
  top: 50%;
  display: flex;
  align-items: center;
  height: 80%;
  padding-left: 1em;
  border-left: 1px solid #aaa;
  color: #B25;
}

.c-bg--wave {
  margin: 6em auto;
  padding: 3em 0;
  background: url("./images/_texture/peaper_02.png") repeat 50% 25%/300px;
  position: relative;
}

.c-bg--wave::before {
  content: "";
  display: block;
  background: url("./images/_texture/peaper_02_round.png") repeat-x top center/300px;
  width: 100%;
  height: 50px;
  position: absolute;
  top: -50px;
}

.c-bg--wave::after {
  content: "";
  display: block;
  background: url("./images/_texture/peaper_02_round.png") repeat-x top center/300px;
  width: 100%;
  height: 50px;
  position: absolute;
  bottom: -50px;
  transform: rotate(180deg);
}

.c-break--v {
  display: block;
  width: 1px;
  background: #aaa;
  margin: 0 1em;
}

.c-add-enclosure {
  padding: 0.3em 1.2em;
  background: #B25;
  color: #fff;
  border-radius: 1.2em;
}

.c-add-enclosure__sp-none {
  padding: 0.3em 1.2em;
  background: #B25;
  color: #fff;
  border-radius: 1.2em;
}

.c-add-enclosure__sp-none:hover {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  color: #fff;
  transform: translateY(-0.125em);
}

@media screen and (max-width: 42em) {
  .c-add-enclosure__sp-none {
    padding: 0;
    background: none;
    color: #751535;
  }
}

.c-add-float {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  padding: 2em 1.2em;
  background: #fff;
  border-radius: 1.2em;
}

.c-n-mofi {
  background: #fbfbfb;
  box-shadow: 1em 1em 2em #dddddd, 0.5em 0.5em 1em #d1d1d1, -0.8em -0.8em 1.6em #fbfbfb, 1px 1px 2px #fff inset;
}

.c-loading--none {
  transition: all 1s cubic-bezier(0.250, 0.460, 0.450, 0.940);
  pointer-events: none;
  opacity: 0;
  z-index: -1000;
}

.c-loading--inner {
  width: 16vmax;
}

@media screen and (max-width: 42em) {
  .c-loading--inner {
    width: 30vmax;
  }
}

.c-loading--inner__svg {
  fill: #aaa;
}

.c-loading--inner__svg:not(:last-child) {
  margin-bottom: 0.6em;
}

#c-loading--wrap {
  transition: all 1s cubic-bezier(0.250, 0.460, 0.450, 0.940);
  background: #fff;
  height: 100vh;
  width: 100vw;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
}

.add-color__1 {
  color: #c92e36;
}

.add-bg__1 {
  color: #fff;
  background-color: #c92e36;
}

.navi--inner > .wp-navi--item > li:nth-child(1) > a {
  background-color: #c92e36;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(1) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

.add-color__2 {
  color: #c99a2e;
}

.add-bg__2 {
  color: #fff;
  background-color: #c99a2e;
}

.navi--inner > .wp-navi--item > li:nth-child(2) > a {
  background-color: #c99a2e;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(2) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

.add-color__3 {
  color: #84c92e;
}

.add-bg__3 {
  color: #fff;
  background-color: #84c92e;
}

.navi--inner > .wp-navi--item > li:nth-child(3) > a {
  background-color: #84c92e;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(3) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

.add-color__4 {
  color: #2ec94d;
}

.add-bg__4 {
  color: #fff;
  background-color: #2ec94d;
}

.navi--inner > .wp-navi--item > li:nth-child(4) > a {
  background-color: #2ec94d;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(4) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

.add-color__5 {
  color: #2ec9c1;
}

.add-bg__5 {
  color: #fff;
  background-color: #2ec9c1;
}

.navi--inner > .wp-navi--item > li:nth-child(5) > a {
  background-color: #2ec9c1;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(5) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

.add-color__6 {
  color: #2e5dc9;
}

.add-bg__6 {
  color: #fff;
  background-color: #2e5dc9;
}

.navi--inner > .wp-navi--item > li:nth-child(6) > a {
  background-color: #2e5dc9;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(6) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

.add-color__7 {
  color: #742ec9;
}

.add-bg__7 {
  color: #fff;
  background-color: #742ec9;
}

.navi--inner > .wp-navi--item > li:nth-child(7) > a {
  background-color: #742ec9;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(7) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

.add-color__8 {
  color: #c92eaa;
}

.add-bg__8 {
  color: #fff;
  background-color: #c92eaa;
}

.navi--inner > .wp-navi--item > li:nth-child(8) > a {
  background-color: #c92eaa;
  display: inline-block;
  padding: 0.75em 1.2em;
  border-radius: 1.2em;
  color: #fff;
}

@media screen and (max-width: 42em) {
  .navi--inner > .wp-navi--item > li:nth-child(8) > a {
    background: none;
    padding: 0;
    margin: 0;
    color: #791c20;
  }
}

body {
  padding-top: 12em;
  background: url("./images/_texture/peaper_03.png") repeat center center/auto;
}

@media screen and (max-width: 42em) {
  body {
    padding-top: 0;
  }
}

a:hover img {
  transform: scale(1.1);
  z-index: 1;
}

h2 {
  font-weight: 700;
  color: #B25;
  position: relative;
}

#top h2.add-deco {
  display: flex;
  justify-content: center;
  align-items: center;
}

#top h2.add-deco::before {
  content: "";
  flex: 1 0 auto;
  display: block;
  height: 1px;
  background: #aaa;
  margin-right: 0.5em;
}

#top h2.add-deco::after {
  content: "";
  flex: 1 0 auto;
  display: block;
  height: 1px;
  background: #aaa;
  margin-left: 0.5em;
}

.navi--inner {
  font-size: 0.86em;
}

/*cssによるドロワーメニューの実装*/
.drawer-menu--btn {
  border-radius: 50%;
}

.drawer-menu--btn__fixed {
  border-radius: 50%;
}

#news--top {
  background: #fff;
  border-radius: 1.2em;
  padding: 1.2em;
  align-items: center;
}

#news--top--heading > *:last-child {
  margin-bottom: 0;
}

.main-visual {
  background: -moz-linear-gradient(top, #B25, #921b42);
  background: -webkit-linear-gradient(top, #B25, #921b42);
  background: linear-gradient(to bottom, #B25, #921b42);
}

.main-visual__bytext--text {
  color: #fff;
}

.main-text {
  background: -moz-linear-gradient(top, #B25, #921b42);
  background: -webkit-linear-gradient(top, #B25, #921b42);
  background: linear-gradient(to bottom, #B25, #921b42);
}

.contents-area--inner__detail {
  background-color: #fff;
  border-radius: 1.5em;
}

.contents-area--inner__detail .item-lst--component {
  width: 100%;
}

.contents-area--inner__detail .item-lst--conversion {
  width: 100%;
}

.flex--triple {
  align-items: stretch;
}

.flex--triple--child > * {
  height: 100%;
}

.image--inner {
  border-radius: 1.2em;
}

.image-text {
  text-align: center;
}

.image-text--img {
  border-radius: 50%;
}

.image-text--right--img {
  border-radius: 50%;
}

.image-text--title > span {
  background: linear-gradient(transparent 60%, rgba(255, 136, 51, 0.4) 60%, rgba(255, 136, 51, 0.4) 95%, transparent 95%);
}

.image-text--difference--img {
  border-radius: 1.5em;
}

.image-text--difference--box {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  background: #fff;
  border-radius: 1.5em;
}

.item-lst--img {
  border-radius: 1em;
}

@media screen and (max-width: 42em) {
  .item-lst--img {
    width: 70vw;
    margin: 0 auto 1.5em;
  }
}

.item-lst--conversion {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  border-radius: 1em;
  background: #fff;
}

.item-lst--conversion > a {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
}

/* ======================================== */
/* ==== tuesday.less ====================== */
/* ==== A quirky CSS Animation Library ==== */
/* ======================================== */
.animated {
  animation-duration: 0.3s;
  animation-fill-mode: both;
}

@keyframes tdFadeIn {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}

@keyframes tdFadeOut {
  0% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}

.tdFadeIn {
  animation-name: tdFadeIn;
}

.tdFadeOut {
  animation-name: tdFadeOut;
}

@keyframes tdFadeInDown {
  0% {
    opacity: 0;
    transform: translateY(-10px);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes tdFadeInLeft {
  0% {
    opacity: 0;
    transform: translateX(10px);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes tdFadeInUp {
  0% {
    opacity: 0;
    transform: translateY(10px);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes tdFadeInRight {
  0% {
    opacity: 0;
    transform: translateX(-10px);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes tdFadeOutUp {
  0% {
    opacity: 1;
    transform: translateY(0);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 0;
    transform: translateY(-10px);
  }
}

@keyframes tdFadeOutRight {
  0% {
    opacity: 1;
    transform: translateX(0);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 0;
    transform: translateX(10px);
  }
}

@keyframes tdFadeOutDown {
  0% {
    opacity: 1;
    transform: translateY(0);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 0;
    transform: translateY(10px);
  }
}

@keyframes tdFadeOutLeft {
  0% {
    opacity: 1;
    transform: translateX(0);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 0;
    transform: translateX(-10px);
  }
}

.tdFadeInDown {
  animation-name: tdFadeInDown;
}

.tdFadeInLeft {
  animation-name: tdFadeInLeft;
}

.tdFadeInUp {
  animation-name: tdFadeInUp;
}

.tdFadeInRight {
  animation-name: tdFadeInRight;
}

.tdFadeOutUp {
  animation-name: tdFadeOutUp;
}

.tdFadeOutRight {
  animation-name: tdFadeOutRight;
}

.tdFadeOutDown {
  animation-name: tdFadeOutDown;
}

.tdFadeOutLeft {
  animation-name: tdFadeOutLeft;
}

@keyframes tdExpandIn {
  0% {
    opacity: 0;
    transform: scale(0.85);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes tdExpandInBounce {
  0% {
    opacity: 0;
    transform: scale(0.85);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  70% {
    transform: scale(1.03);
    animation-timing-function: ease;
  }
  100% {
    opacity: 1;
    transform: scale(1);
    animation-timing-function: ease;
  }
}

@keyframes tdExpandOut {
  0% {
    opacity: 1;
    transform: scale(1);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 0;
    transform: scale(1.2);
  }
}

@keyframes tdExpandOutBounce {
  0% {
    opacity: 1;
    transform: scale(1);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  30% {
    opacity: 1;
    transform: scale(0.95);
    animation-timing-function: ease;
  }
  100% {
    opacity: 0;
    transform: scale(1.2);
  }
}

@keyframes tdShrinkIn {
  0% {
    opacity: 0;
    transform: scale(1.2);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes tdShrinkInBounce {
  0% {
    opacity: 0;
    transform: scale(1.2);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  70% {
    transform: scale(0.95);
    animation-timing-function: ease;
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes tdShrinkOut {
  0% {
    opacity: 1;
    transform: scale(1);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  100% {
    opacity: 0;
    transform: scale(0.85);
    animation-timing-function: ease;
  }
}

@keyframes tdShrinkOutBounce {
  0% {
    opacity: 1;
    transform: scale(1);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  30% {
    opacity: 1;
    transform: scale(1.03);
    animation-timing-function: ease;
  }
  100% {
    opacity: 0;
    transform: scale(0.85);
    animation-timing-function: ease;
  }
}

.tdExpandIn {
  animation-name: tdExpandIn;
}

.tdExpandInBounce {
  animation-name: tdExpandInBounce;
}

.tdExpandOut {
  animation-name: tdExpandOut;
}

.tdExpandOutBounce {
  animation-name: tdExpandOutBounce;
}

.tdShrinkIn {
  animation-name: tdShrinkIn;
}

.tdShrinkInBounce {
  animation-name: tdShrinkInBounce;
}

.tdShrinkOut {
  animation-name: tdShrinkOut;
}

.tdShrinkOutBounce {
  animation-name: tdShrinkOutBounce;
}

@keyframes tdStampIn {
  0% {
    opacity: 0;
    transform: scale(1.3);
    animation-timing-function: cubic-bezier(0.59, 0, 1, 0.375);
  }
  50% {
    opacity: 1;
  }
  70% {
    opacity: 1;
    transform: scale(1);
  }
  90% {
    opacity: 1;
    transform: scale(1.03);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes tdStampInSwing {
  0% {
    opacity: 0;
    transform: scale(1.3) rotate(-10deg);
    animation-timing-function: cubic-bezier(0.59, 0, 1, 0.375);
  }
  50% {
    opacity: 1;
  }
  70% {
    opacity: 1;
    transform: scale(1);
  }
  90% {
    opacity: 1;
    transform: scale(1.03);
  }
  100% {
    opacity: 1;
    transform: scale(1) rotate(0);
  }
}

.tdStampIn {
  animation-name: tdStampIn;
}

.tdStampInSwing {
  animation-name: tdStampInSwing;
}

@keyframes tdSwingIn {
  0% {
    opacity: 0;
    transform: rotate(-10deg) scale(0.85);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  70% {
    opacity: 1;
    transform: rotate(1deg);
    animation-timing-function: ease;
  }
  100% {
    opacity: 1;
    transform: rotate(0deg) scale(1);
    animation-timing-function: ease;
  }
}

@keyframes tdSwingOut {
  0% {
    opacity: 1;
    transform: rotate(0deg) scale(1);
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  30% {
    opacity: 1;
    transform: rotate(-1deg);
    animation-timing-function: ease;
  }
  100% {
    opacity: 0;
    transform: rotate(10deg) scale(0.85);
    animation-timing-function: ease;
  }
}

.tdSwingIn {
  animation-name: tdSwingIn;
}

.tdSwingOut {
  animation-name: tdSwingOut;
}

@keyframes tdHingeFlipIn {
  0% {
    opacity: 0;
    transform: perspective(600px) rotateX(0deg);
    transform-origin: center top;
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  50% {
    transform: perspective(600px) rotateX(-10deg);
    transform-origin: center top;
    animation-timing-function: ease-in;
  }
  100% {
    opacity: 1;
    transform: perspective(600px) rotateX(0deg);
    transform-origin: center top;
    animation-timing-function: ease-out;
  }
}

@keyframes tdHingeFlipOut {
  0% {
    opacity: 1;
    transform: perspective(600px) rotateX(0deg);
    transform-origin: center top;
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
  50% {
    transform: perspective(600px) rotateX(-10deg);
    transform-origin: center top;
    animation-timing-function: ease-in;
  }
  100% {
    opacity: 0;
    transform: perspective(600px) rotateX(0deg);
    transform-origin: center top;
    animation-timing-function: ease-out;
  }
}

.tdHingeFlipIn {
  animation-name: tdHingeFlipIn;
}

.tdHingeFlipOut {
  animation-name: tdHingeFlipOut;
}

@keyframes tdDropInLeft {
  0% {
    opacity: 0;
  }
  1% {
    opacity: 1;
    transform: rotate(2deg) translateY(-15px);
    transform-origin: right bottom;
    animation-timing-function: ease-in;
  }
  50% {
    opacity: 1;
    transform: rotate(0) translateY(0px);
    transform-origin: right bottom;
    animation-timing-function: ease-out;
  }
  75% {
    transform: rotate(-0.5deg) translateY(0px);
    transform-origin: left bottom;
    animation-timing-function: cubic-bezier(0.59, 0, 1, 0.375);
  }
  100% {
    opacity: 1;
    transform: rotate(0) translateY(0px);
    transform-origin: center bottom;
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
}

@keyframes tdDropInRight {
  0% {
    opacity: 0;
  }
  1% {
    opacity: 1;
    transform: rotate(-2deg) translateY(-15px);
    transform-origin: left bottom;
    animation-timing-function: ease-in;
  }
  50% {
    opacity: 1;
    transform: rotate(0) translateY(0px);
    transform-origin: left bottom;
    animation-timing-function: ease-out;
  }
  75% {
    transform: rotate(0.5deg) translateY(0px);
    transform-origin: right bottom;
    animation-timing-function: cubic-bezier(0.59, 0, 1, 0.375);
  }
  100% {
    opacity: 1;
    transform: rotate(0) translateY(0px);
    transform-origin: center bottom;
    animation-timing-function: cubic-bezier(0, 0.59, 0.375, 1);
  }
}

.tdDropInLeft {
  animation-name: tdDropInLeft;
}

.tdDropInRight {
  animation-name: tdDropInRight;
}

@keyframes tdPlopIn {
  0% {
    opacity: 0;
    transform: scale(0.9, 0.9);
  }
  10% {
    opacity: 1;
    transform: scale(0.7, 1.3);
  }
  70% {
    transform: scale(1.1, 0.95);
  }
  90% {
    transform: scale(0.97, 1.05);
  }
  100% {
    opacity: 1;
    transform: scale(1);
  }
}

@keyframes tdPlopInDown {
  0% {
    opacity: 0;
    transform: scale(0.9, 0.8);
    transform-origin: center top;
  }
  10% {
    opacity: 1;
    transform: scale(0.8, 1.3);
    transform-origin: center top;
  }
  70% {
    transform: scale(1, 0.95);
    transform-origin: center top;
  }
  100% {
    opacity: 1;
    transform: scale(1);
    transform-origin: center top;
  }
}

@keyframes tdPlopInUp {
  0% {
    opacity: 0;
    transform: scale(0.9, 0.8);
    transform-origin: center bottom;
  }
  10% {
    opacity: 1;
    transform: scale(0.8, 1.3);
    transform-origin: center bottom;
  }
  70% {
    transform: scale(1, 0.95);
    transform-origin: center bottom;
  }
  100% {
    opacity: 1;
    transform: scale(1);
    transform-origin: center bottom;
  }
}

.tdPlopIn {
  animation-name: tdPlopIn;
}

.tdPlopInDown {
  animation-name: tdPlopInDown;
}

.tdPlopInUp {
  animation-name: tdPlopInUp;
}

html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  font-size: 20px;
  line-height: 2em;
  font-family: "notoSans", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  text-align: justify;
  color: #444;
}

@media screen and (max-width: 88em) {
  html {
    font-size: 14px;
  }
}

@media screen and (max-width: 42em) {
  html {
    font-size: 14px;
  }
}

@media screen and (max-width: 68em) and (orientation: landscape) {
  html {
    font-size: 8px;
  }
}

.invisible {
  transition: all 1.25s cubic-bezier(0.250, 0.460, 0.450, 0.940);
  opacity: 0;
}

.visible {
  transition: all 1.25s cubic-bezier(0.250, 0.460, 0.450, 0.940);
  opacity: 1;
}

/*==============================================
◆2：レイアウト設定
==============================================*/
/* clearfix */
.clearfix:after {
  content: "";
  display: block;
  clear: both;
  visibility: hidden;
  line-height: 0;
}

/*共通設定*/
.pc-hide {
  display: none;
}

.bp3-visible {
  display: none;
}

@media screen and (max-width: 42em) {
  .pc-hide {
    display: block;
  }
  .sp-hide {
    display: none;
  }
}

@media screen and (max-width: 42em) {
  .bp3-visible {
    display: block;
  }
}

/*==============================================
4：WordPress用
==============================================*/
.wp-navi--item {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  margin: 0;
}

@media screen and (max-width: 42em) {
  .wp-navi--item {
    display: block;
    text-align: center;
  }
}

.wp-navi--item > li {
  margin: 0.125em 0;
}

@media screen and (max-width: 42em) {
  .wp-navi--item > li {
    margin: 0 0 1.5em;
  }
}

.wp-navi--item > li:not(:first-child) {
  margin-left: 0.86em;
}

@media screen and (max-width: 42em) {
  .wp-navi--item > li:not(:first-child) {
    margin-left: auto;
  }
}

.wp-navi--main {
  display: contents;
}

.wp-navi--main__block {
  display: block;
  text-align: right;
}

@media screen and (max-width: 42em) {
  .wp-navi--main__block {
    position: absolute;
    top: 0;
    left: 0;
    height: 0;
    width: 0;
  }
}

.wp-navi--icon {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  font-size: 0.86em;
  padding: 0.625em 0.75em;
  border-radius: 1.5em;
  background: #fff;
  color: #B25;
  line-height: 1.2em;
  border: 1px solid #efefef;
}

.wp-navi--icon:not(:first-child) {
  margin-left: 0.86em;
}

@media screen and (max-width: 42em) {
  .wp-navi--icon:not(:first-child) {
    margin-left: auto;
  }
}

@media screen and (max-width: 42em) {
  .wp-navi--icon {
    background: #B25;
    color: #fff;
    border: none;
  }
}

.wp-navi--icon:hover {
  box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  transform: translateY(-0.125em);
}

.wp-navi--icon > svg {
  width: 1.2em;
  fill: #B25;
}

@media screen and (max-width: 42em) {
  .wp-navi--icon > svg {
    fill: #fff;
  }
}

.wp-navi--inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
  padding: 0.3em 0;
}

@media screen and (max-width: 42em) {
  .wp-navi--inner {
    position: fixed;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    background: #fff;
    height: 100vh;
    width: 100vw;
    top: 0;
    left: 0;
  }
  .wp-navi--inner > * {
    display: block;
    margin: 0 auto 1.2em;
    font-size: 1.2em;
  }
  .wp-navi--inner > *:first-child::before {
    content: "MENU";
    display: block;
    text-align: center;
    border-bottom: 1px solid #aaa;
    padding-bottom: 0.86em;
    margin-bottom: 1em;
    color: #aaa;
  }
}

.wp-navi--inner__visible {
  display: flex;
  justify-content: flex-end;
  padding: 0.3em 0;
}

@media screen and (max-width: 42em) {
  .wp-navi--inner__visible {
    position: fixed;
    right: 1.2em;
    top: 50%;
    transform: translateY(-50%);
    flex-direction: column;
  }
  .wp-navi--inner__visible > * {
    box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
    margin: 0 auto 1.2em;
  }
}

.wp-navi--footer--child {
  display: flex;
  margin: 0;
}

@media screen and (max-width: 42em) {
  .wp-navi--footer--child {
    display: block;
    width: 100%;
    margin: 0 auto;
  }
}

.wp-navi--footer--child > li {
  display: flex;
  padding-left: 1.2em;
  flex: 0 1 18em;
}

@media screen and (max-width: 88em) {
  .wp-navi--footer--child > li {
    flex: 0 1 50%;
  }
}

.wp-navi--footer--child > li > a {
  flex: 0 0 40%;
  text-align: center;
  font-weight: 700;
}

.wp-navi--footer--child > li:not(:first-child) {
  border-left: 1px solid #aaa;
}

@media screen and (max-width: 42em) {
  .wp-navi--footer--child > li {
    margin: 0 auto;
    padding: 1.2em 0;
    justify-content: center;
  }
  .wp-navi--footer--child > li:not(:first-child) {
    border-left: none;
    border-top: 1px solid #aaa;
  }
}

.wp-navi--footer--child > li > ul.sub-menu {
  padding: 0;
}

@media screen and (max-width: 42em) {
  .wp-navi--footer--child > li > ul.sub-menu {
    flex: 0 0 60%;
  }
}

.wp-navi--footer--child > li > ul.sub-menu li {
  flex: 0 1 18em;
  font-size: 0.86em;
  padding: 0 1.2em;
}

.wp-navi--footer--child > li > ul.sub-menu li:not(:last-child) {
  margin-bottom: 1em;
}

.wp-post {
  /* IE11に対応させるなら変更する */
  /*
.wp-block-media-text {
  display: grid;
  grid-template-rows: auto;
  align-items: center;
  grid-template-areas: "media-text-media media-text-content";
  grid-template-columns: 50% auto;
}
.wp-block-media-text .wp-block-media-text__media {
  grid-area: media-text-media;
  margin: 0;
}
.wp-block-media-text>figure>img,
.wp-block-media-text>figure>video {
  max-width: unset;
  width: 100%;
  vertical-align: middle;
}
.wp-block-media-text .wp-block-media-text__content {
  word-break: break-word;
  grid-area: media-text-content;
  padding: 0 8%;
}
*/
  /* ブルクオート 装飾変更しても良いかと citeは、引用先 */
  /* プラグイン */
}

.wp-post .has-main-color {
  color: #B25;
}

.wp-post .has-sub-color {
  color: #f83;
}

.wp-post .has-white-color {
  color: #fff;
}

.wp-post .has-main-background-color {
  background-color: #B25;
}

.wp-post .has-sub-background-color {
  background-color: #f83;
}

.wp-post .has-black-background-color {
  background-color: #444;
}

.wp-post table td,
.wp-post table th {
  min-width: 10em;
  text-align: left;
  line-height: 1.2em;
}

@media screen and (max-width: 42em) {
  .wp-post table td,
  .wp-post table th {
    min-width: 7em;
  }
}

@media screen and (max-width: 42em) {
  .wp-post h1 br, .wp-post h2 br, .wp-post h3 br, .wp-post h4 br, .wp-post h5 br, .wp-post h6 br {
    display: none;
  }
}

.wp-post h2 strong {
  font-weight: 700;
  background: linear-gradient(transparent 60%, rgba(255, 136, 51, 0.4) 60%, rgba(255, 136, 51, 0.4) 95%, transparent 95%);
}

.wp-post h3 {
  font-size: 1.5em;
}

.wp-post .contents-area {
  padding: 6em 2em;
  background: #fff;
}

.wp-post .contents-area--inner {
  border-radius: 1em;
  padding: 6em 2em;
  background: #fff;
}

.wp-post .contents-area--wp {
  width: 50em;
  margin: 0 auto;
}

@media screen and (max-width: 42em) {
  .wp-post .contents-area--wp {
    width: 90%;
  }
}

.wp-post .contents-area--wp ol > li > ul,
.wp-post .contents-area--wp ol > li ol {
  padding: 1.2em 0 0;
  margin-left: 2em;
}

.wp-post .contents-area--wp ul > li {
  position: relative;
  padding-left: 1em;
}

.wp-post .contents-area--wp ul > li::before {
  content: "";
  display: inline-block;
  position: absolute;
  border-radius: 50%;
  top: 0.5em;
  left: 0.375em;
  height: 0.25em;
  width: 0.25em;
  background: #701433;
}

.wp-post .contents-area--wp ol {
  counter-reset: number 0;
}

.wp-post .contents-area--wp ol > li::before {
  counter-increment: number 1;
  content: counters(number, "-", decimal-leading-zero) ".";
  padding-right: 0.5em;
  color: #701433;
}

@media screen and (max-width: 88em) {
  .wp-post .contents-area--wp {
    width: 100%;
  }
}

.wp-post .wp-block-group {
  margin-bottom: 3em;
}

.wp-post .wp-block-group__inner-container {
  margin-bottom: 3em;
}

.wp-post .screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute !important;
  height: 1px;
  width: 1px;
  overflow: hidden;
}

.wp-post img .size-full,
.wp-post img .size-large,
.wp-post img .header-image,
.wp-post img .wp-post-image,
.gallery .wp-post img {
  max-width: 100% !important;
  height: auto !important;
}

.wp-post img .size-full,
.wp-post img .size-large,
.wp-post img .header-image,
.wp-post img .wp-post-image, .wp-post img[class*="align"], .wp-post img[class*="wp-image-"], .wp-post img[class*="attachment-"] {
  width: auto\9;
}

[id*="gallery-"] .wp-post img {
  border: none !important;
}

.wp-post .alignleft {
  float: left;
  max-width: 100%;
  margin-right: 1.2em;
  margin-bottom: 1.2em;
}

.wp-post .alignright {
  float: right;
  max-width: 100%;
  margin-left: 1.2em;
  margin-bottom: 1.2em;
}

.wp-post .aligncenter {
  display: block;
  max-width: 100%;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1.2em;
}

.wp-post .alignnone {
  max-width: 100%;
  height: auto;
  margin: 0 1.2em 1.2em 0;
}

.wp-post sup, .wp-post sub {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

.wp-post sup {
  top: -0.5em;
}

.wp-post sub {
  bottom: -0.25em;
}

.wp-post embed,
.wp-post iframe,
.wp-post object,
.wp-post video {
  max-width: 100%;
}

.wp-post .caption-center {
  text-align: center;
}

.wp-post .wp-caption {
  max-width: 100% !important;
  padding: 0.75em;
  border: 1px solid #aaa;
}

.wp-post .wp-caption .wp-caption-text,
.wp-post .gallery-caption,
.wp-post .entry-caption {
  text-align: left;
  font-size: 0.86em;
  font-style: normal;
  color: #444;
  margin-top: 1em;
  margin-bottom: 1.2em;
}

.wp-post .gallery-caption {
  margin: 0;
  padding: 0 1em;
}

.wp-post dl.gallery-item {
  margin: 0;
  padding: 0.6em;
  box-sizing: border-box;
}

.wp-post .size-full,
.wp-post .size-large,
.wp-post .size-medium,
.wp-post .size-thumbnail {
  border-radius: 0.75em;
  overflow: hidden;
}

.wp-post .size-full {
  max-width: 100%;
  width: 100%;
}

.wp-post .size-large {
  max-width: 100%;
  width: 100%;
}

.wp-post .size-medium {
  max-width: 40%;
  width: 40%;
}

@media screen and (max-width: 42em) {
  .wp-post .size-medium {
    max-width: 100%;
    width: 100%;
  }
}

.wp-post .size-thumbnail {
  max-width: 20%;
  width: 20%;
}

@media screen and (max-width: 42em) {
  .wp-post .size-thumbnail {
    max-width: 30%;
    width: 30%;
  }
}

.wp-post p.has-background {
  padding: 1em;
}

@media screen and (max-width: 42em) {
  .wp-post .has-text-align-center {
    text-align: justify;
  }
}

.wp-post .wp-block-button__link {
  font-size: 1.5em;
  padding: 1em 2em;
  border-radius: 1em;
}

.wp-post .wp-block-media-text {
  margin-bottom: 3em;
}

.wp-post .has-large-font-size {
  font-size: 1.2em;
}

.wp-post .has-huge-font-size,
.wp-post .has-larger-font-size {
  font-size: 1.2em;
}

.wp-post .wp-block-gallery .blocks-gallery-image figcaption,
.wp-post .wp-block-gallery .blocks-gallery-item figcaption {
  box-sizing: border-box;
}

.wp-post .wp-block-code {
  max-width: 100%;
  overflow-x: scroll;
}

.wp-post .wp-block-quote.is-large,
.wp-post .wp-block-quote.is-style-large {
  margin: 1.2em 0;
  padding: 1.2em;
}

.wp-post .wp-block-video figcaption {
  text-align: center;
}

.wp-post .wp-block-pullquote {
  border: 1px solid #aaa;
  margin-top: 1.2em;
  margin-bottom: 1.2em;
  padding: 1.2em;
}

.wp-post .wp-block-pullquote blockquote {
  border: none;
  background: none;
  margin: 0;
  padding: 0;
  border-radius: 0;
}

.wp-post .wp-block-pullquote:not(.is-style-solid-color) {
  background: #efefef;
}

.wp-post .wp-block-pullquote.is-style-solid-color blockquote {
  max-width: inherit;
}

.wp-post .wp-block-separator:not(.is-style-wide):not(.is-style-dots) {
  width: 100px;
  margin-left: auto;
  margin-right: auto;
}

.wp-post .wp-block-separator.is-style-dots {
  border-bottom-style: dotted;
}

.wp-post .wp-block-separator.is-style-dots::before {
  display: none;
}

.wp-post .wp-block-image {
  margin-bottom: 1.5em;
}

.wp-post .wp_pagenavi_out {
  margin: 3em 0 0;
  text-align: center;
  flex: 0 0 100%;
}

.wp-post .wp-pagenavi a,
.wp-post .wp-pagenavi span {
  display: inline-block;
  text-decoration: none;
  border: none;
  padding: 0 7px;
  margin: 0 7px;
}

.wp-post .wp-pagenavi a.listpost {
  width: 32px;
  height: 32px;
  line-height: 32px;
  margin: 0 38px;
}

/*==============================================
5：JSライブラリ用スタイルシート
==============================================*/
@font-face {
  font-family: 'swiper-icons';
  src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
  font-weight: 400;
  font-style: normal;
}

:root {
  --swiper-theme-color: #007aff;
}

.swiper-container {
  margin-left: auto;
  margin-right: auto;
  position: relative;
  overflow: hidden;
  list-style: none;
  padding: 0;
  /* Fix of Webkit flickering */
  z-index: 1;
}

.swiper-container-vertical > .swiper-wrapper {
  flex-direction: column;
}

.swiper-wrapper {
  position: relative;
  width: 100%;
  height: 100%;
  z-index: 1;
  display: flex;
  transition-property: transform;
  box-sizing: content-box;
}

.swiper-container-android .swiper-slide,
.swiper-wrapper {
  transform: translate3d(0px, 0, 0);
}

.swiper-container-multirow > .swiper-wrapper {
  flex-wrap: wrap;
}

.swiper-container-multirow-column > .swiper-wrapper {
  flex-wrap: wrap;
  flex-direction: column;
}

.swiper-container-free-mode > .swiper-wrapper {
  transition-timing-function: ease-out;
  margin: 0 auto;
}

.swiper-slide {
  flex-shrink: 0;
  width: 100%;
  height: 100%;
  position: relative;
  transition-property: transform;
}

.swiper-slide-invisible-blank {
  visibility: hidden;
}

/* Auto Height */
.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
  height: auto;
}

.swiper-container-autoheight .swiper-wrapper {
  align-items: flex-start;
  transition-property: transform, height;
}

/* 3D Effects */
.swiper-container-3d {
  perspective: 1200px;
}

.swiper-container-3d .swiper-wrapper,
.swiper-container-3d .swiper-slide,
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom,
.swiper-container-3d .swiper-cube-shadow {
  transform-style: preserve-3d;
}

.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 10;
}

.swiper-container-3d .swiper-slide-shadow-left {
  background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), transparent);
}

.swiper-container-3d .swiper-slide-shadow-right {
  background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), transparent);
}

.swiper-container-3d .swiper-slide-shadow-top {
  background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), transparent);
}

.swiper-container-3d .swiper-slide-shadow-bottom {
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), transparent);
}

/* CSS Mode */
.swiper-container-css-mode > .swiper-wrapper {
  overflow: auto;
  scrollbar-width: none;
  /* For Firefox */
  -ms-overflow-style: none;
  /* For Internet Explorer and Edge */
}

.swiper-container-css-mode > .swiper-wrapper::-webkit-scrollbar {
  display: none;
}

.swiper-container-css-mode > .swiper-wrapper > .swiper-slide {
  scroll-snap-align: start start;
}

.swiper-container-horizontal.swiper-container-css-mode > .swiper-wrapper {
  scroll-snap-type: x mandatory;
}

.swiper-container-vertical.swiper-container-css-mode > .swiper-wrapper {
  scroll-snap-type: y mandatory;
}

/*==============================================
5：MailFormPro用
==============================================*/
/*==============================================
5：IE11対応用
==============================================*/
@media all and (-ms-high-contrast: none) {
  html,
  h1,
  h2,
  h3,
  h4,
  h5,
  h6 {
    font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
  }
  #c-loading--wrap {
    display: none;
  }
  a.navi--icon > svg {
    height: 1.2em;
  }
  svg#logo-mark {
    height: 3.6em;
  }
  svg#logo-type {
    height: 1.65em;
  }
  .main-visual__bytext--img {
    flex: 0 0 62.5%;
    max-width: 62.5%;
  }
  .main-visual__bytext--text {
    flex: 0 0 37.5%;
    max-width: 37.5%;
  }
  .flex--triple--child {
    flex: 0 0 33.3%;
    max-width: 33.3%;
  }
  .flex--triple--child__split {
    flex: 0 0 33.3%;
    max-width: 33.3%;
  }
  .flex--quadruple--child {
    flex: 0 0 25%;
    max-width: 25%;
  }
  .image-text--difference--img {
    flex: 0 0 40.2em;
    max-width: 40.2em;
  }
  .image-text--difference--box {
    flex: 0 0 auto;
    max-width: 29.8em;
  }
}

@media all and (-ms-high-contrast: none) and (max-width: 88em) {
  .flex--triple--child {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .flex--triple--child__split {
    flex: 0 0 100%;
    max-width: 100%;
  }
  .flex--quadruple--child {
    flex: 0 0 50%;
    max-width: 50%;
  }
  .image-text--difference--img {
    flex: 0 0 55.2vw;
    max-width: 55.2vw;
  }
  .image-text--difference--box {
    flex: 0 0 auto;
    max-width: 52.8vw;
  }
  .wp-navi--main--icon {
    box-shadow: 2px 2px 5px rgba(170, 170, 170, 0.15), 4px 4px 12px rgba(170, 170, 170, 0.05);
  }
  .wp-navi--footer--child > li {
    min-width: 16em;
  }
}

/*==============================================
6：カラーミーショップ「どこでもカラーミー」対応
==============================================*/
.item-lst__cart-js {
  width: 100%;
}

.item-lst__cart-js .cartjs_form {
  margin: 0 !important;
}

.item-lst__cart-js .cartjs_box {
  padding: 0 !important;
  border: none !important;
  margin: 0 !important;
}

.item-lst__cart-js .cartjs_box > div {
  width: 100% !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form {
  display: flex !important;
  align-items: center !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table {
  flex: 0 0 54%;
  padding-right: 0.25rem !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table {
  margin: 0 !important;
  border: none !important;
  width: 100% !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table th,
.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table td {
  border: none !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table th {
  padding: 0 0.25rem 0 0 !important;
  font-size: 0.75em !important;
  min-width: 5em !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table td {
  padding: 0 0 0 0.25rem !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table td input {
  display: inline-block !important;
  padding: 0.25em !important;
  margin: 0 0.25rem 0 0 !important;
  width: 4em !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table tr:not(:last-child) th,
.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table tr:not(:last-child) td {
  padding-bottom: 1em !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table th {
  text-align: right !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table .cartjs_sales_price {
  padding-left: 0.25rem !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_product_table table .cartjs_sales_price td {
  color: #444 !important;
  font-size: 1em !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_cart_in {
  flex: 0 0 46%;
  margin: 0 auto !important;
  position: relative !important;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_cart_in::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.8em;
  transform: translateY(-50%);
  width: 0.8em;
  height: 0.8em;
  margin-right: 0.6em;
  background: url("./images/_icon/cart.png") no-repeat center center/100%;
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_cart_in input {
  display: inline-block !important;
  padding: 1.5em 0 1.5em 1.5em !important;
  background: #f83 !important;
  color: #fff !important;
  border-radius: 0.75em !important;
  width: 100% !important;
  height: auto !important;
  font-size: 1.2em !important;
  margin: 0 auto !important;
  text-align: left !important;
  transition: 0.3s;
}

@media screen and (max-width: 42em) {
  .item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_cart_in input {
    text-align: center !important;
  }
}

.item-lst__cart-js .cartjs_box form.cartjs_product_form .cartjs_cart_in input:hover {
  transition: 0.3s;
  background: #ffb142 !important;
  color: #fff !important;
}

.item-lst__cart-js .cartjs_block {
  padding: 0 !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl {
  margin: 0 auto 1em !important;
  border-spacing: 0 !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl tr.cartjs_sales_price th {
  background: none !important;
  text-align: right !important;
  padding: 0.6em 1em !important;
  border: none !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl tr.cartjs_sales_price td {
  padding: 0.6em 1em !important;
  text-align: left !important;
  border: none !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl tr.cartjs_sales_price td > p {
  margin: 0;
  color: #444 !important;
  font-size: 1.2em !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num th {
  background: none !important;
  text-align: right !important;
  padding: 0.6em 1em !important;
  border: none !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num td {
  padding: 0.6em 1em !important;
  text-align: left !important;
  border: none !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num td > p {
  margin: 0 !important;
  color: #444 !important;
  font-size: 1.2em !important;
}

.item-lst__cart-js .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num td input {
  display: inline-block !important;
  padding: 0.25em !important;
  margin: 0 0.25rem 0 0 !important;
  width: 4em !important;
}

.item-lst__cart-js .cartjs_block .cartjs_buy p {
  position: relative !important;
  margin: 0 !important;
}

.item-lst__cart-js .cartjs_block .cartjs_buy p::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 4em;
  transform: translateY(-50%);
  width: 1.5em;
  height: 1.5em;
  margin-right: 0.6em;
  background: url("./images/_icon/cart.png") no-repeat center center/100%;
}

.item-lst__cart-js .cartjs_block .cartjs_buy p input.cartjs_btn {
  display: block;
  font-weight: initial !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  background-color: none !important;
  background-image: none !important;
  border: 1px solid #e67004;
  text-shadow: 0 -1px #ec7804;
  display: inline-block !important;
  padding: 1.5em 0 1.5em 1.5em !important;
  background: #f83 !important;
  color: #fff !important;
  border-radius: 0.75em !important;
  width: 100% !important;
  height: auto !important;
  font-size: 1.2em !important;
  margin: 0 auto !important;
  transition: 0.3s;
}

@media screen and (max-width: 42em) {
  .item-lst__cart-js .cartjs_block .cartjs_buy p input.cartjs_btn {
    text-align: center !important;
  }
}

.item-lst__cart-js .cartjs_block .cartjs_buy p input.cartjs_btn:hover {
  transition: 0.3s;
  background: #ffb142 !important;
  color: #fff !important;
}

.item-lst__cart-js__sell {
  width: 100%;
}

.item-lst__cart-js__sell .cartjs_form {
  margin: 0 !important;
}

.item-lst__cart-js__sell .cartjs_box {
  padding: 0 !important;
  border: none !important;
  margin: 0 !important;
}

.item-lst__cart-js__sell .cartjs_box > div {
  width: 100% !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form {
  display: flex !important;
  align-items: center !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table {
  flex: 0 0 54%;
  padding-right: 0.25rem !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table {
  margin: 0 !important;
  border: none !important;
  width: 100% !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table th,
.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table td {
  border: none !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table th {
  padding: 0 0.25rem 0 0 !important;
  font-size: 0.75em !important;
  min-width: 5em !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table td {
  padding: 0 0 0 0.25rem !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table td input {
  display: inline-block !important;
  padding: 0.25em !important;
  margin: 0 0.25rem 0 0 !important;
  width: 4em !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table tr:not(:last-child) th,
.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table tr:not(:last-child) td {
  padding-bottom: 1em !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table th {
  text-align: right !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table .cartjs_sales_price {
  padding-left: 0.25rem !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_product_table table .cartjs_sales_price td {
  color: #d21 !important;
  font-size: 1em !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_cart_in {
  flex: 0 0 46%;
  margin: 0 auto !important;
  position: relative !important;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_cart_in::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 0.8em;
  transform: translateY(-50%);
  width: 0.8em;
  height: 0.8em;
  margin-right: 0.6em;
  background: url("./images/_icon/cart.png") no-repeat center center/100%;
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_cart_in input {
  display: inline-block !important;
  padding: 1.5em 0 1.5em 1.5em !important;
  background: #f83 !important;
  color: #fff !important;
  border-radius: 0.75em !important;
  width: 100% !important;
  height: auto !important;
  font-size: 1.2em !important;
  margin: 0 auto !important;
  text-align: left !important;
  transition: 0.3s;
}

@media screen and (max-width: 42em) {
  .item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_cart_in input {
    text-align: center !important;
  }
}

.item-lst__cart-js__sell .cartjs_box form.cartjs_product_form .cartjs_cart_in input:hover {
  transition: 0.3s;
  background: #ffb142 !important;
  color: #fff !important;
}

.item-lst__cart-js__sell .cartjs_block {
  padding: 0 !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl {
  margin: 0 auto 1em !important;
  border-spacing: 0 !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl tr.cartjs_sales_price th {
  background: none !important;
  text-align: right !important;
  padding: 0.6em 1em !important;
  border: none !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl tr.cartjs_sales_price td {
  padding: 0.6em 1em !important;
  text-align: left !important;
  border: none !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl tr.cartjs_sales_price td > p {
  margin: 0;
  color: #d21 !important;
  font-size: 1.2em !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num th {
  background: none !important;
  text-align: right !important;
  padding: 0.6em 1em !important;
  border: none !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num td {
  padding: 0.6em 1em !important;
  text-align: left !important;
  border: none !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num td > p {
  margin: 0 !important;
  color: #444 !important;
  font-size: 1.2em !important;
}

.item-lst__cart-js__sell .cartjs_block table.cartjs_dtl_tbl tr.cartjs_product_num td input {
  display: inline-block !important;
  padding: 0.25em !important;
  margin: 0 0.25rem 0 0 !important;
  width: 4em !important;
}

.item-lst__cart-js__sell .cartjs_block .cartjs_buy p {
  position: relative !important;
  margin: 0 !important;
}

.item-lst__cart-js__sell .cartjs_block .cartjs_buy p::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 4em;
  transform: translateY(-50%);
  width: 1.5em;
  height: 1.5em;
  margin-right: 0.6em;
  background: url("./images/_icon/cart.png") no-repeat center center/100%;
}

.item-lst__cart-js__sell .cartjs_block .cartjs_buy p input.cartjs_btn {
  display: block;
  font-weight: initial !important;
  -webkit-box-shadow: none !important;
  box-shadow: none !important;
  background-color: none !important;
  background-image: none !important;
  border: none !important;
  text-shadow: none !important;
  display: inline-block !important;
  padding: 1.5em 0 1.5em 1.5em !important;
  background: #f83 !important;
  color: #fff !important;
  border-radius: 0.75em !important;
  width: 100% !important;
  height: auto !important;
  font-size: 1.2em !important;
  margin: 0 auto !important;
  transition: 0.3s;
}

@media screen and (max-width: 42em) {
  .item-lst__cart-js__sell .cartjs_block .cartjs_buy p input.cartjs_btn {
    text-align: center !important;
  }
}

.item-lst__cart-js__sell .cartjs_block .cartjs_buy p input.cartjs_btn:hover {
  transition: 0.3s;
  background: #ffb142 !important;
  color: #fff !important;
}

/*==============================================
◆9：プリント用
==============================================*/
@media print {
  @page {
    size: A4;
    margin: 0;
    page-break-before: always;
  }
  html {
    font-size: 2mm;
  }
  body {
    background-image: none;
    max-width: 1200px;
    -webkit-print-color-adjust: exact;
  }
  body > * {
    display: none;
  }
  body main {
    display: block;
    padding: 10mm;
    width: 210mm;
  }
}

/*==============================================
◆10：スタイルの見本
==============================================*/
