/* ==================================================
   トップスライダー
================================================== */
#top-slider-section {
    width: 100%;
    padding: 0 0 8px;
}

.slider-inner {
    position: relative;
    max-width: 984px;
    width: 96%;
    margin: 0 auto;
    left: -30px;
}

/* Swiper 共通 */
.swiper-slide img {
    display: block;
    width: 100%;
    height: auto;
    object-fit: cover;
}

.mySwiperMain {
    width: 100%;
    margin-bottom: 10px;
}

/* --- サムネイル（下） --- */
.mySwiperThumb {
    box-sizing: border-box;
    padding: 0;
}

.mySwiperThumb .swiper-slide {
    width: 20%;
    opacity: 0.4;
    cursor: pointer;
    transition: opacity 0.3s;
}

.mySwiperThumb .swiper-slide-thumb-active {
    opacity: 1;
    border: 2px solid #f88000;
    box-sizing: border-box;
}

/* ナビゲーション */
.swiper-button-next,
.swiper-button-prev {
    color: #fff;
    text-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
}


/* ==================================================
   レイアウト
================================================== */
.l_header {
    background-size: auto 76px;
}

.l_main {
    position: relative;
    padding: 0 0 25px;
}

.l_sub_sidebar {
    position: absolute;
    top: 0;
    right: 0;
}

.l_sidebar {
    position: initial;
}

.l_coupon {
    width: 984px;
    margin: 0 auto;

}

/* .l_contents {
    float: left;
    width: 984px;
    margin-left: 0;

} */

.grobalNav {
    margin: 8px auto;
    width: 984px;
    position: relative;
    left: -30px;
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.bunnerArea {
    display: flex;
    gap: 8px;
    margin-bottom: 20px;
}

.bunnerArea .bunnerArea__inner {
    flex: 1;
}

.bunnerArea .bunnerArea__inner img {
    width: 100%;
    height: auto;
}

/* ==================================================
   ナビ
================================================== */
.grobalNav__inner {
    flex: 1;
    display: flex;
    justify-content: center;
}

.grobalNav__link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding: 10px 8px;
    background-color: #ffffff;
    color: #f88000;
    text-decoration: none;
    font-weight: bold;
    font-size: 14px;
    border-radius: 3px;
    text-align: center;
    border: 1px solid #f88000;
    transition: background-color 0.2s, color 0.2s;
}

a.grobalNav__link:link,
a.grobalNav__link:visited {
    color: #f88000;
    text-decoration: none;
}


/* ==================================================
   カード共通
================================================== */
.priceCard,
.categoryCard {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
}

/* 料金カード */
.priceCard__inner {
    flex: 1;
    padding: 32px 16px 20px;
    text-align: center;
    background-color: #fff;
    border: 1px solid #c3c3c3;
    position: relative;
}

.priceCard__inner h3 {
    margin-bottom: 8px;
    margin-top: 0;
    font-size: 14px;
    font-weight: 600;
    background: #5b5b5b;
    position: absolute;
    left: 0;
    top: 0;
    padding: 4px 16px;
    color: #fff;
}

.priceCard__inner img,
.priceCard__inner p {
    margin-bottom: 4px;
}

.priceCard__icon {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: 0;
    padding: 4px 0;
    margin-bottom: 10px;
    font-size: 13px;
}

.priceCard__icon span {
    display: block;
    padding: 2px 0;
    width: 100%;
}

.priceCard__priceText {
    margin-bottom: 8px;
    font-size: 16px;
    font-weight: bold;
}

.priceCart__btn {
    display: flex;
    gap: 8px;
    justify-content: center;
}

.priceCart__btn a {
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 8px;
    background-color: #db2929;
    color: #fff;
    border-radius: 3px;
    flex: 1;
    font-size: 12px;
    text-decoration: none;
    box-shadow: 2px 3px 5px rgba(0, 0, 0, 0.20);
    transition: background-color 0.3s ease;
}

.priceCart__btn a:hover {
    background-color: #b82222;
}

/* カテゴリーカード */
.categoryCard__inner {
    width: calc((100% - 16px) / 3);
}

.categoryCard__inner img {
    width: 100%;
    height: auto;
}

.section .oneline {
    gap: 0;

}

.oneline img,
.banner img {
    width: 100%;
    height: auto;
}

.oneline {
    gap: 0 8px;
    display: flex;
}

.oneline a {
    flex: 1;
}

/* ==================================================
   クーポン
================================================== */
.couponArea {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 20px;
    width: 100%;
}

.couponArea__inner {
    flex: 1;
    text-align: center;
}

.couponArea__inner img {
    width: 100%;
    height: auto;
}

