html, body { margin:0; padding:0; width:100%; overflow-x:hidden; }
body {
    font-size:16px;
    line-height:1.75em;
    font-family:'Noto Sans JP',sans-serif;
    color:#000;
    overflow-x:hidden;
}
a {
	outline : none;
	text-decoration:none;
    color:#000;
}
a.active, a:active, a:focus, a:hover {
	text-decoration:none;
}
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: 200;
  margin:0;
  padding:0;
  }
p{
  margin:0;
  padding:0;
}
img{
    width:100%;
    height:auto;
}
*:focus {
  outline: none;
}
section {
    width:100%;
    padding:0 0 20vw; 
    display:block;
    margin:0 auto;
    position:relative;
    overflow-x:hidden !important;
}
@media screen and (max-width: 767px) {
section {
    padding:0 0 25vw;
    overflow-x:hidden !important;
}
}
.container-fluid{
    padding:0 !important;
    overflow-x:hidden !important;
}
.no-gutters{
    overflow-x:hidden !important;
}
.container{
    padding:0 !important;
}
.mx-auto{
    display:block !important;
    margin:0 auto !important;
}
.text-center{
    text-align:center;
}
.animation01{
    opacity:0;
}

/* --------------------------------------------------------------
  モーダル（共通土台）
-------------------------------------------------------------- */
body.no-scroll {
  position: fixed;
  overflow: hidden;
  width: 100%;
}

.modal {
  display: none; /* JSで開くときに block 等にする想定 */
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
  z-index: 999999999;
}

.modal__bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: calc(var(--vh, 1vh) * 100);
  background: rgba(135, 135, 135, 0.84);
  background-blend-mode: multiply;
}

/* --------------------------------------------------------------
  店舗リスト（#modal-store-01 用）
-------------------------------------------------------------- */
.modal__content__shop {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 600px;
  height: 85vh;
  background:#fff;
  border-radius:10px;
  padding:70px 0 20px;
}
.modal-shop-inner {
  width: 100%;
  max-height: 75vh;
  overflow-y: auto;
    padding:0 20px;
}
/* スクロールバー非表示（必要なら残す） */
.modal-shop-inner::-webkit-scrollbar {
  display: none;
}
.modal-shop-inner p{
  margin:15px 0;
  font-weight:400 !important;
  font-size:14px;
  line-height:1.5;
}
.modal-shop-inner p a{
  text-decoration:underline;
}

/* 閉じる（右上の×画像のクリック領域） */
.js-modal-popup-close-button {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 30px;
  height: 30px;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  line-height: 0;
}
@media screen and (max-width: 767px) {
.modal__content__shop {
    width: 90%;
    height: calc(var(--vh, 1vh) * 87);
    padding:50px 0 20px;
}
.modal-shop-inner {
    padding:0 15px;
    height: 97vh;
}
.modal-shop-inner p{
    font-size:12px;
    margin:10px 0;
}
.js-modal-popup-close-button {
  top: 15px;
  right: 15px;
  width: 20px;
  height: 20px;
}
}

/*--------------------------------------------------------------
KV
--------------------------------------------------------------*/
#minimore_01{
    position:relative;
    z-index:1;
    padding-bottom:0;
}
.kv-area {
  position: relative;
  z-index:1;
}


/*--------------------------------------------------------------
CAMPAIGN
--------------------------------------------------------------*/
.pink-bg{
  position: relative;
  z-index: 2;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_pink_bg_pc.png);
  margin-top: -14vw;

  /* 追加：擬似要素の基準 */
  isolation: isolate; /* これ大事：z-indexの事故を防ぐ */
}
/* PCのみ：装飾オーバーレイ */
@media (min-width: 768px){
  .pink-bg::before{
    content: "";
    position: absolute;

    /* 「上から3%」から開始 */
    top: 3%;
    left: 0;
    width: 100%;
    height: 97%; /* top:3%の残り分。必要なら100%でもOK */

    background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_pink_bg_pc_overlay.png);
    background-repeat: repeat-y;
    background-position: top center;
    background-size: 100% auto; /* 幅100%で表示 */
    z-index: 0;       /* 背景（= min-more_02の背景）の上 */
    pointer-events: none; /* リンククリック等を邪魔しない */
  }

  /* コンテンツは装飾レイヤーより上に */
  #minimore_02 > *{
    position: relative;
    z-index: 2;
  }
}

.pink-bg-02{
  position: relative;
  z-index: 2;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_pink_bg_pc_02.png);
  margin-top: -12vw;

  /* 追加：擬似要素の基準 */
  isolation: isolate; /* これ大事：z-indexの事故を防ぐ */
}
/* PCのみ：装飾オーバーレイ */
@media (min-width: 768px){
  .pink-bg-02::before{
    content: "";
    position: absolute;

    /* 「上から3%」から開始 */
    top: 3%;
    left: 0;
    width: 100%;
    height: 97%; /* top:3%の残り分。必要なら100%でもOK */

    background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_pink_bg_pc_overlay_02.png);
    background-repeat: repeat-y;
    background-position: top center;
    background-size: 100% auto; /* 幅100%で表示 */
    z-index: 0;       /* 背景（= min-more_02の背景）の上 */
    pointer-events: none; /* リンククリック等を邪魔しない */
  }

  /* コンテンツは装飾レイヤーより上に */
  #minimore_02 > *{
    position: relative;
    z-index: 2;
  }
}

