/* フリーページ キャンペーン・クーポン */

@keyframes cmf-fadein {
  from { opacity: 0; transform: translateY(12px); }
  to { opacity: 1; transform: translateY(0); }
}

#cmf-coupon-section { max-width: 960px; margin: 0 auto; padding: 0 24px; box-sizing: border-box; animation: cmf-fadein 0.7s ease both; }

/* H1 */
#cmf-coupon-section .cmf-coupon-h1-wrap { text-align: center; margin: 36px 0 0; padding-bottom: 24px; }
#cmf-coupon-section .cmf-coupon-h1 { font-size: 26px; font-weight: bold; letter-spacing: 0.08em; margin: 0 0 6px; padding: 0; border: none; color: #1a1a1a; line-height: 1.2; }
#cmf-coupon-section .cmf-coupon-h1-ja { display: block; font-size: 12px; font-weight: normal; letter-spacing: 0.18em; color: #999; margin-top: 6px; }
#cmf-coupon-section .cmf-coupon-h1-desc { font-size: 14px; color: #666; line-height: 2; margin: 16px 0 0; letter-spacing: 0.03em; text-align: center; }

/* H2 */
#cmf-coupon-section h2 { display: flex; align-items: center; gap: 18px; font-size: 15px; font-weight: bold; letter-spacing: 0.15em; margin: 60px 0 30px; padding: 0; border: none; color: #1a1a1a; }
#cmf-coupon-section h2::before,
#cmf-coupon-section h2::after { content: ''; flex: 1; height: 1px; background: #d0d0d0; }

