@charset "UTF-8";
/*! ========================================
※※※※※※※※※※※※※※※※※※※※※※※※※※※
  このCSSファイルはSassから生成されていますので、
  編集しないようご注意ください。
※※※※※※※※※※※※※※※※※※※※※※※※※※※
========================================= */
/*!
  1.Foundation // base設定系のCSS関係
  クラスの命名規則は基本的にf-※※※__※※※--※※※もしくは、f-※※※-※※※などで統一
*/
/*====================================
======================================

　Foundation/_mixin.scss


======================================
====================================*/
/*
■メディアクエリー　ブレイクポイント
====================================*/
/*====================================
======================================

　Foundation/_common.scss
　共通設定css

======================================
====================================*/
/*
■リンクアクション設定
====================================*/
/* マウスホバー無し設定 */
.f-none-link {
  pointer-events: none !important;
}

/*
■コンテナ設定
====================================*/
/* メインコンテナの間隔調整用 */
/* コンテナ幅の調整 1200px */
.f-container-1200 {
  max-width: 1200px;
  margin: 0 auto;
}

/* コンテナ幅の調整 1000px */
.f-container-1000 {
  max-width: 1000px;
  margin: 0 auto;
}

/* コンテナ幅の調整 800px */
.f-container-800 {
  max-width: 800px;
  margin: 0 auto;
}

/*
■カラム設定
====================================*/
/* 横並び用のクラス */
.f-flex-between {
  display: flex;
  justify-content: space-between;
}

/*
■　コンテンツの非表示用cssクラス
====================================*/
.class_hidden {
  display: none !important;
}

/*
■使い回しコンテンツ
====================================*/
.sns a i {
  color: #777;
}

.sns a i:hover {
  color: #fff;
  transform: scale(1.1);
  transition-duration: 0.3s;
}

.fnav a:hover {
  color: #fff;
  transition-duration: 0.3s;
}

.method-btn a:hover {
  background: #fff;
  transition-duration: 0.3s;
}

/* 電話お問い合わせモジュール */
.CommonContact {
  width: 60%;
  margin: 0 auto;
  padding-top: 20px;
  display: flex;
}
.CommonContact li {
  background: #f6fafc;
  margin-right: 2%;
  width: 48%;
  text-align: center;
  padding: 40px 10px;
}
.CommonContact li:last-child {
  margin: 0 0 0 2%;
  width: 48%;
}
.CommonContact__tit {
  font-size: 16px;
}
.CommonContact__txt {
  font-size: 13px;
}
.CommonContact__txt span {
  color: #000;
  display: block;
  font-size: 22px;
  font-weight: bold;
}

/*====================================
======================================

  Foundation_text.scss
  リンクボタン周りのCSS設定

======================================
====================================*/
/*
■テキストカラー
====================================*/
/*
■テキスト位置、間隔調整
====================================*/
/* インデント設定　2行目以降を1文字下げる */
/* 行間設定　行間の高さ調整 */
/* 子要素センター揃え */
/*
■テキストサイズ、太さ
====================================*/
/* 太字 */
/* 注釈 */
/*====================================
======================================

  Foundation/_animation.scss
  アニメーション設定css

======================================
====================================*/
/*fadeup*/
.f-fadeup {
  /*
    opacity: 0;
    filter: alpha(opacity=0);
    transition: all 1.5s cubic-bezier(0.165, 0.80, 0.45, 1) 0s;
  */
}

.f-fadeup.active {
  /*
    opacity: 1;
    filter: alpha(opacity=100);
  */
}

.m-fadeup {
  opacity: 0;
  margin: 80px auto;
  transition: 1.5s;
}

.m-fadeup.active {
  opacity: 1;
  margin: 40px auto;
}

:not(.accordion_box).f-fadeup {
  /*
    transform: translateY(40px);
  */
}

:not(.accordion_box).f-fadeup.active {
  transform: translateY(0);
}

.f-fadeup.active .f-fadeinin {
  opacity: 1;
  filter: alpha(opacity=1);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
}

.accordion_box.f-fadeup {
  margin-top: 40px !important;
}

.accordion_box.f-fadeup.active {
  margin-top: 0 !important;
}

/*fadein*/
.f-fadeinin {
  opacity: 0;
  filter: alpha(opacity=0);
  -ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
  -webkit-transition: all 3s cubic-bezier(0.165, 0.8, 0.45, 1) 0.5s;
  transition: all 3s cubic-bezier(0.165, 0.8, 0.45, 1) 0.5s;
}

/*fadein*/
/*!
  2.Layout //サイト全体のブロックを定義する。
  ├ _header.scss //クラス名は .l-header__xxx
  ├ _main.scss //クラス名は .l-main__xxx
  ├ _side.scss //クラス名は .l-side__xxx
  └ _footer.scss //クラス名は .l-footer__xxx
*/
/*!
  object
    ├  3.component // サイト内で使用されるオブジェクト(モジュール)で汎用性が高いもの
    |  クラスの命名規則は基本的にc-※※※__※※※--※※※もしくは、c-※※※-※※※などで統一
    └  4.pages     // 汎用性の低いページオリジナルなもの
        cssの読み込みはスタイルへ統合せずページ単位で読み込み
        クラスの命名規則は基本的に
        ページ名__※※※--※※※,ページ名-ページ名__※※※--※※※もしくは、
        ページ名-※※※-※※※などで統一
*/
/*====================================
======================================

  Object/component/_button.scss
  リンクボタン周りのCSS設定

======================================
====================================*/
/*
■アコーディオン＋アイコン
====================================*/
.c-accordion-icon {
  width: 22px;
  height: 22px;
  display: block;
  border-radius: 50px;
  position: relative;
  z-index: 1;
}
.c-accordion-icon:before {
  content: "";
  width: 14px;
  height: 1px;
  background: #727171;
  position: absolute;
  top: 9px;
  left: 3px;
  z-index: 0;
}
.c-accordion-icon:after {
  content: "";
  width: 14px;
  height: 1px;
  background: #727171;
  position: absolute;
  transform: rotate(90deg);
  top: 9px;
  left: 3px;
  z-index: 0;
  transition-duration: 0.3s;
}

/* クリック時のJSクラス */
.Js-accordion-icon .c-accordion-icon:after {
  content: "";
  width: 13px;
  height: 1px;
  background: #727171;
  position: absolute;
  transform: rotate(0deg);
  top: 9px;
  left: 3px;
  transition-duration: 0.3s;
}

/*
■リンクボタン
====================================*/
/* リンクボタンベース設定 */
.c-link-border-on, .c-link-border-none {
  text-align: center;
  padding: 0 0 30px;
}

.c-link-border-on span, .c-link-border-on a, .c-link-border-none span, .c-link-border-none a {
  max-width: 380px;
  padding: 8px 6px;
  margin: 35px auto 0;
  display: block;
  background: #fff;
  color: #727171;
  border-radius: 50px;
  text-align: center;
  font-size: 15px;
  line-height: 1.5;
}

.product-index-list li:hover .c-link-border-none span, .c-link-border-on:hover span, .c-link-border-on:hover a, .c-link-border-none:hover span, .c-link-border-none:hover a {
  transition-duration: 0.3s;
  background: #727171;
  color: #fff;
}

/* c-link-border-none　ボーダー無し　%linkbtnを継承 */
/* c-link-border-on　ボーダー有り　%linkbtnを継承 */
.c-link-border-on span, .c-link-border-on a {
  border: 1px solid #727171;
}
/* マージン調整用クラス */
.c-link-border-none.spacer10 span, .c-link-border-none.spacer10 a, .c-link-border-on.spacer10 span, .c-link-border-on.spacer10 a {
  margin: 10px auto 0;
}

/*====================================
======================================

　Object/component/_news_list..scss

　News　Common　Class　Set
　↓TargetPages'
　　/news/index.html
　　/news/index.html
　　/news/campaign.html
　　/news/media.html
　　/news/arsoaai.html

　↓ClassList
　1.Animation-Delay
　 →アニメーションタイミングのCSSクラス

======================================
====================================*/
/*
■　Animation-Delay
====================================*/
.c-news-delay:nth-child(1) {
  transition-delay: 0.5s;
}
.c-news-delay:nth-child(2) {
  transition-delay: 1s;
}
.c-news-delay:nth-child(3) {
  transition-delay: 1.5s;
}
.c-news-delay:nth-child(4) {
  transition-delay: 0.5s;
}
.c-news-delay:nth-child(5) {
  transition-delay: 1s;
}
.c-news-delay:nth-child(6) {
  transition-delay: 1.5s;
}
.c-news-delay:nth-child(7) {
  transition-delay: 0.5s;
}
.c-news-delay:nth-child(8) {
  transition-delay: 1s;
}
.c-news-delay:nth-child(9) {
  transition-delay: 1.5s;
}
.c-news-delay:nth-child(10) {
  transition-delay: 0.5s;
}

