/* 全体の設定 */
body{
background-color: #fcf9ed;
}
.fs-body-top{
width:1200px;
margin:0 auto;
}
.fs-l-page{
width:1200px;
margin:0 auto;
background-color: #ffffff;
}
/* h2タグの装飾 */
h2.jabara{
font-weight: bold;
font-size: 1.6em;
border-bottom: solid 1px #FFA500;
margin-top: 50px;
}

/* 商品一覧のお気に入りボタンの非表示 */
.fs-c-button--addToWishList--icon.fs-c-button--particular {
display: none;
}

/* ページ見出しの装飾 */
.fs-c-heading--page{
font-weight: bold;
width: 100%;
background-color: #fcf9ed;
background-image:
repeating-linear-gradient(-45deg,
#ffffff, #ffffff 3px,
transparent 0, transparent 6px);
border-bottom: 1px solid #8b4513;
border-top: 1px solid #8b4513;
}

/* ヘッダー下お知らせ部分の装飾 */
p.oshirase{
text-align: center;
font-size: 18px;
}

/* ログインログアウトのボタン装飾 */
.fs-p-drawer__loginLogout__logout{
height: 25px;
border:none;
}
 .fs-p-drawer__loginLogout__login{
height: 25px;
border:none;
}

/* フリーページの高さ調整 */
#area_freepage{
min-height: 1600px;
}

/* トップページおすすめ商品一覧の高さ（上部コンテンツとの）調整 */
.recomend{
margin-top: 3em;
}

/* トップページおすすめ商品一覧のボックス装飾 */
.recomend_item_top{
border: solid 1px gray;
}

/* トップページバナー（コラム）の設定 */
.fs-pt-column__item{
padding:0;
margin: 1em 0;
}

/* トップページお悩み別紹介の見出し設定 */
.onayami_wrap{
margin-top: 2em;
}

/* トップページお悩み別紹介の症状部分の文章設定 */
.onayami_syoujyou{
font-size: 1.6rem;
font-weight: bold;
padding: .25em 0 .5em .75em;
border-bottom: solid 1px #e99311;
border-left: solid 6px #e99311;
margin: 1.0em 0;
}

/* トップページお悩み別紹介の子設定 */
ul.onayami{
list-style: none;
font-size: 18px;
font-weight: bold;
padding: 10px;
}
li.onayami{
margin: 4px;
display: inline-block;
list-style: none;
}
li.onayami a{
color: #000;
}

/* トップページお悩み別紹介のボタン設定 */
.btn-square-shadow {
display: inline-block;
padding: 0.5em 1em;
text-decoration: none;
background: #fcf9ed;
color: #000;
border-bottom: solid 4px #d2b48c;
border-radius: 3px;
}

/* ボタンを押したとき */
.btn-square-shadow:active {
-webkit-transform: translateY(4px);
transform: translateY(4px);/*下に動く*/
box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);/*影を小さく*/
border-bottom: none;
}


/* ヘッダーロゴ画像調整 */
.fs-l-header__utility{
width: 1200px;
padding: 0;
margin:0;
grid-column: 1;
}
.fs-p-logo{
padding: 0;
margin: auto;
}
.fs-l-header__logo{
margin: auto;
}
.fs-l-header__contents{
width: 1200px;
height: 150px;
padding: 0;
}

/* ヘッダー下部トップ送料お支払いなどの文字とリンクカラーの設定 */
ul.header_list_navi{
list-style: none;
width: 100%;
margin: 10px;
text-align: center;
}
li.fs-pt-list__item{
text-align: center;
width: auto;
padding: 0 15px 0 15px;
display: inline-block;
font-size: 20px;
border-right:1px solid #ccc;
vertical-align: top;
}
.header_list_navi li a{
text-decoration: none;
color: #000;
}

/* サイドナビ横幅、文字の大きさ、余白 */
#subnav{
display: inline-block;
vertical-align:top;
margin: 10px 5px 0px 10px;
width:190px;
}

/* サイドナビ会員ログインボックスの装飾指定 */
#loginbox_wrap{
margin-bottom: 18px;
}

#loginbox_wrap img{
vertical-align: bottom;
}

.loginbox{
margin: 0em;
padding: 1em;
color: #d14d58;
background: #ffdac5;

}
.login_logoutbox{
border: solid 1px #ccc;
padding: 5px;
font-size: 20px;
background-color: #ffffff;
text-align: center;
}

.login_logoutbox a{
color: #000;
}

.shinki{
font-size:14px;
text-align: center;
}

/* サイドナビ検索ボックスの装飾指定 */
#searchbox{
padding: 0.5em 1em;
margin: 2em 0;
color: #000000;
background: #ffdac5;
border-top: solid 10px #d14d58;
font-size: 12px;
}
.fs-p-searchForm__input{
width: calc(100% - 4em);
}

/* トップページなどコンテンツエリア横幅、文字サイズ指定、余白 */
.fs-l-main{
padding: 0px;
width: 1200px;
font-size: 16px;
margin: 10px auto;
}
/* 各ページなどコンテンツエリア横幅、文字サイズ指定、余白 */
.fs-l-pageMain{
display: inline-block;
max-width: 980px;
font-size: 16px;
margin : 10px auto;
}

/* 新着情報の装飾 */
ul.news{
margin: 0px 0px 30px 0px;
padding: 0.5em 0.5em 1em 1em;
border-bottom: solid 1px #ffdac5;
border-right: solid 1px #ffdac5;
border-left:solid 1px #ffdac5;
list-style-type: none;
}
li.news{
line-height: 1.5;
padding: 0.5em 0;
border-bottom: dotted 2px #bdb76b;
}

/* フッターコピーライトの文字の大きさと背景色、文字色 */
.fs-p-footerCopyright__text{
font-size: 14px;
color: #fff;
background-color: #d14d58;
text-align: center;
}
.fs-p-footerCopyright{
padding: 0px;
}

/* フッター支払い方法などのボックス設定 */
.box01{
padding: 0.5em 1em;
margin: 2em 0;
color: #000;
background: white;
border-top: solid 5px #d14d58;
box-shadow: 0 3px 5px rgba(0, 0, 0, 0.22);
font-size: 16px;
}

.footer_box1{
display: inline-block;
width: 50%;
padding: 5px;
vertical-align: top;
}

/* フッター個人情報などのリストの設定 */
.fs-p-footerUtilityMenu__list{
list-style: none;
justify-content: center; 
}
.fs-p-footerUtilityMenu__list li{
display: inline-block;
font-size: 14px;
padding: 5px;
}
.fs-l-footer__utility .fs-p-footerUtilityMenu{
margin-top: 0px;
}

/* フッター背景色設定 */
.fs-l-footer{
background-color: #ffffff;
}

/* フッター下線設定 */
hr.footl_ine{
border:none;
border-top: 1px dashed #8c8b8b;
height:1px;
color:#FFFFFF;
margin-left: 0;
}

