@charset "UTF-8";

/*共通*/
.wrap{width:100%;margin:auto;}
#shop-top section{max-width: 1200px;margin: 40px auto;}
div.headline {margin: 0 0 20px 0; }
div.headline .eng {color: #EEEEEE; font-size: 36px; }
div.headline .jpn {margin-top: -30px; font-size: 18px; }

html[data-browse-mode="S"]  #shop-top section{margin: 20px auto; }

/*カテゴリータイトル非表示*/
h1.block-category-list--header{opacity: 0; line-height: 0;}

/* メインビジュアル */
#shop-top #mainevisual{overflow: hidden; margin: 20px auto; }
.mv-swiper .swiper-slide{width: 34%; }
.mv-img-wrap{position:relative;overflow:hidden}
.mv-img-wrap img{width:100%;object-fit:cover;display:block;}
.new-tag{position:absolute;top:0;left:0;width:0;height:0;border-style:solid;border-width:52px 52px 0 0;border-color:#c0392b transparent transparent transparent;z-index:2;pointer-events:none}
.new-tag::after{content:'NEW';position:absolute;top:-48px;left:4px;color:#fff;font-size:10px;font-weight:700;transform:rotate(-45deg)}
.mv-nav{width: fit-content;display:flex;margin: 20px auto 0;align-items:center;justify-content:center;padding:8px 0;position:relative;}
.mv-nav .swiper-button-prev,.mv-nav .swiper-button-next{position:absolute;top:50%;transform:translateY(-50%);width: 32px;height:32px;margin:0;color:#888;--swiper-navigation-size:18px;background:rgba(255,255,255,0.85);border-radius:50%;}
.mv-nav .swiper-button-prev{left: -8vw;}
.mv-nav .swiper-button-next{right: -8vw;}
.mv-pagination{display:flex;align-items:center;justify-content:center;gap:0;}
.mv-pagination .swiper-pagination-bullet{width: 12px;height: 12px;background:#ccc;opacity:1;margin: 0 6px;}
.mv-pagination .swiper-pagination-bullet-active{background:#525355;}
html[data-browse-mode="S"] .mv-nav .swiper-button-prev{left: -36vw;}
html[data-browse-mode="S"] .mv-nav .swiper-button-next{right: -36vw;}

/* 人気のキーワード */
#shop-top #keyword{background: #efefef;margin-bottom: 0;}
.kw-outer{display:flex;align-items:center;gap:8px;padding:9px 12px;border-bottom:1px solid #e8e8e8}
.kw-label{font-size:12px;color:#333;white-space:nowrap;font-weight:600;flex-shrink:0}
.kw-divider{width:1px;height:18px;background:#ccc;flex-shrink:0}
.kw-btn{background:none;border:none;padding:0 4px;cursor:pointer;color:#999;font-size:12px;flex-shrink:0;line-height:1}
.kw-btn:hover{color:#333}
.kw-swiper-wrap{flex:1;overflow:hidden;min-width:0}
.kw-swiper .swiper-slide{width:auto!important}
.kw-swiper .swiper-slide a{display:inline-block;font-size: 11px;padding:4px 13px;border-radius:20px;white-space:nowrap;border:1px solid #ccc;color:#333;background:#fff;text-decoration:none;transition:background 0.15s;cursor:grab}
.kw-swiper .swiper-slide a:hover{background:#f5f5f5}
.kw-swiper .swiper-slide a.on{border:1.5px solid #c0392b;color:#c0392b}
.kw-swiper .swiper-slide a.on:hover{background:#fff0f0}

html[data-browse-mode="S"] #shop-top #keyword{background: #efefef;padding: 20px 30px 0;margin-bottom: 0;position: relative;flex-wrap: wrap;}
html[data-browse-mode="S"] .kw-label{font-size: 17px;margin-bottom: 1px;color: #333;white-space: nowrap;font-weight: 600;flex-shrink: unset;display: block;text-align: center;width: 100%;}
html[data-browse-mode="S"] .kw-btn{background: none; border: none; padding: 0 4px; cursor: pointer; color: #999; font-size: 12px; flex-shrink: 0; line-height: 1; position: absolute; right: 1%; top: 73%;}
html[data-browse-mode="S"] #kwPrev.kw-btn{left: 1%; right: unset;} html[data-browse-mode="S"] .kw-swiper-wrap{width: 100%; display: block;} html[data-browse-mode="S"] #shop-top #category {background: #efefef;padding: 20px 5px;margin: 0;}
html[data-browse-mode="S"] .pgrid {display: flex;flex-wrap: wrap;border-top: 1px solid #e8e8e8;list-style: none;justify-content: center;width: 100%;gap: 5px;}
html[data-browse-mode="S"] .pgrid li{width: 48%;}
html[data-browse-mode="S"] .pcard, .bcard{display: flex; text-align: center; flex-wrap: wrap; align-items: center; padding: 10px; border-right: 1px solid #e8e8e8; border-bottom: 1px solid #e8e8e8; gap: 0; background: #fff; text-decoration: none; }
html[data-browse-mode="S"] .pcard-info {flex: unset;min-width: unset;margin-right: 7px;width: 52%;}
html[data-browse-mode="S"] .pcard-text, .bcard-text {font-size: 10px;text-align: left;color: #222;line-height: 1.45;}
html[data-browse-mode="S"] .pcard img {/* size: b4; */width: 43%;flex-shrink: 0;}


/* 人気のカテゴリー */
#shop-top #category{background: #efefef; padding: 20px; margin-top: 0; }
.pgrid{display:grid;grid-template-columns:1fr 1fr 1fr;border-top:1px solid #e8e8e8;list-style:none;gap: 15px;}
.pcard,.bcard{display:flex;align-items:center;padding:14px 12px;border-right:1px solid #e8e8e8;border-bottom:1px solid #e8e8e8;gap: 6px;background:#fff;transition:background 0.12s;text-decoration:none}
.pcard:hover,.bcard:hover{background:#fafafa}
.pcard:nth-child(3n),.bcard:nth-child(3n){border-right:none}
.pcard-info{flex:1;min-width:0}
.badge{display:inline-block;background:#c0392b;color:#fff;font-size:11px;font-weight:700;padding:2px 9px;border-radius:3px;margin-bottom:5px}
.pcard-text,.bcard-text{font-size: 17px;color:#222;line-height:1.65}
.bcard-text{flex:1;line-height:1.7}
.miles{font-size:13px;color:#222;margin-top:2px}
.miles b{font-size:19px;font-weight:700;color:#c0392b}
.pcard img{width: 170px;object-fit:cover;border-radius:4px;flex-shrink:0}
.bcard img{width:115px;height:86px;object-fit:cover;border-radius:4px;flex-shrink:0}


/* JALファン固定グリッド */
#shop-top #jal-fan{max-width: unset;margin: auto;text-align: center;}
.fan-sec{background: linear-gradient(to right, #F2E6CA 0%, #FBF5E1 50%, #EBDBAF 100%);padding:28px 16px}
.fan-sec .sec-title{font-size: 24px;text-align: center;font-weight:700;color: #CC0000;margin-bottom:5px}
.sec-sub{text-align:center;font-size: 16px;margin-bottom:16px;line-height:1.6}
.fan-grid{max-width: 1400px;margin: 20px auto;display:grid;grid-template-columns:repeat(6,1fr);gap:10px;list-style:none}
.fan-grid li a img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
html[data-browse-mode="S"] .fan-grid{display: flex; flex-wrap: wrap; }
html[data-browse-mode="S"] .fan-grid li{width: 48%; }

/* おすすめ特集 */
.feat-sec{padding:28px 16px;overflow: hidden;}
.feat-title-wrap{text-align:center;margin-bottom:16px;position:relative;line-height:1}
.feat-swiper{padding:0 38px;position:relative;margin: 20px auto;}
.feat-swiper .swiper-slide{width: 17%; }
.feat-swiper .swiper-slide img{width:100%;object-fit:cover;display:block}
.feat-swiper .swiper-button-prev,.feat-swiper .swiper-button-next{position:absolute;top:50%;transform:translateY(-50%);z-index:10;color: #fff;--swiper-navigation-size:18px;width:30px;height:30px;background: #ccc;border-radius:50%;border:1px solid #ccc;display:flex;align-items:center;justify-content:center;cursor:pointer;/* transition:background 0.15s,border-color 0.15s; */}
.feat-swiper .swiper-button-prev{left:0}
.feat-swiper .swiper-button-next{right:0}
.feat-swiper .swiper-button-prev:hover,.feat-swiper .swiper-button-next:hover{background:#fff;border-color:#999}
.feat-swiper .swiper-button-disabled{opacity:0.3;cursor:default}
html[data-browse-mode="S"] #shop-top #future{margin: 0 auto;padding-bottom: 0;}

/* 取り扱いブランド */
.brand-sec{padding:24px 16px}
.brand-sec .sec-title{margin-bottom:14px;font-size:15px}
.brand-grid{display:grid;grid-template-columns: repeat(8,1fr);gap:8px;list-style:none;margin: 20px auto;}
.brand-grid li a img{width:100%;aspect-ratio:500/200;object-fit:cover;border-radius:4px;display:block}

html[data-browse-mode="S"] .brand-sec{padding:0;}
html[data-browse-mode="S"] .brand-list{overflow-x: scroll; margin-bottom: 20px; }
html[data-browse-mode="S"] .brand-grid{width: 200vw; }

/*総合ランキング*/
.top-ranking-note {display: flex; align-items: end; flex-direction: column; margin-bottom: 20px; }
html[data-browse-mode="S"] .top-ranking-note {flex-direction: unset; padding:0 20px;}
html[data-browse-mode="S"] .block-top-event--goods .block-ranking-r--items{padding: 0 15px; margin: 0; border-top: none; font-size: 0; display: flex; justify-content: space-between; flex-wrap: wrap; }
html[data-browse-mode="S"] .block-top-event--goods .block-ranking-r--items li {width: calc(49% - 7.5px); padding: 0; margin: 0 0 35px 0; vertical-align: top; font-size: 14px; display: block; position: relative; }