/* ========================================
 * カスタマイズ用CSS - 善プラス公式通販
 * ======================================== */

/* ----- 基本設定 ----- */
body {
    font-family: 'Noto Serif JP', serif;
    background-color: white;
}

.inner {
    max-width: 1080px;
    margin: 0 auto;
}

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

a img {
    transition: all 0.5s ease;
}

a:hover img {
    opacity: 0.7;
}

#area_map_top {
    width: 100%;
    height: 274px;
}

/* ----- レイアウト ----- */
.ec-layoutRole {
    min-height: auto !important;
}

.ec-layoutRole .ec-layoutRole__contents {
    max-width: none;
}

.ec-guideRole .ec-role {
    padding: 50px 0;
}

/* ----- ヘッダー / ナビゲーション ----- */
.header_logo {
    float: left;
    width: 17%;
    padding-top: 10px;
}

.header_tel {
    float: right;
    width: 15%;
    font-size: x-large;
    padding-top: 10px;
}

.ec-headerNaviRole {
    padding-bottom: initial;
}

.ec-headerNaviRole__nav {
    width: 60%;
}

.ec-headerRole__cart {
    width: 10%;
    position: absolute;
    top: 0;
    right: 30%;
}

.ec-layoutRole__header,
.ec-categoryNaviRole,
.ec-itemNav,
.ec-itemNav__nav,
.ec-itemNav__nav li a:link,
.ec-itemNav__nav li a:visited,
.ec-itemNav__nav li a:hover,
.ec-guideRole {
    background-color: #222;
    color: #fff;
}

.ec-categoryNaviRole img {
    width: 100%;
    max-width: 100%;
}

/* ----- カート ----- */
.cart_area {
    background-color: #fff;
    position: relative;
    height: 50px;
}

.ec-cartNaviIsset .ec-cartNaviIsset__cartContent {
    color: #222;
}

/* ----- 見出し ----- */
.ec-secHeading {
    padding: 50px 0;
    text-align: center;
    font-weight: normal;
    font-family: "Yu Mincho", YuMincho, "Hiragino Mincho ProN", Meiryo, serif;
}

.ec-secHeading .ec-secHeading__ja {
    font-size: xx-large;
}

.ec-secHeading .ec-secHeading__en {
    font-size: large;
}

/* ----- スライダー ----- */
.ec-sliderRole {
    position: relative;
    max-width: none;
    padding-left: initial;
    padding-right: initial;
    padding-bottom: initial;
    margin-bottom: initial;
}

.ec-sliderRole .only {
    width: 100%;
    position: absolute;
    bottom: 0;
}

/* ----- グリッド / リスト ----- */
.ec-guideRole,
.ec-topicRole {
    background-repeat: repeat;
    background-position: right bottom;
}

.ec-corpRole .ec-corpRole__list,
.ec-categoryRole .ec-rankingRole__list,
.ec-guideRole .ec-guideRole__list {
    display: flex;
    flex-wrap: wrap;
}

.ec-corpRole .ec-corpRole__listItem,
.ec-topicRole .ec-topicRole__listItem,
.ec-guideRole .ec-guideRole__listItem {
    width: calc(100% / 2.23);
}

.ec-topicRole .ec-topicRole__listItemTitle {
    text-align: center;
    font-size: large;
}

.ec-corpRole .ec-corpRole__listItem:nth-of-type(odd),
.ec-guideRole .ec-guideRole__listItem:nth-of-type(odd),
.ec-topicRole .ec-topicRole__listItem:nth-of-type(odd),
.ec-rankingRole__listItem:nth-of-type(odd) {
    margin-right: calc(100% / 20);
}

.ec-corpRole .ec-corpRole__listItem:nth-of-type(even),
.ec-guideRole .ec-guideRole__listItem:nth-of-type(even),
.ec-topicRole .ec-topicRole__listItem:nth-of-type(even),
.ec-rankingRole__listItem:nth-of-type(even) {
    margin-left: calc(100% / 20);
}

