@charset "UTF-8";
@-webkit-keyframes DownAnime {
    from {
        opacity: 0;
        -webkit-transform: translateY(-150px);
                transform: translateY(-150px);
        }
        to {
        opacity: 1;
        -webkit-transform: translateY(0);
                transform: translateY(0);
        }
    }
    @keyframes DownAnime {
        from {
        opacity: 0;
        -webkit-transform: translateY(-150px);
                transform: translateY(-150px);
        }
        to {
        opacity: 1;
        -webkit-transform: translateY(0);
                transform: translateY(0);
    }
}
html {
    scroll-behavior: smooth;
}
header #gnav.fixed {
    -webkit-animation: DownAnime 0.5s forwards;
            animation: DownAnime 0.5s forwards;
}
header {
    opacity: 0;
    position: fixed;
}
body.on header {
    opacity: 1;
}
a {
    display: initial;
}
.spOnly {
    display: block;
}
.top {
    position: relative;
}
.red {
    color: #DC4600;
}
main {
    position: relative;
    overflow: hidden;
    margin-top: 0 !important;
    color: #00281E;
}
section .inner {
    max-width: 700px;
    padding-bottom: 82px;
}
.wrapper {
    background: url(../images/bg-sp.webp) repeat-y;
    background-size: 100% auto;
    background-position: center top;
    position: relative;
}
.wrapper > .inner {
    max-width: 1000px;
    margin: 0 auto;
    background: rgba(255, 255, 255, .85);
}

.yodogawa {
    max-width: 700px;
    margin-inline: auto;
    padding: 42px 20px;
    position: relative;
}
.yodogawa .text {
    font-family: "A1 Gothic R", sans-serif;
    font-size: 1.5rem;
    line-height: 1.6;
}
.yodogawa .image {
    max-width: 692px;
    margin: 16px auto 0;
}
.yodogawa a {
    color: #DC4600;
}

.list {
    padding: 10px 0 0;
}
.products li dl dt {
    height: auto;
}

.products li dl dt h3 {
    font-size: 1.5rem;
    font-feature-settings: 'palt';
    letter-spacing: .1em;
}

.products li dl dt h3 small {
    font-size: 1.2rem;
    line-height: 15px; /* 125% */
    padding-top: 10px;
}
.products dl dt h3 + p {
    margin: 16px 0;
}
.products dl dt .price {
    position: relative;
    bottom: initial;
    font-size: 1.8rem;
}
.products dl dt .price small {
    font-size: 1.3rem;
}
.products dl dt::after {
    display: none;
}
.products .cart_btn {
    width: 100%;
    border: 1px solid #00281E;
    display: block;
    text-align: center;
    line-height: 1;
    padding: 4px 12%;
}
.products .cart_btn.sold {
    border: none;
    background-color: #d0d0ca;
    padding: 9px 0;
}
.products dl dt .notes {
    color: #DC4600;
    font-size: 1.2rem;
    text-align: center;
    padding-top: 8px;
}
.products2 {
    max-width: 300px;
    margin: 44px auto 0;
    display: block;
}
.products2 li {
    width: 100% !important;
}
.products2 li + li{
    margin-top: 44px;
}
.products2 li dl dt h3 {
    font-size: 2rem;
}
.products2 li dl dt h3 small {
    display: inline-block;
    font-size: 1.5rem;
}
.products2 dl dt {
    padding-top: 27px;
}
.products2 dl dt h3 + p {
    margin: 8px 0 0;
    color: #000;
}
.products2 dl dd {
    position: relative;
}
.products2 dl dd::after {
    content: "";
    display: block;
    background: url(/store/shinkuu/images/common/btn_more.svg) no-repeat;
    background-size: contain;
    width: 120px;
    height: 35px;
    position: absolute;
    right: 0;
    bottom: 0;
}
.pre {
    margin-top: 20px;
}
.pre a {
    color: #DC4600;
}
.banner {
    max-width: 460px;
    width: 88%;
    margin: 0 auto;
    padding: 0 0 86px;
}
.banner li + li {
    margin-top: 24px;
}
@media (min-width: 768px) {
    main {
        top: 0;
        position: initial;
    }
    .spOnly {
        display: none;
    }
    .wrapper {
        background: url(../images/bg-pc.webp) repeat-y;
        background-size: 100% auto;
        background-position: center top;
        padding-bottom: 100px;
    }
    .wrapper > .inner {
        background: rgba(255, 255, 255, 1);
    }
    .yodogawa {
        padding: 60px 0 90px;
    }
    .yodogawa .text {
        padding-left: 130px;
        font-size: 1.5rem;
        line-height: 1.6;
    }
    .yodogawa .image {
        margin: 40px auto 0;
    }    
    .info {
        margin: 0 auto 60px;
    }
    .list {
        padding: 0;
        margin-bottom: 0;
    }    
    .products {
        justify-content: center;
        gap: 40px 32px;
    }
    .products dl dt {
        height: 160px;
        padding-top: 1.1em;
    }
    .products2 dl dt {
        padding-top: 0;
    }
    .products li {
        width: 210px;
    }
    .products li dl dt h3 {
        font-size: 1.8rem;
        min-height: 116px;
    }    
    .products li dl dt h3 span {
        line-height: calc(25 / 18);
    }    
    .products li dl dt h3 small {
        font-size: 1.4rem;
    }
    .products li dl dt::after {
        bottom: 0;
    }
    .products li dl dt .price {
        font-size: 1.8rem;
    }
    .products li dl dt .price + span {
        font-size: 1.3rem;
    }
    .products dl dt h3 + p {
        padding-bottom: 16px;
    }
    .products dl dt .notes {
        font-size: 1.3rem;
    }
    .products li .cart {
        bottom: 30px;
    }
    .products li .cart img {
        width: 38px;
    }
    .products2 {
        max-width: 100%;
        padding-top: 70px;
        border-top: 1px solid;
    }
    .products2 dl  {
        display: flex;
        align-items: center;
        gap: 36px;
        position: relative;
    }
    .products2 dl dd img {
        width: 210px;
    }
    .products2 dl dd::after {
        display: none;
    }
    .products2 dl::after {
        content: "";
        display: block;
        background: url(/store/shinkuu/images/common/btn_more.svg) no-repeat;
        background-size: contain;
        width: 120px;
        height: 35px;
        position: absolute;
        right: 0;
        bottom: 0;
    }
    .products2 li dl dt h3 {
        min-height: initial;
        font-size: 2rem;
    }
    .products2 li dl dt h3 small {
        font-size: 1.5rem;
    }
    .products2 dl dt h3 + p {
        padding-bottom: 0;
        font-size: 1.5rem;
    }
    .pre {
        width: max-content;
        margin: 20px auto 0;
    }
    footer {
        margin-top: 0;
    }
}
@media (max-width: 768px) {
    .products {
        gap: 46px 24px;
    }
    .products li {
        width: calc((100% - 24px) / 2);
    }
}
@media (max-width: 980px) {
    header #gnav .gnav_inner {
        height: auto;
    }
}