.pink-bg-03{
  position: relative;
  z-index: 2;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_pink_bg_pc_03.png);
  margin-top: -12vw;

  /* 追加：擬似要素の基準 */
  isolation: isolate; /* これ大事：z-indexの事故を防ぐ */
}
/* PCのみ：装飾オーバーレイ */
@media (min-width: 768px){
  .pink-bg-03::before{
    content: "";
    position: absolute;

    /* 「上から3%」から開始 */
    top: 3%;
    left: 0;
    width: 100%;
    height: 97%; /* top:3%の残り分。必要なら100%でもOK */

    background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_pink_bg_pc_overlay_03.png);
    background-repeat: repeat-y;
    background-position: top center;
    background-size: 100% auto; /* 幅100%で表示 */
    z-index: 0;       /* 背景（= min-more_02の背景）の上 */
    pointer-events: none; /* リンククリック等を邪魔しない */
  }

  /* コンテンツは装飾レイヤーより上に */
  #minimore_02 > *{
    position: relative;
    z-index: 2;
  }
}

.campaign-sub{
    display:block;
    width:530px;
    margin:2% auto 1%;
}
.campaign-title{
    display:block;
    width:640px;
    margin:0 auto;
}
.campaign-img{
    display:block;
    width:750px;
    margin:1% auto 2%;
}
@media screen and (max-width: 767px){
.pink-bg{
    background-image:url(../img/campaign_pink_bg_sp.png);
}
.pink-bg-02{
    background-image:url(../img/campaign_pink_bg_sp_02.png);
}
.pink-bg-03{
    background-image:url(../img/campaign_pink_bg_sp_03.png);
}
.campaign-sub{
    width:60%;
    margin:5% auto 0.5%;
}
.campaign-title{
    width:90%;
    margin:0 auto 1%;
}
.campaign-img{
    display:block;
    width:95%;
    margin:0 auto 5%;
}
.campaign-copyright{
    width:7%;
    position:absolute;
    left:5%;
    bottom:3%;
}
}


.campaign-period-area{
    background-repeat:no-repeat;
    background-position:center center;
    background-size: cover;
    background-image:url(../img/campaing_period_pc.png);
    padding:15px 0;
}
.campaing-period{
    width:330px;
    display:block;
    margin:0 auto;
}

@media screen and (max-width: 767px){
.campaign-period-area{
    background-image:url(../img/campaing_period_sp.png);
}
.campaing-period{
    width:55%;
    padding:5px 0;
}
}




.campaign-eligible-item-title{
    width:400px;
    display:block;
    margin:60px auto 0;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.p-campaign-items{
  position: relative;
  max-width: 950px;     /* 必要なら調整 */
  margin: 50px auto;
}
.p-campaign-items picture,
.p-campaign-items img{
  width: 100%;
  height: auto;
  display: block;
}

.p-campaign-items .hotspot{
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: var(--w);
  height: var(--h);
  display: block;
  cursor: pointer;
  border-radius: 16px;
}
.p-campaign-items .hotspot:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: 2px;
}
.campaign-add-area{
    max-width:850px;
    display:block;
    margin:0 auto 40px;
}
.campaign-add-area p{
    display:block;
    font-size:14px;
    font-weight:600;
    color:#887172;
    line-height:1.7em;
}
@media (min-width: 768px){
  .hs-1{ --x: 4.494%;  --y: 0%;      --w: 22.277%; --h: 45.044%; }
  .hs-2{ --x: 25.061%; --y: 5.855%;  --w: 27.699%; --h: 46.533%; }
  .hs-3{ --x: 50.855%; --y: 0%;      --w: 22.472%; --h: 45.044%; }
  .hs-4{ --x: 70.884%; --y: 6.420%;  --w: 27.992%; --h: 45.968%; }

  .hs-5{ --x: 0.830%;  --y: 47.355%; --w: 29.653%; --h: 45.814%; }
  .hs-6{ --x: 27.748%; --y: 55.367%; --w: 22.277%; --h: 44.581%; }
  .hs-7{ --x: 50.464%; --y: 47.355%; --w: 22.228%; --h: 45.814%; }
  .hs-8{ --x: 70.738%; --y: 55.521%; --w: 28.383%; --h: 44.427%; }
}
@media (max-width: 767px){
.campaign-eligible-item-title{
    width:90%;
    display:block;
    margin:30px auto 0;
}
.p-campaign-items{
    position: relative;
    max-width: 100%;     /* 必要なら調整 */
    margin: 25px auto;
}
.p-campaign-items{ max-width: 520px; } /* SPで大きすぎる場合の保険 */

.hs-1{ --x: 4.205%;  --y: 0.781%;  --w: 31.385%; --h: 29.736%; } /* ヌードワン */
.hs-2{ --x: 30.256%; --y: 8.301%;  --w: 39.077%; --h: 29.590%; } /* レールデュサボン */
.hs-3{ --x: 64.513%; --y: 0.244%;  --w: 31.897%; --h: 29.590%; } /* リフレクト */

.hs-4{ --x: 0.103%;  --y: 33.691%; --w: 39.385%; --h: 29.297%; } /* グレイスルージュ */
.hs-5{ --x: 29.026%; --y: 45.313%; --w: 41.949%; --h: 29.199%; } /* ライジングウェーブ */
.hs-6{ --x: 4.205%;  --y: 70.068%; --w: 31.385%; --h: 29.395%; } /* ラブパスポート イット */

.hs-7{ --x: 64.615%; --y: 33.887%; --w: 31.487%; --h: 29.443%; } /* サニーモアニ */
.hs-8{ --x: 60.410%; --y: 69.336%; --w: 39.487%; --h: 29.346%; } /* フラワリー */

.campaign-add-area{
    max-width:80% !important;
    display:block;
    margin:0 auto 35px;
}
.campaign-add-area p{
    line-height:1.5em;
    font-size:12px;
}
}