/* ----- お知らせ / News ----- */
.ec-newsRole {
    margin: 0 auto;
    background-image: url(/html/template/default/assets/img/top/bg_news.jpg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    padding-bottom: 100px;
}

.ec-newsRole .ec-secHeading {
    color: #fff;
}

.ec-newsRole .ec-newsRole__news {
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-color: rgba(218, 218, 218, 0.8);
    height: 500px;
    border: none;
}

.news_link {
    padding: 10px 0;
    border-bottom: 2px dotted #989797;
}

.news_link a:link,
.news_link a:visited {
    background-image: url(/html/template/default/assets/img/top/icon_news.png);
    background-position: left 15px center;
    background-repeat: no-repeat;
    background-size: 2pc 2pc;
    color: #222;
    cursor: pointer;
    padding: 20px 10px 20px 60px;
}

.surround {
    text-align: center;
    margin-top: 25px;
}

.surround a:link,
.surround a:visited {
    border: 1px solid #000;
    color: #000;
    padding: 10px 30px;
}

/* ----- フッター ----- */
.ec-footerRole {
    margin-top: 0;
}

.ec-footerTitle__logo {
    width: 20%;
    margin: 0 auto 20px;
}

/* ----- 表示制御 ----- */
.sp_only {
    display: none;
}

/* ========================================
 * 商品ページ: 健脳美人
 * ======================================== */

#RelatedProduct-product_area {
    padding-top: 100px;
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/osusume_title.png);
    background-size: 200px;
    background-position: top center;
    background-repeat: no-repeat;
}

#RelatedProduct-product_area .ec-shelfGrid .ec-shelfGrid__item-image {
    max-height: 150px;
}

.m-t-190 {
    margin-top: -190px;
    padding: 20px 20px 10px;
    font-size: 30px;
    font-weight: bold;
}

.m-t-200 {
    padding: 10px 20px;
    font-size: 20px;
    font-weight: bold;
}

.ec-blockTopBtn {
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/go-to-top.jpg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    width: 40px;
    color: rgba(0, 0, 0, 0);
}

.kenno-bijin img {
    width: 100%;
}

.kenno-bijin .caution {
    position: absolute;
    right: 0;
    bottom: 20px;
}

.kenno-bijin .p-r {
    position: relative;
}

.kenno-bijin .big {
    font-size: 3vw;
}

.kenno-bijin .l-2 {
    line-height: 2em;
    border-radius: 1em;
    padding: 0.5em;
    z-index: 9;
    position: relative;
}

.kenno-bijin .flex {
    display: flex;
}

/* 健脳美人 - 背景・色 */
.kenno-bijin .bg-black {
    background-color: black;
}

.kenno-bijin .bg-green {
    background-color: #307e0b;
    padding: 3px;
    font-family: ui-sans-serif;
    font-size: 19px;
}

.kenno-bijin .bg-bage {
    background: linear-gradient(to right, #efe3cd, white);
}

.kenno-bijin .bg-tree {
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/bg-tree.jpg);
    background-size: 100% auto;
    background-repeat: no-repeat;
    padding-bottom: 100px;
}

.kenno-bijin .bg-gold {
    background: linear-gradient(to bottom, #c09750, #f2d68d);
    color: #7c531e;
}

.kenno-bijin .flower {
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/bg-flower.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    position: relative;
    z-index: 1;
}

/* 健脳美人 - osusume / drink / sorry / recomend セクション */
.kenno-bijin .osusume {
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/bg-img-01.jpg);
    background-size: 100% auto;
    height: 47vw;
    background-repeat: no-repeat;
}

.kenno-bijin .osusume .w-50,
.kenno-bijin .sorry .w-60 {
    float: right;
    padding: 100px;
}

.kenno-bijin .drink {
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/bg-img-02.jpg);
    height: 37vw;
    background-repeat: no-repeat;
    background-size: 65% auto;
    background-position-x: right;
}

@media (min-width: 768px) {
    .kenno-bijin .drink .w-50 {
        padding: 150px 0 0 200px;
    }
}