/* お買い物ガイドなどのテキスト背景色設定 */
.fs-c-documentArticle__heading{
background-color: #4c3e3d;
}

/* 特定商取引ページ店舗情報などの見出しの背景 */
.fs-c-documentArticle__heading{
background-color: #d14d58;
}

/* 商品ページよくある質問のリスト設定 */
ul.qa{
padding: 0;
position: relative;
}
li.qa{
color: #343634;
border-left: solid 6px #98b18f;/*左側の線*/
background: #d0e6c8;/*背景色*/
margin-bottom: 3px;/*下のバーとの余白*/
line-height: 1.5;
padding: 0.5em;
list-style-type: none!important;/*ポチ消す*/
font-weight: bold;
width:90%;
text-align: left;
}
li.answer{
width:90%;
list-style-type: none!important;
margin: 10px;
text-align: left;
}

/* 商品ページ誘導バナーの設定 */
ul.inducement{
list-style-type: none;
padding-left: 0;
text-align: center;
}
li.inducement{
display: inline-block;
}

/* 成分表のテーブル設定 */
table.seibun{
border-collapse: collapse;
border: solid 2px #d9d9d9;
width: 100%;
font-size: 18px;
}
table.seibun tr *:nth-child(1){
background: #fcf9ed;
width: 30%;
font-weight: bold;
}
table.seibun td{
padding: 10px;
vertical-align: top;
border: solid 1px #d9d9d9;
}
table.seibun th{
border: solid 1px #d9d9d9;
}


/* 会社概要ページの設定 */
.prof{
margin-bottom:10em;
}
.table1 td{
border: solid 1px;
}
.table1 {
border-collapse: collapse;
border-spacing: 20px;
width: 980px;
}
.table1 th{
text-align: left;
background-color: #ead7c0;
padding: 10px;
border: solid 1px;
}

/* よくある質問ページの見出し設定 */
h2.faq_head{
text-align: center;
font-weight: bold;
color: #fff;
background-color: #5A7A55;
padding: 20px;
margin: 0 auto auto auto;
}

/* お客様の声ページ設定 */
.voice{
width: 100%
}
.voice dt{
font-size: 1.4rem;
font-weight: bold;
}
.img_block{
display: inline-block;
vertical-align: top;
}
.voice_block{
display: inline-block;
width: 75%;
margin: 0 10px 0 30px;
}
hr.voice{
margin-top: 20px;
margin-bottom: 20px;
color: #98b18f;
}
h3.voice{
font-size: 1.6rem;
font-weight: bold;
border-bottom: solid 2px #e99311;
}

/* 商品ページ定期購入バナー設定 */
.teiki_banar{
width: 100%;
text-align: center;
}
.img_teiki_block{
display: inline-block;
}

/* 特定商取引ページのテーブル設定 */
.tokutei_shiharai{
border-collapse: collapse;
text-align: center;
line-height: 1.5;
border: 1px solid #ccc;
width: 100%;
}
.tokutei_shiharai th{
color: #ffffff;
background: #4169e1;
padding: 10px;
font-weight: bold;
border-top: 1px solid #ccc;
border-right: 1px solid #ccc;
border-bottom: 1px solid #ccc;
}
.tokutei_shiharai td{
padding: 10px;
border: 1px solid #ccc;
}

/* ショッピングカート内新聞広告注意の文字設定 */
.cart_text_newspaper{
font-weight: bold;
font-size: 1.2em;
border-bottom: solid 1px #FFA500;
}

/* ショッピングカート内の送料の文字設定 */
.cart_text_takuhai{
font-weight: bold;
font-size: 1.0em;
}

/* 定期購入についてページのテーブル設定 */
table.teiki{
table-layout: fixed;
border-collapse: collapse;
border: solid 1px #b5b5b5;
width: 100%;
}

table.teiki th{
background-color: #d14d58;
border: solid 1px #b5b5b5;
color: white;
}

table.teiki td{
padding: 10px;
border: solid 1px #b5b5b5;
vertical-align: middle;
font-weight: bold;
}

/* パスワード変更しましたの文字サイズ */
.fs-c-panel{
font-size: 2em;
}




/*ログインログアウトの表示切り替え*/
.logout.my-false{
display: none;
}
.login.my-true{
display: none;
}

/*商品ページの文字サイズ設定*/
.product_font_size{
font-size: 24px;
}

/* コピーボタン */
.copy_btn {
  width:80%!important;
  padding: 12px 0;
  margin-left: auto!important;
  margin-right: auto!important;
  color:#ffffff;
  font-weight:bold;
  background:#000000;
  border: solid 2px #000000;
  border-radius: 3px;
  transition: .4s;
  text-align: center;
}
 
.copy_btn:hover {
  background: #ffffff;
  color: #000000;
}
.copy_btn:hover {
	cursor: pointer;
}

/* 梅真珠　愛用者の声 */
table.shinju_voice {
width: 100%;
padding: 10px;
font-weight: bold;
text-align: center;
border-collapse: collapse;
border: dashed 2px black;
}

/* よくある質問のページのサブタイトルボタン*/
.btn--faq,
a.btn--faq {
  color: #000;
  background-color: #f5deb3;
  padding: 10px;
}
.btn--faq:hover,
a.btn--faq:hover {
  color: #000;
  background: #f5deb3;
}

/* よくある質問のページのサブタイトル見出し*/
h2.faq_subhead {
  position: relative;
  padding: 0.6em;
  line-height: normal;
  background: #f5deb3;
}

h2.faq_subhead:after {
  position: absolute;
  content: '';
  top: 100%;
  left: 30px;
  border: 15px solid transparent;
  border-top: 15px solid #f5deb3;
  width: 0;
  height: 0;
}

/* アトピタンLP背景*/
.atopitan_backround {
  background-color: white;
  max-width: 740px;
}

/* 通常カートボタン透かし*/
input[name="submit"]:hover { opacity:0.7; filter:alpha(opacity=70); }

/* 定期カートボタン透かし*/
input[name="subscribe"]:hover { opacity:0.7; filter:alpha(opacity=70); }