/* ===== コンテナ ===== */
.anchor-nav{
  display: grid;
  gap: 20px;
  align-items: stretch;
  margin: 0 auto;
  padding: 16px;
  max-width: 1200px; /* 任意 */
}

/* ===== ボタン ===== */
.anchor-btn{
  position: relative;
  display: grid;
  place-items: center;
  padding: 15px 10px 45px;
  background: linear-gradient(
    90deg,
    #CC464D 0%,
    #CC464D 55%,
    #D85E61 75%,
    #E47574 100%
  );
  border-radius: 6px;
  color: #fff;
  text-decoration: none;
  font-size: clamp(14px, 1.8vw, 20px);
  font-weight: 600;
  line-height: 1.25;
  text-align: center;
  transition: transform .12s ease, filter .12s ease;
}

/* 下向き三角 */
.anchor-btn::after{
  content: "";
  position: absolute;
  left: 50%;
  bottom: 15px;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 10px solid transparent;
  border-right: 10px solid transparent;
  border-top: 17px solid rgba(255,255,255,1.0);
}

.anchor-btn02::after{
  bottom: 30px;
}

/* キーボード操作時のフォーカス（本番でも残す推奨） */
.anchor-btn:focus-visible{
  outline: 3px solid rgba(255,255,255,.9);
  outline-offset: 3px;
}

/* ===== PC：5列 ===== */
@media (min-width: 768px){
  .anchor-nav{
    grid-template-columns: repeat(5, 1fr);
  }
}

/* ===== SP：上3つ + 下2つ ===== */
@media (max-width: 767px){
.anchor-btn{
  padding: 12px 2px 25px;
  font-size: clamp(10px, 3.0vw, 18px);
  transition: transform .12s ease, filter .12s ease;
}
/* 下向き三角 */
.anchor-btn::after{
  bottom: 8px;
  border-left: 6px solid transparent;
  border-right: 6px solid transparent;
  border-top: 10px solid rgba(255,255,255,1.0);
}
.anchor-btn02::after{
  bottom: 15px;
}
.anchor-nav{
  grid-template-columns: repeat(6, 1fr);
  gap: 5px;
  padding: 0 12px;
}

/* 上段：1〜3個目（2カラム幅×3） */
.anchor-nav .anchor-btn:nth-child(-n+3){
grid-column: span 2;
}

/* 下段：4〜5個目も同じ幅（2カラム）に揃える */
.anchor-nav .anchor-btn:nth-child(n+4){
grid-column: span 2;
}

/* 下段を中央寄せ：4個目だけ開始位置をずらす */
.anchor-nav .anchor-btn:nth-child(4){
grid-column: 2 / span 2;
}
}


/*--------------------------------------------------------------
CAMPAIGN01
--------------------------------------------------------------*/
.blue-bg{
  position: relative;
  z-index: 2;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_blue_bg_pc.png);
  margin-top: -12vw;
  isolation: isolate; /* これ大事：z-indexの事故を防ぐ */
  padding-bottom:15vw;
}
/* PCのみ：装飾オーバーレイ */
@media (min-width: 768px){
  .blue-bg::before{
    content: "";
    position: absolute;

    /* 「上から3%」から開始 */
    top: 3%;
    left: 0;
    width: 100%;
    height: 97%; /* top:3%の残り分。必要なら100%でもOK */
    background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_blue_bg_pc_overlay.png);
    background-repeat: repeat-y;
    background-position: top center;
    background-size: 100% auto; /* 幅100%で表示 */
    z-index: 0;       /* 背景（= min-more_02の背景）の上 */
    pointer-events: none; /* リンククリック等を邪魔しない */
  }
}