.kenno-bijin .sorry {
    background-color: white;
    height: 47.6vw;
    display: flex;
}

.kenno-bijin .sorry .w-40 {
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/img03.jpg);
    background-size: 63% auto;
    background-repeat: no-repeat;
    background-position-x: right;
    background-position-y: bottom;
}

.kenno-bijin .sorry .w-40 img {
    padding: 150px 0 0 200px;
}

.kenno-bijin .recomend {
    background-image: url(/html/template/default/assets/img/product/kenno-bijin/bg-img-04.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: bottom;
    height: 65vw;
    max-height: 400px;
    margin-top: 1200px;
}

.reverse-position {
    margin-top: 50px;
}

/* 健脳美人 - レイアウト用ユーティリティ */
.kenno-bijin .t-c {
    text-align: center;
}

.kenno-bijin .m-a {
    margin: auto;
}

.kenno-bijin .f-m {
    font-size: max(2.5vw, 30px);
}

.kenno-bijin .f-n {
    font-size: 15px;
}

.kenno-bijin .f-b {
    font-weight: bold;
}

.kenno-bijin .w-70 { width: 70%; }
.kenno-bijin .w-60 { width: 60%; }
.kenno-bijin .w-50 { width: 50%; }
.kenno-bijin .w-45 { width: 45%; }
.kenno-bijin .w-40 { width: 40%; }

.kenno-bijin .w-80 {
    width: 80%;
    margin: auto;
    max-width: 1200px;
}

.kenno-bijin .w-30 {
    width: 30%;
    margin: auto;
}

.kenno-bijin .w-23 {
    width: 23%;
    margin: 0 auto;
}

.kenno-bijin .w-15 {
    width: 15%;
}

.kenno-bijin .w-10 {
    width: 10%;
    writing-mode: vertical-rl;
}

.kenno-bijin .p-10 {
    padding: 10px 0;
}

.kenno-bijin .p-t-50 {
    padding-top: 45px;
}

.kenno-bijin .p-b-25 {
    padding-bottom: 25px;
}

.kenno-bijin .p-b-50 {
    padding-bottom: 50px;
}

.kenno-bijin .c-gold { color: #dfb569; }
.kenno-bijin .c-white { color: white; }
.kenno-bijin .c-bage { color: #ac9471; }

.kenno-bijin .c-green {
    color: #307e0b;
    font-weight: bold;
}

.kenno-bijin .b-r {
    width: 50%;
    margin: auto;
    padding: 10px;
    position: relative;
    z-index: 100;
}

/* 健脳美人 - secret セクション */
.kenno-bijin .secret {
    position: relative;
    margin-top: -100px;
    z-index: 0;
}

.kenno-bijin .secret-arrow-l {
    position: absolute;
    top: 400px;
    left: 33vw;
    width: 13vw;
}

.kenno-bijin .secret-arrow-r {
    position: absolute;
    top: 400px;
    right: 33vw;
    width: 13vw;
}

.kenno-bijin .secret .w-10 {
    font-size: 2vw;
    line-height: 6vw;
}

.kenno-bijin .point img {
    width: 20px;
}

.kenno-bijin .green-box {
    border: 2px solid #71a758;
    border-radius: 60px;
    padding: 10px;
    color: #348111;
    display: flex;
    height: 4em;
    margin: 10px 0;
    font-size: 1.7vw;
    font-family: sans-serif;
    font-weight: bold;
    background: #fff;
}

.kenno-bijin .green-box .point {
    padding-right: 10px;
}

.kenno-bijin .green-box .green-text,
.kenno-bijin .green-box .point {
    margin: auto 0;
}

.kenno-bijin .gold-line {
    background-color: #dfb569;
    height: 4px;
}

/* 健脳美人 - 素材 (sozai) ブロック */
.sozai {
    background: #fff;
    border: solid #307e0b;
    min-height: 300px;
}

.sozai::before {
    position: absolute;
    content: "";
    left: 50%;
    top: -100px;
    width: 167px;
    height: 100px;
    margin-left: -17px;
    background: url("/html/template/default/assets/img/product/kenno-bijin/green-arrow01_be.png") top left no-repeat;
    background-size: 167px 100px;
}

.sozai::after {
    position: absolute;
    content: "";
    left: 50%;
    bottom: -200px;
    width: 167px;
    height: 200px;
    margin-left: -17px;
    background: url("/html/template/default/assets/img/product/kenno-bijin/green-arrow01_af.png") top left no-repeat;
    background-size: 167px 200px;
}

.sozai-r::before {
    left: initial;
    right: 50%;
    background: url("/html/template/default/assets/img/product/kenno-bijin/green-arrow02_be.png") top left no-repeat;
}

.sozai-r::after {
    left: initial;
    right: 50%;
    background: url("/html/template/default/assets/img/product/kenno-bijin/green-arrow02_af.png") top left no-repeat;
}

/* secret-arrow を全画面サイズで非表示(個別 media query で位置調整は残置) */
.secret-arrow-l,
.secret-arrow-r {
    display: none;
}

/* ========================================
 * 商品ページ: 会社情報 (corp)
 * ======================================== */

.ec-corpintroRole img {
    width: 20%;
}

.ec-corpintroRole .policy {
    font-size: 3vw;
    padding-top: 25px;
}

.ec-corpintroRole .message {
    text-align: center;
    font-size: large;
    padding-bottom: 50px;
}

.ec-corpintroRole .ec-secHeading {
    color: #dfb527;
}

.ec-corpRole {
    background-color: #f8f6f6;
    background-repeat: no-repeat;
    background-position: 80% 10%;
    background-size: 20%;
    background-image: url(/html/template/default/assets/img/corp/logo.png);
    padding-bottom: 50px;
}

.ec-corpinfoRole {
    background-color: #f8f6f6;
    padding-bottom: 50px;
}

.ec-corpRole__listItem p {
    padding-bottom: 1em;
}

.ceo_name {
    font-size: xx-large;
}

.ec-borderedDefs dl:first-child {
    border-top: 1px solid #dfb527;
}

.ec-borderedDefs dl:last-child {
    border-bottom: 1px solid #dfb527;
}

.ec-borderedDefs dl {
    padding: 0;
}

.ec-borderedDefs dt {
    color: #fff;
    background-color: #000;
    text-align: center;
}

.ec-borderedDefs dd {
    margin-left: 5%;
}

/* ========================================
 * 商品ページ: 化石水
 * ======================================== */

.area_intro img {
    width: 100%;
}

.area_intro .text {
    font-size: larger;
    line-height: 1.8em;
}

.item .title {
    color: #789f7c;
    background-image: url(/html/template/default/assets/img/product/5_kasekisui/04relief_titlebg.png);
    background-repeat: no-repeat;
    text-align: center;
    background-position: center bottom;
    font-size: x-large;
    padding: 25px 0;
}

.area_intro_inner1 .description,
.area_intro_inner3 .description {
    float: left;
    width: 50%;
    font-size: larger;
    line-height: 1.8em;
}

.area_intro_inner1 .pic {
    float: right;
    width: 50%;
    margin-bottom: 50px;
}

.area_intro_inner2 {
    background-image: url(/html/template/default/assets/img/product/5_kasekisui/03reason_bg.jpg);
    background-repeat: no-repeat;
    background-position: right top;
    margin-bottom: 50px;
}

.area_intro_inner2 .title {
    margin-left: 10%;
    padding: 50px 0 30px 0;
    display: inline-block;
    color: #947f39;
    font-size: 24pt;
    text-shadow:
        5px 5px 3px #ffffff,
        -5px 5px 3px #ffffff,
        5px -5px 3px #ffffff,
        -5px -5px 3px #ffffff,
        5px 0px 3px #ffffff,
        0px 5px 3px #ffffff,
        -5px 0px 3px #ffffff,
        0px -5px 3px #ffffff;
}

.area_intro_inner2 .text {
    margin-left: 10%;
}

.area_intro_inner3 {
    padding-top: 50px;
    background: linear-gradient(90deg, #e9f2d8, #fff);
}

.area_intro_inner3 .inner {
    max-width: initial;
}

.area_intro_inner3 .text {
    display: inline-block;
    width: 40%;
}

.area_intro_inner3 .title {
    color: #267230;
    font-size: xxx-large;
    width: 15%;
    float: left;
    margin-left: 12.5%;
}

.area_intro_inner3 .pic {
    width: 20%;
    float: right;
    margin-right: 12.5%;
}

.area_intro_inner3 .item {
    width: 75%;
    background-color: #fff;
    margin: 20px auto;
    border: solid #e9f2d8;
    border-radius: 1em;
    min-height: 250px;
}

.area_intro_inner3 .item .list {
    float: left;
    width: 65%;
}

.area_intro_inner3 .item .title {
    width: 100%;
    font-size: x-large;
}

.area_intro_inner3 .item .text {
    width: 80%;
    display: block;
    margin-left: 3%;
    font-size: 1.5vw;
}

.area_intro_inner3 .item img {
    width: 27%;
    margin: 25px 15px;
}

/* ========================================
 * 商品ページ: ホルミン
 * ======================================== */

.area_intro_horumin img {
    width: 100%;
}

.area_intro_horumin .process {
    display: block;
    margin: 0 auto;
    padding: 50px 0;
    width: 60%;
}

.area_intro_horumin .catch img,
.area_intro_horumin .process img {
    display: block;
    margin: 0 auto;
    padding: 50px 0;
    width: 60%;
}

.area_intro_horumin .process img {
    width: 80%;
}

.area_intro_horumin .list_link1 {
    position: relative;
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100%;
    background-image: url(/html/template/default/assets/img/product/horumin/05list.jpg);
    height: calc(99vw * 663 / 1342);
    width: 100%;
}

.area_intro_horumin .list_link2 {
    position: relative;
    background-repeat: no-repeat;
    background-position: top center;
    background-size: 100%;
    background-image: url(/html/template/default/assets/img/product/horumin/07last.jpg);
    height: calc(99vw * 1224 / 1342);
    width: 100%;
}

.area_intro_horumin .list_link1 img,
.area_intro_horumin .list_link2 img {
    position: absolute;
    bottom: 10%;
    margin: auto;
    left: 0;
    right: 0;
    width: 30%;
}

/* IE11 高コントラスト用フォールバック */
@media all and (-ms-high-contrast: none) {
    .area_intro_horumin .list_link1 {
        height: calc(99vw * 663 / 1342);
    }
    .area_intro_horumin .list_link1 img {
        margin: calc(99vw * 663 / 1342) auto 0 auto;
    }
    .area_intro_horumin .list_link2 img {
        margin: calc(99vw * 1224 / 1342) auto 0 auto;
    }
    .area_intro_horumin .list_link2 {
        height: calc(99vw * 1224 / 1342);
    }
}

/* ========================================
 * 商品ページ: マロー
 * ======================================== */

#intro2 .area_intro_inner3 {
    padding: 100px 0;
    background-image: url(/html/template/default/assets/img/product/marrow/04bg.png);
    background-repeat: no-repeat;
    background-position: bottom center;
    background-size: 100%;
}

#intro2 .area_intro_inner3 .title2 {
    color: #2b416e;
    font-size: xx-large;
    text-align: center;
}

#intro2 .area_intro_inner3 .text {
    display: block;
    width: 80%;
    max-width: 800px;
    margin: 0 auto;
    background-color: rgba(255, 255, 255, 0.75);
}

#intro2 .area_intro_inner3 .text2 {
    color: #825720;
    width: 75%;
    font-size: x-large;
    margin: 25px auto 50px;
}

