* {
    box-sizing: border-box;
}


html {
    font-size: 62.5%;
}

html.is-scroll-prevent {
    height: 100%;
    overflow: hidden;
}

body {
    font-family: 'Shippori Mincho', serif;
    position: relative;
    z-index: 0;
    color: #333;
    font-weight: 400;
    letter-spacing: 0.1rem;
    line-height: 1;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

/* print setting */
@media print {
    html {
        font-size: 38%;
    }

    body {
        -webkit-print-color-adjust: exact;
    }
}

a {
    color: inherit;
    text-decoration: none;
    transition: 0.3s ease-out;
}

a:hover,
a:active,
a:focus {
    color: inherit;
    text-decoration: underline;
}

a img,
a svg {
    transition: 0.3s ease-out;
}

::-moz-selection {
    background: #90326D;
    color: #fff;
    text-shadow: none;
}

::selection {
    background: #90326D;
    color: #fff;
    text-shadow: none;
}

h1,
h2,
h3,
h4,
h5,
h6,
p {
    margin: 0;
    font-weight: inherit;
}

figure {
    margin: 0;
}

img {
    width: 100%;
    height: auto;
    max-width: none !important;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

@media screen and (-webkit-min-device-pixel-ratio: 0) and (min-resolution: .001dpcm) {
    img {
        image-rendering: -webkit-optimize-contrast;
    }
}

svg {
    fill: currentcolor;
    max-width: 100%;
}

ul {
    list-style-type: none;
    padding: 0;
}

input,
textarea,
select,
button {
    -moz-appearance: none;
    -webkit-appearance: none;
    appearance: none;
    border-radius: 0;
    border: none;
    transition: 0.3s ease-in;
    cursor: pointer;
    color: #333;
    border: none;
}


.wrapper {
    width: calc(1200 / 1400 * 100%);
    max-width: 1200px;
    margin-left: auto;
    margin-right: auto;
}

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.display_none {
    display: none;
}

.en {
    font-family: 'Cormorant', serif;
}

.link_box {
    margin: 4rem auto 0;
    justify-content: center;
    align-items: center;
    width: 22.6rem;
    height: 6.2rem;
    border: 1px solid #90326d;
    color: #90326d;
    background: #fff;
    font-size: 1.7rem;
}

.link_box:hover {
    background: #90326d;
    color: #fff;
    text-decoration: none;
}


/* ヘッダー
----------------------------------------------------*/

.header_info{
    background: #90326d;
    color: #fff;
    padding: .5rem 10%;
    font-size: 1.3rem;
    line-height: 1.2;
    text-align: center;
}

.header_container {
    position: fixed;
    top: 2.6rem;
    left: 0;
    z-index: 9;
    width: 100%;
    padding-top: 2.6rem;
    padding-bottom: 2.4rem;
}

.header_container:not(.header-top),
.is-fixed.header_container {
    background: #fff;
    border-bottom: 1px solid rgba(0, 0, 0, 0.25);
    color: #90326d;
}

.is-fixed.header_container {
    top: 0;
}

.header_inner {
    position: relative;
    margin-left: 5%;
    margin-right: 5%;
}

.header_logo {
    width: 22rem;
    display: block;
    margin: 0 auto;
    z-index: 1;
    position: relative;
}

.header_nav {
    width: 100%;
    position: absolute;
    top: 0.4rem;
    left: 0;
    font-size: 1.6rem;
    text-transform: uppercase;
}

.header_nav .main_nav_list {
    margin: 0;
}

.header_nav .main_nav_item + .main_nav_item {
    padding-left: 2%;
}

.header_icon_list {
    position: absolute;
    top: -0.2rem;
    right: 0;
    margin: 0;
    align-content: center;
}

.header_icon_item + .header_icon_item {
    margin-left: 2.4rem;
}

.header_icon_item a {
    display: block;
}

.header_icon_item {
    align-items: center;
}

.header_icon_item svg {
    margin-right: .8rem;
}

.drawer-hamburger,
.drawer-nav {
    display: none;
}

/* メインコンテナー
----------------------------------------------------*/

.main_container:not(.top) {
    padding-top: 18rem;
}

/* フッター
----------------------------------------------------*/

.footer_container {
    margin-top: 8rem;
    padding-top: 5.8rem;
    padding-bottom: 3.5rem;
    text-align: center;
    border-top: 1px solid rgba(144, 50, 109, 0.35);
}

.footer_logo {
    width: 21rem;
    display: block;
    margin: auto;
}

.footer_main_nav {
    font-size: 1.6rem;
    text-transform: uppercase;
    padding-top: 3.8rem;
    padding-bottom: 4.4rem;
}

.footer_main_nav .main_nav_list {
    justify-content: center;
    margin: 0;
}

.footer_main_nav .main_nav_item + .main_nav_item {
    padding-left: 2rem;
}

.footer_main_nav a {
    color: #90326d
}

.instagram_link {
    width: 3.2rem;
    display: block;
    margin: auto;
}

.footer_alcohol {
    font-size: 1.2rem;
    line-height: 1.5;
    padding-top: 4rem;
    padding-bottom: 1.2rem;
}

.footer_sub_nav {
    font-size: 1.3rem;
}

.footer_sub_nav .sub_nav_list {
    justify-content: center;
    margin: 0;
}

.footer_sub_nav .sub_nav_item + .sub_nav_item {
    padding-left: 1.4rem;
}

.footer_copyright {
    font-size: 1.2rem;
    padding-top: 2.6rem;
}

.l-copyright__logo {
    display: none;
}

/* 一覧系
----------------------------------------------------*/

.p-category__ttl {
    font-size: 2.4rem;
    padding-bottom: 2rem;
}

.p-item-list-head {
    border-top: 1px solid rgba(144, 50, 109, 0.35) !important;
}

.c-item-list {
    margin: 2rem auto 8rem;
    width: 60%;
}

.c-item-list li + li {
    padding-top: 6rem;
}

.c-item-list__txt {
    padding-top: 3.2rem;
}

.c-item-list__ttl {
    font-size: 2rem;
    line-height: 1.3;
}

.c-item-list__price {
    padding-top: 2.2rem;
    font-size: 1.6rem;
}

.is-strikethrough.c-item-list__price {
    text-decoration: line-through;
    font-size: 88%;
}

.c-pager {
    text-align: center;
}

.c-pager__total {
    padding-bottom: 2rem;
}

.c-pager-list {
    display: flex;
    justify-content: center;
    margin: 0;
}

.c-pager-list li {
    padding: 0 1.2rem;
}

/* 特定商取引法表示・プライバシーポリシー
----------------------------------------------------*/

.c-ttl-second {
    font-size: 2rem;
    font-weight: 600;
    padding-bottom: 1.6rem;
    border-bottom: 1px solid rgba(144, 50, 109, 0.35);
    margin-bottom: 3.2rem;
}

.u-contents {
    margin-bottom: 5rem;
    line-height: 1.5;
}

.c-tbl-list__tr {
    padding-bottom: 4rem;
}

.c-tbl-list__th {
    font-weight: 600;
    font-size: 1.6rem;
    padding-bottom: 1.4rem;
}

.c-tbl-list__td {
    font-size: 1.4rem;
}


/* ジャーナル
----------------------------------------------------*/
.journal_container {
    width: 70rem;
    margin: auto;
}

.journal_header {
    margin-top: 8rem;
}

.journal_header_date {
    font-size: 1.8rem;
    padding-bottom: 3rem;
}

.journal_header_title {
    font-size: 2rem;
    line-height: 1.75;
    padding-bottom: 4.6rem;
}

.journal_header_text {
    margin-bottom: 12rem;
}

.journal_header_text,
.journal_section_text {
    font-size: 1.6rem;
    line-height: 1.875;
}

.journal_section + .journal_section {
    margin-top: 10rem;
}

.journal_section_title {
    font-size: 1.6rem;
    line-height: 1.875;
    font-weight: 600;
    padding-bottom: 2.8rem;
}

.journal_section_img {
    margin-top: 6rem;
}

.journal_section_link {
    margin-top: 4rem;
    text-align: center;
}

.journal_section_text_link {
    color: #90326d;
}

.journal_section_text_link:hover {
    color: #90326d;
}

.journal_link_item {
    margin: 9.6rem auto 0;
    justify-content: center;
    align-items: center;
    width: 22.6rem;
    height: 6.2rem;
    border: 1px solid #90326d;
    color: #90326d;
    background: #fff;
    font-size: 1.7rem;
}

.journal_link_item:hover {
    background: #90326d;
    color: #fff;
    text-decoration: none;
}

/*f2 レシピ*/

.recipe_section {
    border-top: 1px solid rgba(0, 0, 0, 0.25);
    padding-top: 5.6rem;
    padding-bottom: 10rem;
}

.journal_header + .recipe_section {
    margin-top: 2rem;
}

.recipe_section:last-of-type {
    border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

.recipe_section_title {
    font-size: 1.8rem;
    line-height: 1.5;
    font-weight: 600;
    text-align: center;
    padding-bottom: 2.8rem;
}

.recipe_section_text {
    font-size: 1.6rem;
    line-height: 1.875;
    text-align: center;
    padding-bottom: 4.6rem;
}

.recipe_section_img {
    padding-bottom: 7.8rem;
}

.recipe_detail {
    justify-content: space-between;
}

.recipe_detail_zairyo {
    width: 44%;
}

.recipe_detail_header {
    color: #90326d;
    font-weight: 600;
    font-size: 1.6rem;
    padding-bottom: 1.4rem;
}

.recipe_detail_zairyo_list {
    margin: 0;
    border-top: 1px solid rgba(144, 50, 109, 0.35);
}

.recipe_detail_zairyo_list dt {
    width: 48%;
    padding-right: 1%;
    font-weight: 400;
    padding-top: 1.3rem;
    padding-bottom: 1.3rem;
    border-bottom: 1px solid rgba(144, 50, 109, 0.35);
    font-size: 1.5rem;
    line-height: 1.5;
}

.recipe_detail_zairyo_list dd {
    width: 52%;
    text-align: right;
    margin: 0;
    padding-top: 1.3rem;
    padding-bottom: 1.3rem;
    border-bottom: 1px solid rgba(144, 50, 109, 0.35);
    font-size: 1.4rem;
    line-height: 1.5;
}

.recipe_detail_zairyo_name {
    font-size: 1.5rem;
    line-height: 1.5;
    padding-top: 3.2rem;
    padding-bottom: 1.6rem;
}

.recipe_detail_flow {
    width: 45%;
}

.recipe_detail_flow_list {
    margin: 0;
}

.recipe_detail_flow_list dt {
    width: 11%;
    padding-right: 2%;
    font-size: 2.5rem;
    color: #90326d;
    font-weight: 400;
    padding-bottom: 3.2rem;
}

.recipe_detail_flow_list dd {
    width: 89%;
    font-size: 1.6rem;
    line-height: 1.6;
    margin: 0;
    padding-bottom: 3.2rem;
}

.recipe_detail_flow_name {
    font-size: 1.5rem;
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.recipe_credit {
    font-size: 1.4rem;
    text-align: right;
    padding-top: 3.2rem;
}


/*f3 飲み方*/

.howto_section {
    border-top: 1px solid rgba(0, 0, 0, 0.25);
    padding-top: 8rem;
    padding-bottom: 10rem;
}

.journal_header + .howto_section {
    margin-top: 2rem;
}

.howto_section:last-of-type {
    border-bottom: 1px solid rgba(0, 0, 0, 0.25);
}

.howto_title_en {
    text-align: center;
    font-size: 2rem;
    font-style: italic;
    padding-bottom: 1.4rem;
    color: #90326d;
}

.howto_title_en span {
    font-size: 2.4rem;
}

.recipe_section_title {
    font-size: 1.8rem;
    line-height: 1.66;
    font-weight: 400;
    text-align: center;
    padding-bottom: 8rem;
}

.howto_section_inner {
    justify-content: space-between;
}

.howto_section_img {
    width: 50%;
}

.howto_section_body {
    width: 42%;
}

.recipe_section_sub_title {
    font-size: 1.6rem;
    color: #90326d;
    font-weight: 600;
    padding-bottom: 3.4rem;
}

.recipe_section_main_text {
    font-size: 1.6rem;
    line-height: 1.6;
}

.recipe_section_sub_text {
    font-size: 1.3rem;
    line-height: 1.6;
    padding-top: 2.8rem;
}


/*モーダル*/
.overlay {
    display: none;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,0.7);
    position: fixed;
    z-index: 9999;
}
.btn_area {
    width: 400px;
    max-width: 80%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    text-align: center;
    z-index: 10000;
}

.btn_area button {
    font-family: 'Shippori Mincho', serif;
    position: absolute;
    bottom: -6.4rem;
    left: 0;
    right: 0;
    display: block;
    margin: 0 auto;
    background: transparent;
    color: #fff;
    padding: 2rem 1.2rem;
    border: none;
    font-size: 2.4rem
}

/* 年齢制限
----------------------------------------------------*/
.header {
    margin: 0 36% !important;
}

#main_i img{
    width: 150px;
}

.validation_txt {
    color: #90326d !important;
}

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

PCのみ

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

@media screen and (min-width: 900px) {
    .display_sp {
        display: none !important;
    }
}


@media screen and (max-width: 1199px) and (min-width: 900px) {
    html {
        font-size: 56%;
    }
}


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

ドロワーメニュー　1099px以下で有効化

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

@media screen and (max-width: 1099px) {

    /* ヘッダー
    ----------------------------------------------------*/

    .header_nav {
        display: none;
    }

    /*ドロワーメニュー*/

    .drawer-hamburger {
        display: block;
        width: 3.6rem;
        height: 2.4rem;
        padding: 0;
        position: fixed;
        left: 5%;
        top: 2.4rem;
        z-index: 999;
        background: none;
    }

    .drawer-hamburger-icon,
    .drawer-hamburger-icon:after,
    .drawer-hamburger-icon:before {
        transition: all .3s cubic-bezier(.19, 1, .22, 1);
    }

    .drawer-hamburger-icon {
        position: relative;
        display: block;
        width: 100% !important;
        height: 1px;
        background-color: #333;
    }

    .drawer-hamburger-icon:after,
    .drawer-hamburger-icon:before {
        position: absolute;
        content: " ";
        height: 1px;
        width: 100%;
        background-color: #333;
        left: 0;
        right: 0;
        margin: auto;
    }

    .drawer-hamburger-icon:before {
        top: -.9rem !important;
    }

    .drawer-hamburger-icon:after {
        top: .9rem !important;
    }

    .header_container:not(.header-top) .drawer-hamburger-icon,
    .header_container:not(.header-top) .drawer-hamburger-icon:before,
    .header_container:not(.header-top) .drawer-hamburger-icon:after,
    .is-fixed.header_container .drawer-hamburger-icon,
    .is-fixed.header_container .drawer-hamburger-icon:before,
    .is-fixed.header_container .drawer-hamburger-icon:after {
        background-color: #90326d;
    }

    .is-opened .drawer-hamburger-icon {
        background-color: transparent !important;
    }

    .is-opened .drawer-hamburger-icon::before {
        transform: rotate(45deg);
        top: 0 !important;
        background-color: #333;
        width: 120%;
    }

    .is-opened .drawer-hamburger-icon::after {
        transform: rotate(-45deg);
        top: 0 !important;
        background-color: #333;
        width: 120%;
    }

    .is-opened .drawer-hamburger-text {
        color: transparent;
    }

    .drawer-nav {
        display: block;
        background: #fff;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        position: fixed;
        top: -100%;
        bottom: 0;
        left: 0;
        z-index: 998;
        overflow-y: scroll;
        width: 100%;
        height: 100vh;
        height: 100dvh;
        max-height: 100%;
        transition: top .4s cubic-bezier(.19, 1, .22, 1);
        -webkit-overflow-scrolling: touch;
    }

    .is-opened .drawer-nav {
        top: 0;
        transition: top .4s cubic-bezier(.19, 1, .22, 1);
    }

    .drawer_inner {
        width: 18rem;
        min-height: 100vh;
        min-height: 100dvh;
        padding-top: 4rem;
        padding-bottom: 4.8rem;
        justify-content: center;
        align-content: center;
        margin: auto;
        text-align: center;
    }

    .drawer_logo {
        padding-bottom: 4.4rem;
    }

    .drawer_main_nav {
        font-size: 2rem;
        text-transform: uppercase;
        padding-bottom: 3.6rem;
        margin-bottom: 2.4rem;
        border-bottom: 1px solid #333;
    }

    .drawer_main_nav .main_nav_list,
    .drawer_sub_nav .sub_nav_list,
    .drawer_member_nav .sub_nav_list {
        margin: auto;
        flex-direction: column;
        color: #333;
    }

    .drawer_main_nav .main_nav_item + .main_nav_item {
        padding-top: 2rem;
    }

    .drawer_sub_nav {
        padding-bottom: 2.4rem;
        margin-bottom: 2.4rem;
        border-bottom: 1px solid #333;
    }

    .drawer_sub_nav,
    .drawer_member_nav {
        font-size: 1.3rem;
        width: 100%;
    }

    .sub_nav_item + .sub_nav_item {
        padding-top: 1.4rem;
    }

}



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

スマートフォンのみ

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


@media screen and (max-width: 899px) {

    .wrapper {
        width: 100%;
        margin-left: auto;
        margin-right: auto;
        padding-left: 4%;
        padding-right: 4%;
    }

    .display_pc {
        display: none !important;
    }

    .link_box {
        margin: 2rem auto 0;
        width: 64%;
        height: 5.4rem;
        font-size: 1.5rem;
    }

    /* ヘッダー
    ----------------------------------------------------*/


    .header_info{
        padding: .5rem 4%;
        font-size: 1.1rem;
    }

    .header_container {
        top: 2.2rem;
        padding-top: 1.9rem;
        padding-bottom: 1.6rem;
    }

    .header_inner {
        margin-left: 4%;
        margin-right: 4%;
    }

    .header_logo {
        width: 16rem;
    }

    .header_icon_list {
        top: 0;
    }

    .header_icon_item + .header_icon_item {
        margin-left: .9rem;
    }

    .header_icon_item svg {
        width: auto;
        height: 2.2rem;
    }

    .drawer-hamburger {
        width: 3rem;
        height: 2rem;
        left: 4%;
        top: 4.1rem;
    }

    .is-fixed .drawer-hamburger{
        top: 2rem;
    }


    /* メインコンテナー
    ----------------------------------------------------*/

    .main_container:not(.top) {
        padding-top: 10rem;
    }

    /* フッター
    ----------------------------------------------------*/

    .footer_container {
        margin-top: 6rem;
        padding-top: 6.2rem;
        padding-bottom: 2.8rem;
    }

    .footer_logo {
        width: 20rem;
    }

    .footer_main_nav {
        padding-top: 2.8rem;
        padding-bottom: 3.8rem;
    }

    .footer_main_nav .main_nav_list,
    .footer_sub_nav .sub_nav_list {
        flex-direction: column;
        align-content: center;
    }

    .footer_main_nav .main_nav_item + .main_nav_item {
        padding-left: 0;
        padding-top: 1.4rem;
    }

    .instagram_link {
        width: 2.8rem;
    }

    .footer_alcohol {
        padding-bottom: 2rem;
    }

    .footer_sub_nav {
        font-size: 1.1rem;
    }

    .footer_sub_nav .sub_nav_item + .sub_nav_item {
        padding-left: 0;
        padding-top: 1.2rem;
    }

    .footer_copyright {
        font-size: 1rem;
        padding-top: 3.8rem;
    }


    /* 一覧系
    ----------------------------------------------------*/

    .p-category__ttl {
        font-size: 2rem;
        padding-bottom: 1.4rem;
    }

    .c-item-list {
        margin: 0 auto 6rem;
        width: 100%;
    }

    .c-pager {
        font-size: 1.3rem;
    }

    /* 特定商取引法表示・プライバシーポリシー
    ----------------------------------------------------*/

    .c-ttl-second {
        font-size: 1.8rem;
        padding-bottom: 1.2rem;
        margin-bottom: 2.8rem;
    }

    .u-contents {
        margin-bottom: 4rem;
    }

    .c-tbl-list__tr {
        padding-bottom: 3rem;
    }

    .c-tbl-list__th {
        font-size: 1.5rem;
        padding-bottom: 1rem;
    }

    .c-tbl-list__td {
        font-size: 1.3rem;
    }


    /* ジャーナル
    ----------------------------------------------------*/
    .journal_container {
        width: 100%;
    }

    .journal_header {
        margin-top: 4rem;
    }

    .journal_header_date {
        font-size: 1.5rem;
        padding-bottom: 2rem;
    }

    .journal_header_title {
        font-size: 1.8rem;
        padding-bottom: 3.2rem;
    }

    .journal_header_text {
        margin-bottom: 8rem;
    }

    .journal_header_text,
    .journal_section_text {
        font-size: 1.4rem;
    }

    .journal_section + .journal_section {
        margin-top: 6rem;
    }

    .journal_section_title {
        font-size: 1.5rem;
        padding-bottom: 2rem;
    }

    .journal_section_img {
        margin-top: 3.2rem;
    }

    .journal_section_link {
        margin-top: 2.8rem;
    }

    .journal_section_link a {
        font-size: 1.5rem;
    }

    .journal_link_item {
        margin: 6rem auto 0;
        width: 64%;
        height: 5.4rem;
        font-size: 1.5rem;
    }


    /*f2 レシピ*/

    .recipe_section {
        padding-top: 4.4rem;
        padding-bottom: 2.8rem;
    }

    .journal_header + .recipe_section {
        margin-top: 1.2rem;
    }

    .recipe_section_title {
        font-size: 1.7rem;
        padding-bottom: 2rem;
    }

    .recipe_section_text {
        font-size: 1.4rem;
        padding-bottom: 3.2rem;
    }

    .recipe_section_img {
        padding-bottom: 4rem;
    }

    .recipe_detail_zairyo {
        width: 100%;
        margin-bottom: 4.8rem;
    }

    .recipe_detail_zairyo_list dt,
    .recipe_detail_zairyo_list dd {
        font-size: 1.3rem;
    }

    .recipe_detail_header {
        font-size: 1.5rem;
    }

    .recipe_detail_zairyo_name {
        font-size: 1.4rem;
        padding-top: 3.2rem;
        padding-bottom: 1.2rem;
    }

    .recipe_detail_flow {
        width: 100%;
    }

    .recipe_detail_flow_list {
        margin: 0;
    }

    .recipe_detail_flow_list dt {
        font-size: 2.1rem;
        padding-bottom: 2.4rem;
        width: 8%;
        padding-right: 1%;
    }

    .recipe_detail_flow_list dd {
        font-size: 1.4rem;
        padding-bottom: 2.4rem;
        width: 92%;
    }

    .recipe_detail_flow_name {
        padding-bottom: 1.2rem;
    }

    .recipe_credit {
        font-size: 1.2rem;
        padding-top: 2.4rem;
    }



    /*f3 飲み方*/

    .howto_section {
        padding-top: 4.4rem;
        padding-bottom: 5.2rem;
    }

    .journal_header + .howto_section {
        margin-top: 1.2rem;
    }

    .howto_title_en {
        font-size: 1.6rem;
        padding-bottom: 2rem;
    }

    .howto_title_en span {
        font-size: 2rem;
    }

    .recipe_section_title {
        font-size: 1.7rem;
        padding-bottom: 4.4rem;
    }

    .howto_section_img {
        width: 100%;
        padding-bottom: 4rem;
    }

    .howto_section_body {
        width: 100%;
    }

    .recipe_section_sub_title {
        font-size: 1.5rem;
        padding-bottom: 2rem;
    }

    .recipe_section_main_text {
        font-size: 1.4rem;
    }

    .recipe_section_sub_text {
        font-size: 1.2rem;
    }


    /* 年齢制限
    ----------------------------------------------------*/
    .header {
        margin: 0 20% !important;
    }

    .main {
        margin: 15px 8% !important;
    }

    #main_i img{
        width: 30%;
    }


    /*モーダル*/
    .btn_area button {
        font-size: 1.8rem
    }

}
