@charset "UTF-8";

.grid {
display: grid;
}

.flex {
    display: flex;
}

.o-flex {
    display: flex;
    gap: 5rem;
}
@media only screen and (max-width: 559px) {
    .o-flex {
        flex-direction: column;
    }
}
.o-flex--c {
    justify-content: center;
}
.o-flex--b {
    justify-content: space-between;
}
.o-flex--e {
    justify-content: flex-end;
}
.o-flex__item {
    width: calc((100% - 5rem) / 2);
}
@media only screen and (max-width: 559px) {
    .o-flex__item {
        width: 100%;
    }
}
.o-flex__item--1 {
    width: calc((100% - 6rem) / 3);
}
.o-flex__item--2 {
    width: calc((100% - 6rem) / 3 * 2);
}

.sp-slider img {
    width: 100%;
    height: auto;
    display: block;
}

/* ドット全体 */
.slick-dots {
    text-align: center;
    margin-top: 10px;
    padding: 0;
    margin-bottom: 20px;
}

/* ドットのリスト */
.slick-dots li {
    display: inline-block;
    margin: 0 0.4rem;
}

/* ドットボタン */
.slick-dots button {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background-color: #ccc;
    border: none;
    text-indent: -9999px;
    overflow: hidden;
    cursor: pointer;
    transition: background-color 0.3s ease;
    padding: 0;
}

/* アクティブなドット */
.slick-dots .slick-active button {
    background-color: #ff74c8;
}

/* 矢印の共通設定 */
.slick-prev,
.slick-next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    z-index: 10;
    width: 2.5rem;
    height: 2.5rem;
    background-color: rgba(255, 116, 200, 0.4);
    color: white;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    font-size: 0;
    line-height: 0;
    transition: background-color 0.3s ease;
}

/* 左矢印 */
.slick-prev {
    left: -1rem;
}

/* 右矢印 */
.slick-next {
    right: -1rem;
}

/* アイコン用の疑似要素 */
.slick-prev::before,
.slick-next::before {
    font-family: "slick";
    font-size: 1.4rem;
    line-height: 1;
    color: #fff;
}

/* Slick標準の矢印文字 */
.slick-prev::before {
    content: "←";
}

.slick-next::before {
    content: "→";
}

body {
    background: url(https://xs042290.xsrv.jp/oshiga/assets/images/bk.webp);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    background-attachment: fixed;
    overflow-x: hidden;
}

.holder {
    width: 900px;
    margin-inline: auto;
}
@media only screen and (max-width: 1024px) {
    .holder {
        width: 100%;
        padding: 0 30px;
    }
}

.pc {
    display: block;
}
@media only screen and (max-width: 559px) {
    .pc {
        display: none;
    }
}

.sp {
    display: none;
}
@media only screen and (max-width: 559px) {
    .sp {
        display: block;
    }
}

h2,
p {
    color: black;
}

ul li {
    margin-bottom: 0;
}

.item-list {
    column-gap: 30px;
}

.footer {
    border-top: none;
    padding-top: 15px;
    background: #e1e6eb;
    padding-bottom: 8px;
}
@media only screen and (max-width: 559px) {
    .footer {
        padding-top: 30px;
        padding-bottom: 0;
    }
}

.footer-bottom {
    background: #e1e6eb;
}

.footer-info {
    padding-left: 0;
}
@media only screen and (max-width: 559px) {
    .footer-info {
        flex-direction: column;
        align-items: flex-start;
    }
}

@media only screen and (max-width: 559px) {
    .footer-menu-list-item {
        font-size: 14px;
        padding: 0;
        margin-bottom: 10px;
        line-height: 1;
    }
}

@media only screen and (max-width: 559px) {
    .footer-menu-list-item:not(:last-child) {
        border-right: none;
    }
}

@media only screen and (max-width: 559px) {
    .footer-contents {
        margin: 0 20px;
        padding: 0;
    }
}

#start-contents .contents-section {
    margin-block: 0;
}

.copy-right {
    margin-bottom: 0;
    padding-bottom: 25px;
}
@media only screen and (max-width: 559px) {
    .copy-right {
        text-align: left;
        padding-left: 20px;
        padding-bottom: 30px;
        font-size: 11px;
    }
}

.footer-menu {
    margin-bottom: 0;
}

.information-list,
.news-link {
    border-color: #fff;
}

header {
    height: auto;
}

.second-nav {
    align-items: center;
    gap: 20px;
    transform: scale(1.2);
    margin-top: 20px;
}
.second-nav li span {
    padding: 8px 0;
}
.second-nav img {
    margin-bottom: 2px;
}

.header-inner:first-child {
    border-bottom: none;
}

.search-box {
    display: block;
}

.search-icon {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 17px;
    height: 17px;
    left: 10px;
}
.search-icon img {
    width: 17px;
    height: 17px;
    margin: 0;
}

.btn-go.search-url {
    position: relative;
}

a.btn-go {
    background-color: inherit;
}

.close {
    display: none;
}

input[type="text"] {
    width: 144px;
    height: 28px;
    border-bottom: none;
    border-radius: calc(infinity * 1px);
    margin: 0;
    padding: 5px 10px 5px 35px;
}

span.cart-badge {
    width: 17px;
    height: 17px;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 50%;
    top: -5px;
    right: -13px;
    background: #d70000;
    padding: 0 !important;
}

.top-bar {
    box-shadow: none;
}

.header-wrap {
    padding-block: 10px;
    padding-right: 200px;
}
@media screen and (max-width: 1184px) {
    .header-wrap {
        padding-right: 50px;
    }
}
@media only screen and (max-width: 559px) {
    .header-wrap {
        padding: 0;
    }
}