/*=============================

　MediaKv-Customize-css
　↓TargetPages'
　　/kimura/2020keyvisual.html
　　/kimura/3stepkimura.html
　　/mao/2020kvmovie.html
　　/mao/2020keyvisual.html
　　/mao/keyvisual2019.html
　　/mao/3stepmao.html
　　/mao/keyvisual2017.html
　　/mao/keyvisual.html
　　/mao/concept2014.html
　　/mao/concept.html

　↓Class-Set-List
　0.MediaKv　Common　Class　Set

=============================*/
/*----------------------------

　MediaKv　Common　Class　Set
　↓TargetPages'
　　/kimura/2020keyvisual.html
　　/kimura/3stepkimura.html
　　/mao/2020kvmovie.html
　　/mao/2020keyvisual.html
　　/mao/keyvisual2019.html
　　/mao/3stepmao.html
　　/mao/keyvisual2017.html
　　/mao/keyvisual.html
　　/mao/concept2014.html
　　/mao/concept.html

　↓ClassList
　1.MediaKv-common-Set
　 →キービジュアルテキスト部分のCSSクラス
　2.MediaKvVideo-common-Set
　 →キービジュアルYouTubeiframeのCSSクラス
　3.MediaKvBtn-common-Set
　 →キービジュアルリンククラスのCSSクラス

------------------------------*/
/* MediaKv-common-Set */
.MediaKv {
  text-align: center;
}
.MediaKv__txt {
  margin-top: 2em;
  margin-bottom: 3em;
  font-family: 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", "Hiragino Mincho Pro", HGS明朝E, メイリオ, Meiryo, serif;
  letter-spacing: 1px;
  line-height: 1.7;
}
.MediaKv__txt p {
  margin-bottom: 1em;
  font-size: 16px;
}

/* MediaKvVideo-common-Set */
.MediaKvVideo {
  max-width: 630px;
  margin: 40px auto 0;
}
.MediaKvVideo h2 {
  margin-bottom: 5px;
}
.MediaKvVideo__videobox {
  width: 100%;
}
.MediaKvVideo__videobox iframe {
  aspect-ratio: 16/9;
  width: 100%;
  height: 100%;
}

/* MediaKvBtn-common-Set */
.MediaKvBtn {
  margin: 50px 0;
}
.MediaKvBtn a {
  margin: 0 auto;
}

/*====================================
======================================

　Object/pages/_company.scss

　Company　Common　Class　Set
　↓TargetPages'
　　/company/profile.html
　　/company/history.html

======================================
====================================*/
/*
　■テーブル設定
====================================*/
.company-table {
  margin: 30px auto;
}
.company-table th {
  padding: 3px 0 2px;
  font-weight: normal;
  text-align: left;
  vertical-align: top;
  color: #4b4129;
  white-space: nowrap;
}
.company-table td {
  padding: 3px 0 2px 10px;
  border-left: 2px solid #fee0e0;
}
.company-table a:hover {
  text-decoration: underline;
}
.company-table__street p {
  margin-top: 5px;
}
.company-table_month {
  padding-right: 10px;
}

/*
■　見出しのCSSクラス
====================================*/
.company-title-sab {
  font-size: 20px;
  font-weight: 500;
  border-left: 3px solid #e5004a;
  text-align: left;
  padding-left: 10px;
  line-height: 1.2;
  margin-bottom: 15px;
}

/*
■　フレックスコンテンツのCSSクラス
====================================*/
.company-flex {
  display: flex;
  justify-content: space-between;
  text-align: left;
}
.company-flex__reed {
  width: 75%;
  max-width: 1000px;
}
.company-flex__photo {
  margin: 0 0 15px 20px;
  text-align: left;
  width: 204px;
}
.company-flex__photo dd {
  margin: 0;
  padding: 10px;
  background: #f6f6f6;
}
.company-flex__photo dd a {
  width: auto;
  font-size: 13px;
  height: 30px;
  margin-top: 10px;
}

/*
■　記事コンテンツのCSSクラス
====================================*/
.company-article {
  text-align: center;
}
.company-article h3 {
  line-height: 1.2;
  margin-top: 50px;
  border-left: none;
}
.company-article__sabsct {
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 20px;
  font-weight: normal;
}
.company-article__sabsct span {
  background: #e5004a;
  width: 55px;
  height: 2px;
  margin: 0 8px;
}

.company-article__philosophy {
  position: relative;
  margin: 30px auto;
  z-index: 0;
}
.company-article__philosophy--lead {
  font-size: 25px;
}
.company-article__philosophy--point {
  margin: 16px 0 15px;
}
.company-article__philosophy--point li {
  margin-bottom: 10px;
}
.company-article__philosophy--point li:nth-child(1) p {
  color: #f04c7c;
}
.company-article__philosophy--point li:nth-child(2) {
  margin-left: 28px;
}
.company-article__philosophy--point li:nth-child(2) p {
  color: #1e963d;
}
.company-article__philosophy--point li:nth-child(3) p {
  color: #a440a7;
}
.company-article__philosophy--point li:last-child {
  width: 180px;
  margin: 0 auto;
}
.company-article__philosophy--point li p {
  font-size: 25px;
}
.company-article__philosophy--point li span {
  font-size: 18px;
}

.company-article__efforts--ttl {
  font-size: 20px;
  font-weight: 500;
  line-height: 1.2;
  margin-bottom: 15px;
  text-align: center;
}
.company-article__efforts--ttl span {
  display: block;
  color: #777;
  font-size: 14px;
  margin-top: 2px;
}
.company-article__efforts img {
  max-width: 600px;
  width: 100%;
  margin: 0 auto;
  display: block;
}
.company-article__efforts p {
  font-size: 15px;
}
.company-article__efforts p.small_txt {
  font-size: 14px !important;
  width: 100% !important;
}

.company-article {
  margin: 90px auto 60px;
  font-size: 18px;
}
.company-article__link {
  margin: 16px 0 15px;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
}
.company-article__link li {
  width: 30%;
  padding: 0 10px;
  text-align: center;
}
.company-article__link li a {
  color: #e5004a;
  display: block;
  text-decoration: none;
}

/*====================================
====================================

　Object/component/question_top.scss　

　Question　privacy　Class　Set
　↓TargetPages'
　　/question/privacy.html
　　/question/privacy1.html
　　/question/privacy2.html
　　/question/privacy3.html
　　/question/privacy4.html
　　/question/privacy1b.html
　　/question/privacy2b.html
　　/question/privacy3b.html
　　/question/privacy4b.html

====================================
====================================*/
/*
■　プライバシーポリシー系統のページのCSSクラス
====================================*/
.question-privacy h2 {
  margin: 20px 0 10px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.2;
  color: #666;
}
.question-privacy h3 {
  margin: 20px 0 10px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.2;
  color: #666;
}
.question-privacy h4 {
  margin: 50px 0 5px;
}
.question-privacy a {
  color: #297cf9;
  text-decoration: underline;
}

/* question-privacy-Top-Default-Set */
.question-privacy__ReedLink {
  margin: 10px 0 0;
  display: flex;
  justify-content: center;
}
.question-privacy__ReedLink li {
  margin: 0 0 5px;
}
.question-privacy__ReedLink li:first-child {
  margin: 0 30px 0 0;
}

.question-privacy.Privacy-Center {
  text-align: center;
}

/* question-privacy-UnderType1-Default-Set */
.question-privacy.UnderType1 h3 {
  color: #000;
  margin: 0 0 15px;
  padding: 0 0 4px;
  font-size: 20px;
  font-weight: normal;
  text-align: left;
  line-height: 1.2;
  border-bottom: 1px solid #ccc;
}
.question-privacy.UnderType1 ul {
  padding-left: 20px;
}
.question-privacy.UnderType1 ul li {
  list-style-type: decimal;
  margin: 30px 0;
}
.question-privacy.UnderType1 ul li ul li {
  list-style-type: none;
  margin: 0;
  text-indent: -2.8em;
  padding-left: 2em;
}
.question-privacy.UnderType1 .type1-comment {
  margin: 30px;
  text-align: right;
}

/* question-privacy-type2-Default-Set */
.question-privacy.type2 h3 {
  color: #000;
  margin: 0 0 15px;
  padding: 0 0 4px;
  font-size: 20px;
  font-weight: normal;
  text-align: left;
  line-height: 1.2;
  border-bottom: 1px solid #ccc;
}
.question-privacy.type2 ul {
  margin: 5px 0 0;
}
.question-privacy.type2 ul li {
  text-indent: -2.8em;
  padding-left: 2em;
  margin: 0 0 10px;
}
.question-privacy.type2 ul li ol li {
  list-style-type: none;
  margin: 0;
  text-indent: -1.3em;
  padding-left: 2em;
}
.question-privacy.type2 .type2-index {
  margin: 30px 0 0;
}
.question-privacy.type2 .type2-index ul {
  margin: 0;
}
.question-privacy.type2 .type2-index ul li {
  text-indent: 0;
  padding-left: 0;
  margin: 0;
}
.question-privacy.type2 .type2-shared dt {
  font-weight: bold;
  margin: 5px 0 0;
}
.question-privacy.type2 .type2-shared dd {
  margin: 0 0 10px;
  padding: 0 0 0 40px;
  text-indent: 0;
}
.question-privacy.type2 .type2-shared dd dd {
  padding: 0;
}
.question-privacy.type2 .type2-shared dd li {
  padding: 0;
}
.question-privacy.type2 .type2-shared .type2-disc {
  padding: 0;
}
.question-privacy.type2 .type2-shared .type2-disc li {
  margin: 0;
  text-indent: 0;
  list-style-type: disc;
  padding-left: 0;
}
.question-privacy.type2 .type2-address {
  background: #eee;
  text-indent: 0;
  padding: 20px;
  margin: 10px 0;
}