.couponCard {
    background: linear-gradient(135deg, #ffffff 0%, #ffffff 50%, #ffffff 100%);
    color: #ff7f01;
    padding: 18px 24px;
    text-align: center;
    position: relative;
    min-height: 160px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 4px;
    overflow: hidden;
    border: solid 1px #ff7f01;
}

/* バッジ行：横線＋中央バッジ */
.couponCard__badgeLine {
    display: flex;
    align-items: center;
    width: 100%;
    gap: 12px;
    margin-bottom: 0;
}

.couponCard__badgeLine::before,
.couponCard__badgeLine::after {
    content: '';
    flex: 1;
    height: 1px;
    background-color: #dcdcdc;
}

.couponCard__badge {
    display: inline-block;
    background-color: #dcdcdc;
    color: #1c2235;
    font-size: 11px;
    font-weight: bold;
    padding: 5px 22px;
    letter-spacing: 0.08em;
    white-space: normal;
    text-align: center;
    line-height: 1.4;
    clip-path: polygon(0 0, 100% 0, calc(100% - 10px) 50%, 100% 100%, 0 100%, 10px 50%);
}

.couponCard__off {
    display: flex;
    font-size: 45px;
    align-items: center;
    font-weight: bold;
    text-box-edge: cap alphabetic;
    font-family: 'Noto Sans', sans-serif;
    font-weight: 600;
    justify-content: center;
    line-height: 1em;
    margin-bottom: 8px;
}

.couponCard__title {
    font-size: 17px;
    font-weight: bold;
    text-align: center;
    margin: 4px 0;
    padding: 0;
    /* border: red solid; */
    line-height: 1em;
}

.couponCard__off span {
    font-size: 15px;
    display: block;
    margin-left: 8px;
    text-align: left;
    line-height: 1.4;
    font-family: initial;
}

.couponCard__img {
    width: 100%;
    height: auto;
    margin: 4px 0 8px;
}

.couponCard__code {
    font-size: 13px;
    font-weight: bold;
    background-color: #ff7f01;
    color: #fff;
    border: none;
    border-radius: 20px;
    padding: 8px 20px;
    letter-spacing: 0.08em;
    margin-bottom: 12px;
    line-height: 1em;
    max-width: 250px;
    margin: 0 auto;
}

.couponCard__expire {
    display: flex;
    align-items: center;
    width: 100%;
    gap: 10px;
    font-size: 11px;
    color: #1c2235;
    margin: 0;
    white-space: nowrap;
}

.couponCard__expire::before,
.couponCard__expire::after {
    content: '';
    flex: 1;
    height: 1px;
    background-color: #dcdcdc;
}

/* ==================================================
   料金表
================================================== */
.priceTable {
    margin-bottom: 20px;
}

.priceTable_title {
    padding: 8px 15px 7px 8px;
    background: #F3F3F3;
    border: 1px solid #E5E5E5;
}

.priceTable_title h4 {
    margin: 0;
    font-size: 24px;
    font-size: 2.4rem;
    line-height: 1;
    color: #707172;
    display: inline-block;
}




.priceTable .priceTab {
    display: flex;
    flex-wrap: wrap;
    gap: 0 4px;
}

.priceTable .priceTab input {
    display: none;
}

/* タブラベル */
.priceTable .priceTab label {
    display: block;
    flex: 1;
    text-align: center;
    box-sizing: border-box;
    padding: 12px 8px;
    margin-right: 0;
    background: #f88000;
    color: #fff;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    line-height: 1em;
    border-radius: 4px 4px 0 0;
    border: 2px solid transparent;
    border-bottom: none;
}

/* アクティブタブ */
.priceTable .priceTab input:checked+label {
    background: #fff;
    color: #f88000;
    border: 2px solid #f88000;
    border-bottom: none;
}

/* コンテンツ外枠 */
.priceTable .priceTab_contents {
    width: 100%;
    box-sizing: border-box;
    border: 2px solid #f88000;
    padding: 24px;
    background: #fff;
}

/* コンテンツ切り替え */
.priceTable .priceTab_content {
    display: none;
}

#priceTab-u:checked~.priceTab_contents .priceTab_content:nth-child(1),
#priceTab-o:checked~.priceTab_contents .priceTab_content:nth-child(2),
#priceTab-s:checked~.priceTab_contents .priceTab_content:nth-child(3),
#priceTab-nt:checked~.priceTab_contents .priceTab_content:nth-child(4),
#priceTab-sen:checked~.priceTab_contents .priceTab_content:nth-child(5) {
    display: block;
}



/* ==================================================
   ご注文の流れ
================================================== */
.orderFlow {
    margin-bottom: 20px;
}

.orderFlow__title {
    background: #f88000;
    color: #fff;
    padding: 10px 15px;
    margin: 0;
    font-size: 18px;
    font-weight: bold;
    border-left: 4px solid #c66400;
}

.orderFlow__note {
    text-align: center;
    font-size: 13px;
    color: #333;
    margin: 12px 0;
}

.orderFlow__steps {
    display: flex;
    gap: 8px;
}

.orderFlow__step {
    flex: 1;
    text-align: center;
    border: 1px solid #f88000;
    background: #fff;
    padding: 40px 16px;
    position: relative;
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    transition: background-color 0.2s;
}

.orderFlow__step:hover {
    background-color: #fff7ef;
}