@media only screen and (max-width: 559px) {
    .contents-section {
        padding: 0;
        max-width: 100%;
        margin: 0;
    }
}

@media only screen and (max-width: 559px) {
    .check__ttl {
        margin-bottom: 10px;
    }
}
@media only screen and (max-width: 559px) {
    .check__ttl img {
        height: 17px;
        width: auto;
    }
}

@media only screen and (max-width: 559px) {
    .item-list {
        column-gap: 15px;
    }
}

.shop-logo img {
    width: 155px;
    height: auto;
}
@media only screen and (max-width: 559px) {
    .shop-logo img {
        width: 94.5px;
    }
}

@media only screen and (max-width: 559px) {
    .header-inner:first-child {
        padding-top: 5px;
        padding-bottom: 5px;
    }
}


@media only screen and (max-width: 559px) {
    .mv__area {
        padding-top: 63px;
    }
}

@media only screen and (max-width: 559px) {
    .sp-nav-wrap a {
        position: relative;
        color: #fff;
        display: flex;
        align-items: center;
        gap: 10px;
    }
}

@media only screen and (max-width: 559px) {
    .menu-trigger {
        left: inherit;
        right: 10px;
        width: 30px;
        height: 30px;
        top: 17px;
        transition: 0.5s;
    }
}
@media only screen and (max-width: 559px) {
    .menu-trigger.active {
        top: 60px;
        right: 30px;
    }
}

@media only screen and (max-width: 559px) {
    .menu-trigger span {
        height: 2px;
    }
}

@media only screen and (max-width: 559px) {
    .menu-trigger span:nth-of-type(2) {
        top: 10px;
    }
    .menu-trigger span:nth-of-type(3) {
        bottom: 11px;
    }
    .menu-trigger.active span:nth-of-type(3) {
        transform: translateY(-3px) rotate(45deg);
        background: #fff;
    }
    .menu-trigger.active span:nth-of-type(1) {
        transform: translateY(10px) rotate(-45deg);
        background: #fff;
    }
    span.cart-badge {
        position: static;
    }
}
.oshiga__wrap {
    background: #fff;
    width: 1000px;
    margin-inline: auto;
    padding-inline: 50px;
    margin-top: 105px;
    padding-block: 30px 55px;
}
@media only screen and (max-width: 1024px) {
    .oshiga__wrap {
        width: 100%;
        padding-inline: 25px;
        margin-top: 60px;
        padding-bottom: 25px;
    }
}

.item-title-wrap {
    padding: 0;
}

@media only screen and (max-width: 559px) {
    .accordion-container .article-title,
    nav li a,
    .accordion-content a {
        color: #fff;
    }
    nav.open {
        background: #000 !important;
        padding-top: 60px;
    }
    nav ul {
        margin-top: 45px;
    }
    dl.search1 dt {
        background: #000;
    }
    dl.search1 dd button span {
        filter: invert(1);
        opacity: 0.5;
    }
    .cart-link {
        margin-left: 0;
        padding: 10px 20px;
    }
    dl.search1 dt input {
        color: #fff;
    }
}
.accordion-content p {
    margin-bottom: 0;
}

.breadcrumb {
    border-bottom: 1px solid #9a9a9a;
    width: fit-content;
}

.breadcrumb-item {
    font-size: 14px;
    font-weight: 500;
}
@media only screen and (max-width: 559px) {
    .breadcrumb-item {
        font-size: 11px;
    }
}

@media only screen and (max-width: 559px) {
    header {
        height: auto;
    }
}

.original,
.top-news {
    border-bottom: none;
}
@media only screen and (max-width: 1024px) {
    .original,
    .top-news {
        padding-inline: 30px;
    }
}

.original,
.check {
    background: #fff;
    width: 100vw;
    left: 50%;
    transform: translateX(-50%);
    position: relative;
    padding: 55px 0 35px;
}
@media only screen and (max-width: 559px) {
    .original,
    .check {
        padding: 40px 0 25px;
    }
}

.check {
    padding: 0;
}
.check .holder {
    padding: 55px 25px 35px;
}
@media only screen and (max-width: 559px) {
    .check .holder {
        padding: 40px 25px 25px;
    }
}

.mv__area {
    margin-bottom: 0;
    background: #000;
    padding-top: 0;
}
@media only screen and (max-width: 559px) {
    .mv__area {
        padding-bottom: 5px;
        display: flex;
        flex-direction: column;
        gap: 5px;
    }
}

.swiper-slide a {
    display: block;
    cursor: pointer;
}
.swiper-slide a:hover {
    opacity: 0.8;
}

.swiper-slide img {
    width: 100%;
    height: auto;
    aspect-ratio: 426/312;
    object-fit: cover;
}
@media only screen and (max-width: 559px) {
    .swiper-slide img {
        aspect-ratio: 375/453;
    }
}

.swiper-wrapper {
    transition-timing-function: ease-in-out !important;
}

@media only screen and (max-width: 559px) {
    .swiper-container {
        height: 250px;
    }
}

.swiper-pagination1 {
    display: block !important;
    opacity: 1 !important;
    z-index: 10 !important;
}

.swiper-button-prev,
.swiper-button-next {
    width: 35px;
    height: 35px;
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
}
@media only screen and (max-width: 559px) {
    .swiper-button-prev,
    .swiper-button-next {
        width: 25px;
        height: 25px;
    }
}

