.fs-preview-header { display: none; }

/* ===== トップページ：ヘッダーアイコンを白表示（PC版） ===== */
.fs-body-top .Header_Main:not(.active) .Header_Content01_02 .Header_IconList a img {
    -webkit-filter: brightness(0) saturate(100%) invert(100%) drop-shadow(0 0 3px rgba(0,0,0,0.45)) !important;
    filter: brightness(0) saturate(100%) invert(100%) drop-shadow(0 0 3px rgba(0,0,0,0.45)) !important;
    opacity: 1 !important;
}
/* =========================================
   カタログギフト シリーズ一覧 アンカーボタン
========================================= */
.cataloggift_anchor_nav {
    margin: 24px 0 32px;
}

.cataloggift_anchor_nav_list {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.cataloggift_anchor_nav_item {
    margin: 0;
    padding: 0;
}

.cataloggift_anchor_nav_link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 120px;
    min-height: 44px;
    padding: 10px 18px;
    border: 1px solid #d7d0c7;
    border-radius: 999px;
    background: #ffffff;
    color: #333333;
    font-size: 18.2px; /* 14px × 1.3 */
    font-weight: 700;
    line-height: 1.4;
    text-decoration: none;
    box-sizing: border-box;
    transition: all 0.25s ease;
}

.cataloggift_anchor_nav_link:hover,
.cataloggift_anchor_nav_link:focus {
    background: #333333;
    border-color: #333333;
    color: #ffffff;
    text-decoration: none;
    outline: none;
}

#Link_Sogo,
#Link_Gourmet,
#Link_Bridal,
#Link_Birth,
#Link_Brand,
#Link_Experience,
#Link_Buddhist {
    scroll-margin-top: 120px;
}

@media screen and (max-width: 767px) {
    .cataloggift_anchor_nav {
        margin: 20px 0 28px;
    }

    .cataloggift_anchor_nav_list {
        gap: 8px;
        justify-content: center;
    }

    .cataloggift_anchor_nav_item {
        width: calc(50% - 4px);
    }

    .cataloggift_anchor_nav_link {
        width: 100%;
        min-width: auto;
        min-height: 44px;
        padding: 10px 12px;
        font-size: 16.9px; /* 13px × 1.3 */
    }
}
.register-point-highlight {
  color: #e60012;
  font-weight: bold;
}
.register-point-highlight {
  color: #e60012;
  font-weight: bold;
}
/* =========================================
   強化LP専用：ギフトサービス PC表示調整
   商品詳細ページの既存部品には影響させない
========================================= */

/* =========================================
   強化LP専用：ギフトサービス PC表示調整
   商品詳細ページの見え方に近づける版
========================================= */

.fs-lp-gift-service,
.fs-lp-gift-service *,
.fs-lp-gift-service *::before,
.fs-lp-gift-service *::after {
    box-sizing: border-box;
}

.fs-lp-gift-service {
    width: 100%;
    margin: 0 auto;
    padding: 0;
}

.fs-lp-gift-service .Original_GiftService {
    width: 100%;
    margin: 0 auto;
}