/*====================================
====================================

　Question　guide & compliance　Set
　↓TargetPages'
　　/question/guide.html
　　/question/compliance.html

====================================
====================================*/
/*
■　コンテンツベースのCSSクラス
====================================*/
.question-guide__leed {
  margin: 10px 0 20px;
}
.question-guide h3 {
  margin: 20px 0 10px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.2;
  color: #666;
}
.question-guide ul {
  padding: 0 0 0 20px;
}
.question-guide ul li {
  list-style-type: disc;
}

/*====================================
====================================

　Object/component/product.scss　

　Product　Common　Class　Set
　↓TargetPages'
　　/product/_All

====================================
====================================*/
/*
■　価格表記リード文のcssクラス
====================================*/
.price-lead {
  font-size: 15px;
}

/*
■　製品詳細のアコーディオンボタン用のcssクラス
====================================*/
.productl-accordion-btn {
  width: 160px;
  margin: 30px auto;
  padding: 10px;
  color: #727171;
  cursor: pointer;
  display: flex;
  justify-content: space-evenly;
  align-items: center;
  text-align: left;
}
.productl-accordion-btn p {
  font-size: 18px;
}
.productl-accordion-btn__Icon, .product-detail__inr--inimg span, .product-detail__inr--listborder span, .product-detail__inr--listbox ul li div span, .product-detail__inr--list span {
  background: url(../img/off.png?v2) no-repeat center;
  background-size: 100%;
  display: block;
  width: 27px;
  height: 27px;
  padding: 2px;
}