/* 前へボタン用の画像 */
.swiper-button-prev {
    background-image: url("https://xs042290.xsrv.jp/oshiga/assets/images/left.webp");
}

/* 次へボタン用の画像 */
.swiper-button-next {
    background-image: url("https://xs042290.xsrv.jp/oshiga/assets/images/right.webp");
}

.swiper-button-next:after,
.swiper-button-prev:after {
    display: none;
}

.about {
    padding: 70px 0 50px;
    margin-bottom: 0;
}
@media only screen and (max-width: 1024px) {
    .about {
        padding-inline: 30px;
    }
}
@media only screen and (max-width: 559px) {
    .about {
        padding-inline: 20px;
        padding-block: 30px;
        margin-bottom: 0;
        margin-top: 0;
    }
}
.about__flex {
    justify-content: center;
    gap: 55px;
}
@media only screen and (max-width: 559px) {
    .about__flex figure {
        margin-inline: auto;
    }
}
@media only screen and (max-width: 559px) {
    .about__flex figure img {
        width: 245px;
        height: auto;
    }
}
@media only screen and (max-width: 559px) {
    .about__flex {
        flex-direction: column-reverse;
        gap: 10px;
    }
}
.about__ttl {
    margin-bottom: 35px;
    text-align: left;
    font-size: 38px;
    line-height: 1.5;
}
@media only screen and (max-width: 559px) {
    .about__ttl {
        font-size: 28px;
        margin-bottom: 20px;
    }
}
.about__message {
    font-size: 16px;
    line-height: 2.1;
    text-align: left;
}
@media only screen and (max-width: 559px) {
    .about__message {
        padding: 0;
        font-size: 14px;
        line-height: 1.75;
    }
}
.about__message span {
    color: #ff73c8;
    font-weight: 700;
}

.original {
    display: none;
}
.original__wrap {
    overflow: hidden;
    width: 100%;
    display: flex;
    gap: 50px;
    margin-bottom: 30px;
}
@media only screen and (max-width: 559px) {
    .original__wrap {
        margin-bottom: 15px;
    }
}
.original__inner {
    display: flex;
    gap: 50px;
    animation: scrollSlider 40s linear infinite;
    width: max-content;
}
@media only screen and (max-width: 559px) {
    .original__inner {
        animation: scrollSlider 80s linear infinite;
    }
}
.original__list {
    display: flex;
    gap: 50px;
}
@media only screen and (max-width: 559px) {
    .original__list {
        flex-wrap: nowrap;
        gap: 25px;
    }
}
.original__listitem {
    flex-shrink: 0;
}
@media only screen and (max-width: 559px) {
    .original__listitem img {
        width: 97.5px;
        height: auto;
    }
}
.original__text {
    line-height: 1;
}
@media only screen and (max-width: 559px) {
    .original__text {
        font-size: 13px;
        margin-bottom: 25px;
    }
}
.original__text--02 {
    text-align: center;
    font-size: 12px;
}
@media only screen and (max-width: 559px) {
    .original__text--02 {
        font-size: 10px;
    }
}
@media only screen and (max-width: 559px) {
    .original__ttl {
        margin-bottom: 10px;
        line-height: 1;
    }
}
@media only screen and (max-width: 559px) {
    .original__ttl img {
        height: 17px;
        width: auto;
    }
}

@keyframes scrollSlider {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-50%);
    }
}
@media only screen and (max-width: 559px) {
    .top-news {
        padding-block: 40px 30px;
    }
}

@media only screen and (max-width: 1024px) {
    .information-list-wrap {
        width: 100%;
        padding: 0 30px;
    }
}
@media only screen and (max-width: 559px) {
    .information-list-wrap {
        padding: 0;
    }
}

.information-label,
.information-contents {
    font-weight: 700;
    line-height: 1.6;
}
@media only screen and (max-width: 559px) {
    .information-label,
    .information-contents {
        font-size: 15px;
    }
}

.product-caption {
    font-weight: 500;
    font-size: 14px;
    line-height: 1.75;
}
@media only screen and (max-width: 559px) {
    .product-caption {
        font-size: 11px;
        display: block;
        line-height: 1.75;
    }
}

@media only screen and (max-width: 559px) {
    .product-price {
        font-size: 11px;
        margin-top: 0;
    }
}

@media only screen and (max-width: 559px) {
    .check .contents-section h3 {
        line-height: 1;
        font-size: 10px;
        margin-bottom: 20px;
    }
}
@media only screen and (max-width: 559px) {
    .check span.product-caption,
    .check .product-price {
        font-size: 11px;
        display: block;
    }
}

.top-name {
    padding-top: 105px;
}
@media only screen and (max-width: 559px) {
    .top-name {
        padding-top: 63px;
    }
}
.top-name__wrap {
    overflow: hidden;
    width: 100%;
    background: #000;
}
.top-name__inner {
    display: flex;
    gap: 0;
    animation: scrollName 30s linear infinite;
    width: max-content;
}
.top-name img {
    height: 55px;
    width: auto;
}
@media only screen and (max-width: 559px) {
    .top-name img {
        height: 35px;
    }
}

@keyframes scrollName {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(-50%);
    }
}
.cart-title {
    font-size: 24px;
    display: flex;
    gap: 15px;
    border-bottom: none;
    letter-spacing: 0;
    align-items: center;
}
@media only screen and (max-width: 559px) {
    .cart-title {
        margin-bottom: 10px;
    }
}

.cart-text-head {
    display: none;
}