/* 商品詳細ページ側と同等の表示幅を確保 */
.fs-lp-gift-service .Original_GiftService_Inner {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* タイトル */
.fs-lp-gift-service .Original_GiftService_Title {
    text-align: center;
}

/* 3カラム */
.fs-lp-gift-service .Original_GiftService_Main {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    gap: 25px;
    width: 100%;
    margin: 0 auto;
}

/* 各ボックス：ここが重要 */
.fs-lp-gift-service .Original_GiftService_Box {
    width: 370px;
    max-width: 370px;
    flex: 0 0 370px;
    margin: 0;
}

/* 画像 */
.fs-lp-gift-service .Original_GiftService_Box_Img {
    width: 100%;
}

.fs-lp-gift-service .Original_GiftService_Box_Img img {
    width: 100%;
    max-width: 100%;
    height: auto;
    display: block;
}

/* テキスト */
.fs-lp-gift-service .Original_GiftService_Box_Title {
    text-align: left;
}

.fs-lp-gift-service .Original_GiftService_Box_Text {
    text-align: left;
}

/* PC/SP表示制御 */
.fs-lp-gift-service .sp {
    display: none;
}

.fs-lp-gift-service .pc {
    display: inline-flex;
}
/* =========================================
   共通：贈る相手別ランキング PC
   対象：出産内祝い / 結婚内祝い / 快気祝い / 出産祝い など
   既存パーツに干渉しないよう .Recipient_Ranking 配下に限定
========================================= */

.Recipient_Ranking,
.Recipient_Ranking *,
.Recipient_Ranking *::before,
.Recipient_Ranking *::after {
    box-sizing: border-box;
}

/* セクション導入文 */
.Recipient_Ranking .Recipient_Ranking_Lead {
    max-width: 820px;
    margin: 0 auto 34px;
    padding: 0;
    text-align: center;
}

.Recipient_Ranking .Recipient_Ranking_Lead p {
    margin: 0;
    padding: 0;
    color: #333333;
    font-size: 16px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.03em;
}

/* カテゴリナビ */
.Recipient_Ranking .Recipient_Ranking_Nav {
    margin: 0 auto 56px;
    padding: 0;
}

.Recipient_Ranking .Recipient_Ranking_Nav_List {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.Recipient_Ranking .Recipient_Ranking_Nav_Item {
    margin: 0;
    padding: 0;
}

.Recipient_Ranking .Recipient_Ranking_Nav_Link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 150px;
    min-height: 46px;
    padding: 11px 22px;
    border: 1px solid #d7d0c7;
    border-radius: 999px;
    background: #ffffff;
    color: #333333;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
    text-decoration: none;
    transition: all 0.25s ease;
}

.Recipient_Ranking .Recipient_Ranking_Nav_Link:hover,
.Recipient_Ranking .Recipient_Ranking_Nav_Link:focus {
    background: #333333;
    border-color: #333333;
    color: #ffffff;
    text-decoration: none;
    outline: none;
}

/* カテゴリブロック */
.Recipient_Ranking .Recipient_Ranking_Block {
    margin: 0 auto 70px;
    padding: 0;
}

/* 最後のカテゴリだけ下余白を少し短く */
.Recipient_Ranking .Recipient_Ranking_Block:last-of-type {
    margin-bottom: 42px;
}

/* カテゴリ説明文 */
.Recipient_Ranking .Recipient_Ranking_Text {
    max-width: 780px;
    margin: 0 auto 30px;
    padding: 0;
    text-align: center;
}

.Recipient_Ranking .Recipient_Ranking_Text p {
    margin: 0;
    padding: 0;
    color: #333333;
    font-size: 15px;
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.03em;
}

/* 商品表示エリア：既存 Osusume_Item のレイアウトを活かす */
.Recipient_Ranking .Osusume_Item {
    margin-top: 0;
}

/* ランキング注釈 */
.Recipient_Ranking .Recipient_Ranking_Note {
    margin: 12px auto 0;
    padding: 0;
    color: #777777;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.8;
    text-align: center;
}

/* 固定ヘッダー対策 */
#Recipient_Ranking_01,
#Recipient_Ranking_02,
#Recipient_Ranking_03,
#Recipient_Ranking_04,
#Recipient_Ranking_05 {
    scroll-margin-top: 120px;
}
/* =========================================
   共通マナーコンテンツ PC
   対象：出産内祝い / 結婚内祝い / 結婚祝い / 出産祝い など
   FutureShop フリーパーツ用
========================================= */

.GiftManner,
.GiftManner *,
.GiftManner *::before,
.GiftManner *::after {
    box-sizing: border-box;
}

.GiftManner {
    width: 100%;
    margin: 70px auto 80px;
    padding: 0;
    color: #333333;
    font-family: inherit;
    line-height: 1.9;
    letter-spacing: 0.03em;
}