#intro2 .area_intro_inner3 .item .title2 {
    color: #cbbdaf;
    font-size: 22px;
    text-align: center;
    background-image: none;
    padding: 25px 0 25px 15%;
}

#intro2 .area_intro_inner3 .item .text {
    width: 90%;
    display: block;
    margin-left: 3%;
    font-size: 1vw;
}

#intro2 .area_intro_inner3 .item .no {
    float: left;
    margin: 0;
}

#intro2 .crown {
    width: 80%;
    margin: 100px auto 25px;
    max-width: 300px;
    display: block;
}

.marrow_data {
    padding: 25px 0;
    background-image: url(/html/template/default/assets/img/product/marrow/05bg.png);
    background-repeat: no-repeat;
    background-position: bottom center;
    background-size: 100%;
}

.marrow_list {
    display: flex;
    width: 100%;
    max-width: 1024px;
    margin: 0 auto;
    list-style: none;
    flex-wrap: wrap;
}

.marrow_list li {
    width: 23%;
    margin: 0 5%;
}

.marrow_list li img {
    width: 100%;
}

.marrow_list li div {
    font-weight: bold;
    padding: 15px 0;
}

/* ========================================
 * メディアクエリ
 * ======================================== */

/* タブレット - 大: 1024〜1550px */
@media all and (min-width: 1024px) and (max-width: 1550px) {
    .kenno-bijin .secret-arrow-l {
        top: 20vw;
        left: 27vw;
    }
    .kenno-bijin .secret-arrow-r {
        top: 20vw;
        right: 27vw;
    }
    .kenno-bijin .secret .w-10 {
        line-height: 8vw;
    }
}