.cart {
    margin-top: 20px;
}
@media only screen and (max-width: 559px) {
    .cart {
        margin-top: 0;
    }
}
.cart .img {
    width: 30%;
}
.cart .img img {
    width: 100%;
    height: auto;
    aspect-ratio: 1/1;
}
@media only screen and (max-width: 559px) {
    .cart .img img {
        padding-right: 0;
    }
}
.cart .name {
    width: 100%;
    font-size: 21px;
    margin-bottom: 20px;
}
@media only screen and (max-width: 559px) {
    .cart .name {
        margin-bottom: 7.5px;
    }
}
.cart .name a {
    padding-bottom: 20px;
    border-bottom: 1px solid #dddddd;
    display: block;
    margin-bottom: 20px;
}
@media only screen and (max-width: 559px) {
    .cart .name a {
        font-size: 14px;
        padding-bottom: 7.5px;
        margin-bottom: 7.5px;
        line-height: 1.75;
    }
}
.cart .price {
    font-size: 21px;
    margin-bottom: 20px;
}
@media only screen and (max-width: 559px) {
    .cart .price {
        font-size: 12px;
        margin-bottom: 7.5px;
    }
}
.cart .price span {
    font-size: 16px;
}
@media only screen and (max-width: 559px) {
    .cart .price span {
        font-size: 8px;
    }
}
.cart .qty {
    width: 100%;
}
@media only screen and (max-width: 559px) {
    .cart .qty {
        gap: 5px;
        align-items: center;
    }
}
.cart .remove {
    width: 50px;
    border-radius: 5px;
    background-color: #000;
    margin-left: 10px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
}
@media only screen and (max-width: 559px) {
    .cart .remove {
        width: 25px !important;
        height: 30px;
        margin: 0;
    }
}
.cart .remove a {
    color: #fff;
    font-size: 27px;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    text-align: center;
    transition: 0.5s;
}
@media only screen and (max-width: 559px) {
    .cart .remove a {
        font-size: 11px;
    }
}
.cart .remove a:hover {
    background-color: #ff74c8;
    opacity: 1;
    border-radius: 5px;
}
.cart .total {
    text-align: center;
    margin: 35px 0 30px;
}
@media only screen and (max-width: 559px) {
    .cart .total {
        margin: 20px;
    }
}
@media only screen and (max-width: 559px) {
    .cart .total .total-text {
        padding: 0;
        margin: 0;
        font-size: 20px;
        line-height: 1;
    }
}
@media only screen and (max-width: 559px) {
    .cart .total .total-price {
        font-size: 20px;
        padding-left: 0px;
    }
}
.cart .total--head {
    margin: 0;
    background: #f0f0f0;
    margin-bottom: 20px;
}
@media only screen and (max-width: 559px) {
    .cart .total--head {
        margin-bottom: 10px;
    }
}
.cart .total--head .total-text {
    text-align: left;
    line-height: 1;
    padding: 15px 25px;
    margin: 0;
    font-size: 21px;
}
@media only screen and (max-width: 559px) {
    .cart .total--head .total-text {
        font-size: 14px;
    }
}
.cart .total--head .total-price {
    font-weight: 700;
    font-size: 21px;
    padding-left: 5px;
}
@media only screen and (max-width: 559px) {
    .cart .total--head .total-price {
        font-size: 12px;
    }
}
.cart .total--head .total-text-small {
    font-weight: 700;
}
@media only screen and (max-width: 559px) {
    .cart .total--head .total-text-small {
        font-size: 12px;
    }
}

.cart-option-area {
    width: 100%;
    font-size: 21px;
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid #dddddd;
}
@media only screen and (max-width: 559px) {
    .cart-option-area {
        font-size: 12px;
        margin-bottom: 7.5px;
        padding-bottom: 7.5px;
        line-height: 1.75;
    }
}

@media only screen and (max-width: 559px) {
    .awesome {
        height: 30px !important;
        margin-bottom: 0 !important;
    }
}
.awesome a {
    background: #000 !important;
    width: 200px !important;
    margin-left: 10px;
    transition: 0.5s;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 17px;
    appearance: none;
    -webkit-appearance: none;
}
@media only screen and (max-width: 559px) {
    .awesome a {
        width: 85px !important;
        padding: 0;
        height: 30px !important;
        margin: 0;
        border-radius: 3px;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 11px;
    }
}
.awesome a:hover {
    background-color: #ff74c8 !important;
    opacity: 1;
}

.cart-product {
    gap: 20px;
    border-bottom: none;
    background: #f0f0f0;
    padding: 10px;
    align-items: flex-start;
    padding-top: 15px;
}
@media only screen and (max-width: 559px) {
    .cart-product {
        gap: 10px;
        padding: 10px;
    }
}
.cart-product:not(:last-child) {
    margin-bottom: 20px;
}
@media only screen and (max-width: 559px) {
    .cart-product:not(:last-child) {
        margin-bottom: 10px;
    }
}

.cart-item-text {
    flex-direction: column;
    width: 70%;
    align-items: flex-start;
}

.cart-point,
.cart-nameprint-area,
.item-cart-options {
    margin-top: 10px;
    letter-spacing: 0.05em;
    line-height: 1;
}
@media only screen and (max-width: 559px) {
    .cart-point,
    .cart-nameprint-area,
    .item-cart-options {
        font-size: 10px;
        margin: 0;
    }
}

.quantity-notification {
    width: 330px;
    height: 50px;
    border-radius: 5px;
    box-shadow: none;
    appearance: none;
    -webkit-appearance: none;
}
@media only screen and (max-width: 559px) {
    .quantity-notification {
        width: 85px;
        height: 30px;
        border: 1px solid;
        font-size: 16px;
    }
}