/* 元気ノ国CP見出し*/
.cp_head{
  font-size: 3em;
  font-weight: bold;
  text-shadow:2px 2px 0 #fff;
  padding: 1rem;
  color: #b22222;
  background-image: -webkit-linear-gradient(315deg, #ffffe0 0%, #ffce08 40%, #ffffe0 60%, #ffce08 100%);
  background-image: linear-gradient(135deg, #ffffe0 0%, #ffce08 40%, #ffffe0 60%, #ffce08 100%);
}

/* 元気ノ国サブCP見出し*/
.cp_subhead{
  padding: 1rem 2rem;
  font-size: 2em;
  font-weight: bold;
  border-top: 3px dotted #ffce08;
  background-color: #fffacd;
}

/* 元気ノ国CP期間*/
.cp_period{
  width: 200px;
  background-color: #fffacd;
  border-radius: 100vh;
  color: #000;
  padding: 10px;
  text-align:justify;
}

/* 元気ノ国CPフォント*/
.cp_font{
  font-size: 1.8rem;
}

/* 元気ノ国CP下線*/
.cp_under {
  width: 500px;
  font-weight: bold;
  color: #fa8072;
  font-size: 2.5rem;
  background: linear-gradient(transparent 70%, #fff0f5 50%);
}

.cp_under:link {
  color: #fa8072;
}

.cp_under:visited {
  color: #fa8072;
}

/* 元気ノ国CP吹き出し*/
.cp_balloon-left {
  position: relative;
  display: inline-block;
  margin: 1.5em 0 1.5em 15px;
  padding: 25px 5px;
  width: 160px;
  height: 100px;
  font-size: 15px;
  font-weight: bold;
  color: #fff;
  background: #FF0033;
  border-radius: 70%;
  box-sizing: border-box;
  text-align: center;
}

.cp_balloon-left:before {
  content: "";
  position: absolute;
  top: 50%;
  left: -23px;
  margin-top: -15px;
  border: 15px solid transparent;
  border-right: 15px solid #FF0033;
  z-index: 0;
}

/* 元気ノ国CP枠線*/
.cp_box {
    padding: 0.5em 1em;
    margin: 2em 0;
    border: solid 3px #000000;
}
.cp_box p {
    margin: 0; 
    padding: 0;
}

/* 定期購入する*/
.btn-teiki {
　width: 500px;
  position: relative;
  display: inline-block;
  padding: 0.25em 0.5em;
  text-decoration: none;
  font-size: 2em;
  color: #fff;
  background: #1ba55a;/*背景色*/
  border-bottom: solid 2px #1ba55a;/*少し濃い目の色に*/
  border-radius: 4px;/*角の丸み*/
  box-shadow: inset 0 2px 0 rgba(255,255,255,0.2), 0 2px 2px rgba(0, 0, 0, 0.19);
  font-weight: bold;
}

.btn-teiki:active {
  color: #fff;
  border-bottom: solid 2px #ff8c00;
  box-shadow: 0 0 2px rgba(0, 0, 0, 0.30);
}

.btn-teiki:link {
  color: #fff;
}

.btn-teiki:visited {
  color: #fff;
}

/* ヘッダー下のお知らせアコーディオンメニュー*/
input[name=navinput]{
  display: none;
}
.listnav01:hover,
.listnav02:hover{
  color: #999;
}
.listnav01:after,
.listnav02:after{
  content: "";
}
#nav01:checked ~ .title .listnav01:after,
#nav02:checked ~ .title .listnav02:after{
  content: "↑";
}
.box{
  opacity: 0;
  height: 0;
  overflow: hidden;
  transition: 0.5s;
  padding: 0 10px;
}
#nav01:checked ~ .box01,
#nav02:checked ~ .box02{
  height: auto;
  opacity: 1;
  background: #eee;
  padding: 10px;
}

.ato-fs-l-footer__utility {
    display: flex;
    flex-direction: column-reverse;
    margin: 24px auto 0;
    max-width: 740px;
}

.fs-c-purchaseHere__message {
    font-size: 1.6rem;
    font-weight: bold;
}

.fs-c-button--primary {
    background: #CF4B56;
    border: 1px solid #CF4B56;
    color: #ffffff;
    cursor: pointer;
    display: inline-block;
    font-size: 1.4rem;
    line-height: 1;
    text-decoration: none;
    text-align: center;
    padding: 0.8em 1.6em 0.6em;
    box-shadow: 0 0 2px #b2b2b2;
    min-width: 240px;
    font-weight:bold;
}

.fs-c-button--secondary{
    background: #2BA833;
    border: 1px solid #2BA833;
    color: #ffffff;
    cursor: pointer;
    display: inline-block;
    font-size: 1.4rem;
    line-height: 1;
    text-decoration: none;
    text-align: center;
    padding: 0.8em 1.6em 0.6em;
    box-shadow: 0 0 2px #b2b2b2;
    min-width: 240px;
    font-weight:bold;
}


/* 〇〇円で送料無料を削除*/
.fs-c-cartDiscountInfo.fs-c-cartDiscountInfo--postage {
    display: none;
}


/* you tube*/
.video{
width:100%;
padding-bottom: 56.25%;
height:0px;
position: relative;
}
.video iframe{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}

/* ボーダーライン無し*/
td.noborder {
  border: 0px;
}

/* 注意アナウンス*/
.frame {
 width: 80%;
 margin: 30px auto 20px;
 padding: 20px 20px 0;
 border: 3px solid #aaa;
 position: relative;
 border-radius: 3px;
 background-color: #fff;
}
.frame-title {
 position: absolute;
 top: -13px;
 left: 20px;
 padding: 5px;
 background-color: #fff;
}
.frame-title .fa {
 margin-right: 5px;
}
.caution {
 background-color: #ff4500;
 border: 2px solid #ff4500;
 color: #fff;
 border-radius: 3px;
}
.frame-red {
 border-color: #ff4500;
}

/* 会員特典*/
h2.bene {
  position: relative;
  padding-left: 4em;
}

h2 span.bene {
  position: absolute;
  top: 0;
  left: 0;
  padding: 0.3rem 2rem;
  color: #e3f5d8;
  background: #22ac38;
  font-weight: bold;
}

h2 span.bene:after {
  position: absolute;
  top: calc(50% - 7px);
  right: -11px;
  width: 0;
  height: 0;
  content: '';
  border-width: 7px 0 7px 12px;
  border-style: solid;
  font-weight: bold;
  border-color: transparent transparent transparent #22ac38;
}

.ribbon16-wrapper {  
  display: block;
  position: relative;
  margin: 15px auto;
  padding: 10px 0;
  width: 300px;
  background: #f1f1f1;
  box-sizing: border-box;
  }

.ribbon16 {  
  display: inline-block;
  position: absolute;
  top: -6px;
  right: 10px;
  margin: 0;
  padding: 10px 0 7px;
  z-index: 2;
  width: 40px;
  text-align: center;
  color: white;
  font-size: 13px;
  background: #fa8383;
  border-radius: 2px 0 0 0;
  }

.ribbon16:before {
  position: absolute;
  content: '';
  top: 0;
  right: -5px;
  border: none;
  border-bottom: solid 6px #d07676;
  border-right: solid 5px transparent;
}

.ribbon16:after {
  content: '';
  position: absolute;
  left: 0;
  top: 100%;
  height: 0;
  width: 0;
  border-left: 20px solid transparent;
  border-right: 20px solid transparent;
  border-top: 10px solid #fa8383;
}

/* 強調*/
strong {
	background-image: linear-gradient( transparent 60%, #e6d300 60%, #e6d300 100%);
}

/* 打ち消し線*/
.del {
position: relative;

}

.del:after {
content: '';
display: block;
width: 100%;
height: 2px;
margin-top: -2px;
border-top: solid 1px #800000;
border-bottom: solid 1px #800000;
position: absolute;
left: 0;
top: 50%;
}

/* 二重価格*/
.wprice{
  font-size: 2em;
  font-weight: bold;
  text-shadow:2px 2px 0 #fff;
  padding: 1rem;
  color: #b22222;
}

/*注文手続き・お申込み手続き見出し*/
.fs-c-checkout-preview__title {
    font-size: 1.2em;
    font-weight: bold;
}

/*返品特約位置変更*/
@media screen and (min-width: 960px) {
  [class^="fs-body-checkout"] .fs-l-checkout {
    display: block;
  }
  [class^="fs-body-checkout"] .fs-l-checkout__mainColumn {
    max-width: 100%;
    padding-right: 0;
  }
  [class^="fs-body-checkout"] .fs-l-checkout__sideColumn {
    margin-top: 24px;
  }


/* you tube　高家追加分*/
.youtube {
  width: 100%;
  aspect-ratio: 16 / 9;
}
.youtube iframe {
  width: 100%;
  height: 100%;
}

/*会員情報入力画面の必須マーク「＊」を「必須」のテキスト表示に変更*/
.fs-c-requiredMark{
    overflow: visible;
    text-indent: 0;
    width:auto;
}
.fs-c-requiredMark::before{
    display: none;
}

/*Q&Aの見出し*/
h2.qa {
  position: relative;
  padding: 1.5rem 2rem;
  border: 3px solid #d8d8d8;
  border-radius: 10px;
  background: #f9f9f9;
}

h2 qa:before {
  position: absolute;
  bottom: -14px;
  left: 1em;
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 12px 0 12px;
  border-style: solid;
  border-color: #d8d8d8 transparent transparent transparent;
}

h2 qa:after {
  position: absolute;
  bottom: -10px;
  left: 1em;
  width: 0;
  height: 0;
  content: '';
  border-width: 14px 12px 0 12px;
  border-style: solid;
  border-color: #f9f9f9 transparent transparent transparent;
}


/* ヘッダー下部SNSアイコンの横並び設定 */
}
ul.sns-ft{
 display: flex;
}
li.sns-ft{
  list-style: none;
  margin-left: 20px;
}


/* 継続中の定期・頒布会販売のお届け先情報も変更するの文字装飾 */
.fs-body-my-account-settings-edit .fs-c-additionalCheckField .fs-c-checkbox__label {
padding: 10px 10px;
background-color: #CEF6F5;
}

/* 矢印---------------------------------------------- */

.arrowbtn a {
	--arrow-color:#333; /* 矢印の色を設定 */
	position: relative; /* 疑似要素を位置指定するための基準 */
	padding: 0 2.5em .5em .5em; /* 内側の余白（右に矢印部分を空ける） */
	color: var(--arrow-color); /* 文字色を矢印の色と統一 */
	text-decoration: none; /* 下線を非表示 */
}

.arrowbtn a::before {
	border-bottom: 1px solid var(--arrow-color); /* 下線としての矢印部分 */
	border-right: 1px solid var(--arrow-color); /* 右線としての矢印部分 */
	bottom: 0; /* 矢印をボタン下部に配置 */
	content: ''; /* 疑似要素でコンテンツを空に設定 */
	height: 12px; /* 矢印の高さ */
	position: absolute; /* 親要素から相対的に配置 */
	left: 0; /* 矢印の位置を左端に */
	transform: skewX(50deg); /* 矢印の形状を傾けてデザイン */
	width: 100%; /* ボタン全体の幅に矢印を合わせる */
	transition: all .3s; /* なめらかな動き（ホバー時） */
}

/* マウスオーバー時の動き */
.arrowbtn a:hover::before {
	left: 10%; /* ホバー時、矢印が右に10%ずれる */
}

/* CTAボタン（橙・緑） */
a.green-cta,
a.orange-cta {
  display: inline-block;
  padding: 0.6em 1.2em;
  padding-left: 2em;
  border-radius: 5px;
  text-decoration: none !important;
  font-size: 1.1em; /* 少し大きめに */
  font-weight: bold; /* 太字に変更 */
  white-space: nowrap;
  line-height: 1.2;
  position: relative;
  transition: background-color 0.2s ease;
  cursor: pointer;
  color: #fff !important;
}

a.green-cta {
  background-color: #388e3c;
}

a.orange-cta {
  background-color: #eb6d3a;
}

a.green-cta::before,
a.orange-cta::before {
  content: "▶";
  position: absolute;
  left: 0.7em;
  top: 50%;
  transform: translateY(-50%);
  font-size: 0.8em;
  color: #fff;
}

a.green-cta:hover,
a.green-cta:focus {
  background-color: #0e7a01;
}

a.orange-cta:hover,
a.orange-cta:focus {
  background-color: #e68a00;
}



/* リンク関係 */
a {
text-decoration:none;
}

a:link {
color:#000;
}

a:visited {
color:#000;
}

a:hover {
color:#33CC00;
text-decoration:underline;
}

a:active {
color:#33CC00;
}

/* Amazon Payの定期・頒布会申込は会員登録内容変更からのお届け先情報変更不可の説明追記 */
[for="fs_input_syncDestinationInfo"] > .fs-c-checkbox__labelText::after{
content: "\A（Amazon Payでお支払いの場合、変更されない場合がございます。定期申込履歴をご確認いただき、変更されていない場合は別途ご連絡ください。）";
white-space: pre-wrap;
}

/* 元気ノ国夏号2026通常---------------------------------------------- */

@charset "UTF-8";

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ベースリセット
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo {
  width: 100%;
  max-width: 980px;
  margin: 0 auto;
  padding: 0;
  line-height: 1;
}

/* sr-only — スクリーンリーダー・見出し階層補完用 */
.genki2026summer-tsujo .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

/* 見出し・本文・定義リストの margin/padding リセット */
.genki2026summer-tsujo h1,
.genki2026summer-tsujo h2,
.genki2026summer-tsujo h3,
.genki2026summer-tsujo h4,
.genki2026summer-tsujo h5,
.genki2026summer-tsujo p,
.genki2026summer-tsujo dl,
.genki2026summer-tsujo dt,
.genki2026summer-tsujo dd {
  margin: 0;
  padding: 0;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   MakeShop システムCSS リセット
   上位 CSS（fs_original.css 等）の干渉を打ち消す
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo strong {
  background-image: none;
}

.genki2026summer-tsujo a:hover {
  color: inherit !important;
  text-decoration: none !important;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ブロック要素・画像・リンク
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo section,
.genki2026summer-tsujo picture,
.genki2026summer-tsujo img,
.genki2026summer-tsujo a {
  display: block;
}

.genki2026summer-tsujo__img {
  display: block;
  margin-top: 25px;
}

/* camp1-photo・camp2-10off：原寸センタリング */
.genki2026summer-tsujo__img img,
.genki2026summer-tsujo__camp2-10off-img img {
  margin: 0 auto;
}

.genki2026summer-tsujo__img3 {
  display: block;
  margin-top: 130px;
  margin-bottom: 0;
}

.genki2026summer-tsujo img {
  max-width: 100%;
  height: auto;
  border: 0;
  vertical-align: top;
}

.genki2026summer-tsujo a {
  color: inherit;
  text-decoration: none;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   camp2 ヘッダー画像（PC/SP両対応）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo__camp2-header {
  display: block;
}

/* SP専用: camp3 overview 1枚目・2枚目、B写真2枚目（PCでは非表示）
   !important 必須: `.genki2026summer-tsujo picture { display:block }` (詳細度0,1,1)
   に負けないようにするため */
.genki2026summer-tsujo__camp3-overview-sp1,
.genki2026summer-tsujo__camp3-overview-sp2,
.genki2026summer-tsujo__camp3-b-sp2 {
  display: none !important;
}

/* camp3 ボトム装飾帯（PC表示、SPでは非表示） */
.genki2026summer-tsujo__camp3-bottom-bg {
  display: block;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   テキストブロック
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo__text {
  width: auto;
  margin-top: 5px;
  margin-bottom: 12px;
  margin-left: 190px;
  margin-right: 120px;
  padding: 0;
  color: #333;
  font-family: 'Meiryo', メイリオ, sans-serif;
}

.genki2026summer-tsujo__headline {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-weight: bold;
  font-size: 25px;
  line-height: 1.5;
  margin-bottom: 6px !important;
  font-feature-settings: "palt";
  text-align: justify;
}

.genki2026summer-tsujo__body {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 8px !important;
  font-feature-settings: "palt";
  text-align: justify;
}

/* ■ 条件テキスト: PC では 1 行に固定 */
.genki2026summer-tsujo__conditions-list--inline {
  display: flex;
  align-items: center;
}
.genki2026summer-tsujo__conditions-list--inline .genki2026summer-tsujo__conditions,
.genki2026summer-tsujo__conditions-list--inline .genki2026summer-tsujo__note {
  margin: 0 !important;
}

.genki2026summer-tsujo__conditions {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 3px !important;
  white-space: nowrap;
}
.genki2026summer-tsujo__conditions::first-letter {
  color: #1EAEDB;
}

.genki2026summer-tsujo__note {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 3px !important;
  font-feature-settings: "palt";
  text-align: justify;
}

/* camp2: body 行送り */
.genki2026summer-tsujo__camp2 .genki2026summer-tsujo__body {
  line-height: 1.6;
  margin-top: 10px;
  margin-bottom: 10px !important;
}

/* coupon-usage テキスト */
.genki2026summer-tsujo__coupon-usage .genki2026summer-tsujo__conditions {
  font-size: 16px;
}
.genki2026summer-tsujo__coupon-usage .genki2026summer-tsujo__body {
  line-height: 1.8;
  margin-bottom: 6px !important;
}
.genki2026summer-tsujo__coupon-usage .genki2026summer-tsujo__conditions-list {
  margin-top: 16px;
}

/* PC/SP 改行制御のデフォルト（PCでは sp-br 非表示） */
.genki2026summer-tsujo .sp-br {
  display: none;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ボタン共通
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo__button {
  position: relative;
  clip-path: inset(0);
  padding: 0;
}

.genki2026summer-tsujo button {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: none;
  cursor: pointer;
}

/* ホバー: 白透明オーバーレイ */
.genki2026summer-tsujo__button::after {
  content: '';
  position: absolute;
  top: -2px;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(255, 255, 255, 0);
  transition: background 0.15s ease;
  pointer-events: none;
}

.genki2026summer-tsujo__button:hover::after,
.genki2026summer-tsujo__button:active::after,
.genki2026summer-tsujo__button:focus-visible::after {
  background: rgba(255, 255, 255, 0.4);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ボタンエリア（背景＋ボタン分離構造）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo__btn-area {
  position: relative;
  line-height: 0;
  overflow: hidden;
}

/* ABC ボタンエリア: btn は通常フロー（position:static、width:100%） */
.genki2026summer-tsujo__btn-area--3a .genki2026summer-tsujo__button,
.genki2026summer-tsujo__btn-area--3b .genki2026summer-tsujo__button,
.genki2026summer-tsujo__btn-area--3c .genki2026summer-tsujo__button {
  position: static;
  transform: none;
  left: auto;
  width: 100%;
  clip-path: none;
}

/* ABC: button の ::after は非表示（btn-area::after でホバー制御） */
.genki2026summer-tsujo__btn-area--3a .genki2026summer-tsujo__button::after,
.genki2026summer-tsujo__btn-area--3b .genki2026summer-tsujo__button::after,
.genki2026summer-tsujo__btn-area--3c .genki2026summer-tsujo__button::after {
  display: none;
}

/* ABC: 背景画像側でホバーマスク（btn-area::after）白透明オーバーレイ */
.genki2026summer-tsujo__btn-area--3a::after,
.genki2026summer-tsujo__btn-area--3b::after,
.genki2026summer-tsujo__btn-area--3c::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 89.7959%; /* 880/980 */
  background: rgba(255, 255, 255, 0);
  transition: background 0.15s ease;
  pointer-events: none;
}
.genki2026summer-tsujo__btn-area--3a:has(.genki2026summer-tsujo__button:hover)::after,
.genki2026summer-tsujo__btn-area--3a:has(.genki2026summer-tsujo__button:active)::after,
.genki2026summer-tsujo__btn-area--3b:has(.genki2026summer-tsujo__button:hover)::after,
.genki2026summer-tsujo__btn-area--3b:has(.genki2026summer-tsujo__button:active)::after,
.genki2026summer-tsujo__btn-area--3c:has(.genki2026summer-tsujo__button:hover)::after,
.genki2026summer-tsujo__btn-area--3c:has(.genki2026summer-tsujo__button:active)::after {
  background: rgba(255, 255, 255, 0.4);
}

/* クーポンボタンのみ絶対配置 */
.genki2026summer-tsujo__btn-area--coupon .genki2026summer-tsujo__button {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 89.7959%; /* 880/980 */
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   コピートースト（クーポンコード）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo__copy-toast {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 3;
  transform: translate(-50%, -50%);
  padding: 10px 22px;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  line-height: 1;
  background: rgba(0, 0, 0, 0.78);
  border-radius: 4px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.16s ease;
}
.genki2026summer-tsujo__copy-toast.is-visible {
  opacity: 1;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   キャンペーン2 固有
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
/* クーポンボタンエリア */
.genki2026summer-tsujo__btn-area--coupon {
  margin: 28px 0 30px;
}

/* クーポン利用ガイド（880px / 980px = 89.7959%） */
.genki2026summer-tsujo__camp2-guide {
  width: 89.7959%; /* 880/980 */
  margin: 10px auto 0;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   キャンペーン4（バナーのみ）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-tsujo__camp4 {
  margin-top: 0;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SP レイアウト (max-width: 767px)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 767px) {
  .genki2026summer-tsujo {
    max-width: 390px;
    width: 100%;
    margin-top: 0;
  }

  /* SPトップ隙間排除: header section を上端ぴったりに */
  .genki2026summer-tsujo__header {
    margin: 0;
    padding: 0;
    font-size: 0;
    line-height: 0;
  }
  .genki2026summer-tsujo__header picture,
  .genki2026summer-tsujo__header img {
    margin: 0;
    padding: 0;
    display: block;
  }

  .genki2026summer-tsujo__img {
    margin-top: -15px;
  }

  .genki2026summer-tsujo__img3 {
    display: block;
    margin-top: 40px;
    margin-bottom: 40px;
  }

  /* camp2ヘッダー：PC/SP両対応のため非表示ルール不要 */

  /* camp3 overview SP1・SP2枚目、B写真SP2枚目：SP時のみ表示 */
  .genki2026summer-tsujo__camp3-overview-sp1,
  .genki2026summer-tsujo__camp3-overview-sp2,
  .genki2026summer-tsujo__camp3-b-sp2 {
    display: block !important;
  }

  /* camp3 ボトム装飾帯：SPでは非表示 */
  .genki2026summer-tsujo__camp3-bottom-bg {
    display: none;
  }

  /* PC改行タグ非表示 */
  .pc-br {
    display: none;
  }
  .genki2026summer-tsujo .sp-br {
    display: inline;
  }

  .genki2026summer-tsujo__text {
    width: auto;
    margin: 8px 32px;
    padding: 0;
    line-height: 1.6;
  }

  .genki2026summer-tsujo__text--camp2 {
    margin-top: 28px;
    margin-bottom: 20px;
    margin-left: 32px;
    margin-right: 32px;
  }

  .genki2026summer-tsujo__headline {
    font-size: 22px;
    line-height: 1.5;
    margin-top: 5px;
  }

  /* SP: __body 行送り */
  .genki2026summer-tsujo__body {
    line-height: 1.8;
    letter-spacing: 0;
    margin-bottom: 6px !important;
  }

  /* SP: __conditions は折り返しを許可 */
  .genki2026summer-tsujo__conditions {
    white-space: normal;
    line-height: 1.5;
    margin-bottom: 2px !important;
  }

  /* SP: __note ツメ */
  .genki2026summer-tsujo__note {
    line-height: 1.5;
    margin-bottom: 6px !important;
  }

  /* SP camp2: body 行間・段落間 */
  .genki2026summer-tsujo__camp2 .genki2026summer-tsujo__body {
    line-height: 1.8;
    margin-top: 8px;
    margin-bottom: 12px !important;
    text-align: left;
  }

  /* SP camp2: note */
  .genki2026summer-tsujo__camp2 .genki2026summer-tsujo__note {
    line-height: 1.5;
    margin-top: 6px;
    margin-bottom: 8px !important;
  }

  /* SP ABC マスク幅 (640/780) */
  .genki2026summer-tsujo__btn-area--3a::after,
  .genki2026summer-tsujo__btn-area--3b::after,
  .genki2026summer-tsujo__btn-area--3c::after {
    width: 82.0513%; /* 640/780 */
  }

  /* SP クーポンボタン幅・位置 */
  .genki2026summer-tsujo__btn-area--coupon .genki2026summer-tsujo__button {
    width: 82.0513%; /* 640/780 */
    left: 7.1795%; /* 28/390 */
    transform: none;
  }

  .genki2026summer-tsujo__coupon-usage .genki2026summer-tsujo__conditions-list {
    margin-top: -6px !important;
  }
  .genki2026summer-tsujo__coupon-usage dd + dt {
    margin-top: 32px;
  }

  .genki2026summer-tsujo__camp2-guide {
    width: 82.0513%;
    margin-left: 7.1795%;
    margin-right: 0;
    margin-top: -5px;
  }

  /* camp4: camp3-bottom-bg の高さ分だけ上に重ねる */
  .genki2026summer-tsujo__camp4 {
    margin-top: -60px;
    position: relative;
    z-index: 1;
  }

  /* SP: ABCボタン・camp4バナー センタリング */
  .genki2026summer-tsujo__btn-area--3a img,
  .genki2026summer-tsujo__btn-area--3b img,
  .genki2026summer-tsujo__btn-area--3c img,
  .genki2026summer-tsujo__camp4 img {
    margin: 0 auto;
  }
}

@media (min-width: 768px) {
  /* camp2テキストは全て基本値 190px に統一（クルクル巻いて等と同じ行頭） */
  .genki2026summer-tsujo__camp2 .genki2026summer-tsujo__text--camp2 {
    margin-top: 20px;
    margin-bottom: 22px;
  }
  .genki2026summer-tsujo__coupon-usage .genki2026summer-tsujo__conditions-list {
    margin-top: 40px;
  }
  .genki2026summer-tsujo__coupon-usage dd + dt {
    margin-top: 30px;
    white-space: nowrap;
  }
}

/* レイアウト調整 */
.genki2026summer-tsujo {
	overflow: hidden;
}

@media (min-width: 768px) {
	.genki2026summer-tsujo__camp1 { margin-bottom: 50px; }
	.genki2026summer-tsujo__camp2-10off-img img {
		width: 880px;
		hight: auto;
	}
	br.sp { display: none; }
}
@media (max-width: 767px) {
	.genki2026summer-tsujo__camp1 {
		margin-bottom: 40px;
	}
	br.sp { display: inline; }
}


/* 元気ノ国夏号2026定期---------------------------------------------- */
@charset "UTF-8";

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ベースリセット
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki {
  width: 100%;
  max-width: 989px;
  margin: 0 auto;
  padding: 0;
  line-height: 1;
}

/* sr-only — スクリーンリーダー・見出し階層補完用 */
.genki2026summer-teiki .sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

/* 見出し・本文・定義リストの margin/padding リセット */
.genki2026summer-teiki h1,
.genki2026summer-teiki h2,
.genki2026summer-teiki h3,
.genki2026summer-teiki h4,
.genki2026summer-teiki h5,
.genki2026summer-teiki p,
.genki2026summer-teiki dl,
.genki2026summer-teiki dt,
.genki2026summer-teiki dd {
  margin: 0;
  padding: 0;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   MakeShop システムCSS リセット【追記3】
   上位 CSS（fs_original.css 等）の干渉を打ち消す
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki strong {
  background-image: none;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ブロック要素・画像・リンク
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki section,
.genki2026summer-teiki picture,
.genki2026summer-teiki img,
.genki2026summer-teiki a {
  display: block;
}

.genki2026summer-teiki__img {
  display: block;
  margin-top: 25px;
}

.genki2026summer-teiki__img2 {
  display: block;
  padding-top: 40px;
  margin-bottom: 15px;
}

.genki2026summer-teiki__img3 {
  display: block;
  margin-top: 70px;
  margin-bottom: 110px;
}
/*
.genki2026summer-teiki__section {
  margin-bottom: 50px;
}
*/
.genki2026summer-teiki img {
  width: 100%;
  max-width: 100%;
  height: auto;
  border: 0;
  vertical-align: top;
}

.genki2026summer-teiki a {
  color: inherit;
  text-decoration: none;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   テキストブロック【追記1】
   Meiryo + font-feature-settings: "palt" + text-align: justify
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki__text {
  width: auto;
  margin-top: 5px;
  margin-bottom: 12px;
  margin-left: 190px;   /* ★行頭アワセ: DevToolsの↑↓キーで調整 */
  margin-right: 120px;  /* DevToolsの↑↓キーで調整 */
  padding: 0;
  color: #333;
  font-family: 'Meiryo', メイリオ, sans-serif;
}

.genki2026summer-teiki__headline {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-weight: bold;
  font-size: 25px;
  line-height: 1.5;
  margin-bottom: 6px !important;
  font-feature-settings: "palt";
  text-align: justify;
}

.genki2026summer-teiki__body {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-size: 16px;
  line-height: 1.8;
  margin-bottom: 8px !important;
  font-feature-settings: "palt";
  text-align: justify;
}

/* ブロック別に左右マージンが異なる場合はここで上書き */
/* 例: camp1の1つ目のテキストブロックだけ位置が異なる場合
.genki2026summer-teiki__text--camp1 {
  margin-top: 12px !important;
  margin-bottom: 15px;
  line-height: 1.5;
}
 */
/* camp2: body 行送りツメ */
.genki2026summer-teiki__camp2 .genki2026summer-teiki__body {
  line-height: 1.5;
  margin-top: 17px;
  margin-bottom: 27px !important;
}

/* camp2: conditions前アキ */
.genki2026summer-teiki__camp2 .genki2026summer-teiki__conditions-list {
  margin-top: 20px;
}

/* camp4: coupon-usage テキスト ★ツメ ★行送りツメ */
.genki2026summer-teiki__coupon-usage .genki2026summer-teiki__body {
  line-height: 1.5;
  margin-bottom: 6px !important;
}

/* camp4: conditions前 ★アキ */
.genki2026summer-teiki__coupon-usage .genki2026summer-teiki__conditions-list {
  margin-top: 16px;
}

/* camp4: 10%OFF対象商品 見出し（ボタンではなく見出し） */
.genki2026summer-teiki__camp4-heading {
  clip-path: none;
  padding: 0;
}
.genki2026summer-teiki__camp4-heading::after {
  display: none;
}

/*
.genki2026summer-teiki__camp4 .genki2026summer-teiki__text:first-of-type {
  margin-top: 60px;
  margin-left: 152px;
}
*/

/* ■ 条件テキスト: PC では 1 行に固定【追記2】*/
.genki2026summer-teiki__conditions-list--inline {
  display: flex;
  align-items: center;
}
.genki2026summer-teiki__conditions-list--inline .genki2026summer-teiki__conditions,
.genki2026summer-teiki__conditions-list--inline .genki2026summer-teiki__note {
  margin: 0 !important;
}

.genki2026summer-teiki__conditions {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 3px !important;
  white-space: nowrap;
}
.genki2026summer-teiki__conditions::first-letter {
  color: #1EAEDB;
}

.genki2026summer-teiki__note {
  font-family: 'Meiryo', メイリオ, sans-serif;
  font-size: 14px;
  line-height: 1.4;
  margin-bottom: 3px !important;
  font-feature-settings: "palt";
  text-align: justify;
}

.genki2026summer-teiki__coupon-usage .genki2026summer-teiki__conditions {
  font-size: 16px;
}
.genki2026summer-teiki__coupon-usage .genki2026summer-teiki__body {
  line-height: 1.8;
}

/* PC/SP 改行制御のデフォルト（PCでは sp-br 非表示、pc-br 表示） */
.genki2026summer-teiki .sp-br {
  display: none;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ボタン共通
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki__button {
  position: relative;
  clip-path: inset(0);
  padding: 0;
}

.genki2026summer-teiki button {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: none;
  cursor: pointer;
}

/* ホバー: 白オーバーレイ */
.genki2026summer-teiki__button::after {
  content: '';
  position: absolute;
  top: -2px;
  right: 0;
  bottom: 0;
  left: 0;
  background: rgba(255, 255, 255, 0);
  transition: background 0.15s ease;
  pointer-events: none;
}

.genki2026summer-teiki__button:hover::after,
.genki2026summer-teiki__button:focus-visible::after {
  background: rgba(255, 255, 255, 0.4);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   ボタンエリア（背景＋ボタン分離構造）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki__btn-area {
  position: relative;
  line-height: 0;
  overflow: hidden;
}

/* ABCボタンエリア内では button の clip-path / ::after を無効化 */
.genki2026summer-teiki__btn-area--3a .genki2026summer-teiki__button,
.genki2026summer-teiki__btn-area--3b .genki2026summer-teiki__button,
.genki2026summer-teiki__btn-area--3c .genki2026summer-teiki__button {
  clip-path: none;
}
.genki2026summer-teiki__btn-area--3a .genki2026summer-teiki__button::after,
.genki2026summer-teiki__btn-area--3b .genki2026summer-teiki__button::after,
.genki2026summer-teiki__btn-area--3c .genki2026summer-teiki__button::after {
  display: none;
}

/* ABC: 背景画像側でホバーマスク（btn-area::after） */
.genki2026summer-teiki__btn-area--3a::after,
.genki2026summer-teiki__btn-area--3b::after,
.genki2026summer-teiki__btn-area--3c::after {
  content: '';
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 89.8888%; /* 889/989 */
  background: rgba(255, 255, 255, 0);
  transition: background 0.15s ease;
  pointer-events: none;
}
.genki2026summer-teiki__btn-area--3a:has(.genki2026summer-teiki__button:hover)::after,
.genki2026summer-teiki__btn-area--3a:has(.genki2026summer-teiki__button:active)::after,
.genki2026summer-teiki__btn-area--3b:has(.genki2026summer-teiki__button:hover)::after,
.genki2026summer-teiki__btn-area--3b:has(.genki2026summer-teiki__button:active)::after,
.genki2026summer-teiki__btn-area--3c:has(.genki2026summer-teiki__button:hover)::after,
.genki2026summer-teiki__btn-area--3c:has(.genki2026summer-teiki__button:active)::after {
  background: rgba(255, 255, 255, 0.4);
}

/* ボタン画像: btn-area 内で中央絶対配置 */
.genki2026summer-teiki__btn-area .genki2026summer-teiki__button {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   コピートースト（クーポンコード）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki__copy-toast {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 3;
  transform: translate(-50%, -50%);
  padding: 10px 22px;
  color: #fff;
  font-weight: bold;
  font-size: 18px;
  line-height: 1;
  background: rgba(0, 0, 0, 0.78);
  border-radius: 4px;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.16s ease;
}
.genki2026summer-teiki__copy-toast.is-visible {
  opacity: 1;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   PC ボタン幅（89.8888% = 889/989）
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki__btn-area--3a .genki2026summer-teiki__button,
.genki2026summer-teiki__btn-area--3b .genki2026summer-teiki__button,
.genki2026summer-teiki__btn-area--3c .genki2026summer-teiki__button,
.genki2026summer-teiki__btn-area--coupon .genki2026summer-teiki__button,
.genki2026summer-teiki__btn-area--camp4 .genki2026summer-teiki__button {
  width: 89.8888%; /* 889/989 */
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   キャンペーン4 固有
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
.genki2026summer-teiki__camp4 {
  margin-top: 30px;
}

/* クーポンボタンエリア */
.genki2026summer-teiki__btn-area--coupon {
  margin: 28px 0 30px;
}

/* クーポン利用ガイド（880px / 989px = 88.9787%） */
.genki2026summer-teiki__camp4-guide {
  width: 88.9787%; /* 880/989 */
  margin: 30px auto 0;
}

/* CTAボタンエリア */
.genki2026summer-teiki__btn-area--camp4 {
  margin: 50px 0;
}

/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   SP レイアウト (max-width: 767px)
━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
@media (max-width: 767px) {
  .genki2026summer-teiki {
    max-width: 390px;
    width: 100%;
  }

  .genki2026summer-teiki__img {
    margin-top: -15px;
  }

  .genki2026summer-teiki__img2 {
    margin-top: 5px;
    margin-bottom: 20px;
  }

.genki2026summer-teiki__img3 {
  display: block;
  margin-top: 40px;
  margin-bottom: 40px;
}

  .pc-br {
    display: none; /* 改行タグを非表示 */
  }
  .genki2026summer-teiki .sp-br {
    display: inline; /* 改行有効 */
  }

.genki2026summer-teiki__camp4 .genki2026summer-teiki__note {
  margin-top: 20px;
}

.genki2026summer-teiki__coupon-usage .genki2026summer-teiki__conditions-list {
  margin-top: -6px !important;
}
.genki2026summer-teiki__coupon-usage dd + dt {
  margin-top: 32px;
}
.genki2026summer-teiki__camp4-guide {
  margin-top: -5px;
}

  .genki2026summer-teiki__text {
    width: auto;
    margin: 8px 32px;
    padding: 0;
    line-height: 1.6;
  }

/* ブロック別に左右マージンが異なる場合はここで上書き */
/* 例: camp1の1つ目のテキストブロックだけ位置が異なる場合 */
.genki2026summer-teiki__text--camp2 {
  margin-top: 20px;
  margin-bottom: 30px;
}

  .genki2026summer-teiki__headline {
    font-size: 22px;
    line-height: 1.5;
    margin-top: 5px;
  }

  /* SP: __body 行送りツメ */
  .genki2026summer-teiki__body {
    line-height: 1.8;
    letter-spacing: 0;
    margin-bottom: 6px !important;
  }

  /* SP: __conditions は折り返しを許可【追記2】はPC限定 + ★ツメ */
  .genki2026summer-teiki__conditions {
    white-space: normal;
    line-height: 1.5;
    margin-bottom: 2px !important;
  }

  /* SP: __note ★ツメ */
  .genki2026summer-teiki__note {
    line-height: 1.5;
    margin-bottom: 1.8px !important;
  }

  /* SP camp2: body 行送りツメ */
  .genki2026summer-teiki__camp2 .genki2026summer-teiki__body {
    line-height: 1.8;
    margin-bottom: 18px !important;
  }

  /* SP ABC マスク幅 (640/780) */
  .genki2026summer-teiki__btn-area--3a::after,
  .genki2026summer-teiki__btn-area--3b::after,
  .genki2026summer-teiki__btn-area--3c::after {
    width: 82.0513%; /* 640/780 */
  }

  /* SP ボタン幅 (640/767) */
  .genki2026summer-teiki__btn-area--3a .genki2026summer-teiki__button,
  .genki2026summer-teiki__btn-area--3b .genki2026summer-teiki__button,
  .genki2026summer-teiki__btn-area--3c .genki2026summer-teiki__button,
  .genki2026summer-teiki__btn-area--coupon .genki2026summer-teiki__button,
  .genki2026summer-teiki__btn-area--camp4 .genki2026summer-teiki__button {
    width: 82.0513%; /* 640/780 */
  }

  /* SP クーポンボタン位置 */
  .genki2026summer-teiki__btn-area--coupon .genki2026summer-teiki__button {
    left: 7.1795%; /* 28/390 */
    transform: none;
  }

  /* SP CTAボタン位置（x=56/2=28px → 28/390）*/
  .genki2026summer-teiki__btn-area--camp4 .genki2026summer-teiki__button {
    left: 7.1795%; /* 28/390 */
    transform: none;
  }

  .genki2026summer-teiki__btn-area--camp4 .genki2026summer-teiki__button::after {
    left: -2px;
  }

  /* SP キャンペーン4
  .genki2026summer-teiki__camp4 {
    margin-top: 50px;
  }
 */
.genki2026summer-teiki__camp4 .genki2026summer-teiki__text:first-of-type {
  margin-top: 0;  /* 打ち消し */
}
.genki2026summer-teiki__camp4 .genki2026summer-teiki__text:first-of-type .genki2026summer-teiki__body {
  margin-top: 10px;
}

  .genki2026summer-teiki__camp4-guide {
    width: 82.0513%;
    margin-left: 7.1795%;
    margin-right: 0;
  }

  .genki2026summer-teiki__btn-area--camp4 {
    margin: 15px 0 100px;
  }
}
@media (min-width: 768px) {
  .genki2026summer-teiki__camp4 .genki2026summer-teiki__text {
    margin-left: 150px;
    margin-right: 120px;
  }
  .genki2026summer-teiki__camp4 .genki2026summer-teiki__text:first-of-type {
    margin-top: 60px;
  }
.genki2026summer-teiki__coupon-usage .genki2026summer-teiki__conditions-list {
  margin-top: 40px;
}
.genki2026summer-teiki__coupon-usage dd + dt {
  margin-top: 60px;
  white-space: nowrap;
}
}