/* タブレット - 中: 768〜1024px */
@media all and (min-width: 768px) and (max-width: 1024px) {
    .m-t-190 {
        padding: 20px 10px 10px;
        font-size: 18px;
        margin-top: -138px;
    }
    .m-t-200 {
        font-size: 15px;
        padding: 0 10px 10px;
    }
    .kenno-bijin .secret-arrow-l {
        top: 37vw;
        width: 14vw;
    }
    .kenno-bijin .secret-arrow-r {
        top: 37vw;
        width: 14vw;
    }
    .kenno-bijin .drink .w-50 {
        padding: 35px 0 0 78px;
    }
    .kenno-bijin .osusume .w-50,
    .kenno-bijin .sorry .w-60 {
        float: right;
        padding: 65px;
    }
    .kenno-bijin .recomend {
        height: 0;
        margin-top: 1200px;
    }
    .kenno-bijin .secret .w-10 {
        font-size: 2vw;
        line-height: 8vw;
    }
    .kenno-bijin .secret {
        padding-bottom: 175px;
    }
    .sozai {
        min-height: 470px;
    }
}

/* スマートフォン: 〜767px */
@media only screen and (max-width: 767px) {
    .sp_only {
        display: initial;
    }
    .pc_only {
        display: none !important;
    }

    /* レイアウト */
    .ec-headerNaviRole {
        z-index: 10;
        height: 65px;
        background-color: #222;
        position: fixed;
        top: 0;
    }
    .ec-headerNaviRole img {
        width: 185%;
        max-width: 185%;
    }
    .ec-headerNavSP {
        right: 0;
        left: initial;
        background-color: #222;
        color: #dfb527;
        font-size: 25px;
    }
    .ec-headerRole__navSP {
        height: 45px;
        position: fixed;
        margin-bottom: 45px;
    }
    .ec-headerRole__navSP .header_logo {
        position: fixed;
        top: 5px;
        width: 80px;
    }
    .cart_area {
        top: 65px;
        width: 100%;
        position: fixed;
        z-index: 10;
    }
    .ec-cartNaviIsset {
        width: 80vw;
        margin-right: -80px;
    }
    .ec-cartNavi {
        padding: 15px 0 0 20px;
    }
    .ec-cartNaviNull {
        width: 80vw;
        margin-right: -80px;
    }
    .ec-layoutRole__contents {
        margin-top: 105px;
    }
    .ec-secHeading {
        padding: 25px 0;
    }
    .ec-categoryRole .ec-categoryRole__listItem {
        width: 50%;
    }
    .ec-corpRole .ec-corpRole__listItem,
    .ec-topicRole .ec-topicRole__listItem {
        width: 100%;
    }
    .ec-corpRole .ec-corpRole__listItem:nth-of-type(odd),
    .ec-corpRole .ec-corpRole__listItem:nth-of-type(even),
    .ec-topicRole .ec-topicRole__listItem:nth-of-type(odd),
    .ec-topicRole .ec-topicRole__listItem:nth-of-type(even) {
        margin-left: 0;
        margin-right: 0;
    }
    .ec-newsRole {
        background-size: auto 100%;
    }
    .ec-footerTitle__logo {
        width: 60%;
        margin: auto;
    }
    .ec-footerTitle__logo img {
        width: 100%;
    }

    /* 健脳美人 */
    .kenno-bijin .w-50 {
        width: 100% !important;
    }
    .m-t-190 {
        margin-top: -145px;
        font-size: 18px;
    }
    .m-t-200 {
        font-size: 15px;
    }
    .ec-blockTopBtn {
        right: 20px;
        bottom: 40px;
    }
    .kenno-bijin .caution {
        position: absolute;
        right: 0;
        bottom: 10px;
        font-size: 8px;
    }
    .kenno-bijin .green-box {
        font-size: 14px;
    }
    .kenno-bijin .w-45 {
        width: 44%;
    }
    .kenno-bijin .w-23 {
        width: 48%;
    }
    .kenno-bijin .w-80 {
        width: 95%;
    }
    .kenno-bijin .black {
        color: black;
    }
    .kenno-bijin .big {
        font-size: 13vw;
    }
    .kenno-bijin .secret-arrow-l {
        top: 35vh;
        left: 21vw;
        width: 28vw;
    }
    .kenno-bijin .secret-arrow-r {
        top: 35vh;
        right: 21vw;
        width: 28vw;
    }
    .kenno-bijin .secret .w-10 {
        font-size: 5vw;
        line-height: 12vw;
        width: 12%;
    }
    .kenno-bijin .secret .m-a {
        margin: 0;
    }
    .kenno-bijin .secret .l-2 {
        line-height: 1.4em;
    }
    .kenno-bijin .secret {
        margin-top: -120px;
        padding-bottom: 0px;
    }
    .kenno-bijin .bg-green {
        padding: 3px 10px;
        font-size: 12px;
    }
    .kenno-bijin .bg-green .f-m {
        font-size: 18px;
    }
    .kenno-bijin .bg-green .p-t-50 {
        padding-top: 20px;
    }
    .kenno-bijin .top {
        margin-top: 0px;
    }
    .kenno-bijin .flower {
        background-image: url(/html/template/default/assets/img/product/kenno-bijin/bg-flower_sp.png);
        background-position-y: 63px;
        margin-top: -63px;
    }
    .kenno-bijin .flower .w-30 {
        width: 65%;
    }
    .kenno-bijin .f-m {
        font-size: 25px;
    }
    .kenno-bijin .p-10 img {
        border-radius: 5px;
    }
    .kenno-bijin .bg-tree .w-80 {
        width: 100%;
    }
    .kenno-bijin .b-r {
        width: 90%;
        padding: 15px;
    }
    .kenno-bijin .osusume {
        background-position-x: -16vw;
        height: 60vw;
    }
    .kenno-bijin .osusume .w-50 {
        padding: 15px;
        width: 80% !important;
    }
    .kenno-bijin .sorry .w-60 {
        padding: 15px;
        width: 100% !important;
    }
    .kenno-bijin .drink {
        background-image: none;
        height: auto;
        min-height: 650px;
    }
    .kenno-bijin .sorry {
        background-image: url(/html/template/default/assets/img/product/kenno-bijin/img03_sp.png);
        background-size: 38% auto;
        background-repeat: no-repeat;
        padding-bottom: 100px;
        background-position-x: center;
        background-position-y: bottom;
        height: 80vw;
    }
    .kenno-bijin .sorry .w-40 {
        width: 0%;
    }
    .kenno-bijin .recomend {
        height: 265vw;
        max-height: 1030px;
        margin-top: 225vw;
    }
    .sozai {
        min-height: 300px;
    }

    /* 化石水 / 会社情報 */
    .ec-corpintroRole .policy {
        font-size: 5vw;
    }
    .ec-corpintroRole .message {
        font-size: initial;
    }
    .area_intro .text {
        margin: 0 auto;
        width: 90%;
        text-align: justify;
    }
    .area_intro_inner1 .description,
    .area_intro_inner1 .pic {
        float: initial;
        width: 90%;
        margin: 0 auto 50px auto;
        text-align: justify;
    }
    .area_intro_inner2 {
        background-image: url(/html/template/default/assets/img/product/5_kasekisui/03reason_bg_sp.jpg);
    }
    .area_intro_inner2 .title {
        margin: 0 5%;
        font-size: x-large;
        padding: 35px 0 25px 0;
    }
    .area_intro_inner3 .title {
        font-size: xx-large;
        width: 35%;
        margin-left: 5%;
    }
    .area_intro_inner3 .text {
        display: block;
        width: 90%;
    }
    .area_intro_inner3 .item {
        width: 90%;
    }
    .area_intro_inner3 .item .list {
        float: initial;
        width: 100%;
    }
    .area_intro_inner3 .item .title {
        width: 100%;
        margin-left: 0;
    }
    .area_intro_inner3 .item .text {
        margin: 0 auto;
        font-size: large;
    }
    .area_intro_inner3 .item img {
        width: 95%;
        margin: 0 auto;
        display: block;
    }
    .area_intro_inner3 .item .pc_only {
        display: none;
    }
    .area_intro_inner3 .pic {
        width: 50%;
        float: initial;
        margin-right: initial;
    }
    .area_intro_inner3 img {
        width: 47%;
        float: initial;
    }

    /* ホルミン */
    .area_intro_horumin .list_link1 {
        background-image: url(/html/template/default/assets/img/product/horumin/05list_sp.jpg);
        height: calc(100vw * 995 / 750);
    }
    .area_intro_horumin .list_link2 {
        background-image: url(/html/template/default/assets/img/product/horumin/07last_sp.jpg);
        height: calc(100vw * 2250 / 750);
    }
    .area_intro_horumin .list_link1 img,
    .area_intro_horumin .list_link2 img {
        width: 70%;
        bottom: 7%;
    }

    /* マロー */
    #intro2 .area_intro_inner3 .text2 {
        font-size: large;
    }
    #intro2 .area_intro_inner2 .marrow {
        background-color: #fff;
        padding: 5%;
        font-size: large;
    }
    #intro2 .area_intro_inner3 .item .text {
        font-size: 4vw;
    }
    #intro2 .area_intro_inner3 .item .no {
        width: 25%;
    }
    .marrow_list {
        padding-left: 0;
    }
    .marrow_list li {
        width: 40%;
    }

    /* SP 専用ユーティリティ */
    .marginsp {
        width: 90% !important;
        margin: 0 auto;
        display: block;
    }
}

/* スマートフォン - 小: 〜450px */
@media only screen and (max-width: 450px) {
    .sozai {
        min-height: 650px;
    }
    .sozai::before {
        top: -50px;
        width: 83px;
        height: 50px;
        background-size: 83px 50px;
        margin-left: -5px;
    }
    .sozai::after {
        width: 83px;
        height: 78px;
        background: url("/html/template/default/assets/img/product/kenno-bijin/green-arrow01_af_sp.png") top left no-repeat;
        background-size: 83px 78px;
        bottom: -78px;
    }
    .sozai-r::after {
        background: url("/html/template/default/assets/img/product/kenno-bijin/green-arrow02_af_sp.png") top left no-repeat;
        background-size: 83px 78px;
    }
    .kenno-bijin .secret {
        padding-bottom: 115px;
    }
    .kenno-bijin .c-gold {
        margin-top: 50px;
    }
}