.GiftManner a {
    color: inherit;
    text-decoration: none;
}

.GiftManner_Inner {
    width: 100%;
    max-width: 1120px;
    margin: 0 auto;
    padding: 0 20px;
}

/* リードエリア */
.GiftManner_Lead {
    margin: 0 auto 38px;
    padding: 42px 44px;
    background: #fbf8f4;
    border: 1px solid #e5ded4;
    border-radius: 22px;
    text-align: center;
}

.GiftManner_Eyebrow {
    margin: 0 0 10px;
    padding: 0;
    color: #9b7b56;
    font-size: 13px;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.16em;
}

.GiftManner_Title {
    margin: 0 0 20px;
    padding: 0;
    color: #333333;
    font-size: 34px;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.06em;
}

.GiftManner_LeadText {
    max-width: 880px;
    margin: 0 auto 12px;
    padding: 0;
    color: #333333;
    font-size: 15px;
    font-weight: 400;
    line-height: 2;
}

.GiftManner_LeadText:last-child {
    margin-bottom: 0;
}

/* =========================================
   GiftManner 内アンカー PC
   3列×3行固定 / 既存上部アンカー風
========================================= */

.GiftManner_LocalNavi {
    width: 100%;
    max-width: 920px;
    margin: 0 auto 58px;
    padding: 0;
}

.GiftManner_LocalNavi_Inner {
    width: 100%;
    max-width: 100%;
    margin: 0 auto;
    padding: 0;
}

.GiftManner_LocalNavi_List {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 14px 0 !important;
    width: 100%;
    margin: 0 !important;
    padding: 0 !important;
    list-style: none !important;
}

.GiftManner_LocalNavi_List li,
.GiftManner_LocalNavi_List li:nth-child(2n),
.GiftManner_LocalNavi_List li:nth-child(3n),
.GiftManner_LocalNavi_List li:nth-child(4n),
.GiftManner_LocalNavi_List li:nth-child(n+4),
.GiftManner_LocalNavi_List li:nth-child(n+5) {
    display: block !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 58px !important;
    margin: 0 !important;
    padding: 0 18px !important;
    border-right: 1px solid #dddddd !important;
    border-left: none !important;
    border-top: none !important;
    border-bottom: none !important;
    background: transparent !important;
}

.GiftManner_LocalNavi_List li:nth-child(3n) {
    border-right: none !important;
    padding-right: 0 !important;
}

.GiftManner_LocalNavi_List li:nth-child(3n + 1) {
    padding-left: 0 !important;
}

.GiftManner_LocalNavi_List li a {
    position: relative;
    display: flex !important;
    flex-direction: column !important;
    justify-content: center !important;
    align-items: center !important;
    width: 100% !important;
    min-height: 58px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #333333 !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 1.45 !important;
    text-align: center !important;
    white-space: normal !important;
    word-break: keep-all !important;
    overflow-wrap: anywhere !important;
    text-decoration: none !important;
    transition: opacity 0.25s ease;
}

.GiftManner_LocalNavi_List li a::after {
    content: "";
    display: block;
    width: 9px;
    height: 9px;
    margin-top: 8px;
    border-right: 1px solid #333333;
    border-bottom: 1px solid #333333;
    transform: rotate(45deg);
    flex-shrink: 0;
}

.GiftManner_LocalNavi_List li a:hover,
.GiftManner_LocalNavi_List li a:focus {
    opacity: 0.65;
    text-decoration: none !important;
    outline: none;
}

.GiftManner_LocalNavi_Empty {
    pointer-events: none !important;
}

.GiftManner_LocalNavi_Empty::before {
    content: "";
    display: block;
    min-height: 58px;
}

/* セクション共通 */
.GiftManner_Section {
    margin: 0 auto 52px;
    padding: 40px 44px;
    background: #ffffff;
    border: 1px solid #e5ded4;
    border-radius: 20px;
}

