@charset "UTF-8";
.sw-FloatClear { clear: both; }

.sw-FrameSimple_Gray { background-color: #f3f3f3; padding: 20px; border-radius: 5px; font-size: 15px; }

.sw-FrameSimple_Pink { background-color: #ffeeee; padding: 20px; border-radius: 5px; font-size: 15px; }

.sw-frameMessage { background-color: #fbf8ec; padding: 20px; border-radius: 5px; font-size: 16px; border: 1px solid #c4b189; }

/* PCフッター注意事項等 */
.sw-FooterNoteBox { width: 1000px; margin: 60px auto; background: #ffffff; border-radius: 5px; }

.sw-FooterNote { background: #ffffff; border-radius: 5px; border: 1px solid #e2e2e2; padding: 20px 40px; text-align: left; }

.sw-FooterNote a, .sw-FooterNote a:visited { color: #0063dc; text-decoration: none; cursor: pointer; }

.sw-FooterNote_TextRed { color: #da0201; font-weight: bold; }

.sw-FooterNote_Content { padding-bottom: 30px; line-height: 1.8; margin-left: 0; }

.sw-FooterNote_Content li { line-height: 2; }

.sw-FooterNote_Content:last-child { padding-bottom: 0; }

.sw-FooterNote_Content-textNormal { margin: 0; padding: 10px 0 10px 11px; font-size: 15px; }

.sw-FooterNote_ListCircle { list-style-type: disc; margin: 0; padding: 10px 0 0 24px; font-size: 15px; }

.sw-FooterNote_ListCircle-indent { list-style-type: circle; padding: 2px 0 20px 25px; font-size: 15px; }

.sw-FooterNote_ListNumber { padding: 10px 0 10px 12px; list-style-type: none; list-style-position: inside; }

.sw-FooterNote_ListNumber-contents { counter-increment: cnt; margin-left: 1.7em; text-indent: -1.7em; }

.sw-FooterNote_ListNumber-contents:before { display: marker; content: "(" counter(cnt) ") "; }

.sw-FooterNote_ListNumber .sw-FooterNote_ListCircle:last-child { padding-bottom: 0; }

.sw-FooterNote_ListCircle .sw-FooterNote_ListNumber:last-child { padding-bottom: 0; }

.sw-FooterNote_ListNumber .sw-FooterNote_ListCircle .sw-FooterNote_ListCircle-indent:last-child { padding-bottom: 0; }

.sw-FooterNote_ListNumber-first { padding: 10px 0; list-style-type: none; list-style-position: inside; }

.sw-FooterNote_listStyleNone { list-style: none; margin-left: -1em; }

.sw-FooterNote_HeadingBox { margin-top: 23px; text-align: center; }

.sw-FooterNote_HeadingBox + p, .sw-FooterNote_HeadingBox + ol.sw-FooterNote_ListNumber-first, .sw-FooterNote_HeadingBox + ul.sw-FooterNote_ListCircle-first { padding-top: 0; }

.sw-FooterNote_Heading { font-size: 16px; margin-bottom: 28px; position: relative; padding: 0 30px 9px; display: inline-block; }

.sw-FooterNote_Heading:after { display: inline-block; position: absolute; bottom: 0; left: 50%; -webkit-transform: translateX(-50%); -moz-transform: translateX(-50%); transform: translateX(-50%); transform: translate(-50%); min-width: 200px; width: 100%; height: 2px; content: ""; background-color: #fea000; }

.sw-FooterNote_MiddleHeading { font-size: 15px; position: relative; display: inline-block; margin-bottom: 5px; padding-left: 0.8em; height: 20px; line-height: 20px; }

.sw-FooterNote_MiddleHeading:before { display: inline-block; position: absolute; content: ""; top: 30%; bottom: 0; left: 0; width: 9px; height: 9px; background: #525252; }

.sw-FooterNote_SmallHeading { position: relative; display: inline-block; margin-left: 1.2em; height: 20px; line-height: 20px; }

.sw-FooterNote_SmallHeading:before { left: -1em; content: "【"; position: absolute; }

.sw-FooterNote_SmallHeading:after { content: "】"; position: absolute; }

.sw-FooterNote_SmallHeading-first { font-size: 10pt; position: relative; display: inline-block; margin-left: 0.5em; height: 20px; line-height: 20px; }

.sw-FooterNote_SmallHeading-first:before { left: -1em; content: "【"; position: absolute; }

.sw-FooterNote_SmallHeading-first:after { content: "】"; position: absolute; }

.sw-FooterNote_ListAsterisk { margin: 0; font-size: 15px; padding-left: 30px; }

.sw-FooterNote_ListAsterisk li { list-style-type: none; text-indent: -1.5em; }

.sw-FooterNote_ListAsterisk li:before { content: "※"; margin-right: 5px; }

.sw-FooterNote_ListAsterisk-first li { list-style-type: none; text-indent: -1.3em; }

.sw-FooterNote_ListAsterisk-first li:before { content: "※"; }

/* 売れる 定期商品のボーナスポイントキャンペーン 2025.11 */
.subscriptioncp-Body { overflow-x: hidden; width: 100%; text-align: center; letter-spacing: 1px; }

.subscriptioncp-EndInfo { background: #ffeeee; padding: 15px 0; font-size: 15px; text-align: center; border-bottom: 1px solid #cccccc; }

.subscriptioncp-AnnounceBox { padding: 15px 0; background: #f2f9d0; }

.subscriptioncp-Announce { width: 860px; margin: auto; font-weight: bold; line-height: 1.8; }

.subscriptioncp-Title { background: #f2f9d0; background-size: 100%; margin: 0; }

.subscriptioncp-Title_Image { vertical-align: top; }

.subscriptioncp-Title_ImageEnd { padding-bottom: 20px; }

.subscriptioncp-Term { width: 100%; background: #f2f9d0; }

.subscriptioncp-Term_Box { border-radius: 10px; background: #ffffff; margin: 0 auto; padding: 20px; font-size: 24px; }

.subscriptioncp-Term_Text { color: #00ad00; font-weight: 900; font-size: 26px; margin: 0 auto; letter-spacing: 0.2em; }

.subscriptioncp-ButtonTop { padding: 40px 0 34px; background: #f2f9d0; }

.subscriptioncp-Flow { background: #f2f9d0; padding-bottom: 30px; }

.subscriptioncp-Flow_Title { margin: auto; padding: 30px 0 25px; font-size: 24px; font-weight: 900; letter-spacing: 0.2em; color: #00ad00; }

.subscriptioncp-Flow_List { list-style-type: none; width: 800px; margin: auto; padding: 0; counter-reset: titlenum; }

.subscriptioncp-Flow_Box { display: block; align-items: center; justify-content: center; background: #ffffff; width: 800px; border-radius: 5px; padding: 10px; margin-bottom: 20px; line-height: 1.8; }

.subscriptioncp-Flow_Box-text { font-size: 20px; margin: 0; font-weight: bold; color: #465f51; line-height: 1.8; }

.subscriptioncp-Flow_Box-text:before { counter-increment: titlenum; content: "Step " counter(titlenum); width: 90px; height: 28px; border-radius: 24px; margin-right: 15px; text-align: center; display: inline-block; font-size: 17px; font-weight: bold; color: #ffffff; background: #00ad00; line-height: 1.8; }

.subscriptioncp-Flow_Box-sub { display: block; width: 100%; background: #fffdde; margin-top: 15px; padding: 12px 0; font-size: 13px; }

.subscriptioncp-Flow_Box-subTextBold { font-weight: bold; }

.subscriptioncp-Flow_Box-subPointBold { font-weight: bold; font-size: 15px; }

.subscriptioncp-Flow_SupplementaryText { font-size: 13px; }

.subscriptioncp-Flow_Text-bottom { width: 800px; margin: 0 auto; font-size: 16px; line-height: 1.8; text-align: left; }

.subscriptioncp-Ad { background: #f2f9d0; padding-bottom: 30px; }

.subscriptioncp-Ad_Title { margin: auto; padding: 30px 0 25px; font-size: 24px; font-weight: 900; letter-spacing: 0.2em; color: #00ad00; }

.subscriptioncp-AdListMain { width: 830px; margin: 0 auto; padding: 0; }

.subscriptioncp-AdList { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; display: inline-block; position: relative; width: 385px; margin: 15px; background: #ffffff; border-radius: 6px; text-align: left; border: 1px solid #40B743; box-shadow: 0 5px 0 #40B743; }

.subscriptioncp-AdListBoxLink { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; width: 100%; height: 100%; display: block; color: #000000; }
.subscriptioncp-AdListBoxLink :hover { background: #fffceb; border-radius: 6px; }

.subscriptioncp-AdListBoxLink_Used { position: relative; }

.subscriptioncp-AdListBoxLink_Used:before { content: ""; position: absolute; top: 0; right: 0; bottom: 0; left: 0; background-color: rgba(0, 0, 0, 0.5); border-radius: 6px; }

.subscriptioncp-AdListBoxLink_Used-message { color: #ffffff; font-weight: bold; z-index: 2; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); width: 350px; text-align: center; margin: 0; }

.subscriptioncp-AdListBox { padding: 15px; }

.subscriptioncp-AdListBnr { display: inline-block; width: 27%; }

.subscriptioncp-AdListBnrImg { width: 85px; height: 85px; display: inline-block; vertical-align: top; line-height: 75px; margin: auto; }
.subscriptioncp-AdListBnrImg img { width: 100%; vertical-align: middle; }

.subscriptioncp-AdListSpec { display: inline-block; vertical-align: top; width: 70%; font-size: 14px; }

.subscriptioncp-AdListSpec_Title { width: 95%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; font-weight: bold; color: #000000; line-height: 1.5; }

.subscriptioncp-AdListSpec_Acquirement { width: 95%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #000000; }

.subscriptioncp-AdListSpec_PointBefore { color: #000000; }

.subscriptioncp-Modal { height: 100vh; position: fixed; top: 0; width: 100%; z-index: 100; display: none; }

.subscriptioncp-Modal_Bg { background: rgba(0, 0, 0, 0.5); height: 100vh; position: absolute; width: 100%; z-index: 9999; }

.subscriptioncp-Modal_Content { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; position: absolute; top: 50%; left: 50%; border-radius: 5px; transform: translate(-50%, -50%); background: #ffffff; padding: 20px 20px 40px; width: 670px; text-align: center; z-index: 10000 !important; }

.subscriptioncp-Modal_CloseBtn { text-align: right; cursor: pointer; }

.subscriptioncp-Modal_Body { position: relative; }

.subscriptioncp-Modal_Title { font-weight: bold; color: #00ad00; font-size: 25px; margin: 0 0 30px; }

.subscriptioncp-ButtonBox { width: 100%; position: fixed; bottom: 0; padding: 24px 0; border: 1px solid #addeaf; border-bottom: 0; border-radius: 3px 3px 0 0; z-index: 10; background-color: rgba(255, 255, 255, 0.7); }

.subscriptioncp-Button { border-radius: 5px; display: block; text-decoration: none; font-weight: bold; line-height: 1; width: 100%; text-align: center; transition: all 0.2s ease-in-out; width: 640px; height: 60px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; line-height: 60px; display: block; text-decoration: none; margin: auto; color: #670000; font-size: 24px; letter-spacing: 0.1em; background: #f9f170; border: none; border-radius: 30px; box-shadow: 0 6px 0 #fccd2d; cursor: pointer; }
.subscriptioncp-Button a { color: #670000; text-decoration: none; display: block; }
.subscriptioncp-Button:hover { transform: translateY(3px); box-shadow: 0 0 0 #fccd2d; }

.subscriptioncp-Button_EntryCompleted { border-radius: 5px; display: block; text-decoration: none; font-weight: bold; line-height: 1; width: 100%; text-align: center; width: 640px; height: 60px; -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; line-height: 60px; display: block; text-decoration: none; margin: auto; color: #a0a0a0; font-size: 24px; letter-spacing: 0.1em; background: #eeeeee; border: none; border-radius: 30px; pointer-events: none; }

.subscriptioncp-AdListSpec_Details { width: 100%; height: 30px; line-height: 30px; border: 1px #00ad00 solid; color: #007700; font-size: 14px; text-align: center; margin-top: 5px; letter-spacing: 0.05em; border-radius: 30px; background: #ffffff; }

.subscriptioncp-AdListSpec_Details:hover { border-radius: 30px; background: #ffffff; }