/* キャンペーン */
.cmf-coupon-flex-around { display: flex; flex-wrap: wrap; justify-content: flex-start; gap: 28px; margin: 8px 0; padding: 0; }
.cmf-coupon-flex-item { width: calc(50% - 14px); box-sizing: border-box; background: #fff; box-shadow: 0 4px 20px rgba(0,0,0,0.14); transition: box-shadow 0.35s ease, transform 0.35s ease; }
.cmf-coupon-flex-item:hover { transform: translateY(-5px); box-shadow: 0 18px 44px rgba(0,0,0,0.22); }
.cmf-coupon-flex-item > a { display: block; width: 78%; margin: 24px auto 0; transition: transform 0.55s ease, box-shadow 0.55s ease; }
.cmf-coupon-flex-item:hover > a { transform: rotate(2deg); box-shadow: 4px 8px 20px rgba(0,0,0,0.15); }
.cmf-coupon-flex-item > a img { width: 100%; margin: 0; display: block; }
.cmf-coupon-flex-item > img { width: 78%; margin: 24px auto 0; display: block; }
.cmf-coupon-campaign-desc { margin: 18px 20px 20px; }
.cmf-coupon-campaign-desc p:first-child { text-align: center; font-size: 15px; font-weight: bold; letter-spacing: 0.06em; margin: 0 0 12px; padding: 0 0 12px; border-bottom: 1px solid #e8e8e8; color: #1a1a1a; }
.cmf-coupon-campaign-desc p { font-size: 14px; margin-top: 8px; padding: 0; line-height: 1.9; color: #444; }
.cmf-coupon-campaign-box { font-size: 13px; padding: 10px 14px; margin: 12px 0 0; border: 1px solid #ebebeb; background: #fafafa; line-height: 1.9; color: #555; }
.cmf-coupon-campaign-desc .cmf-coupon-campaign-box p { margin: 0; text-align: left; font-weight: normal; font-size: 13px; }
.cmf-coupon-note { color: #8b3a3a; }

/* クーポン */
.cmf-coupon-list-wrap { margin: 5px 0 20px; }
.cmf-coupon-list { display: flex; flex-wrap: wrap; gap: 18px; justify-content: center; }
.cmf-coupon-item { width: calc(33.333% - 12px); box-sizing: border-box; background: #fff; overflow: hidden; box-shadow: 0 4px 20px rgba(0,0,0,0.14); transition: box-shadow 0.35s ease, transform 0.35s ease; }
.cmf-coupon-item:hover { transform: translateY(-4px); box-shadow: 0 14px 36px rgba(0,0,0,0.22); }
.cmf-coupon-item img { width: 72%; margin: 0 auto; display: block; padding-top: 20px; }
.cmf-coupon-item ul { list-style: none; padding: 18px 16px 16px; margin: 16px 0 0; font-size: 13px; line-height: 1.9; border-top: 1px solid #ebebeb; color: #444; }
.cmf-coupon-item ul li { margin-bottom: 5px; }
.cmf-coupon-item-ttl { text-align: center; font-weight: bold; font-size: 14px; letter-spacing: 0.06em; color: #1a1a1a; margin-top: 0 !important; margin-bottom: 12px !important; padding-bottom: 10px; border-bottom: 1px solid #e8e8e8; }

/* ポイントサービス */
.cmf-coupon-point { margin: 10px 0 20px; padding: 30px 40px; text-align: center; background: #f7f7f7; }
.cmf-coupon-point p { font-size: 14px; line-height: 1.9; color: #444; text-align: center; }
.cmf-coupon-point img { width: 68%; max-width: 540px; border: 6px solid #fff; }
.cmf-coupon-point-note { font-size: 12px; color: #888; margin-top: 10px; text-align: left; }

/* その他のサービス */
.cmf-coupon-other-services { text-align: center; margin: 5px 0 28px; }
.cmf-coupon-other-services a { display: block; }
.cmf-coupon-other-services img { display: block; margin: 0 auto 10px; max-width: 100%; }

@media screen and (max-width: 768px) {
  #cmf-coupon-section { padding: 0 16px; }
  .cmf-coupon-flex-around { gap: 20px; }
  .cmf-coupon-flex-item { width: 100%; }
  .cmf-coupon-flex-item > a { width: 80%; }
  .cmf-coupon-flex-item > img { width: 80%; }
  .cmf-coupon-list { gap: 14px; }
  .cmf-coupon-item { width: calc(50% - 7px); }
  .cmf-coupon-point { padding: 22px 20px; }
  .cmf-coupon-point img { width: 85%; }
}

@media screen and (max-width: 600px) {
  .cmf-coupon-item { width: 100%; }
  .cmf-coupon-item img { width: 48%; }
}

@media screen and (max-width: 480px) {
  #cmf-coupon-section .cmf-coupon-h1-wrap { margin: 22px 0 0; padding-bottom: 18px; }
  #cmf-coupon-section .cmf-coupon-h1 { font-size: 26px; letter-spacing: 0.14em; }
  #cmf-coupon-section .cmf-coupon-h1-desc { text-align: left; }
  #cmf-coupon-section h2 { font-size: 14px; margin: 40px 0 20px; letter-spacing: 0.1em; }
  .cmf-coupon-campaign-desc { margin: 16px 14px 16px; }
  .cmf-coupon-point { padding: 20px 16px; text-align: left; }
  .cmf-coupon-point p { text-align: left; }
  .cmf-coupon-point img { width: 100%; }
}


/*お買い物ガイド*/
:root{--g-white:#ffffff;--g-surface:#f5f4f2;--g-ink:#1e1e1e;--g-sub:#58534e;--g-muted:#8a8480;--g-border:#d8d4ce;--g-border-lt:#eae7e2;--g-accent:#5c4f42;--g-red:#b8312b;--g-radius-sm:4px;--g-radius:8px;--g-radius-lg:12px;}
#cmg-guide{scroll-behavior:smooth;}
.cmg-guide{max-width:840px;margin:0 auto;padding:0 24px 80px;font-size:15px;line-height:1.8;color:var(--g-ink);}
.cmg-guide *{box-sizing:border-box;}
.cmg-guide img{max-width:100%;height:auto;display:block;}
.cmg-guide a{color:var(--g-accent);text-decoration:underline;text-underline-offset:.2em;transition:opacity .15s;}
.cmg-guide a:hover{opacity:.65;}
.cmg-guide p{margin:0 0 10px;}
.cmg-guide p:last-child{margin-bottom:0;}
.cmg-guide section{margin:0;}
.cmg-page-header{padding:36px 0 24px;}
.cmg-page-header__title{font-size:clamp(20px, 3vw, 26px);font-weight:700;letter-spacing:.02em;line-height:1.2;margin:0 0 6px;color:var(--g-ink);}
.cmg-page-header__sub{font-size:13px;color:var(--g-muted);margin:0;}
.cmg-toc{margin:24px 0 0;padding:16px 18px 12px;background:var(--g-white);border:1px solid var(--g-border);border-radius:var(--g-radius-lg);}
.cmg-toc *{box-sizing:border-box;}
.cmg-toc::before{content:'目次';display:block;font-size:11px;font-weight:700;letter-spacing:.16em;color:var(--g-muted);margin-bottom:10px;padding-bottom:10px;border-bottom:2px solid var(--g-accent);}
@media (min-width: 640px){
.cmg-toc{display:grid;grid-template-columns:repeat(3, 1fr);gap:0 20px;align-items:start;}
.cmg-toc::before{grid-column:1 / -1;}
}
.cmg-toc__box{margin:0;}
.cmg-toc__list{list-style:none;padding:0;margin:0;}
.cmg-toc__item{margin:0;}
.cmg-toc__link{display:block;padding:7px 8px;font-size:14px;font-weight:700;letter-spacing:.04em;text-decoration:none;color:var(--g-ink);border-top:1px solid var(--g-border-lt);border-radius:2px;transition:background .15s;}
.cmg-toc__link::before{display:none;}
.cmg-toc__link:hover{background:var(--g-surface);color:var(--g-ink);text-decoration:none;opacity:1;}
.cmg-toc__item:first-child .cmg-toc__link{border-top:none;}
.cmg-toc__sublist{list-style:none;padding:0;margin:0 0 4px 16px;}
.cmg-toc__subitem{margin:0;}
.cmg-toc__sublink{display:block;padding:3px 2px;font-size:14px;color:var(--g-sub);text-decoration:none;transition:color .15s;}
.cmg-toc__sublink:hover{color:var(--g-accent);opacity:1;}
.cmg-guide__section{padding:36px 0;border-top:none;}
.cmg-guide__section:first-of-type{padding-top:28px;}
.cmg-guide__h2{margin:20px 0 24px;padding:0 0 12px;font-size:clamp(18px, 2.5vw, 22px);font-weight:700;letter-spacing:.05em;line-height:1.4;color:var(--g-ink);border-bottom:2px solid var(--g-accent);}
.cmg-guide__h2::before{display:none;}
.cmg-guide__lead{margin:0 0 16px;font-size:14px;color:var(--g-sub);line-height:1.75;}
.cmg-guide__lead span{font-weight:700;color:var(--g-ink);}
.cmg-box{margin:12px 0 0;padding:18px 20px;background:var(--g-white);border:1px solid var(--g-border-lt);border-radius:var(--g-radius-lg);}
.cmg-box:first-child{margin-top:0;}
.cmg-box + .cmg-box{margin-top:10px;}
.cmg-box__h3{margin:0 0 12px;font-size:15px;font-weight:700;color:var(--g-ink);padding-bottom:10px;border-bottom:1px solid var(--g-border-lt);}
.cmg-box__h3 span{background:none;color:inherit;padding:0;border-radius:0;font-size:inherit;}
.cmg-sub__h4{margin:18px 0 8px;font-size:14px;font-weight:700;color:var(--g-ink);}
.cmg-delivery{margin:8px 0 0;}
.cmg-delivery img{max-width:50%;height:auto;}
@media (max-width: 639px){
.cmg-delivery img{max-width:100%;}
}
.cmg-holiday{margin:14px 0 0;padding:16px 18px;background:var(--g-surface);border:1px solid var(--g-border);border-radius:var(--g-radius);}
.cmg-holiday__title{margin:0 0 12px;font-size:14px;font-weight:700;color:var(--g-ink);padding:0 0 10px;border-bottom:1px solid var(--g-border-lt);}
.cmg-holiday__date{margin:0 0 12px;padding:8px 12px;background:#fff;border-radius:var(--g-radius-sm);font-size:14px;}
.cmg-holiday__date span{font-weight:700;}
.cmg-holiday__date-value{font-weight:700;color:var(--g-red);}
.cmg-holiday__blocks + p{margin-top:14px;}
.cmg-holiday__blocks{display:flex;flex-direction:column;gap:10px;margin:14px 0 0;}
.cmg-holiday__block2{border:1px solid var(--g-border);border-radius:4px;overflow:hidden;}
.cmg-holiday__block2-heading{padding:6px 16px;background:#58534e;font-size:15px;font-weight:700;line-height:1.6;color:#fff;}
.cmg-holiday__tbl{width:100%;border-collapse:collapse;font-size:14px;line-height:1.6;background:#fff;}
.cmg-holiday__tbl tr{border-bottom:1px solid #eae7e2;}
.cmg-holiday__tbl tr:last-child{border-bottom:none;}
.cmg-holiday__tbl td{padding:10px 16px;vertical-align:middle;}
.cmg-holiday__tbl .c-type{font-weight:700;width:36%;}
.cmg-holiday__tbl .c-label{width:24%;text-align:center;}
.cmg-guide .cmg-holiday__tbl .c-label span{display:inline-block;min-width:100px;text-align:center;font-size:13px;font-weight:normal;color:#1e1e1e;border:1px solid #666;border-radius:2px;padding:2px 8px;white-space:nowrap;}
.cmg-holiday__tbl .c-date{font-weight:700;color:var(--g-red);text-align:right;}
@media (max-width: 600px){
.cmg-holiday__tbl,.cmg-holiday__tbl tbody,.cmg-holiday__tbl tr,.cmg-holiday__tbl td{display:block;width:100%;}
.cmg-holiday__tbl tr{padding:10px 16px;border-bottom:1px solid #eae7e2;}
.cmg-holiday__tbl tr:last-child{border-bottom:none;}
.cmg-holiday__tbl td{padding:0;}
.cmg-holiday__tbl .c-type{font-size:14px;font-weight:700;margin-bottom:6px;}
.cmg-holiday__tbl .c-label{text-align:left;margin-bottom:4px;}
.cmg-holiday__tbl .c-date{text-align:left;font-size:13px;}
}
.cmg-terms{margin:8px 0 0;}
.cmg-terms__dt{margin:10px 0 3px;font-size:12px;font-weight:700;color:var(--g-muted);letter-spacing:.04em;}
.cmg-terms__dt:first-child{margin-top:0;}
.cmg-terms__dd{margin:0;padding:7px 12px;font-size:14px;line-height:1.7;background:var(--g-surface);border-radius:var(--g-radius-sm);}
.cmg-terms__dd span{font-weight:700;color:var(--g-ink);}
.cmg-pay{margin:12px 0 8px;display:flex;flex-wrap:wrap;gap:10px;align-items:center;}
.cmg-pay .cmg-pay__img{height:40px;width:auto;max-width:none;}
.cmg-pay .cmg-pay__icon{height:40px;width:auto;}
.cmg-explain{margin:12px 0 0;}
.cmg-explain__dt{margin:12px 0 3px;font-size:14px;font-weight:700;color:var(--g-ink);}
.cmg-explain__dt:first-child{margin-top:0;}
.cmg-explain__dd{margin:0;padding:7px 12px;font-size:14px;line-height:1.7;background:var(--g-surface);border-radius:var(--g-radius-sm);}
.cmg-note{margin:12px 0 0;padding:0;list-style:none;}
.cmg-note__item{margin:0 0 5px;padding:8px 12px 8px 28px;position:relative;font-size:13px;line-height:1.75;color:var(--g-sub);background:var(--g-surface);border-radius:var(--g-radius-sm);}
.cmg-note__item::before{content:'※';position:absolute;left:10px;top:9px;font-size:12px;color:var(--g-muted);}
.cmg-coupon{margin:14px 0 0;}
.cmg-coupon__grid{display:grid;grid-template-columns:1fr;gap:12px;}
@media (min-width: 600px){
.cmg-coupon__grid{grid-template-columns:repeat(3, 1fr);}
}
.cmg-coupon__card{padding:16px;background:var(--g-white);border:1px solid var(--g-border-lt);border-radius:var(--g-radius-lg);}
.cmg-guide .cmg-coupon__img{margin:0 auto 12px;max-width:190px;border-radius:var(--g-radius-sm);}
.cmg-coupon__dl{margin:0;}
.cmg-coupon__dt{margin:0 0 8px;font-size:14px;font-weight:700;line-height:1.5;}
.cmg-coupon__dd{margin:0 0 4px;font-size:13px;color:var(--g-sub);line-height:1.65;}
.cmg-contact{font-style:normal;}
.cmg-contact__link{display:inline-block;font-size:15px;font-weight:700;color:var(--g-accent);text-decoration:underline;text-underline-offset:.2em;transition:opacity .15s;}
.cmg-contact__link:hover{opacity:.65;}
.cmg-contact__note{margin:10px 0 0;font-size:13px;color:var(--g-sub);}
.cmg-text-bold{font-weight:700;}
.cmg-text-or{color:var(--g-red);}
.cmg-text-orrd{color:var(--g-red);}
.cmg-guide span:not([class]){font-weight:700;}
.cmg-timeline-wrap{margin:12px 0 0;padding:20px 32px 0;border:1px solid var(--g-border);border-radius:var(--g-radius);}
.cmg-timeline-wrap__note{font-size:14px;color:#e8501a;margin:0 0 16px;}
.cmg-timeline{position:relative;height:4px;margin:28px 7px 44px;}
.cmg-timeline__line-green{position:absolute;top:0;left:0;height:4px;background:#3aaa7a;}
.cmg-timeline__line-orange{position:absolute;top:0;height:4px;background:#e8501a;}
.cmg-timeline__line-dashed{position:absolute;top:0;right:0;width:6%;height:0;border-top:4px dashed #e8501a;}
.cmg-timeline__dot{position:absolute;top:50%;transform:translate(-50%, -50%);width:14px;height:14px;border-radius:50%;}
.cmg-timeline__dot--green{background:#3aaa7a;left:0;}
.cmg-timeline__dot--orange{background:#e8501a;}
.cmg-timeline__label{position:absolute;white-space:nowrap;transform:translateX(-50%);font-size:13px;color:#333;}
.cmg-timeline__label--days{bottom:calc(100% + 8px);top:auto;font-size:14px;font-weight:700;color:#3aaa7a;}
.cmg-timeline__label--range{bottom:calc(100% + 8px);top:auto;font-size:14px;color:#e8501a;}
.cmg-timeline__label--start{left:0;top:calc(100% + 12px);}
.cmg-timeline__label--mid{top:calc(100% + 12px);}
@media (max-width: 639px){
.cmg-guide{padding:0 3px 60px;}
.cmg-guide__h2{margin:20px 12px 20px;}
.cmg-guide .cmg-guide__lead{margin-left:12px;margin-right:12px;}
.cmg-page-header{padding:24px 12px 18px;}
.cmg-box{padding:12px 12px;}
.cmg-toc{padding:14px 14px 10px;}
.cmg-timeline-wrap{padding:16px 20px 0;}
.cmg-timeline__label--range{font-size:12px;}
.cmg-timeline__label{font-size:12px;}
.cmg-timeline__line-dashed{width:20px;}
.cmg-pay__img{max-width:100%;height:auto;}

}
@media print{
.cmg-toc{display:none;}
.cmg-box{break-inside:avoid;}
}