/*
■　製品動画用cssクラス
====================================*/
.productl-movie {
  background-size: cover;
  height: 500px;
  text-align: center;
  padding-top: 30px;
}
.productl-movie__youtube {
  max-width: 700px;
  margin: 20px auto 0;
}
.productl-movie__youtube--video {
  position: relative;
  width: 100%;
  padding-top: 56.25%;
}
.productl-movie__youtube--video iframe {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

/*
■　プッシュフェイシャル説明用cssクラス
====================================*/
.Push .productl-push__tit {
  margin: 0 0 30px;
  text-align: center;
  font-weight: normal;
  line-height: 1.3;
  font-size: 32px;
  color: #e5004a;
}
.Push .productl-push__list {
  display: flex;
  justify-content: center;
  flex-direction: row-reverse;
  align-items: center;
  width: 900px;
  margin: 0 auto;
  padding-bottom: 40px;
}
.Push .productl-push__list--info {
  width: 650px;
  font-size: 15px;
  line-height: 1.6;
}
.Push .productl-push__list--info p {
  text-align: left;
}
.Push .productl-push__list--info ol {
  margin: 1em 1em 1em 2.3em;
  text-indent: -1.3em;
}
.Push .productl-push__list--info ol li {
  width: auto;
  margin: 0 0 5px;
  text-align: left;
  cursor: none;
  display: block;
  z-index: 0;
}
.Push .productl-push__list--info ol li strong {
  margin-right: 0.5em;
}

/*
■　js用cssクラス
====================================*/
body.fixed {
  position: fixed;
  width: 100%;
  height: 100%;
  left: 0;
}

.modal_off {
  z-index: -999;
  opacity: 0;
  right: -100%;
  transition-duration: 0.8s !important;
}

.modal_on {
  z-index: 1200;
  opacity: 1;
  right: 0;
  transition-duration: 0.5s;
}

.modal_bg {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: -1;
  cursor: pointer;
}

/*
■　製品紹介の背景、スライド付きコンテンツのベースCSSクラス
====================================*/
.product-rich {
  padding: 140px 0 100px;
  position: relative;
}
.product-rich__step {
  display: flex;
  justify-content: center;
  text-align: center;
  color: #e5004a;
  margin: 0 0 70px;
}
.product-rich__step li {
  width: 100px;
  margin: 0 30px;
}
.product-rich__step li p {
  padding: 15px 0 0;
  font-size: 20px;
}
.product-rich__intro {
  text-align: center;
  margin: 0 0 60px;
}
.product-rich__intro h2 {
  margin: 0 0 30px;
  text-align: center;
  font-size: 32px;
  font-weight: normal;
  line-height: 1.3;
  color: #e5004a;
  padding-top: 20px;
}
.product-rich__intro p {
  line-height: 2;
  font-size: 15px;
}
.product-rich__material {
  text-align: center;
}
.product-rich__material--title {
  margin-top: 80px;
}
.product-rich__material--title h3 {
  position: relative;
  margin-bottom: 15px;
  padding-bottom: 12px;
  font-size: 26px;
  font-weight: normal;
}
.product-rich__material--title h3:after {
  content: "";
  width: 50px;
  height: 2px;
  position: absolute;
  left: 50%;
  bottom: 0;
  transform: translateX(-50%);
}
.product-rich__material--txt {
  margin: 15px 0 30px;
  font-size: 13px;
  line-height: 1.38;
}
.product-rich__material dl dt {
  margin: 55px 0 15px;
  font-size: 16px;
}

.product-rich__inr {
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}

/* 背景の表示・非表示 */
.product-rich.on_bg {
  padding: 0px 0 100px;
  position: relative;
}
.product-rich.on_bg .product-rich__bg {
  width: 100%;
  padding-top: 140px;
  position: relative;
  z-index: 0;
}
.product-rich.on_bg .product-rich__bg:before {
  content: "";
  width: 100%;
  height: 70px;
  position: absolute;
  left: 0;
  top: -1px;
  z-index: -1;
  background: url(../img/skin/frame01.png) no-repeat center top;
}
.product-rich.on_bg .product-rich__bg:after {
  content: "";
  width: 100%;
  height: 70px;
  position: absolute;
  left: 0;
  bottom: -1px;
  z-index: -1;
  transform: rotate(180deg);
  background: url(../img/skin/frame01.png) no-repeat center top;
}

/*
■　スライドコンテンツのCSSクラス
====================================*/
.product-slide {
  margin: 0 0 80px;
  text-align: center;
}
.product-slide .photo {
  padding: 20px 0 0;
  margin: 5px 0 15px;
}
.product-slide .photo img {
  display: initial;
}
.product-slide img {
  margin: 0 auto;
}
.product-slide h3 {
  color: #e5004a;
  margin: 0 0 10px;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 24px;
}
.product-slide h4 {
  font-size: 20px;
  font-weight: 500;
  margin: 0 0 10px;
  color: #e5004a;
}
.product-slide p {
  line-height: 1.5;
}
.product-slide ul {
  margin: 0 -5px;
}
.product-slide ul li {
  float: left;
  width: 350px;
  background: #fff;
  color: #000;
  padding: 20px 10px;
  margin: 0;
}
.product-slide .lead_txt {
  font-size: 4vw;
  padding: 10px 0;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
}
.product-slide__number {
  text-align-last: left;
  font-size: 23px;
  width: 240px;
  color: #e5004a;
  display: block;
  width: 67%;
  margin: 0 auto;
}

/* slick上書き用 */
.product-slide .slick-slide {
  margin: 0 10px;
}
.product-slide .slick-dots {
  padding: 0;
}

/* product-slide内flex要素 */
.product-slide p {
  margin: 10px 0;
}
.product-slide__Con01 {
  display: flex;
  justify-content: center;
  padding: 0;
  align-items: center;
}
.product-slide__Con01 p {
  font-size: 18px !important;
  padding: 0 !important;
  margin: 0;
}
.product-slide__Con01 img {
  width: 30px;
}
.product-slide__right {
  text-align: right;
}
.product-slide__read02 {
  text-align: center;
  font-size: 20px;
  font-weight: normal;
  line-height: 1.3;
  margin: 0 0 45px;
}

.type_sp {
  box-shadow: 1px 1px 15px #dbdcde;
}
.type_sp h2 {
  height: auto;
  font-size: 5vw;
  color: #e5004a;
  margin: 0;
  padding: 20px 0 0;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
}
.type_sp .product-slide {
  box-shadow: 0 0 0;
  margin: 0;
}
.type_sp .product-slide img {
  margin: 0;
}
.type_sp .type {
  justify-content: center;
}
.type_sp .type__in h4 {
  margin: 0 0 23px;
  padding: 0 0 15px;
  color: #000;
  font-size: 35px;
  font-weight: normal;
  text-align: center;
  position: relative;
  display: block;
}
.type_sp .type__in h4:after {
  content: "";
  width: 60px;
  height: 4px;
  background: #e5004a;
  position: absolute;
  left: 50%;
  bottom: 0;
  margin: 0 0 0 -30px;
}
.type_sp .type__in div {
  width: 170px;
  margin: 0 auto 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.type_sp .type__in div span {
  font-size: 30px;
  font-weight: bold;
  line-height: 1;
}
.type_sp .type__in div .icon_text-color {
  color: #e5004a;
  margin: 0 5px;
}
.type_sp .type__in div.second {
  width: 110px;
}
.type_sp .type.type_bottom {
  width: 300px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.type_sp .type.type_bottom .type__in {
  width: auto;
  margin: 0;
  padding: 0;
}
.type_sp .type.type_bottom .type__in div {
  justify-content: start;
}
.type_sp .type.type_bottom .type__in div img {
  margin-right: 5px;
}

.product-crl3 .product-slide02 {
  max-width: 600px;
  margin: 0 auto;
}

.product-crl3 .product-slide02 li {
  margin: 20px 0;
}

.product-detail .product-slide p {
  font-size: 15px;
}

/*
■　PCグリッドコンテンツのCSSクラス
====================================*/
.product-grid {
  max-width: 980px;
  margin: 0 auto 30px;
  display: flex;
  flex-wrap: wrap;
}
.product-grid ul {
  width: 50%;
  box-sizing: border-box;
}
.product-grid ul:last-child {
  margin-top: 130px;
}
.product-grid ul li {
  background: #fff;
  margin: 0 20px 40px;
  text-align: center;
  border-radius: 2px;
  box-shadow: 1px 1px 15px #dbdcde;
  will-change: filter;
  padding: 30px;
  min-height: 450px;
  flex-direction: column;
  display: flex;
  justify-content: center;
}
.product-grid ul li h3 {
  color: #e5004a;
  font-weight: normal;
  font-size: 22px;
  padding: 0 0 22px;
  line-height: 1.6;
}
.product-grid ul li p {
  margin: 10px 0;
  line-height: 2;
}
.product-grid ul li small {
  font-size: 85%;
}
.product-grid .tikara__info .subtitle {
  margin: 0 0 23px;
}
.product-grid .tikara__info p {
  line-height: 2.4;
  margin-bottom: 15px;
}
.product-grid .tikara__info p.caps {
  line-height: 1.6;
  margin-top: 10px;
  font-size: 11px;
  text-align: right;
}
.product-grid__Con01 {
  display: flex;
  justify-content: center;
  padding: 20px 0;
  align-items: center;
}
.product-grid__Con01 p {
  font-size: 18px !important;
  padding: 3px 0 !important;
}
.product-grid__Con01 img {
  width: 30px;
}
.product-grid__right {
  text-align: right;
}

/*
■　使い方コンテンツのCSSクラス
====================================*/
.product-howto h2 {
  text-align: center;
  font-size: 32px;
  font-weight: normal;
  line-height: 1.3;
  color: #e5004a;
  margin: 0 0 30px;
}
.product-howto ul {
  display: flex;
  justify-content: space-between;
  margin-bottom: 50px;
}
.product-howto ul.illust {
  justify-content: center;
}
.product-howto ul.illust li {
  width: 280px;
  margin: 0 20px;
  padding: 18px;
}
.product-howto ul.type {
  justify-content: center;
}
.product-howto ul.type li {
  width: 280px;
  margin: 0 20px;
  padding: 18px;
}
.product-howto ul.type li h4 {
  margin: 0 0 23px;
  padding: 10px 0 15px;
  color: #000;
  font-size: 35px;
  font-weight: normal;
  text-align: center;
  position: relative;
  display: block;
}
.product-howto ul.type li h4:after {
  content: "";
  width: 60px;
  height: 4px;
  background: #e5004a;
  position: absolute;
  left: 50%;
  bottom: 0;
  margin: 0 0 0 -30px;
}
.product-howto ul.type li div {
  width: 170px;
  margin: 0 auto 10px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.product-howto ul.type li div span {
  font-size: 30px;
  font-weight: bold;
  line-height: 1;
}
.product-howto ul.type li div .icon_text-color {
  color: #e5004a;
  margin: 0 5px;
}
.product-howto ul.type li div.second {
  width: 110px;
}
.product-howto ul.type.type_bottom {
  width: 300px;
  margin: 0 auto;
  justify-content: space-between;
}
.product-howto ul.type.type_bottom li {
  width: auto;
  margin: 0;
  padding: 0;
}
.product-howto ul.type.type_bottom li div {
  justify-content: start;
}
.product-howto ul.type.type_bottom li div img {
  margin-right: 5px;
}
.product-howto ul li {
  box-sizing: border-box;
  width: 214px;
  text-align: center;
  margin: 0 5px;
  position: relative;
}
.product-howto ul li h4 {
  color: #e5004a;
  font-weight: normal;
  font-size: 18px;
  padding: 10px 0 15px;
}
.product-howto .photo {
  padding-bottom: 20px;
}
.product-howto__number {
  text-align-last: left;
  font-size: 23px;
  width: 240px;
  color: #e5004a;
}
.product-howto .product-howto-info {
  font-size: 13px;
  text-align: left;
  display: flex;
  align-items: center;
  padding-bottom: 20px;
}
.product-howto .product-howto-info__img img {
  width: 130px;
}
.product-howto .product-howto-info__text {
  padding-left: 15px;
  box-sizing: border-box;
  text-align: left;
}
.product-howto .product-howto-info__text span {
  display: block;
  font-size: 16px;
}
.product-howto__lead02 {
  text-align: center;
  font-size: 20px;
  font-weight: normal;
  line-height: 1.3;
  margin: 0 0 45px;
}
.product-howto__center {
  text-align: center;
}

/*
■　背景の白波のCSSクラス
====================================*/
.product-wave {
  padding: 30px 0;
  position: relative;
}
.product-wave:before {
  content: "";
  width: 100%;
  height: 70px;
  position: absolute;
  left: 0;
  top: 0;
  background: url(../img/skin/bg03.png) no-repeat center top;
}

/*
■　製品のキービジュアルのCSSクラス
====================================*/
.product-kv {
  margin: 0 auto;
  padding: 40px 0;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
}
.product-kv__leftbox {
  width: 50%;
  text-align: center;
}
.product-kv__leftbox p {
  font-weight: bold;
  font-size: 18px;
}
.product-kv__rightbox {
  max-width: 50%;
  box-sizing: border-box;
  padding-left: 30px;
  line-height: 2;
}
.product-kv__rightbox--ttl {
  padding-bottom: 20px;
  line-height: 1.5;
  font-size: 26px;
}
.product-kv__rightbox--ttl.origin {
  color: #e5004a;
  font-size: 42px;
}
.product-kv__rightbox--txt {
  line-height: 1.8;
  font-size: 14px;
}
.product-kv__rightbox--txt span {
  font-size: 19px;
}
.product-kv__leftbox2 {
  width: 30%;
  text-align: center;
}
.product-kv__leftbox2 p {
  font-weight: bold;
  font-size: 18px;
}
.product-kv__rightbox2 {
  width: 48%;
  box-sizing: border-box;
  padding-left: 30px;
  line-height: 2;
}

/*
■　各製品TOPのリード文のCSSクラス
====================================*/
.product-index-leed {
  text-align: center;
  font-size: 18px;
}

/*
■　各製品TOPのリストのCSSクラス
====================================*/
.product-index-list {
  width: 100%;
  max-width: 1100px;
  margin: 100px auto 30px;
  display: flex;
  flex-flow: wrap;
  justify-content: center;
  text-align: center;
}
.product-index-list li {
  width: 33.3333%;
  margin-bottom: 30px;
  box-sizing: border-box;
  padding: 0 15px;
}
.product-index-list a {
  color: #000;
}
.product-index-list a h3 {
  padding-bottom: 20px;
  font-size: 17px;
  font-weight: normal;
}
.product-index-list a h3 span {
  font-weight: 500;
  font-size: 30px;
}
.product-index-list a p {
  font-size: 15px;
}

/*　product-index-list　リストの左寄せ用　*/
.product-index-list.list-left {
  justify-content: start;
}

/*　product-index-list　連続使用時のマージン調整用　*/
.product-index-list.list-bottom {
  margin: 0 auto 30px;
}

/* リストに対してホバー指定　%linkbtnを継承 */
/*----------------------------

　Productbase Set
　↓TargetPages'
　　/product/製品詳細ページ

　↓ClassList
　1.%Productbase
　 →製品リストベース
　 Product　3 Column　Only　Class　Set　へ設定引き継ぎ
　 Product　2 Ccolumn　Only　Class　Set　へ設定引き継ぎ
　2.class_linkbtn_type1
　 →BasemakeUPメイクツール調整用
　3.flex_baseline
　 →縦のそろいを頭合わせに調整
　4.link_type-1
　 →製品リスト　非リンク対応用

------------------------------*/
/*　Productbase Set　*/
.product-crl2, .product-crl3.crl3-small, .product-crl3 {
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.product-crl2 li, .product-crl3.crl3-small li, .product-crl3 li {
  width: 350px;
  margin: 40px auto;
  text-align: center;
  cursor: pointer;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 0;
}
.product-crl2 li.column1, .product-crl3 li.column1 {
  width: 450px;
}
.product-crl2 li p, .product-crl3.crl3-small li p, .product-crl3 li p {
  width: 100%;
  font-size: 20px;
  padding-bottom: 2px;
}
.product-crl2 li:nth-child(1), .product-crl3 li:nth-child(1), .product-crl2 li:nth-child(4), .product-crl3 li:nth-child(4), .product-crl2 li:nth-child(7), .product-crl3 li:nth-child(7), .product-crl2 li:nth-child(10), .product-crl3 li:nth-child(10), .product-crl2 li:nth-child(13), .product-crl3 li:nth-child(13), .product-crl2 li:nth-child(16), .product-crl3 li:nth-child(16), .product-crl2 li:nth-child(19), .product-crl3 li:nth-child(19) {
  transition-delay: 0.5s;
}
.product-crl2 li:nth-child(3), .product-crl3 li:nth-child(3), .product-crl2 li:nth-child(6), .product-crl3 li:nth-child(6), .product-crl2 li:nth-child(9), .product-crl3 li:nth-child(9), .product-crl2 li:nth-child(12), .product-crl3 li:nth-child(12), .product-crl2 li:nth-child(15), .product-crl3 li:nth-child(15), .product-crl2 li:nth-child(18), .product-crl3 li:nth-child(18), .product-crl2 li:nth-child(21), .product-crl3 li:nth-child(21) {
  transition-delay: 1s;
}
.product-crl2 li:nth-child(5), .product-crl3 li:nth-child(5), .product-crl2 li:nth-child(8), .product-crl3 li:nth-child(8), .product-crl2 li:nth-child(11), .product-crl3 li:nth-child(11), .product-crl2 li:nth-child(14), .product-crl3 li:nth-child(14), .product-crl2 li:nth-child(17), .product-crl3 li:nth-child(17), .product-crl2 li:nth-child(20), .product-crl3 li:nth-child(20), .product-crl2 li:nth-child(23), .product-crl3 li:nth-child(23) {
  transition-delay: 1.5s;
}
.product-crl2 h2, .product-crl3.crl3-small h2, .product-crl3 h2 {
  font-weight: normal;
  width: 100%;
}
.product-crl2 h2 span:first-child, .product-crl3 h2 span:first-child {
  font-size: 16px;
  letter-spacing: 2px;
}
.product-crl2 img, .product-crl3.crl3-small img, .product-crl3 img {
  margin: 10px auto;
}
.product-crl2__Win, .product-crl3.crl3-small__Win, .product-crl3__Win {
  width: 70%;
}
.product-crl2__Win02, .product-crl3.crl3-small__Win02, .product-crl3__Win02 {
  width: 60%;
}
.product-crl2__Win03, .product-crl3.crl3-small__Win03, .product-crl3__Win03 {
  width: 60%;
}
.product-crl2__Win04, .product-crl3.crl3-small__Win04, .product-crl3__Win04 {
  max-width: 122%;
}
.product-crl2__Win05, .product-crl3.crl3-small__Win05, .product-crl3__Win05 {
  max-width: 100%;
}
.product-crl2 .produc-sab-title, .product-crl3 .produc-sab-title {
  position: relative;
  font-size: 14px;
}
.product-crl2 .produc-sab-title:before, .product-crl3 .produc-sab-title:before {
  content: "";
  left: 0;
  transform: translateX(-100%);
  transition-duration: 0.3s;
}
.product-crl2__pricebody, .product-crl3.crl3-small__smalltxt, .product-crl3.crl3-small__pricebody, .product-crl3__smalltxt, .product-crl3__pricebody {
  font-size: 15px !important;
}
/*　class_linkbtn_type1　*/
.class_linkbtn_type1 {
  position: absolute;
  bottom: -91px;
  z-index: 0;
}

/*　flex_baseline　*/
.flex_baseline {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: baseline;
}
.flex_baseline p {
  font-size: 15px;
}

/*　link_type-1　*/
.link_type-1 li {
  cursor: auto;
}
.link_type-1 li:hover .produc-sab-title:before {
  content: "";
  width: 0;
  height: 0;
  background: transparent;
  position: absolute;
  top: 0;
  left: 0;
  transform: translateX(0%);
  transition-duration: 0.3s;
}
.link_type-1 li.link_on {
  cursor: pointer;
}
.link_type-1 li.link_on:hover .produc-sab-title:before {
  content: "";
  width: 100px;
  height: 2px;
  background: #e5004a;
  position: absolute;
  top: -6px;
  left: 50%;
  transform: translateX(-50%);
  transition-duration: 0.3s;
}
.link_type-1 li.link_on .productl-accordion-btn {
  margin: auto;
}

/*----------------------------

　Product　3 Column　Only　Class　Set
　↓TargetPages'
　　/product/配下のかく製品詳細ページ（３カラム）

　↓ClassList
　1.product-crl3
　 →「Productbase Set」の設定を継承

------------------------------*/
.product-crl3 {
  max-width: 1200px; /*　3 Column設定　*/
}
.product-crl3.crl3-small {
  max-width: 1200px; /*　3 Column設定　*/
}
.product-crl3.crl3-small li p {
  font-size: 14px;
}
.product-crl3.crl3-small__pricebody {
  font-size: 0.9rem;
}
/*----------------------------

　Product　2 Ccolumn　Only　Class　Set
　↓TargetPages'
　　/product/配下のかく製品詳細ページ（２カラム）用

　↓ClassList
　1.product-crl2
　 →2カラムリストクラスへ「Productbase Set」の設定を継承

------------------------------*/
.product-crl2 {
  max-width: 1000px; /*　2 Column設定　*/
}
/*----------------------------

　product-detail Set
　↓TargetPages'
　　/product/配下の各製品詳細ページ

　↓ClassList
　1.product-detail Set
　 →製品詳細モーダル部分の設定
　2.product-detail02
　 →コチャママ製品詳細モーダル部分の設定
------------------------------*/
/*　product-detail Set　*/
.product-detail {
  width: 100%;
  height: 100%;
  min-height: 100vh;
  background: #fff;
  text-align: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1100;
  overflow-y: scroll;
  display: none;
}
.product-detail__close {
  width: 45px;
  height: 45px;
  border-radius: 50px;
  position: fixed;
  top: 25px;
  right: 25px;
  z-index: 10;
  cursor: pointer;
}
.product-detail__close:before, .product-detail__close:after {
  content: "";
  width: 33px;
  height: 3px;
  background: #727171;
  position: absolute;
  top: 18px;
  left: 5px;
}
.product-detail__close:before {
  transform: rotate(45deg);
}
.product-detail__close:after {
  transform: rotate(-45deg);
}

.product-detail__inr--smallText {
  padding: 30px 0 0;
  font-size: 14px;
}
.product-detail__inr h3 {
  margin: 0 0 20px;
  padding: 80px 0 0;
  font-weight: normal;
  font-size: 31px;
}
.product-detail__inr h4 {
  margin: 0 0 20px;
  padding: 110px 0 0;
  background: url(../img/skin/bg03.png) no-repeat 0 35px/100%;
  font-weight: normal;
  font-size: 31px;
}
.product-detail__inr h5 {
  margin: 0 0 20px;
  padding: 30px 0 0;
  font-weight: normal;
  font-size: 31px;
}

.product-detail__inr--leadtxt {
  margin: 0 0 50px;
  font-size: 15px;
}
.product-detail__inr--con01 {
  display: flex;
  justify-content: center;
  padding: 0 0 20px;
  align-items: center;
}
.product-detail__inr--con01 p {
  font-size: 18px !important;
  padding: 3px 0 !important;
}
.product-detail__inr--con01 img {
  width: 30px;
}
.product-detail__inr--color {
  margin: 0 auto 35px;
}
.product-detail__inr--color h3 {
  padding: 0;
}
.product-detail__inr--color .color-title span {
  font-size: 31px;
}
.product-detail__inr--color .color-naming {
  max-width: 350px;
  width: 90%;
  margin: 0 auto;
}
.product-detail__inr--color ul {
  max-width: 1200px;
  margin: 30px auto 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.product-detail__inr--color ul li {
  display: block;
  width: 10%;
  margin: 0;
  padding: 0 10px 40px;
}
.product-detail__inr--color ul li {
  cursor: auto;
}
.product-detail__inr--color ul li span {
  font-size: 14px;
}
.product-detail__inr--color ul li p {
  font-size: 12px;
}
.product-detail__inr--list {
  width: 440px;
  margin: 0 auto;
  padding: 15px;
  background: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  cursor: pointer;
}
.product-detail__inr--link {
  text-align: center;
  padding: 0 0 30px;
}
.product-detail__inr--link a {
  max-width: 380px;
  padding: 8px 6px;
  margin: 35px auto 0;
  display: block;
  background: #fff;
  color: #727171;
  border: 1px solid #727171;
  border-radius: 50px;
  text-align: center;
  font-size: 15px;
}
.product-detail__inr--link:hover a {
  transition-duration: 0.3s;
  background: #727171;
  color: #fff;
}
.product-detail__inr--link.ProductLinkFaq {
  padding: 0 0 0;
}
.product-detail__inr--listbox h4 {
  margin: 0;
  padding: 15px 15px 0;
  width: 100%;
  background: transparent;
  font-weight: normal;
}
.product-detail__inr--listbox p {
  padding: 0 0 15px;
}
.product-detail__inr--listbox ul {
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.product-detail__inr--listbox ul li {
  width: 23%;
  padding: 20px 0 20px;
  box-sizing: border-box;
  border: 1px solid #e5004a;
  margin: 0 1% 2%;
}
.product-detail__inr--listbox ul li div {
  width: 100%;
  margin: 0 auto;
  padding: 15px;
  background: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  border-top: 1px solid #f2f6f9;
  cursor: pointer;
}
.product-detail__inr--relation h3 {
  color: #e5004a;
  padding: 40px 0 10px;
}
.product-detail__inr--relation ul {
  background: #fff;
  margin: 40px auto 0;
  text-align: center;
  display: flex;
  justify-content: center;
  flex-flow: row wrap;
}
.product-detail__inr--relation ul li {
  margin: 0 40px 20px;
  cursor: auto;
}
.product-detail__inr--relation ul li > img {
  margin: 20px auto;
}
.product-detail__inr--relation ul li a {
  width: 325px;
  padding: 10px 0;
  display: block;
}
.product-detail__inr--relation ul li a span {
  display: block;
  color: #000;
}

.product-detail__inr--listborder {
  width: 440px;
  margin: 0 auto;
  padding: 15px;
  background: #fff;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  border-top: 1px solid #e8eef4;
  cursor: pointer;
}
.product-detail__inr--listborder.last {
  border-top: none;
}
.product-detail__inr--inimg {
  width: 440px;
  margin: 0 auto;
  padding: 15px;
  background: #fff;
  font-size: 14px;
  border-top: 1px solid #e8eef4;
  cursor: pointer;
}
.product-detail__inr--inimg.last {
  border-top: none;
}

.product-detail__inr--listborder .product-detail__inr--leadtxt {
  padding: 5px;
}

.product-detail__inr--makeuptool {
  margin: 80px 0 50px;
}
.product-detail__inr--makeuptool p {
  font-size: 16px;
}
.product-detail__inr--makeuptool h3 {
  color: #e5004a;
  margin: 0;
  padding: 30px 0 0;
}

.product-detail .product-howto p {
  font-size: 15px;
}

/* product-detail02 */
.product-detail02 {
  width: 100%;
  height: 100%;
  min-height: 100vh;
  background: rgba(0, 0, 0, 0.8);
  text-align: center;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1100;
  overflow-y: scroll;
  display: none;
}
.product-detail02__Close {
  width: 45px;
  height: 45px;
  border-radius: 50px;
  position: fixed;
  top: 25px;
  right: 25px;
  z-index: 10;
  cursor: pointer;
}
.product-detail02__Close:before, .product-detail02__Close:after {
  content: "";
  width: 33px;
  height: 3px;
  background: #727171;
  position: absolute;
  top: 18px;
  left: 5px;
}
.product-detail02__Close:before {
  transform: rotate(45deg);
}
.product-detail02__Close:after {
  transform: rotate(-45deg);
}

/*----------------------------

　　product-component Set
　↓TargetPages'
　　/product/配下の各製品詳細ページ

　↓ClassList
　1.　product-component Set
　 →製品成分表記モーダル部分の設定

------------------------------*/
/*　product-component Set　*/
.product-component {
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.8);
  position: fixed;
  top: 0;
  overflow: scroll;
}
.product-component__Close {
  width: 45px;
  height: 45px;
  border-radius: 50px;
  position: fixed;
  top: 25px;
  right: 25px;
  z-index: 1000;
  cursor: pointer;
}
.product-component__Close:before, .product-component__Close:after {
  content: "";
  width: 33px;
  height: 3px;
  background: #727171;
  position: absolute;
  top: 18px;
  left: 5px;
}
.product-component__Close:before {
  transform: rotate(45deg);
}
.product-component__Close:after {
  transform: rotate(-45deg);
}
.product-component__in {
  padding: 50px;
  margin: 0 0 50px;
  height: auto;
  background: #fff;
  max-width: 500px;
  width: 100%;
  position: absolute;
  top: 5%;
  left: 50%;
  z-index: 0;
  transform: translateX(-50%);
  transition-duration: 0.3s;
}
.product-component__in h3 {
  text-align: center;
  margin-bottom: 30px;
  font-size: 40px;
  font-weight: normal;
  font-size: 40px;
}
.product-component__in ul li {
  width: 100%;
  border-bottom: 1px solid #e8eef4;
  margin: 0;
  padding: 12px 0;
  text-align: center;
}
.product-component__in ul li:first-child {
  border-top: 1px solid #e8eef4;
}
.product-component__in ul li.jus_between {
  display: flex;
  justify-content: space-between;
}
.product-component__in ul li.double_line {
  border-top: 1px double #e8eef4;
  margin-top: 4px;
}
.product-component__inimg--imgC {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 10;
  transform: translate(-50%, -50%);
}
.product-component__inimg--in {
  display: flex;
  margin-bottom: -7px;
}
.product-component__inimg--in li {
  padding-right: 4px;
  width: auto;
  margin: 0;
  text-align: center;
  cursor: pointer;
  display: block;
  flex-wrap: wrap;
  align-items: stretch;
  justify-content: start;
  position: relative;
  z-index: 0;
}
.product-component__inimg--in li a {
  background-color: transparent;
}
.product-component__inimg--in li a img {
  margin: 0 0 7px;
  vertical-align: bottom;
}
.product-component__inimg--imgbg {
  padding: 50px;
  background: #fff;
  display: inline-block;
}

/*----------------------------

　product-detail-large Set
　↓TargetPages'
　　/product/配下の各製品詳細ページ

　↓ClassList
　1.product-detail Set
　 →製品詳細モーダル部分の設定

------------------------------*/
.product-detail-large {
  padding: 120px 0;
  position: relative;
}
.product-detail-large:before {
  content: "";
  width: 100%;
  height: 70px;
  position: absolute;
  left: 0;
  top: 0;
  background: url(../img/skin/bg03.png) no-repeat center top;
}
.product-detail-large h2 {
  margin: 0 0 30px;
  font-weight: normal;
  line-height: 1.3;
  text-align: center;
  font-size: 40px;
}
.product-detail-large ul {
  display: flex;
  justify-content: center;
}
.product-detail-large ul li {
  background: #fff;
  color: #000;
  text-align: left;
  margin: 0 30px;
  width: 440px;
}
.product-detail-large ul li h3 {
  padding: 15px 25px 15px 0;
  font-weight: normal;
  line-height: 1.1;
  height: 125px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  font-size: 26px;
}
.product-detail-large ul li .product-detail__inr--list {
  padding: 25px 25px;
  border-top: 1px solid #e8eef4;
  border-bottom: 1px solid #e8eef4;
  font-size: 17px;
}

/*----------------------------
skincare2022_lp　ロゴ追加用一時クラス
------------------------------*/
.skincare2022_lp_firstImg {
  width: 50%;
}

.skincare2022_lp_productImg {
  width: 82%;
}

/*====================================
======================================

　Object/component/_announce.scss

　Announce　Common　Class　Set
　↓TargetPages'
　　/index.html
　　/campaign/sustainabeauty2020/
　　/campaign/sustainabeauty2022/

======================================
====================================*/
.c-instaAnnounce {
  max-width: 635px;
  margin: 0px auto 80px;
}
.c-instaAnnounce--topicTop {
  margin: 54px auto 0;
}
.c-instaAnnounce--sustaina {
  margin: 0px auto 40px;
}
.c-instaAnnounce--sustaina2022 {
  width: 98%;
  margin: 0px auto 40px;
}
.c-instaAnnounce__intext dt {
  font-size: 18px;
  font-weight: bold;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  cursor: pointer;
}
.c-instaAnnounce__intext dd {
  padding: 27px;
  margin-top: 30px;
  display: none;
}
.c-instaAnnounce__intext dd p {
  font-size: 16px;
  line-height: 1.4;
  text-align: left;
}
.c-instaAnnounce__intext a {
  color: #e5254a;
}
.c-instaAnnounce__intext--top .c-accordion-icon {
  position: relative;
  right: auto;
  top: auto;
  transform: translateY(0);
}
.c-instaAnnounce__intext--top dt {
  color: #727171;
  font-size: 1.3vw;
}
.c-instaAnnounce__intext--top dt.lines {
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
}
.c-instaAnnounce__intext--top dd {
  border: 1px solid #727171;
}
.c-instaAnnounce__intext--top dd p {
  font-size: 1.0416666667vw;
}
.c-instaAnnounce__intext--sustaina dt {
  color: #fff;
}
.c-instaAnnounce__intext--sustaina .c-accordion-icon {
  border: 1px solid #fff;
}
.c-instaAnnounce__intext--sustaina .c-accordion-icon::before {
  background: #fff;
}
.c-instaAnnounce__intext--sustaina .c-accordion-icon::after {
  background: #fff;
}
.c-instaAnnounce__intext--sustaina dd {
  border: 1px solid #fff;
  background: #fff;
}
.c-instaAnnounce__intext--sustaina2022 dt {
  color: #3a9ec9;
}
.c-instaAnnounce__intext--sustaina2022 dt .c-accordion-icon {
  border: 1px solid #3a9ec9;
}
.c-instaAnnounce__intext--sustaina2022 dt .c-accordion-icon::before {
  background: #3a9ec9;
}
.c-instaAnnounce__intext--sustaina2022 dt .c-accordion-icon::after {
  background: #3a9ec9;
}
.c-instaAnnounce__intext--sustaina2022 dd {
  border: 1px solid #3a9ec9;
}

/*!
5.External　//フレームワークや外部CSSなどを利用するときはこのレイヤー
*/

@media screen and (max-width: 1099px){
  .f-container-1200 {
    padding: 0 20px;
  }
  .f-container-1000 {
    padding: 0 20px;
  }
  .f-container-800 {
    padding: 0 20px;
  }
  .product-rich__inr {
    padding: 0 20px;
  }
  .product-detail-large ul li {
    margin: 0;
    width: 48%;
  }
}

@media screen and (max-width: 768px){
  .f-container-1200 {
    padding: 0 15px;
  }
  .f-container-1000 {
    padding: 0 15px;
  }
  .f-container-800 {
    padding: 0 15px;
  }
  .f-flex-between {
    display: block;
  }
  .CommonContact {
    display: block;
    width: 100%;
    display: block;
    text-align: center;
  }
  .CommonContact li {
    width: 100%;
    margin: 0 0 20px;
  }
  .CommonContact li:last-child {
    width: 100%;
    margin: 0 0 20px;
  }
  .c-link-border-on span, .c-link-border-on a, .c-link-border-none span, .c-link-border-none a {
    max-width: 300px;
    margin: 25px auto 0;
  }
  .c-news-delay:nth-child(1), .c-news-delay:nth-child(2), .c-news-delay:nth-child(3), .c-news-delay:nth-child(4), .c-news-delay:nth-child(5), .c-news-delay:nth-child(6), .c-news-delay:nth-child(7), .c-news-delay:nth-child(8), .c-news-delay:nth-child(9), .c-news-delay:nth-child(10) {
    transition-delay: 0s;
  }
  .company-flex {
    display: block;
  }
  .company-flex__reed {
    width: 100%;
  }
  .company-flex__photo {
    margin: 20px auto 0;
  }
  .company-article h3 {
    font-size: 25px;
  }
  .company-article__philosophy--lead {
    font-size: 1.8rem;
  }
  .company-article__efforts p {
    margin: 16px auto 10px;
    width: 90%;
    text-align: justify;
  }
  .company-article__link li {
    width: 100%;
    margin: 20px;
  }
  .question-privacy__ReedLink {
    display: block;
  }
  .question-privacy.type2 ul li {
    text-indent: 0;
    padding-left: 0;
  }
  .question-privacy.type2 ul li ol li {
    text-indent: 0;
    padding-left: 0;
  }
  .question-privacy.type2 .type2-shared dd {
    padding: 0;
  }
  .question-privacy.type2 .type2-shared .type2-disc li {
    margin: 0 0 0 16px;
  }
  .price-lead {
    font-size: 1.4rem;
  }
  .productl-accordion-btn p {
    width: auto;
    font-size: 2rem;
  }
  .productl-movie {
    height: 300px;
    padding-top: 20px;
  }
  .productl-movie__youtube {
    width: 95%;
    max-width: 100%;
    margin-top: 10px;
  }
  .Push .productl-push__tit {
    margin: 0;
    font-size: 6.5vw;
  }
  .Push .productl-push__list {
    display: block;
    width: 90%;
    margin: 0 auto;
  }
  .Push .productl-push__list--photo {
    margin: 20px 0;
    text-align: center;
  }
  .Push .productl-push__list--info {
    width: auto;
  }
  .Push .productl-push__list--info ol li {
    width: auto;
    margin: 0;
  }
  body.fixed {
    position: static;
    height: auto;
  }
  body.fixed_sp {
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
  }
  .modal_bg {
    background-color: #fff;
  }
  .product-rich {
    padding: 50px 0 50px;
  }
  .product-rich__step {
    margin: 0 0 20px;
  }
  .product-rich__step li {
    width: 72px;
    margin: 0 10px;
  }
  .product-rich__step li p {
    padding: 10px 0 0;
    font-size: 1.8rem;
  }
  .product-rich__intro {
    margin: 0 0 20px;
  }
  .product-rich__intro h2 {
    margin: 0 0 15px;
  }
  .product-rich__intro p {
    font-size: 1.4rem;
  }
  .product-rich__material--title {
    margin-top: 5.3333333333vw;
  }
  .product-rich__material--title h3 {
    font-size: 2.8rem;
  }
  .product-rich__material--title p {
    margin: 3.6vw 0;
    line-height: 1.77;
  }
  .product-rich__material--txt {
    font-size: 1.3rem;
    margin: 3.6vw 0 13.3333333333vw;
  }
  .product-rich__material dl dt {
    margin: -2.6666666667vw 0 2.6666666667vw;
    font-size: 2rem;
  }
  .product-rich__material dl dd {
    margin: 0 0 13.3333333333vw;
    font-size: 1.4rem;
  }
  .product-rich__inr {
    padding: 0 15px;
  }
  .product-rich.on_bg .product-rich__bg {
    padding-top: 50px;
  }
  .product-rich.on_bg .product-rich__bg:before {
    background: url(../img/skin/frame01_sp.png) no-repeat center top/100%;
  }
  .product-rich.on_bg .product-rich__bg:after {
    background: url(../img/skin/frame01_sp.png) no-repeat center top/100%;
  }
  .product-slide {
    box-shadow: 1px 1px 15px #dbdcde;
    margin: 0 3% 60px;
  }
  .product-slide h3 {
    font-size: 1.8rem;
  }
  .product-slide ul {
    margin: 0;
    background: #fff;
    padding-bottom: 5vh;
  }
  .product-slide ul li {
    float: none;
    width: 100%;
  }
  .product-slide .slick-slide {
    margin: 0;
  }
  .product-slide .slick-dots li {
    display: inline-block;
    margin: 0 10px;
    position: relative;
    width: auto;
    padding: 0;
    background: none;
    height: auto;
  }
  .product-slide .slick-dots li button {
    background: none;
    border: none;
    cursor: pointer;
    outline: none;
    background: #fff;
    border: 1px solid #e5004a;
    font-size: 0;
    width: 14px;
    height: 14px;
    border-radius: 50%;
  }
  .product-slide .slick-dots .slick-active button {
    background: #e5004a;
    width: 20px;
    height: 20px;
  }
  .product-slide .SlideInfo {
    display: flex;
    align-items: center;
    margin: 0 0 20px;
  }
  .product-slide .SlideInfo__img {
    width: 35%;
  }
  .product-slide .SlideInfo__Text {
    padding-left: 15px;
    width: 65%;
    box-sizing: border-box;
    text-align: left;
  }
  .product-slide .SlideInfo__Text span {
    display: block;
    font-size: 4vw;
  }
  .type_sp .type__in h4:after {
    width: 50px;
    margin: 0 0 0 -25px;
  }
  .product-howto ul.type li h4 {
    font-size: 38px;
    padding: 60px 0 15px;
  }
  .product-howto ul.type li h4:after {
    width: 50px;
    margin: 0 0 0 -25px;
  }
  .product-wave {
    margin: 0;
    padding: 30px 0 15px;
  }
  .product-wave:before {
    height: 30px;
    background-size: cover;
    top: -29px;
  }
  .product-kv__leftbox {
    width: 100%;
  }
  .product-kv__leftbox p {
    font-size: 1.5rem;
  }
  .product-kv__rightbox {
    max-width: 100%;
    width: 100%;
    padding-left: 0;
    text-align: center;
  }
  .product-kv__rightbox--ttl {
    font-size: 2.3rem;
  }
  .product-kv__rightbox--ttl.origin {
    font-size: 2.3rem;
  }
  .product-kv__rightbox--txt {
    font-size: 1.5rem;
  }
  .product-kv__rightbox--txt span {
    font-size: 1.8rem;
  }
  .product-kv__leftbox2 {
    width: 100%;
  }
  .product-kv__leftbox2 p {
    font-size: 1.6rem;
  }
  .product-kv__rightbox2 {
    text-align: center;
    width: 100%;
    padding-left: 0;
  }
  .product-index-leed {
    font-size: 1.5rem;
  }
  .product-index-list {
    display: block;
  }
  .product-index-list li {
    width: 100%;
    margin-bottom: 60px;
    padding: 0;
  }
  .product-index-list a h3 {
    font-size: 1.3rem;
  }
  .product-index-list a h3 span {
    font-size: 2.6rem;
  }
  .product-index-list a p {
    font-size: 1.4rem;
  }
  .product-crl2 li, .product-crl3.crl3-small li, .product-crl3 li {
    width: 100%;
    margin: 20px auto 50px;
  }
  .product-crl2 li p, .product-crl3.crl3-small li p, .product-crl3 li p {
    font-size: 2.3rem;
  }
  .product-crl2 li:nth-child(1), .product-crl3 li:nth-child(1), .product-crl2 li:nth-child(3), .product-crl3 li:nth-child(3), .product-crl2 li:nth-child(4), .product-crl3 li:nth-child(4), .product-crl2 li:nth-child(5), .product-crl3 li:nth-child(5), .product-crl2 li:nth-child(6), .product-crl3 li:nth-child(6), .product-crl2 li:nth-child(8), .product-crl3 li:nth-child(8), .product-crl2 li:nth-child(7), .product-crl3 li:nth-child(7), .product-crl2 li:nth-child(9), .product-crl3 li:nth-child(9), .product-crl2 li:nth-child(11), .product-crl3 li:nth-child(11), .product-crl2 li:nth-child(10), .product-crl3 li:nth-child(10), .product-crl2 li:nth-child(12), .product-crl3 li:nth-child(12), .product-crl2 li:nth-child(14), .product-crl3 li:nth-child(14), .product-crl2 li:nth-child(13), .product-crl3 li:nth-child(13), .product-crl2 li:nth-child(15), .product-crl3 li:nth-child(15), .product-crl2 li:nth-child(17), .product-crl3 li:nth-child(17), .product-crl2 li:nth-child(16), .product-crl3 li:nth-child(16), .product-crl2 li:nth-child(18), .product-crl3 li:nth-child(18), .product-crl2 li:nth-child(20), .product-crl3 li:nth-child(20), .product-crl2 li:nth-child(19), .product-crl3 li:nth-child(19), .product-crl2 li:nth-child(21), .product-crl3 li:nth-child(21), .product-crl2 li:nth-child(23), .product-crl3 li:nth-child(23) {
    transition-delay: 0s;
  }
  .product-crl2 h2 span:first-child, .product-crl3 h2 span:first-child {
    font-size: 2rem;
  }
  .product-crl2__Win, .product-crl3.crl3-small__Win, .product-crl3__Win {
    width: 100%;
  }
  .product-crl2__Win02, .product-crl3.crl3-small__Win02, .product-crl3__Win02 {
    width: 40%;
  }
  .product-crl2__Win03, .product-crl3.crl3-small__Win03, .product-crl3__Win03 {
    width: 60%;
  }
  .product-crl2__Win04, .product-crl3.crl3-small__Win04, .product-crl3__Win04 {
    width: 80%;
  }
  .product-crl2__Win05, .product-crl3.crl3-small__Win05, .product-crl3__Win05 {
    width: 90%;
  }
  .product-crl2 .produc-sab-title, .product-crl3 .produc-sab-title {
    font-size: 1.5rem;
  }
  .product-crl2__pricebody, .product-crl3.crl3-small__smalltxt, .product-crl3.crl3-small__pricebody, .product-crl3__smalltxt, .product-crl3__pricebody {
    font-size: 1.3rem !important;
  }
  .flex_baseline p {
    font-size: 1.4rem;
  }
  .product-crl3.crl3-small li p {
    font-size: 1.5rem;
  }
  .product-crl3.crl3-small__pricebody {
    font-size: 1.3rem;
  }
  .product-detail {
    padding: 0 0 80px;
    position: relative;
    z-index: 0;
    margin-top: -70px;
    padding-top: 70px;
  }
  .product-detail__close {
    display: none;
  }
  .product-detail__inr h3 {
    padding: 0 0 0;
    font-size: 2.3rem;
  }
  .product-detail__inr h4 {
    padding: 30px 0 0;
    background-position: 0 4px;
    font-size: 2.2rem;
  }
  .product-detail__inr h5 {
    font-size: 2.3rem;
  }
  .product-detail__inr--leadtxt {
    margin: 0 0 15px;
    padding: 5px 20px;
    font-size: 1.4rem !important;
  }
  .product-detail__inr--con01 {
    padding: 0 0 10px;
  }
  .product-detail__inr--con01 p {
    font-size: 1.3rem !important;
  }
  .product-detail__inr--con01 img {
    width: 23px;
  }
  .product-detail__inr--bulk {
    width: 30%;
  }
  .product-detail__inr--bulk02 {
    width: 80%;
  }
  .product-detail__inr--color {
    width: 100%;
  }
  .product-detail__inr--color .color-title span {
    font-size: 2.6rem;
  }
  .product-detail__inr--color .color-naming {
    width: 70%;
  }
  .product-detail__inr--color ul li {
    width: 33.3333%;
  }
  .product-detail__inr--color ul li span {
    font-size: 1.3rem;
  }
  .product-detail__inr--color ul li p {
    font-size: 1rem;
  }
  .product-detail__inr--list {
    width: 90%;
    font-size: 1.4rem;
  }
  .product-detail__inr--link a {
    max-width: 300px;
    margin: 25px auto 0;
  }
  .product-detail__inr--listbox ul {
    display: block;
  }
  .product-detail__inr--listbox ul li {
    width: 95%;
    margin: 0 auto 15px;
  }
  .product-detail__inr--listbox ul li div {
    width: 90%;
    font-size: 1.4rem;
  }
  .product-detail__inr--listborder {
    width: 90%;
    padding: 15px 20px;
    font-size: 1.5rem;
  }
  .product-detail__inr--inimg {
    width: 90%;
    font-size: 1.3rem !important;
  }
  .product-detail__inr--makeuptool p {
    font-size: 1.7rem;
  }
  .product-detail02 {
    padding: 0 0 80px;
    position: relative;
    z-index: 0;
  }
  .product-detail02__Close {
    display: none;
  }
  .product-component__Close {
    width: 45px;
    height: 44px;
    display: block;
    border-radius: 50px;
    position: fixed;
    top: 5px;
    right: 5px;
    z-index: 1000;
    cursor: pointer;
  }
  .product-component__in {
    margin: 0;
    padding: 20px 20px 80px;
    height: 100vh;
    background: #fff;
    max-width: 100%;
    width: 100%;
    overflow-y: scroll;
    position: absolute;
    top: 0;
    right: 0;
  }
  .product-component__in h3 {
    font-size: 2.6rem;
  }
  .product-component__in ul {
    padding-bottom: 60px;
  }
  .product-component__inimg--imgC {
    top: 10px;
    left: 0;
    transform: translate(0);
  }
  .product-component__inimg--imgbg {
    padding: 20px;
  }
  .product-detail-large {
    margin: 0;
    padding: 30px 0 60px;
  }
  .product-detail-large:before {
    height: 30px;
    background-size: cover;
    top: -29px;
  }
  .product-detail-large h2 {
    font-size: 2.6rem;
  }
  .product-detail-large ul {
    display: block;
  }
  .product-detail-large ul li {
    width: 100%;
    margin: 0 0 20px;
  }
  .product-detail-large ul li h3 {
    padding: 20px 20px 20px 0;
    font-size: 2.6rem;
  }
  .skincare2022_lp_firstImg {
    width: 80%;
  }
  .skincare2022_lp_productImg {
    width: 40%;
  }
  .c-instaAnnounce {
    width: 94%;
    margin: 0px auto 50px;
  }
  .c-instaAnnounce__intext dt {
    font-size: 16px;
  }
  .c-instaAnnounce__intext dd {
    padding: 5% 4.5%;
    margin-top: 5%;
  }
  .c-instaAnnounce__intext--top dt {
    font-size: 3.5vw;
  }
  .c-instaAnnounce__intext--top dd p {
    font-size: 3vw;
  }
}

@media screen and (max-width: 950px){
  .CommonContact {
    display: block;
  }
  .CommonContact li {
    background: #f6fafc;
    margin-bottom: 20px;
    margin-right: 0;
    width: 100%;
  }
  .CommonContact li:last-child {
    margin: 0 0 0 0;
    width: 100%;
  }
}

@media screen and (min-width: 767px){
  .delay05 {
    transition-delay: 0.5s !important;
  }
  .delay10 {
    transition-delay: 1s !important;
  }
  .delay15 {
    transition-delay: 1.5s !important;
  }
  .delay20 {
    transition-delay: 2s;
  }
  .delay25 {
    transition-delay: 2.5s;
  }
  .delay30 {
    transition-delay: 3s;
  }
  .delay35 {
    transition-delay: 3.5s;
  }
  .delay40 {
    transition-delay: 4s;
  }
  .delay45 {
    transition-delay: 4.5s;
  }
  .delay50 {
    transition-delay: 5s;
  }
}

@media screen and (min-width: 769px){
  .company-article h3 {
    font-size: 19px;
  }
  .company-article__philosophy--point {
    padding: 10px;
  }
}

@media screen and (max-width: 768px) and (max-width: 768px){
  .product-rich__intro h2 {
    font-size: 2.4rem;
  }
}