.GiftManner_Section:last-child {
    margin-bottom: 0;
}

.GiftManner_SectionSoft {
    background: #fbf8f4;
}

.GiftManner_SectionHead {
    margin: 0 0 22px;
    padding: 0;
    text-align: center;
}

.GiftManner_Heading {
    margin: 0;
    padding: 0;
    color: #333333;
    font-size: 26px;
    font-weight: 700;
    line-height: 1.55;
    letter-spacing: 0.05em;
}

.GiftManner_TextBlock {
    max-width: 900px;
    margin: 0 auto;
    padding: 0;
    text-align: center;
}

.GiftManner_TextBlock p {
    margin: 0 0 14px;
    padding: 0;
    color: #333333;
    font-size: 15px;
    font-weight: 400;
    line-height: 2;
}

.GiftManner_TextBlock p:last-child {
    margin-bottom: 0;
}

/* ポイントボックス */
.GiftManner_PointBox {
    max-width: 860px;
    margin: 26px auto 0;
    padding: 24px 28px;
    background: #ffffff;
    border: 1px solid #e5ded4;
    border-radius: 16px;
}

.GiftManner_Section:not(.GiftManner_SectionSoft) .GiftManner_PointBox {
    background: #fbf8f4;
}

.GiftManner_PointTitle {
    margin: 0 0 12px;
    padding: 0;
    color: #333333;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.6;
    text-align: center;
}

.GiftManner_CheckList {
    max-width: 560px;
    margin: 0 auto;
    padding: 0;
    list-style: none;
}

.GiftManner_CheckList li {
    position: relative;
    margin: 0 0 8px;
    padding: 0 0 0 22px;
    color: #333333;
    font-size: 15px;
    line-height: 1.9;
    text-align: left;
}

.GiftManner_CheckList li:last-child {
    margin-bottom: 0;
}

.GiftManner_CheckList li::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0.78em;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background: #9b7b56;
}

/* テーブル */
.GiftManner_TableWrap {
    width: 100%;
    margin: 26px auto 0;
    overflow-x: auto;
    border: 1px solid #e5ded4;
    border-radius: 16px;
    background: #ffffff;
}

.GiftManner_Table {
    width: 100%;
    min-width: 760px;
    margin: 0;
    border-collapse: collapse;
}

.GiftManner_Table th,
.GiftManner_Table td {
    padding: 17px 18px;
    border-bottom: 1px solid #e5ded4;
    color: #333333;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.8;
    text-align: center;
    vertical-align: middle;
}

.GiftManner_Table th {
    background: #f0e8de;
    color: #333333;
    font-weight: 700;
}

.GiftManner_Table tbody th {
    width: 24%;
}

.GiftManner_Table tr:last-child th,
.GiftManner_Table tr:last-child td {
    border-bottom: none;
}

/* のし画像 */
.GiftManner_NoshiImage {
    max-width: 640px;
    margin: 28px auto 0;
    padding: 0;
    text-align: center;
}

.GiftManner_NoshiImage img {
    display: block;
    width: 100%;
    height: auto;
    margin: 0 auto;
    border-radius: 16px;
    border: 1px solid #e5ded4;
}

.GiftManner_NoshiImage figcaption {
    margin: 10px 0 0;
    padding: 0;
    color: #777777;
    font-size: 13px;
    font-weight: 400;
    line-height: 1.8;
}

/* 注釈 */
.GiftManner_Note {
    max-width: 860px;
    margin: 22px auto 0;
    padding: 18px 22px;
    background: #fffaf2;
    border: 1px solid #ead9bb;
    border-radius: 14px;
    color: #6f655d;
    font-size: 14px;
    font-weight: 400;
    line-height: 1.9;
    text-align: center;
}

/* カード */
.GiftManner_Grid {
    display: grid;
    gap: 18px;
    margin: 26px auto 0;
}