.payment-add-btn {
    flex-direction: row;
    align-items: flex-start;
    justify-content: center;
    gap: 35px;
    display: flex;
}
@media only screen and (max-width: 559px) {
    .payment-add-btn {
        margin-bottom: 10px;
        flex-direction: column-reverse;
    }
}

.add-btn {
    background: #000;
    font-size: 22px;
    border-radius: 5px;
    width: 400px;
    height: 55px;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.5s;
}
@media only screen and (max-width: 559px) {
    .add-btn {
        font-size: 14px;
        width: 200px;
        height: 40px;
        margin-inline: auto;
    }
}
.add-btn:hover {
    background-color: #ff74c8;
}
.add-btn a {
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: 0.5s;
}

@media only screen and (max-width: 559px) {
    .add-btn-left {
        width: 100%;
        display: flex;
        justify-content: center;
    }
}

.add-btn-right {
    width: 400px;
}
@media only screen and (max-width: 559px) {
    .add-btn-right {
        width: 100%;
        display: flex;
        justify-content: center;
        flex-direction: column;
    }
}

.amazon-button {
    width: 400px;
    display: block;
}
@media only screen and (max-width: 559px) {
    .amazon-button {
        width: 200px;
        margin-inline: auto;
    }
}

.cart-page .breadcrumb {
    margin-bottom: 40px;
}
@media only screen and (max-width: 559px) {
    .cart-page .breadcrumb {
        margin-bottom: 20px;
    }
}

@media only screen and (max-width: 559px) {
    .cart-table {
        border-top: none;
    }
    .cart-item-text div {
        width: auto !important;
    }
}
.makeshop-option-label {
    margin-bottom: 9px;
}

.item-inner {
    margin-top: 0;
}
@media only screen and (max-width: 559px) {
    .item-inner .description-text {
        line-height: 1.75;
    }
}
@media only screen and (max-width: 559px) {
    .item-inner .product-price-block {
        font-size: 26px;
        margin-bottom: 10px;
        line-height: 1;
    }
}
.item-inner .product-name {
    font-size: 26px;
    font-weight: 700;
    border-bottom: none;
    padding-bottom: 0;
    margin-bottom: 0;
}
@media only screen and (max-width: 559px) {
    .item-inner .product-name {
        font-size: 20px;
        margin-bottom: 10px;
    }
}

.item-image {
    flex: inherit;
    max-width: 50%;
}
@media only screen and (max-width: 559px) {
    .item-image {
        max-width: 100%;
    }
}

.detail {
    gap: 40px;
    justify-content: flex-start;
}

.detail-right {
    flex: inherit;
    max-width: 46%;
    padding-top: 0;
}
@media only screen and (max-width: 559px) {
    .detail-right {
        max-width: 100%;
    }
}

.item-image-large {
    padding-left: 0;
}

.item-image-list {
    margin-right: 0;
}

.bg-section {
    background-color: #fff;
    padding: 0;
}
@media only screen and (max-width: 559px) {
    .bg-section {
        margin-top: 20px;
    }
}

