@charset "UTF-8";

/* ////////////////////////////////////////////////////////////////////
///// 全ページ共通CSS ///////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// */

/* ==================================================
FONT SETTING
================================================== */
html {
    font-size: 52%;
}

@media screen and (min-width:641px) {
    html {
        font-size: 62.5%;
    }
}

@media screen and (min-width:961px) {
    html {
        font-size: calc(8px + .2vw);
    }

    #ftr {
        font-size: calc(7px + .05vw);
    }
}

@media screen and (min-width:1281px) {
    html {
        font-size: calc(9px + .1vw);
    }

    #ftr {
        font-size: calc(8px + .01vw);
    }
}

body {
    /*ゴシック系*/
    font-family: 'Poppins', "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, sans-serif;
    /*明朝系
    font-family: "游明朝", "Yu Mincho", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", serif;*/
    font-weight: 300;
    font-style: normal;
    background: #ffffff;
    font-size: 1rem;
    line-height: 1.5;
    -ms-font-feature-settings: "normal";
    -webkit-font-feature-settings: "palt";
    font-feature-settings: "palt";
    max-width: 1200px;
}

.enGothicBold {
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-style: normal;
}
.enSerif {
    font-family: 'Arbutus Slab', sans-serif;
    font-weight: 400;
    font-style: normal;
}

.itaric {
    font-style: italic;
}

p {
    line-height: 1.7;
    letter-spacing: 0em;
}

.gNaviTxt {
    letter-spacing: .16em;
}

.StrongTitle {
    font-size: 3.0rem;
    line-height: .9;
    letter-spacing: .05em;
}

.pagerTxt,
.mbTitle {
    font-size: 6rem;
    line-height: .9;
    letter-spacing: -.05em;
}

.MainTitle {
    font-size: 2.8rem;
    line-height: 1.35;
    letter-spacing: 0.01em;
}

h1.MainTitle {
    line-height: 1;
}

.SubTitle {
    font-size: 3rem;
    line-height: 1.4;
}
.STitle {
    font-size: 3rem;
    line-height: 1.2;
    letter-spacing: .05em;
}

.XlTxt {
    font-size: 2.4rem;
    letter-spacing: .1em;
}

.LTxt {
    font-size: 2.0rem;
    letter-spacing: .1em;
}

.gNaviTxt,
.MTxt {
    font-size: 1.8rem;
}

.STxt {
    font-size: 1.2rem;
    letter-spacing: .05em;
}

.XsTxt {
    font-size: .9rem;
    letter-spacing: .05em;
}

.fs400 {
    font-size: 400%;
}

.fs300 {
    font-size: 300%;
}

.fs200 {
    font-size: 200%;
}

.fs180 {
    font-size: 180%;
}

.fs160 {
    font-size: 160%;
}

.fs150 {
    font-size: 150%;
}

.fs140 {
    font-size: 140%;
}

.fs130 {
    font-size: 130%;
}

.fs120 {
    font-size: 120%;
}

.fs110 {
    font-size: 110%;
}

.fs90 {
    font-size: 90%;
}

.fs80 {
    font-size: 80%;
}

.fs70 {
    font-size: 70%;
}

.fs60 {
    font-size: 60%;
}

.fs50 {
    font-size: 50%;
}

.fwBold {
    font-weight: bold;
}

.fsItalic {
    font-style: italic;
}

@media screen and (min-width:641px) {}

@media screen and (min-width:961px) {
    .STxt {
        font-size: 1.5rem;
        letter-spacing: .05em;
    }
    .MTxt {
        font-size: 2.5rem;
    }


    .LTxt {
        font-size: 3.0rem;
        letter-spacing: .1em;
    }
}

@media screen and (min-width:1281px) {}

/* ==================================================
font line height
================================================== */
.nowloading .spinner {
    width: 61vw;
    height: 30vw;
    max-width: 427px;
    max-height: 210px;
}

/* ==================================================
color
================================================== */

body {
    color: #000;
}

.mainColor {
    color: #231815;
}

.titColor {
    color: #231815;
}

.weakColor {
    color: #808080;
}

.backColor {
    color: #ffffff;
}

.attention {
    color: #a80028;
}

.freshClr {
    color: #e49090;
}

.feminineClr {
    color: #90cbe4;
}

.healthyClr {
    color: #e49090;
}

.stylishClr {
    color: #9a90e4;
}

.pinkColor {
    color: #ed95a4;
}

/* ==================================================
link
================================================== */

a:link {
    color: #333333;
    text-decoration: none;
}

a:visited {
    color: #333333;
    text-decoration: none;
}

a:active {
    color: #333333;
    text-decoration: none;
}