.orderFlow__number {
    font-size: 16px;
    font-weight: bold;
    color: #ffffff;
    position: absolute;
    top: 0;
    font-weight: normal;
    left: 0;
    padding: 3px;
    width: 25px;
    background: #f88000;
    height: 25px;
}

.orderFlow__icon {
    margin-bottom: 12px;
}

.orderFlow__icon i {
    font-size: 48px;
    color: #eca050;
}

.orderFlow__text {
    font-weight: bold;
    color: #333;
    margin: 0;
    background: #ececec;
    border-radius: 100px;
    padding: 3px 9px;
    font-size: 12px;
    display: inline-block;
}

/* ==================================================
   お知らせエリア
================================================== */
.section .newsbox {
    width: 100%;
    height: 300px;
    float: initial;
}

.section .bns {
    float: initial;
}

.section .newsbox ul li a .news_topic {
    width: 843px;
    line-height: 1.6;
}

/* ============================== */
/* facebook */
/* ============================== */

.facebook {
    width: 100%;
}

/* SDK が親ページに生成する span・iframe の固定幅を上書き */
.facebook .fb-page,
.facebook .fb-page span,
.facebook iframe {
    width: 100% !important;
    min-width: unset !important;
}

/* ==================================================
   価格データ表（price-fetch.js で動的生成）
   .priceDataTable 系クラスでデザインを調整できます
================================================== */

/* スクロールラッパー: max-height を変えると表示行数を調整できます */
.priceDataTable-scroll {
    max-height: 450px;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
}

.priceDataTable {
    width: 100%;
    border-collapse: collapse;
    font-size: 14px;
}

/* タイトル行 */
.priceDataTable .priceDataTable__title td {
    background: #f88000;
    color: #fff;
    font-weight: bold;
    text-align: center;
    font-size: 15px;
    padding: 10px;
}

.priceDataTable .priceDataTable__listLink {
    display: inline-block;
    margin-left: 15px;
    font-size: 13px;
    color: #fff;
    text-decoration: underline;
}

.priceDataTable .priceDataTable__listLink:hover {
    text-decoration: none;
}

/* ヘッダー行（本数／1色／2色） */
.priceDataTable .priceDataTable__head td {
    background: #fff3e0;
    font-weight: bold;
    text-align: center;
    border: 1px solid #ccc;
    padding: 8px 10px;
}

/* スクロール時のヘッダー固定（名入れ・扇子タブ: theadを持つテーブルに適用） */
.priceDataTable thead .priceDataTable__title td {
    position: sticky;
    top: 0;
    z-index: 2;
}

.priceDataTable thead .priceDataTable__head td {
    position: sticky;
    top: 38px;
    /* タイトル行の高さ分オフセット */
    z-index: 1;
}

/* データ行 */
.priceDataTable .priceDataTable__row td {
    border: 1px solid #ccc;
    padding: 8px 10px;
}

/* 本数セル（左列）は中央揃え */
.priceDataTable .priceDataTable__row td:first-child {
    text-align: center;
}

/* 価格セル（右列）は右揃え */
.priceDataTable .priceDataTable__row td:not(:first-child) {
    text-align: center;
}

/* 偶数行（薄いオレンジ） */
.priceDataTable .priceDataTable__row:nth-child(even) td {
    background: #fef6ec;
}

.priceDataTable .priceDataTable__row td font {
    color: #333;
    font-weight: normal;
}

/* 奇数行（白） */
.priceDataTable .priceDataTable__row:nth-child(odd) td {
    background: #fff;
}

/* 最終行（太字・強調） */
.priceDataTable .priceDataTable__row--last td {
    background: #fff3e0;
    font-weight: bold;
    border-top: 2px solid #f88000;
}

/* ==================================================
   text-field (お知らせ・ニュース欄)
================================================== */
.text-field {
    width: 100%;
    max-width: 984px;
    margin-bottom: 20px;
    background-color: #fff;
}

.text-field__title {
    background: #f88000;
    color: #fff;
    padding: 10px 15px;
    margin: 0;
    font-size: 18px;
    font-weight: bold;
    border-left: 4px solid #c66400;
}

.info-list {
    list-style: none;
    padding: 20px 30px;
    margin: 0;
}

.info-list li {
    display: flex;
    align-items: flex-start;
    padding: 20px 0;
    border-bottom: 1px solid #ccc;
}

.info-list li:last-child {
    border-bottom: none;
}

.info-date {
    font-weight: bold;
    color: #333;
    width: 120px;
    flex-shrink: 0;
    font-family: 'Noto Sans', sans-serif;
    letter-spacing: 0.05em;
}

.info-text {
    flex-grow: 1;
    color: #333;
    line-height: 1.8;
}

@media (max-width: 768px) {
    .text-field__title {
        font-size: 16px;
        padding: 12px 15px;
    }

    .info-list {
        padding: 10px 15px;
    }

    .info-list li {
        flex-direction: column;
        padding: 15px 0;
    }

    .info-date {
        margin-bottom: 8px;
    }
}