.oshiga__item .item-list {
    padding-left: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .item-list {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }
}
.oshiga__item .item-list .product-list-item {
    width: 100%;
    margin: 0;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .holder {
        padding: 0;
    }
}
.oshiga__item .product-wrap {
    margin-bottom: 0;
    border-bottom: none;
}
.oshiga__item .productnum-wrap {
    margin-block: 20px;
    padding-block: 20px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .productnum-wrap {
        margin-block: 10px;
        padding-block: 10px;
        display: flex;
        align-items: center;
        gap: 10px;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item .purchase-num {
        font-size: 14px;
        margin-bottom: 5px;
        line-height: 1;
    }
}
.oshiga__item input.productnum {
    width: 140px;
    height: 50px;
    border: 1px solid;
    padding: 0 10px;
    appearance: none;
    -webkit-appearance: none;
    border-radius: 0;
}
@media only screen and (max-width: 559px) {
    .oshiga__item input.productnum {
        width: 85px;
        height: 35px;
        font-size: 18px;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item input.spinner-up {
        width: 10px;
        height: 10px;
        margin-top: 10px;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item input.spinner-down {
        width: 10px;
        height: 10px;
        margin-top: -5px;
    }
}
.oshiga__item div.button {
    margin-top: -5px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item div.button {
        padding-left: 10px;
    }
}
.oshiga__item .favorite {
    display: none;
}
.oshiga__item .detail-description h3 {
    font-size: 14px;
    padding-bottom: 0;
}
.oshiga__item .bg-section .description-text {
    column-count: inherit;
    line-height: 1.75;
}
.oshiga__item .detail {
    padding-bottom: 70px;
    border-bottom: 1px solid #c8c8c8;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .detail {
        padding-bottom: 25px;
    }
}
.oshiga__item .contents-section {
    width: 100%;
    margin: 0;
}
.oshiga__item .contents-section h3 {
    padding-top: 30px;
    padding-bottom: 0;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .contents-section h3 {
        padding-top: 25px;
    }
}
.oshiga__item .item-image-small {
    padding-left: 0;
    display: grid;
    gap: 15px;
    grid-template-columns: repeat(3, 1fr);
    padding-right: 80px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .item-image-small {
        grid-template-columns: repeat(4, 1fr);
        padding-right: 0;
    }
}
.oshiga__item .item-image-small .item-image-list {
    width: 100%;
    display: block;
    max-width: 100%;
}
.oshiga__item .sku-add-btn,
.oshiga__item .add-btn {
    background-color: #000;
    border-radius: calc(infinity * 1px);
    transition: 0.5s;
}
.oshiga__item .sku-add-btn:hover,
.oshiga__item .add-btn:hover {
    background-color: #ff74c8;
    border-radius: calc(infinity * 1px);
}
.oshiga__item .sku-add-btn a,
.oshiga__item .add-btn a {
    transition: 0.5s;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .sku-add-btn a,
    .oshiga__item .add-btn a {
        padding: 10px 0;
        font-size: 14px;
    }
}
.oshiga__item .sku-add-btn a:hover,
.oshiga__item .add-btn a:hover {
    background-color: #ff74c8;
    border-radius: calc(infinity * 1px);
}
.oshiga__item .add-btn {
    width: 320px;
    height: 60px;
    margin-inline: 0;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .add-btn {
        width: 100%;
        height: 45px;
    }
}
.oshiga__item .add-btn a {
    position: relative;
    gap: 10px;
    font-weight: 500;
    height: 60px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .add-btn a {
        height: 45px;
    }
}
.oshiga__item .add-btn a::before {
    content: "";
    background: url(https://xs042290.xsrv.jp/oshiga/assets/images/cart.webp) no-repeat center center/contain;
    width: 29px;
    height: 24px;
}
.oshiga__item .sku-add-btn a {
    position: relative;
    gap: 10px;
    padding-left: 10px;
    display: flex;
    justify-content: center;
    font-size: 16px;
    font-weight: 500;
}
.oshiga__item .sku-add-btn a::before {
    content: "";
    background: url(https://xs042290.xsrv.jp/oshiga/assets/images/cart.webp) no-repeat center center/contain;
    width: 25px;
    height: 25px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .cart-add-btn {
        margin-block: 20px;
    }
}
.oshiga__item .sku td {
    font-size: 20px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .sku td {
        font-size: 16px;
        padding: 0;
        margin-bottom: 10px;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item .sku td:first-child {
        border-bottom: none;
        padding-top: 10px;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item .sku tr {
        display: flex;
        flex-direction: column;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item .sku th {
        width: 100%;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item .sku th:first-child {
        border-bottom: none;
    }
}
.oshiga__item .price {
    font-size: 18px;
    line-height: 1;
}
.oshiga__item .item-stock-sku {
    font-size: 14px;
}
.oshiga__item .price,
.oshiga__item .item-stock-sku {
    display: inline-block;
    margin-bottom: 10px;
}
.oshiga__item .breadcrumb {
    margin-bottom: 20px;
    display: flex;
    display: none;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .makeshop-option-select-wrap {
        height: 40px;
        display: inline-block;
        width: 100%;
    }
}
.oshiga__item .makeshop-option-select {
    appearance: none;
    -webkit-appearance: none;
    width: 100%;
    height: 50px;
    font-size: 17px;
    color: #6e6e6e;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .makeshop-option-select {
        height: 40px;
        font-size: 14px;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__item .makeshop-option-select-wrap::before {
        top: 15px;
    }
}
.oshiga__item .option-area {
    padding-bottom: 20px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .option-area {
        padding-bottom: 10px;
    }
}
.oshiga__item .cart-add-btn {
    margin-top: 20px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .cart-add-btn {
        margin-top: 10px;
    }
}
.oshiga__item .makeshop-option-label {
    font-size: 18px;
}
@media only screen and (max-width: 559px) {
    .oshiga__item .makeshop-option-label {
        font-size: 18px;
    }
}

.oshiga__news {
    background: #fff;
}
.oshiga__news .news__ttl img {
    width: 79px;
    height: 17px;
}
@media only screen and (max-width: 559px) {
    .oshiga__news .news__ttl img {
        width: 64px;
        height: 14px;
    }
}
.oshiga__news .information-list {
    border-color: #dcdcdc;
}
.oshiga__news .breadcrumb {
    margin-bottom: 40px;
}
@media only screen and (max-width: 559px) {
    .oshiga__news .breadcrumb {
        margin-bottom: 20px;
    }
}
.oshiga__news .contents-wrap {
    width: 1000px;
}
@media only screen and (max-width: 1024px) {
    .oshiga__news .contents-wrap {
        width: 100%;
        padding: 0;
        margin-bottom: 25px;
    }
}

.pager .pagination li a:hover,
.pager .pagination li a.active {
    background: #ff74c8;
    border-radius: 50%;
    width: 50px;
    height: 50px;
}
@media only screen and (max-width: 559px) {
    .pager .pagination li a:hover,
    .pager .pagination li a.active {
        width: 30px;
        height: 30px;
        font-size: 12px;
    }
}

.pager .pagination li {
    width: 50px;
    height: 50px;
/*    background: #fff; */
}
@media only screen and (max-width: 559px) {
    .pager .pagination li {
        width: 30px;
        height: 30px;
    }
}

.pager ul.pagination {
    display: flex;
    justify-content: center;
    gap: 15px;
}

@media only screen and (max-width: 559px) {
    .pager {
        margin-bottom: 0;
    }
}

.oshiga__news .news__flex {
    display: flex;
    border-bottom: 1px solid #9a9a9a;
    padding-bottom: 20px;
    margin-bottom: 45px;
    align-items: center;
    gap: 55px;
}
@media only screen and (max-width: 559px) {
    .oshiga__news .news__flex {
        flex-direction: column;
        gap: 10px;
        padding-bottom: 20px;
        margin-bottom: 20px;
        align-items: flex-start;
    }
}
.oshiga__news .contents-wrap p {
    line-height: 1;
    margin-bottom: 0;
}
@media only screen and (max-width: 559px) {
    .oshiga__news .oshiga__date {
        font-size: 15px;
    }
}
.oshiga__news .contents-section h3 {
    padding-bottom: 0;
    border-bottom: none;
    margin-bottom: 0;
    font-weight: 500;
    font-size: 21px;
line-height: 1.7;
}
@media only screen and (max-width: 559px) {
    .oshiga__news .contents-section h3 {
        font-size: 15px;
        line-height: 1.7;
    }
}
@media only screen and (max-width: 559px) {
    .oshiga__news .contents-section {
        margin-bottom: 25px;
    }
}

@media only screen and (max-width: 559px) {
    .news__ttl {
        margin-bottom: 25px;
        padding-bottom: 0;
        line-height: 1;
        font-size: 10px;
    }
}
.cat .oshiga__wrap {
    margin-top: -8px;
    padding-top: 40px;
}
@media only screen and (max-width: 559px) {
    .cat .oshiga__wrap {
        padding: 0;
        margin-top: 0;
    }
}
.cat .category-image {
    margin-top: 6px;
    margin-bottom: 0;
}
.cat .item-list {
    padding-left: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 30px;
}
@media only screen and (max-width: 559px) {
    .cat .item-list {
        grid-template-columns: repeat(2, 1fr);
        gap: 15px;
    }
}
.cat .item-list .product-list-item {
    width: 100%;
    margin: 0;

}
@media only screen and (max-width: 559px) {
    .cat .product-list {
        margin-bottom: 25px;
    }
}
@media only screen and (max-width: 559px) {
    .cat .holder {
        padding: 0 25px 25px;
    }
}
@media only screen and (max-width: 559px) {
    .cat .product-wrap {
        padding: 30px 0 0;
    }
}
.cat .check__ttl {
    text-align: center;
    margin-bottom: 30px;
    padding-top: 30px;
    border-top: 1px solid #9a9a9a;
}
@media only screen and (max-width: 559px) {
    .cat .check__ttl {
        padding-top: 25px;
        margin-bottom: 15px;
    }
}
@media only screen and (max-width: 559px) {
    .cat .holder .product-wrap {
        padding: 0;
    }
}

.sns {
    padding-bottom: 50px;
}
@media only screen and (max-width: 559px) {
    .sns {
        padding-bottom: 40px;
    }
}
.sns__list {
    display: flex;
    justify-content: center;
    align-items: center;
    padding-left: 0;
    gap: 30px;
}

h2.category__originalttl {
    margin-bottom: 15px;
    font-weight: 700;
    line-height: 1;
}
@media only screen and (max-width: 559px) {
    h2.category__originalttl {
        font-size: 17px;
        text-align: left;
        margin-bottom: 5px;
    }
}

h3.category__originalcatch {
    font-size: 30px;
    padding-inline: 40px;
    line-height: 1;
    padding-bottom: 10px;
}
@media only screen and (max-width: 559px) {
    h3.category__originalcatch {
        font-size: 20px;
        text-align: left;
        padding: 0;
        border-bottom: 0;
        margin: 0 0 25px;
        line-height: 1.5;
    }
}

p.category__originaltext {
    font-size: 15px;
    line-height: 1.75;
    margin-bottom: 40px;
}
@media only screen and (max-width: 559px) {
    p.category__originaltext {
        font-size: 14px;
        margin-bottom: 0;
    }
}

@media only screen and (max-width: 559px) {
    .gray__wrap {
        background: #e1e6eb;
        padding: 15px 0 30px;
    }
}

@media only screen and (max-width: 559px) {
    .cat .product-container {
        padding-inline: 25px;
        padding-bottom: 30px;
        overflow: hidden;
    }
}

@media only screen and (max-width: 559px) {
    .category-image:before {
        height: auto;
    }
}

.oshiga__guide {
    background: #fff;
}

.guide__ttl {
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 50px;
}
@media only screen and (max-width: 559px) {
    .guide__ttl {
        font-size: 20px;
        text-align: left;
        margin-bottom: 25px;
    }
}
.guide__itemttl {
    font-size: 17px;
    border-bottom: none;
    line-height: 1.75;
    margin: 0;
    padding: 0;
}
@media only screen and (max-width: 559px) {
    .guide__itemttl {
        font-size: 15px;
    }
}
.guide__list {
    padding: 0;
}
.guide__item:not(:last-child) {
    margin-bottom: 40px;
}
@media only screen and (max-width: 559px) {
    .guide__item:not(:last-child) {
        margin-bottom: 5px;
    }
}
.guide__item p {
    font-size: 17px;
    line-height: 1.75;
    margin: 0;
}
@media only screen and (max-width: 559px) {
    .guide__item p {
        font-size: 15px;
    }
}

.privacy-policy,
.legal {
    background: #fff;
}
.privacy-policy .section-title,
.legal .section-title {
    text-align: center;
    border-bottom: none;
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 50px;
}
@media only screen and (max-width: 559px) {
    .privacy-policy .section-title,
    .legal .section-title {
        font-size: 20px;
        text-align: left;
        margin-bottom: 25px;
    }
}
.privacy-policy .policy-section pre,
.legal .policy-section pre {
    font-size: 17px;
    letter-spacing: 0;
    line-height: 1.75;
    font-family: "Noto Sans JP", sans-serif;
    font-optical-sizing: auto;
    font-weight: 500;
    font-style: normal;
}
@media only screen and (max-width: 559px) {
    .privacy-policy .policy-section pre,
    .legal .policy-section pre {
        font-size: 15px;
        white-space: pre-wrap;
    }
}

.privacy-policy .section-title {
    padding-top: 30px;
}
@media only screen and (max-width: 559px) {
    .privacy-policy .section-title {
        padding-top: 10px;
        padding-bottom: 0;
    }
}

.legal .section-title {
    padding-bottom: 0;
}
.legal .contract-section-title {
    color: #000;
    letter-spacing: 0;
    line-height: 1.75;
    margin-bottom: 0;
}
.legal .contract-section:not(:last-child) {
    margin-bottom: 40px;
}
@media only screen and (max-width: 559px) {
    .legal .contract-section:not(:last-child) {
        margin-bottom: 10px;
    }
}
.legal .contract-section p {
    line-height: 1.75;
}
.legal .breadcrumb {
    margin-bottom: 40px;
}
@media only screen and (max-width: 559px) {
    .legal .breadcrumb {
        margin-bottom: 20px;
    }
}
.legal .contents-wrap {
    padding-left: 0;
}
@media only screen and (max-width: 559px) {
    .legal .contract-section {
        margin-bottom: 0;
    }
}

.kiyaku {
    background: #fff;
}
.kiyaku .section-title {
    text-align: center;
    border-bottom: none;
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 50px;
    padding-bottom: 0;
    padding-top: 30px;
}
@media only screen and (max-width: 559px) {
    .kiyaku .section-title {
        text-align: left;
        font-size: 20px;
        margin-bottom: 25px;
        padding-top: 10px;
    }
}
@media only screen and (max-width: 559px) {
    .kiyaku ul {
        padding-left: 0;
        font-size: 12px;
    }
}
.kiyaku__wrap > ul {
    display: flex;
    flex-direction: column;
    gap: 40px;
    padding-left: 0;
}
@media only screen and (max-width: 559px) {
    .kiyaku__wrap > ul {
        gap: 10px;
    }
}
.kiyaku__wrap p {
    padding-left: 20px;
    margin-bottom: 0;
}
@media only screen and (max-width: 559px) {
    .kiyaku__wrap p {
        padding-left: 0;
    }
}
.kiyaku__wrap ul > li h3 {
    font-size: 17px;
    border-bottom: none;
    line-height: 1.75;
    margin: 0;
    padding: 0;
    color: #000;
}
@media only screen and (max-width: 559px) {
    .kiyaku__wrap ul > li h3 {
        font-size: 15px;
    }
}
.kiyaku__wrap ul > li h3 + ul li {
    color: #000;
}
.kiyaku__wrap li {
    color: #000;
}

.serch-page .product-list {
    padding-left: 0;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
}
@media only screen and (max-width: 559px) {
    .serch-page .product-list {
        grid-template-columns: repeat(2, 1fr);
    }
}
.serch-page .product-list-item {
    width: 100%;
    min-width: 100%;
    margin: 0;
}
.serch-page .product-wrap {
    border-bottom: none;
    margin-bottom: 0;
}
.serch-page .pager {
    margin-bottom: 0;
    margin-top: 60px;
}
@media only screen and (max-width: 559px) {
    .serch-page .pager {
        margin-top: 25px;
    }
}
@media only screen and (max-width: 559px) {
    .serch-page h2.item-title {
        font-size: 22px;
        padding-left: 0;
        margin-bottom: 0;
    }
}
@media only screen and (max-width: 559px) {
    .serch-page .list-head-sort {
        align-items: center;
    }
}
.serch-page .list-head-sort dt {
    font-size: 12px;
}
.serch-page .list-head-sort dd {
    line-height: 1;
}
@media only screen and (max-width: 559px) {
    .serch-page .list-head-sort a {
        font-size: 10px;
    }
}

.contents-section h3 {
    font-size: 10px;
    margin-bottom: 30px;
    line-height: 1;
}
@media only screen and (max-width: 559px) {
    .contents-section h3 {
        margin-bottom: 15px;
    }
}

.news__ttl {
    margin-bottom: 30px;
    font-size: 10px;
    line-height: 1;
}
@media only screen and (max-width: 559px) {
    .news__ttl {
        margin-bottom: 15px;
    }
}

.original__ttl {
    margin-bottom: 15px;
    font-size: 10px;
    line-height: 1;
}
@media only screen and (max-width: 559px) {
    .original__ttl {
        margin-bottom: 10px;
    }
}

.original,
.top-news,
.check .holder {
    padding-top: 40px;
}
@media only screen and (max-width: 559px) {
    .original,
    .top-news,
    .check .holder {
        padding-top: 30px;
    }
}

.news-link {
    margin-bottom: 0;
}
/*# sourceMappingURL=style.css.map */
.outstock-btn {
    line-height: 1;
}
.cart-add-btn .on {
    margin-bottom: 0;
}
.detail-sold-out {
    padding: 6px 10px 2px;
}

.slick-prev,
.slick-next {
    width: 30px;
    height: 30px;
    background-color: transparent;
}
.slick-prev {
    background: url(https://xs042290.xsrv.jp/oshiga/assets/images/left.webp) no-repeat center center/contain;
}
.slick-next {
    background: url(https://xs042290.xsrv.jp/oshiga/assets/images/right.webp) no-repeat center center/contain;
}
.slick-prev::before,
.slick-next::before {
    display: none;
}
@media (max-width: 559px) {
  .product-list {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-auto-flow: row;        
    align-items: start !important;
    gap: 20px 30px;           
    padding-left: 0;          
  }
  .product-list > li { min-width: 0; } 
}