.weakColor a:link {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:visited {
    color: #888888;
    text-decoration: underline;
}

.weakColor a:active {
    color: #888888;
    text-decoration: underline;
}

.tagList li a:link,
.tagList li a:visited,
.tagList li a:active {
    text-decoration: none;
}

.bnrmenuLists li a:link,
.bnrmenuLists li a:visited,
.bnrmenuLists li a:active {
    border-bottom: 2px solid #333333;
}

/* ==================================================
common
================================================== */
.new::after {
    color: #d83232;
    font-family: 'Work Sans', sans-serif;
    padding: 0 0 0 1rem;
}



svg {
    fill: #000;
}

input {
    -webkit-appearance: none;
}

.scrollArrow span {
    width: 1px;
}

.slideIn {
    -webkit-transition: all 2.8s cubic-bezier(0.215, 0.61, 0.355, 1);
    transition: all 2.8s cubic-bezier(0.215, 0.61, 0.355, 1);
}

.nowPage {
    position: relative;
}

.nowPage::after {
    content: "";
    display: none;
    background: #000;
    width: 70%;
    height: 1px;
    position: absolute;
    bottom: 5px;
    left: 8vw;
}

@media screen and (min-width:641px) {
    .nowPage::after {
        left: 4vw;
    }
}

@media screen and (min-width:961px) {
    .nowPage::after {
        bottom: -5px;
        left: 50%;
        width: 80%;
        -webkit-transform: translate(-50%, 0);
        transform: translate(-50%, 0);
    }
}

@media screen and (min-width:1281px) {
    .menuOnline {
        display: none;
    }
}

/* ==================================================
BtnSet
================================================== */
.BtnCenter {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-transition: .8s all ease-in;
    transition: .8s all ease-in;
    text-align: center;
}

.BtnCenter svg {
    height: 1.2em;
    width: 1.2em;
    margin: 0 10px 0 0;
}

.BtnCenter a {
    padding: .8em 10px;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    position: relative;
    z-index: 10;
    width: 100%;
    text-align: center;
    margin: 0 auto;
}

.BtnCenter a figure {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.kadoRBtn {
    border-radius: 4px;
}

.roundBtn {
    border-radius: 4em;
}

.btnLine.mainBtn {
    background: rgba(255, 255, 255, 1);
    border: 1px solid #dc042a;
}

.btnLine.bkBtn {
    background: rgba(255, 255, 255, 0);
    border: 1px solid #666;
    width: 100%;
    margin: 0 auto;
}

.btnLine.grBtn {
    background: #cccccc;
    border: 1px solid #cccccc;
    width: 100%;
    max-width: 230px;
    margin: 0 auto;
}

.btnLine.whBtn {
    background: rgba(220, 4, 42, 1);
    border: 1px solid #ffffff;
}

.btnLine.mainBtn a {
    color: #dc042a;
}

.btnLine.bkBtn a {
    color: #666;
}

.btnLine.grBtn a {
    color: #ffffff;
}

.btnLine.whBtn a {
    color: #ffffff;
}

#ftr .btnLine.whBtn {
    background: rgba(255, 255, 255, 0);
    border: 1px solid rgba(255, 255, 255, .3);
}

.btnBeta {
    overflow: hidden;
    position: relative;
}

.efBtn::after {
    content: "";
    width: 0;
    position: absolute;
    left: -10%;
    top: 0;
    height: 100px;
    background: #000;
    opacity: .1;
    -webkit-transform: skewX(15deg);
    transform: skewX(15deg);
    -webkit-transition: .3s width ease-in-out;
    transition: .3s width ease-in-out;
}

.btnBeta.whBtn {
    background: #ffffff;
    border: 1px solid #ffffff;
}

.btnBeta.bkBtn {
    background: #a0a0a0;
    border: 1px solid #a0a0a0;
}

.btnBeta.efBtn a {
    text-decoration: none;
}

.btnBeta.efBtn::after {
    width: 0%;
}

.efBtn.efOn::after {
    width: 150%;
    -webkit-transition: .6s width ease-out;
    transition: .6s width ease-out;
}

.btnBeta.grBtn {
    background: #a0a0a0;
    border: 1px solid #a0a0a0;
}

.btnBeta.mainBtn {
    background: #fc90a4;
    border: 1px solid #fc90a4;
    width: 80%;
    margin: 0 auto;
}

.btnBeta.mainBtn a,
.btnBeta.grBtn a,
.btnBeta.bkBtn a,
{
    color: #ffffff;
}

.btnBeta.whBtn a {
    color: #dc042a;
}

.btnBeta.mainBtn svg,
.btnBeta.bkBtn svg {
    fill: #ffffff;
}

.btnBeta.whBtn svg {
    fill: #dc042a;
}

.mainBtn p,
.grBtn p,
.bkBtn p,
.whBtn p {
    position: relative;
    padding: 0;
    display: inline-block;
    line-height: 1;
    width: 100%;
}

.mainBtn p::after,
.grBtn p::after,
.bkBtn p::after,
.whBtn p::after {
    display: block;
    /* content: ""; */
    position: absolute;
    top: 50%;
    right: 0;
    width: 8px;
    height: 8px;
    -webkit-transform: translate(0, -50%) rotate(-45deg);
    transform: translate(0, -50%) rotate(-45deg);
    -webkit-transition: .8s all ease-in;
    transition: .8s all ease-in;
}

.btnBeta.grBtn p::after,
.btnBeta.mainBtn p::after .btnBeta.bkBtn p::after {
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
}

.btnBeta.whBtn p::after {
    border-right: 1px solid #dc042a;
    border-bottom: 1px solid #dc042a;
}

.btnLine.bkBtn p::after {
    border-right: 1px solid #a0a0a0;
    border-bottom: 1px solid #a0a0a0;
}

.btnLine.mainBtn p::after {
    border-right: 1px solid #dc042a;
    border-bottom: 1px solid #dc042a;
}

.btnLine.whBtn p::after {
    border-right: 1px solid #ffffff;
    border-bottom: 1px solid #ffffff;
}

#ftr .whBtn p::after {
    border-right: 1px solid rgba(255, 255, 255, .7);
    border-bottom: 1px solid rgba(255, 255, 255, .7);
}