.blue-bg-02{
  position: relative;
  z-index: 2;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_blue_bg_pc_02.png);
  margin-top: -12vw;
  isolation: isolate; /* これ大事：z-indexの事故を防ぐ */
  padding-bottom:15vw;
}
/* PCのみ：装飾オーバーレイ */
@media (min-width: 768px){
  .blue-bg-02::before{
    content: "";
    position: absolute;

    /* 「上から3%」から開始 */
    top: 3%;
    left: 0;
    width: 100%;
    height: 97%; /* top:3%の残り分。必要なら100%でもOK */
    background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_blue_bg_pc_overlay_02.png);
    background-repeat: repeat-y;
    background-position: top center;
    background-size: 100% auto; /* 幅100%で表示 */
    z-index: 0;       /* 背景（= min-more_02の背景）の上 */
    pointer-events: none; /* リンククリック等を邪魔しない */
  }

  /* コンテンツは装飾レイヤーより上に */
  #minimore_02 > *{
    position: relative;
    z-index: 2;
  }
}
.section-title-01{
    width:220px;
    display:block;
    margin:60px auto 30px;
}
.campaign-01-pop{
    width:600px;
    display:block;
    margin:15px auto 0;
}
.campaign-01-type{
    width:170px;
    display:block;
    margin:10px auto;
}
.campaign-01-orijginal-sticker-text{
    width:750px;
    display:block;
    margin:30px auto;
}
@media screen and (max-width: 767px){
.blue-bg{
  background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_blue_bg_sp.png);
}
.blue-bg-02{
  background-image:url(https://d2w53g1q050m78.cloudfront.net/storefitsjapanco/uploads/item/minimore2026ss/img/campaign_blue_bg_sp_02.png);
}
.section-title-01{
    width:40%;
    display:block;
    margin:30px auto 5px;
}
.campaign-01-pop{
    width:100%;
    display:block;
    margin:10px auto 5px;
}
.campaign-01-type{
    width:20%;
    display:block;
    margin:5px auto 15px;
}
.campaign-01-orijginal-sticker-text{
    width:88%;
    display:block;
    margin:0 auto 20px;
}
}



/* ===== 白い角丸カード ===== */
.notice-card{
  max-width: 750px;
  margin: 0 auto;
  background: #fff;
  border-radius: 15px;
  padding: 25px clamp(36px, 6.4vw, 60px);
  filter: drop-shadow(0px 2.21px 3.32px rgba(90, 152, 191, 0.23));
  display: flex;
  align-items: center;
  gap: clamp(9px, 1.5vw, 20px);
}

/* 左画像 */
.notice-card__thumb{
  flex: 0 0 auto;
  width: clamp(120px, 15vw, 220px);
}
.notice-card__thumb img{
  width: 100%;
  height: auto;
  display: block;
}

/* 右側 */
.notice-card__body{
  flex: 1 1 auto;
  min-width: 0;
}

/* タイトル */
.notice-card__title{
  margin: 0 0 14px;
  color: #c24548; /* 赤系 */
  font-weight: 600;
  line-height: 1.3;
  letter-spacing: 0.02em;
  font-size: clamp(14px, 1.6vw, 24px);
}
/* マーカー本体 */
.notice-card__title .marker{
  position: relative;
  display: inline-block;
  z-index: 0; /* マーカーを背面に */
}

/* 文字の背面に帯を敷く */
.notice-card__title .marker::before{
  content: "";
  position: absolute;
  left: -0.06em;   /* 少しだけ左右に余白を足す */
  right: -0.06em;
  bottom: 0.06em;  /* 文字の下側に合わせる（微調整ポイント） */
  height: 0.46em;  /* マーカーの太さ */
  background: rgba(255, 170, 180, 0.55); /* ピンク帯（色/濃さ調整） */
  border-radius: 0.16em;
  z-index: -1;
}


/* 本文 */
.notice-card__text{
  margin: 0;
  color: #c24548;
  font-weight: 500;
  line-height: 1.4;
  letter-spacing: 0.01em;
  font-size: clamp(11px, 1.2vw, 16px);
}

/* SP改行：PCでは非表示 */
.is-sp{ display: none; }

/* ===== レスポンシブ ===== */
@media (max-width: 767px){
  .notice-card{
    width:90%;
    /* SPでも横並び固定 */
    flex-direction: row;
    align-items: center;

    /* 添付デザイン寄せ：左右余白は少し薄め、上下に余白を出す */
    padding: clamp(14px, 3.8vw, 22px) clamp(16px, 4.2vw, 26px);

    /* 余白と詰まりの調整 */
    gap: clamp(10px, 2.8vw, 16px);

    /* SPは角丸少し大きめがそれっぽい */
    border-radius: 18px;
  }

  .notice-card__thumb{
    /* 左画像を添付っぽく：横幅は固定寄りで安定させる */
    width: clamp(150px, 38vw, 220px);
    flex: 0 0 auto;
  }

  .notice-card__body{
    flex: 1 1 auto;
    min-width: 0;
  }

  /* タイトル：添付は「こちらの」や「が目印！」も同じ行内で見せたいので少し詰める */
  .notice-card__title{
    margin: 0 0 5px;
    font-size: clamp(14px, 4.1vw, 20px);
    line-height: 1.25;
  }

  /* 本文：添付は少し小さめ＆行間控えめ */
  .notice-card__text{
    font-size: clamp(10px, 2.7vw, 12px);
    line-height: 1.45;
  }

  /* タイトルのSP改行を有効化する場合は、HTML側で <br class="is-sp"> を使う前提 */
  .is-sp{ display: inline; }
}