.GiftManner_Grid3 {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.GiftManner_Card {
    padding: 22px 22px;
    background: #ffffff;
    border: 1px solid #e5ded4;
    border-radius: 16px;
    text-align: center;
}

.GiftManner_CardTitle {
    margin: 0 0 8px;
    padding: 0;
    color: #333333;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6;
}

.GiftManner_Card p {
    margin: 0;
    padding: 0;
    color: #333333;
    font-size: 14px;
    line-height: 1.9;
}

/* CTA */
.GiftManner_CtaBox {
    display: flex;
    align-items: center;
    justify-content: center;
    max-width: 900px;
    margin: 30px auto 0;
    padding: 0;
    background: transparent;
    border: none;
}

.GiftManner_CtaButtonWrap {
    display: flex;
    justify-content: center;
    gap: 14px;
    width: 100%;
}

.GiftManner_Button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 300px;
    min-height: 50px;
    padding: 13px 26px;
    border: 1px solid #d79a4b;
    border-radius: 999px;
    background: #ffffff;
    color: #333333;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.4;
    text-align: center;
    text-decoration: none;
    transition: all 0.25s ease;
}

.GiftManner_Button:hover,
.GiftManner_Button:focus {
    background: #fff7ee;
    border-color: #d79a4b;
    color: #333333;
    opacity: 1;
    text-decoration: none;
    outline: none;
}

/* メッセージ文例 */
.GiftManner_MessageList {
    max-width: 900px;
    margin: 26px auto 0;
    padding: 0;
}

.GiftManner_Message {
    margin: 0 0 16px;
    padding: 22px 24px;
    background: #ffffff;
    border: 1px solid #e5ded4;
    border-radius: 16px;
    text-align: center;
}

.GiftManner_Message:last-child {
    margin-bottom: 0;
}

.GiftManner_MessageTitle {
    margin: 0 0 8px;
    padding: 0;
    color: #333333;
    font-size: 16px;
    font-weight: 700;
    line-height: 1.6;
}

.GiftManner_Message p {
    margin: 0;
    padding: 0;
    color: #333333;
    font-size: 14px;
    line-height: 1.9;
}

/* FAQ */
.GiftManner_FaqList {
    max-width: 900px;
    margin: 26px auto 0;
    padding: 0;
}

.GiftManner_FaqItem {
    margin: 0 0 12px;
    padding: 0;
    background: #ffffff;
    border: 1px solid #e5ded4;
    border-radius: 14px;
    overflow: hidden;
}

.GiftManner_FaqItem:last-child {
    margin-bottom: 0;
}

.GiftManner_FaqQuestion {
    position: relative;
    display: block;
    cursor: pointer;
    margin: 0;
    padding: 18px 52px 18px 22px;
    color: #333333;
    font-size: 15px;
    font-weight: 700;
    line-height: 1.7;
    list-style: none;
    text-align: left;
}

.GiftManner_FaqQuestion::-webkit-details-marker {
    display: none;
}

.GiftManner_FaqQuestion::after {
    content: "+";
    position: absolute;
    right: 22px;
    top: 50%;
    transform: translateY(-50%);
    color: #9b7b56;
    font-size: 22px;
    font-weight: 400;
    line-height: 1;
}

.GiftManner_FaqItem[open] .GiftManner_FaqQuestion::after {
    content: "−";
}

.GiftManner_FaqAnswer {
    padding: 0 22px 20px;
}

.GiftManner_FaqAnswer p {
    margin: 0;
    padding: 0;
    color: #333333;
    font-size: 14px;
    line-height: 1.9;
    text-align: left;
}

/* 固定ヘッダー対策 */
#GiftManner,
#GiftManner_Basic,
#GiftManner_Timing,
#GiftManner_Budget,
#GiftManner_Noshi,
#GiftManner_Recipient,
#GiftManner_Message,
#GiftManner_Ng,
#GiftManner_Service,
#GiftManner_Faq {
    scroll-margin-top: 120px;
}