.innerLinkBtn a p {
    letter-spacing: .15em;
    border-bottom: 1px solid #999999;
    padding: 0 10px 8px;
    margin: 0 auto;
    -webkit-transition: all .8s;
    transition: all .8s;
}

@media screen and (min-width:641px) {
    .btnLine.bkBtn {
        max-width: 230px;
    }
}

@media screen and (min-width:961px) {
    .BtnCenter a {
        padding: 18px 16px 16px;
    }
}

/* ==================================================
nowloading
================================================== */
.double-bounce1,
.double-bounce2 {
    background-color: #292929;
}

button.nl {
    height: 60px;
    width: 40px;
    background: rgba(255, 255, 255, .4);
    border-radius: 50%;
    border-top: 2px solid #0081c3;
    border-right: 2px solid transparent;
    border-bottom: none;
    border-left: none;
    -webkit-animation: spinner5 700ms linear infinite;
    animation: spinner5 700ms linear infinite;
}

@-webkit-keyframes spinner5 {
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

@keyframes spinner5 {
    to {
        -webkit-transform: rotate(360deg);
        transform: rotate(360deg);
    }
}

.loadingSet {
    display: none;
    width: 90%;
    position: fixed;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

.loadingSet p img {
    max-width: 80px;
    width: 30%;
    height: auto;
}

.loadingSet figure {
    width: 100%;
    margin: 20px auto 0;
}

.loadingSet figure svg {
    width: 140px;
    height: 32px;
    fill: #dc042a;
}

.loadingSet figure figcaption {
    line-height: 1.5;
    margin: 5px auto 0;
    text-align: center;
    font-weight: bold;
}

.nowloading .loadingSet {
    display: block;
}



/* ==================================================
footer
================================================== */
.home #ftr {}

.pageTop{
position: fixed;
right: 5%;
bottom: 4%;
z-index: -1;
opacity: 0;
-webkit-transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}
.pageTop a{
position: relative;
text-align: center;
padding: 1.2rem 0 0;
line-height: 1.2;
}
.pageTop a::before{
content: "";
border-right: 1px solid #666;
border-bottom: 1px solid #666;
position: absolute;
width: 12px;
height: 12px;
top: 0;
left: 0;
right: 0;
margin: 0 auto;
-webkit-transform: rotate(-135deg);
transform: rotate(-135deg);
}

.scrolledMenu .pageTop{
opacity: 1;
z-index: 10;
-webkit-transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
transition: all 1.2s cubic-bezier(0.215, 0.61, 0.355, 1);
}

#ftr {
    margin: 0 auto;
    position: relative;
    padding: 5rem 0;
}




@media screen and (min-width:641px) {}

@media screen and (min-width:961px) {
    .pageTop{
    right: 3%;
    bottom: 2%;
    }

    .pageTop a{
        font-size: 1.2rem;
        padding: 1.5rem 0 0;
        line-height: 1.2;
    }
    .pageTop a::before{
        width: 16px;
        height: 16px;
    }

}

/* ==================================================
main
================================================== */

#cnts {
    min-height: calc(100vh - 12rem);
}

.swiper-container-vertical > .swiper-pagination-bullets {
    right: 5px;
    top: 45vh;
    -webkit-transform: translate3d(0, -50%, 0);
    transform: translate3d(0, -50%, 0);
}

.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 6px auto;
}

.swiper-pagination-bullet {
    width: 4px;
    height: 4px;
    display: inline-block;
    border-radius: 100%;
    background: #000;
    opacity: 1;
}

.swiper-pagination-bullet-active {
    width: 8px;
    height: 8px;
    display: inline-block;
    border-radius: 100%;
    background: none;
    border: 1px solid #000;
}