/* 520px以下でも縦積みにしない（ここが今回の肝） */
@media (max-width: 520px){
  .notice-card{
    flex-direction: row;
    align-items: center;
  }

  .notice-card__thumb{
    width: clamp(100px, 33vw, 160px);
  }
}



.sticker-area{
    margin:50px auto  40px !important;
}
.sticker-column img{
    filter: drop-shadow(0px 2.21px 3.32px rgba(90, 152, 191, 0.23));
}
.campaign-01-eligible-title{
    width:470px;
    display:block;
    margin:60px auto 0;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
@media (min-width: 768px){
.sticker-column:nth-child(2n+1){
    padding:0 10px 15px 0;
}
.sticker-column:nth-child(2n){
    padding:0 0 15px 10px;
}
}
@media (max-width: 767px){
.sticker-area{
    width:90%;
    margin:15px auto  20px !important;
}
.sticker-column{
    margin:5px 0;
}
.campaign-01-eligible-title{
    width:90%;
    display:block;
    margin:0 auto !important;
}
}

.store-link-area{
  margin:35px auto !important;
}

/* ▼PC：等間隔 + 2段目(2個)中央寄せ */
.store-link-area .row{
  display:flex;
  flex-wrap:wrap;
  justify-content:center;  /* 2段目(Qoo10/Yahoo!)を中央寄せ */
  gap:12px;                /* ボタン間隔（上段と同じ） */
  margin-left:0;
  margin-right:0;
}

.store-link-area .store-link-column{
  padding:0 !important; /* 旧 nth-child の余白を無効化 */
  flex:0 0 calc((100% - 24px)/3);   /* 3列：gap(12px)×2=24px */
  max-width:calc((100% - 24px)/3);
}

.store-link-column a{
  font-size: clamp(16px, 4.0vw, 24px);
  font-weight:600;
  border:1px solid #c24548;
  border-radius:50px;
  padding:10px 12px;

  /* 高さ統一（span有無でも同じ高さ） */
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  text-align:center;
  min-height:74px; /* 必要なら 70〜80px で微調整 */

  /* 背景：#FFFFFF 50% */
  background: rgba(255,255,255,0.5);
  box-sizing:border-box;
}

.store-link-column a span{
  font-size: clamp(12px, 3.5vw, 16px);
  display:block;
  line-height:1.2;
}

.store-link-area .store-link-column > a{
  color:#c24548 !important;
}
.store-link-area .store-link-column > a span{
  color:#c24548 !important;
}

/* ▼下部テキスト（元のまま） */
.campaign-add-area02{
  max-width:850px;
  display:block;
  margin:40px auto 0;
}
.campaign-add-area02 p{
  display:block;
  font-size:14px;
  color:#887172;
  line-height:1.7em;
}
.campaign-add-font-plus p{
  font-size:17px;
}

.store-link-area .store-link-column:empty {
  display: none;
}
/* ▼PC：上3つと同じ幅(1/3)のまま、2段目の2つも中央寄せ＋gapで揃える */
@media (min-width: 768px){
/* 親要素：中央寄せ設定 */
.store-link-area .row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center !important; /* 中央に寄せる */
  gap: 12px;               /* ボタンの間隔 */
  margin-left: 0;
  margin-right: 0;
}

/* 子要素（カラム）：mx-autoを無効化して幅を指定 */
.store-link-area .store-link-column {
  padding: 0 !important;
  
  /* ▼ここが修正のキモです */
  margin: 0 !important;   /* mx-auto（自動余白）を強制的にゼロにする */
  
  /* 3列計算： (100% - gap合計24px) ÷ 3 */
  flex: 0 0 calc((100% - 24px) / 3);
  max-width: calc((100% - 24px) / 3);
}
}

/* ▼SP：1列構成（767px以下） */
@media (max-width: 767px){
  .store-link-area{
    width:80%;
    display:block;
    margin:15px auto 0 !important;
  }

  .store-link-area .row{
    gap:10px;
    margin-left:0;
    margin-right:0;
  }

  .store-link-area .store-link-column{
    flex:0 0 100%;
    max-width:100%;
  }

  .store-link-column a{
    font-size: clamp(16px, 4.0vw, 20px);
    line-height:1.4;
    min-height:64px; /* SP用 */
  }

  .store-link-column a span{
    font-size: clamp(10px, 2.4vw, 14px);
    display:block;
  }

  .campaign-add-area02{
    max-width:90% !important;
    display:block;
    margin:20px auto 15px;
  }
  .campaign-add-area02 p{
    font-size:10px;
    line-height:1.5em;
  }
  .campaign-add-font-plus p{
    font-size:13px;
  }
}



/*--------------------------------------------------------------
CAMPAIGN02 CLEAR FILE
--------------------------------------------------------------*/
.section-title-02{
    width:220px;
    display:block;
    margin:80px auto 10px;
}
.campaign-02-pop{
    width:700px;
    display:block;
    margin:10px auto 0;
}
.campaign-02-type{
    width:170px;
    display:block;
    margin:0 auto;
}
.campaign-02-clear-file-text{
    width:850px;
    display:block;
    margin:15px auto;
}
@media screen and (max-width: 767px){
.section-title-02{
    width:40%;
    display:block;
    margin:30px auto 5px;
}
.campaign-02-pop{
    width:100%;
    display:block;
    margin:0px auto;
}
.campaign-02-type{
    width:20%;
    display:block;
    margin:0px auto 15px;
}
.campaign-02-clear-file-text{
    width:70%;
    display:block;
    margin:0 auto 20px;
}
}

.clear-file-area{
    margin:40px auto !important;
}
.clear-file-item{
    position:relative;
}
.campaign-clear-file-store-link{
    width:37%;
    position:absolute;
    bottom:3%;
    left:0;
    right:0;
    margin:auto;
}
.campaign-add-area03{
    width:100%;
    display:block;
    margin:40px auto 0;
}
.campaign-add-area03 strong{
    font-size:18px !important;
    line-height:1.4;
    color:#c24548;
    display:block;
    font-weight:600;
}
.campaign-add-area03 p{
    display:block;
    font-size:14px;
    font-weight:600;
    color:#887172;
    line-height:1.7em;
}
@media (min-width: 768px){
.clear-file-column:nth-child(2n+1){
    padding:0 10px 15px 0;
}
.clear-file-column:nth-child(2n){
    padding:0 0 15px 10px;
}
}
@media (max-width: 767px){
.clear-file-area{
    margin:20px auto !important;
    width:94%;
}
.clear-file-column{
    margin:3px 0;
}
.campaign-clear-file-store-link{
    width:50%;
    bottom:4%;
}
.campaign-add-area03{
    max-width:90% !important;
    display:block;
    margin:20px auto 0;
}
.campaign-add-area03 strong{
    font-size:14px !important;
}
.campaign-add-area03 p{
    font-size:10px;
    line-height:1.5em;
    font-weight:500;
}
}


/*--------------------------------------------------------------
CAMPAIGN03 PO(CH
--------------------------------------------------------------*/

.section-title-03{
    width:220px;
    display:block;
    margin:60px auto 30px;
}
.campaign-03-pop{
    width:550px;
    display:block;
    margin:30px auto 0;
}
.campaign-03-type{
    width:450px;
    display:block;
    margin:0 auto;
}
.campaign-dot{
    width:5px;
    display:block;
    margin:25px auto;
}
.campaign-03-pouch-text{
    width:800px;
    display:block;
    margin:30px auto;
}
.campaign-w-chance{
    width:280px;
    display:block;
    margin:10px auto;
}
.campaign-coupon-present{
    width:750px;
    display:block;
    margin:15px auto;
}
.campaign-coupon{
    width:550px;
    display:block;
    margin:15px auto;
}
.add-coupon-area{
    max-width:600px;
    display:block;
    margin:0 auto 40px;
}
@media screen and (max-width: 767px){
.section-title-03{
    width:40%;
    display:block;
    margin:30px auto 0px;
}
.campaign-03-pop{
    width:76%;
    display:block;
    margin:20px auto 5px;
}
.campaign-03-type{
    width:65%;
    display:block;
}
.campaign-dot{
    width:0.8vw;
    margin:10px auto;
}
.campaign-03-pouch-text{
    width:72%;
    display:block;
    margin:0 auto 20px;
}
.pouch-area{
    margin:10px auto !important;
}
.campaign-w-chance{
    width:40%;
}
.campaign-coupon-present{
    width:85%;
    display:block;
    margin:15px auto 10px;
}
.campaign-coupon{
    width:60%;
    display:block;
    margin:5px auto 10px;
}
.campaign-add-area{
    max-width:80% !important;
    display:block;
    margin:0 auto 35px;
}
.add-coupon-area p{
    font-size:10px;
}
}


.apply-step-area{
    margin:30px 0;
}
.line-apply-btn{
    width:350px;
    display:block;
    margin:30px auto;
    filter: drop-shadow(0px 4px 4px rgba(107, 107, 107, 0.25));
}
.general-desc-area{
    background: rgba(255, 255, 255, 0.5);
    box-shadow: 0px 2px 5px #aad3ef;
    border-radius:20px;
}
.pc-line-box{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:22px 26px;

}

/* 左側：文章＋矢印 */
.pc-line-text{
  display:flex;
  align-items:center;
  gap:18px;
  min-width:0; /* 長文でも崩れにくくする */
}

.pc-line-text p{
  margin:0;
  color:#c24548;
  font-weight:700;
  line-height:1.55;

  /* 文字サイズはお好みで */
  font-size:20px;
  letter-spacing:0.02em;
}

/* 矢印 */
.pc-line-arrows{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  gap:8px;
  color:#c24548;
  font-size:18px;
  font-weight:700;
  white-space:nowrap;
}

/* 右側：QR */
.pc-line-qr{
  flex:0 0 auto;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius:3px;
  background:#fff;
}

.pc-line-qr img{
  display:block;
  width:120px;      /* QRサイズ：ここを調整 */
  height:auto;
}



.campaign-precautions-title{
    width:460px;
    display:block;
    margin:90px auto 30px;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.precautions-desc-area{
    padding:25px;
}
.campaign-precautions-area01,.campaign-precautions-area02,.campaign-precautions-area03{
    width:100%;
    display:block;
}
.campaign-precautions-area01 p,.campaign-precautions-area02 p,.campaign-precautions-area03 p{
    display:block;
    font-size:14px;
    font-weight:600;
    color:#887172;
    line-height:1.7em;
}
.campaign-precautions-area01{
    padding-bottom:10px;
    border-bottom:1px solid #887172;
}
.campaign-precautions-area02{
    padding-top:10px;
}
.apply-term-btn{
    width:300px;
    display:block;
    text-align:center;
    margin:40px auto;
    font-size:28px;
    font-weight:600;
    color: #5A98BF;
    border:2px solid #5A98BF;
    border-radius:50px;
    padding:17px 15px 17px 25px;
}
@media screen and (max-width: 767px){
.campaign-precautions-title{
    width:90%;
    margin:45px auto 20px;
}
.apply-step-area{
    margin:15px 0;
}
.precautions-desc-area{
    width:90%;
    display:block;
    margin:5px auto;
    padding:15px;
}
.campaign-precautions-area01 p,.campaign-precautions-area02 p,.campaign-precautions-area03 p{
    display:block;
    font-size:12px;
}
.campaign-apply-step{
    padding:0 5%;
}
.line-apply-btn{
    width:80%;
    margin:12px auto 20px;
}
.apply-term-btn{
    width:45%;
    margin:10px auto 55px;
    font-size:16px !important;
    border-radius:30px;
    border:1px solid #5A98BF;
    padding:5px 10px 5px 20px;
}
}





.reciept-precautions-title{
    width:580px;
    display:block;
    margin:90px auto 30px;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.reciet-precautions-area{
    display:flex;
    align-items:center;
    padding:50px 80px;
}
.reciet-precautions-img{
    width:45%;
    padding-right:3%;
}
.reciet-precautions-desc{
    width:55%;
}
.reciept-incorrect-title{
    width:450px;
    display:block;
    margin:90px auto 30px;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.reciept-incorrect-area{
    padding-bottom:80px;
}
@media screen and (min-width: 768px){
.reciept-incorrect-column:nth-child(4n+1){
    padding:0 15px 20px 0;
}
.reciept-incorrect-column:nth-child(4n+2){
    padding:0 10px 20px 5px;
}
.reciept-incorrect-column:nth-child(4n+3){
    padding:0 5px 20px 10px;
}
.reciept-incorrect-column:nth-child(4n){
    padding:0 0 20px 15px;
}
}
@media screen and (max-width: 767px){
.reciept-precautions-title{
    width:90%;
    margin:45px auto 20px;
}
.reciet-precautions-area{
    display:block;
    width:90%;
    margin:0 auto;
    padding:20px 15px;
}
.reciet-precautions-img{
    width:100%;
    padding-right:0;
    margin:0 0 10px;
}
.reciet-precautions-desc{
    width:100%;
}
.reciept-incorrect-title{
    width:90%;
    margin:45px auto 20px;
}
.reciept-incorrect-area{
    width:90%;
    padding-bottom:20px;
}
.reciept-incorrect-column:nth-child(2n+1){
    padding:0 5px 20px 5%;
}
.reciept-incorrect-column:nth-child(2n){
    padding:0 5% 20px 5px;
}
}



/*--------------------------------------------------------------
CAMPAIGN04 CLEAR FILE
--------------------------------------------------------------*/
.section-title-04{
    width:220px;
    display:block;
    margin:80px auto 10px;
}
.campaign-04-pop{
    width:400px;
    display:block;
    margin:50px auto 25px;
}
.campaign-04-type{
    width:140px;
    display:block;
    margin:0 auto;
}
.campaign-04-clear-file-text{
    width:700px;
    display:block;
    margin:15px auto;
}
.campaign-04-clear-file{
    margin:50px auto;
}
@media screen and (max-width: 767px){
.section-title-04{
    width:40%;
    display:block;
    margin:30px auto 5px;
}
.campaign-04-pop{
    width:80%;
    display:block;
    margin:35px auto 0px;
}
.campaign-04-type{
    width:22%;
    display:block;
    margin:15px auto 10px;
}
.campaign-04-clear-file-text{
    width:80%;
    display:block;
    margin:0 auto 20px;
}
.campaign-04-clear-file{
    width:90%;
    display:block;
    margin:20px auto;
}
}

.campaign-04-eligible-item-title{
    width:540px;
    display:block;
    margin:70px auto 25px;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.eligible-item{
    position:relative;
}
.campaign-04-eligible-item-btn{
  filter: drop-shadow(0px 4px 4px rgba(235, 128, 133, 1));
  position:absolute;
  bottom:6.5%;
  left:0;
  right:0;
  margin:auto;
  width:50%;
}
.campaign-add-area04{
    width:100%;
    display:block;
    margin:25px auto;
}
.campaign-add-area04 p{
    display:block;
    font-size:14px;
    font-weight:600;
    color:#887172;
    line-height:1.5em;
    margin-bottom:15px;
    font-family: "Zen Kaku Gothic New", sans-serif;
}
.collaboration-title{
    width:450px;
    display:block;
    margin:80px auto 25px;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.collaboration-text{
    color:#c24548;
    font-size:22px;
    font-weight:600;
    line-height:1.6;
}
.youtube-area iframe{
  width: 100%;
  aspect-ratio: 16 / 9;
  height: auto;
  display: block;
}
.about-nijisanji-title{
    width:450px;
    display:block;
    margin:100px auto 35px;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.nijisanji-link-area{
    margin:35px auto !important;
}
.nijisanji-link-column:nth-child(3n+1){
    padding:0 10px 0 0;
}
.nijisanji-link-column:nth-child(3n+2){
    padding:0 5px;
}
.nijisanji-link-column:nth-child(3n){
    padding:0 0 0 10px;
}
.nijisanji-link-column a{
    font-size: clamp(16px, 4.0vw, 24px);
    font-weight:600;
    border-radius:50px;
    padding: 15px;
    background: linear-gradient(
    90deg,
    #CC464D 0%,
    #CC464D 55%,
    #D85E61 75%,
    #E47574 100%
    );
    color:#fff;
    display:block;
    filter: drop-shadow(0px 4px 4px rgba(235, 128, 133, 1));
}
.nijisanji-logo{
	width:250px;
	display:block;
	margin:60px auto 30px;
}
.nijisanji-text{
    color:#c24548;
    font-size:18px;
    line-height:1.6;
}
@media (min-width: 768px){
.eligible-item-column:nth-child(2n+1){
    padding:0 10px 15px 0;
}
.eligible-item-column:nth-child(2n){
    padding:0 0 15px 10px;
}
}
@media (max-width: 767px){
.campaign-04-eligible-item-title{
    width:92%;
    display:block;
    margin:40px auto 25px;
}
.eligible-item-column{
    margin:5px 0;
}
.campaign-add-area04{
    margin:60px auto 0px;
}
.campaign-add-area04 p{
    font-size:10px;
    line-height:1.3em;
}
.collaboration-title{
    width:90%;
    margin:20px auto 20px;
}
.collaboration-text{
  padding:0 5%;
  font-size: clamp(14px, 2.2vw, 16px);
}
.collaboration-text02{
  font-size: clamp(11px, 2.0vw, 13px);
}
.youtube-area{
    padding:0 5%;
}
.about-nijisanji-title{
    width:90%;
    margin:60px auto 20px;
}
.nijisanji-link-area{
    width:80%;
    display:block;
    margin:30px auto 0 !important;
}
.nijisanji-link-area > .row{
    margin-left: 0;
    margin-right: 0;
}
.nijisanji-link-column:nth-child(2n+1){
    padding:0;
}
.nijisanji-link-column:nth-child(2n){
    padding:0;
}
.nijisanji-link-column a{
    width:80%;
    display:block;
    font-size: clamp(16px, 3.0vw, 18px);
    margin:7px auto;
    line-height:1.4;
    padding: 7px 10px 9px;
}

.nijisanji-logo{
	width:50%;
}
.nijisanji-text{
  font-size: clamp(11px, 2.0vw, 13px);
}
}


/*--------------------------------------------------------------
FOOTER
--------------------------------------------------------------*/
#minimore_07{
    padding-bottom:5vw;
}
.white-bg{
  position: relative;
  z-index: 2;
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
  background-image:url(../img/footer_bg_pc.png);
  margin-top: -15vw;
  isolation: isolate; /* これ大事：z-indexの事故を防ぐ */
}
.footer-title{
    width:280px;
    display:block;
    margin:80px auto 40px;
    filter: drop-shadow(0px 2px 5px rgba(222, 114, 116, 0.2));
}
.footer-text{
    color:#c24548;
    font-size:20px;
    font-weight:600;
    line-height:1.3;
}
.footer-text02{
    margin-top:35px;
    line-height:1.5;
}
.footer-text a{
    color:#c24548;
}
.footer-text-time{
    display:block;
    margin:0 auto;
    width:300px;
}
@media screen and (max-width: 767px){
#minimore_07{
    padding-bottom:15vw;
}
.white-bg{
    background-image:url(../img/footer_bg_sp.png);
  margin-top: -13vw;
}
.footer-title{
    width:200px;
    margin:60px auto 15px;
}
.footer-text{
    font-size: 14px;
    line-height:1.5;
}
.footer-text02{
    margin-top:25px;
    line-height:1.2;
}
.footer-text-time{
    width:220px;
}
}