:root{--bg:#f0f6ff;--card-bg:#e8f0fd;--gold:#4a90d9;--gold2:#2a6db5;--cream:#1a2d42;--muted:#6b8ba4;--border:rgba(74,144,217,.2);--modal-bg:#ffffff}
*{box-sizing:border-box;margin:0;padding:0}
body{background:var(--bg);color:var(--cream);font-family:'DM Sans','Noto Sans JP',sans-serif;min-height:100vh;overflow-x:hidden}
header{text-align:center;padding:48px 20px 30px;position:relative;overflow:hidden}
header::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 50% -20%,rgba(74,144,217,.12),transparent 70%);pointer-events:none}
h1{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,6vw,4.2rem);font-weight:700;line-height:1;margin-bottom:4px}
h1 span{color:var(--gold)}
.sub{font-size:.66rem;letter-spacing:.28em;color:var(--muted);text-transform:uppercase;margin-bottom:18px}
.gold-line{width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);margin:0 auto 16px}

/* UI LANG BAR */
.ui-lang-bar{max-width:100%;margin:0 auto 20px;padding:18px 20px;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.ui-lang-lbl{font-size:.6rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase}
.ui-sep{width:1px;height:14px;background:rgba(74,144,217,.2)}
.ui-btn{background:rgba(74,144,217,.06);border:1px solid rgba(74,144,217,.18);color:var(--muted);font-size:.72rem;padding:5px 14px;border-radius:20px;cursor:pointer;transition:all .2s;font-family:inherit}
.ui-btn.active,.ui-btn:hover{background:rgba(74,144,217,.18);border-color:var(--gold);color:var(--gold2)}




/* FILTER BAR */
.filter-bar{max-width:1100px;margin:10px auto 0;padding:0 20px 14px;display:flex;gap:12px;align-items:flex-start;flex-wrap:wrap;border-bottom:1px solid rgba(74,144,217,.2)}
.filter-block{display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.filter-block-left{flex:1 1 0;min-width:0}
.filter-block-right{flex:1 1 0;min-width:0;display:flex;flex-wrap:wrap;gap:5px;align-items:center}
.filter-sep{width:1px;min-height:28px;background:rgba(74,144,217,.18);align-self:center;flex-shrink:0}
.filter-lbl{font-size:.58rem;letter-spacing:.13em;color:var(--muted);text-transform:uppercase;white-space:nowrap;margin-right:2px;line-height:2}
.fbtn{background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.1);color:var(--muted);font-size:.68rem;padding:3px 11px;border-radius:14px;cursor:pointer;transition:all .2s;font-family:inherit;white-space:nowrap}
.fbtn:hover{border-color:rgba(74,144,217,.4);color:var(--cream)}
.fbtn.active{border-color:rgba(192,57,43,.5);background:rgba(192,57,43,.1);color:#c0392b}
.fbtn.choco.active{border-color:rgba(74,144,217,.55);background:rgba(74,144,217,.12);color:var(--gold2)}
/* CATS */

.result-count{max-width:1100px;margin:8px auto 16px;padding:0 24px;font-size:.68rem;color:var(--muted)}

/* GRID */
.grid{max-width:1100px;margin:0 auto;padding:0 20px 60px;display:grid;grid-template-columns:repeat(auto-fill,minmax(162px,1fr));gap:13px}
/* 手機・平板：強制 2 欄，桌機維持 auto-fill */
@media (max-width:1023px){
  .grid{grid-template-columns:repeat(2,1fr);gap:10px}
}
.pcard{background:var(--card-bg);border:1px solid rgba(74,144,217,.15);border-radius:10px;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent;transition:transform .2s,box-shadow .2s,border-color .2s;animation:fadeUp .4s ease both}
.pcard:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(74,144,217,.2),0 0 0 1px rgba(74,144,217,.3);border-color:rgba(74,144,217,.35)}
@media(hover:none){.pcard:hover{transform:none;box-shadow:none;border-color:rgba(74,144,217,.15)}}
.img-wrap{width:100%;aspect-ratio:1000/590;overflow:hidden;background:#dce8f5;position:relative}
.img-wrap img{width:100%;height:100%;object-fit:contain;object-position:center;display:block;transition:transform .35s ease}
.pcard:hover .img-wrap img{transform:scale(1.04)}
@media(hover:none){.pcard:hover .img-wrap img{transform:none}}
.no-img-ph{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:2.6rem;opacity:.2}
.pcard-body{padding:9px 12px 13px}
.pcard-badge{display:inline-block;font-size:.55rem;letter-spacing:.08em;background:rgba(74,144,217,.1);border:1px solid rgba(74,144,217,.2);color:var(--gold);padding:2px 7px;border-radius:10px;margin-bottom:5px}
.pcard-name{font-size:.78rem;line-height:1.35;color:var(--cream)}
.pcard-name.zh{font-family:'Noto Sans TC',sans-serif}
.pcard-name.ko{font-family:'Noto Sans KR',sans-serif;font-size:.75rem}
.pcard-name.en{font-family:'DM Sans',sans-serif}
@keyframes fadeUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* MODAL */
.overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;pointer-events:none;transition:opacity .22s}
.overlay.open{opacity:1;pointer-events:all}
.modal{background:var(--modal-bg);border:1px solid var(--border);border-radius:14px;max-width:580px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;transform:translateY(18px);transition:transform .22s;position:relative}
.modal-scroll{overflow-y:auto;flex:1}
.overlay.open .modal{transform:translateY(0)}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:10px 14px;background:rgba(240,246,255,.96);border-bottom:1px solid rgba(74,144,217,.15);border-radius:14px 14px 0 0;position:sticky;top:0;z-index:20}
.modal-header-title{font-size:.6rem;letter-spacing:.2em;color:var(--muted);text-transform:uppercase}
.modal-close{background:rgba(0,0,0,.07);border:none;color:var(--cream);font-size:.9rem;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0}
.modal-close:hover{background:rgba(0,0,0,.12)}
.modal-img{width:100%;aspect-ratio:1000/590;overflow:hidden;border-radius:0;position:relative}
.modal-img img{width:100%;height:100%;object-fit:cover;display:block}
.modal-img-ph{width:100%;height:230px;background:linear-gradient(135deg,#c8dff0,#a8c8e8);display:flex;align-items:center;justify-content:center;font-size:5rem;opacity:.35;border-radius:0}
.modal-body{padding:20px 22px 26px}
.m-badge{font-size:.58rem;letter-spacing:.12em;color:var(--gold);text-transform:uppercase;background:rgba(74,144,217,.1);border:1px solid rgba(74,144,217,.2);padding:2px 9px;border-radius:10px;display:inline-block;margin-bottom:9px}
.m-main{font-size:1.25rem;font-weight:500;color:var(--cream);margin-bottom:12px;line-height:1.3}
.m-main.zh{font-family:'Noto Sans TC',sans-serif}
.m-main.ko{font-family:'Noto Sans KR',sans-serif;font-size:1.15rem}
.m-alts{display:flex;flex-wrap:wrap;gap:14px;margin-bottom:18px;padding-top:10px;border-top:1px solid rgba(74,144,217,.1)}
.alt-item .alt-lbl{font-size:.54rem;letter-spacing:.15em;color:var(--gold);opacity:.65;text-transform:uppercase;display:block;margin-bottom:1px}
.alt-item .alt-val{font-size:.8rem;color:rgba(26,45,66,.75)}
.alt-item .alt-val.zh{font-family:'Noto Sans TC',sans-serif}
.alt-item .alt-val.ko{font-family:'Noto Sans KR',sans-serif}
.ing-tabs{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.ing-tab{background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.09);color:var(--muted);font-size:.67rem;letter-spacing:.07em;padding:4px 12px;border-radius:14px;cursor:pointer;transition:all .2s;font-family:inherit}
.ing-tab.active{background:rgba(74,144,217,.15);border-color:var(--gold);color:var(--gold2)}
.ing-ttl{font-size:.6rem;letter-spacing:.18em;color:var(--gold);text-transform:uppercase;margin-bottom:9px;opacity:.75}
.ing-pills{display:flex;flex-wrap:wrap;gap:5px}
.pill{background:rgba(0,0,0,.04);border:1px solid rgba(0,0,0,.08);color:rgba(26,45,66,.85);font-size:.74rem;padding:3px 10px;border-radius:11px;line-height:1.4}
.pill.ko,.allerg-pill.ko{font-family:'Noto Sans KR',sans-serif;font-size:.7rem}
.pill.zh,.allerg-pill.zh{font-family:'Noto Sans TC',sans-serif}
.pill.alert{background:rgba(192,57,43,.1);border-color:rgba(192,57,43,.28);color:#c0392b}
.m-link{display:inline-block;margin-top:14px;font-size:.68rem;color:var(--gold);opacity:.65;text-decoration:none;letter-spacing:.07em;transition:opacity .2s}
.m-link:hover{opacity:1}
.m-desc{font-size:.82rem;line-height:1.7;color:rgba(26,45,66,.82);margin-bottom:18px;padding:12px 14px;background:rgba(74,144,217,.05);border:1px solid rgba(74,144,217,.12);border-radius:8px}
.m-desc.zh{font-family:'Noto Sans TC',sans-serif}
.m-desc.ko{font-family:'Noto Sans KR',sans-serif;font-size:.78rem}
.allerg-section{margin-bottom:16px;padding:10px 14px;background:rgba(192,57,43,.05);border:1px solid rgba(192,57,43,.2);border-radius:8px}
.allerg-ttl{font-size:.6rem;letter-spacing:.18em;color:#c0392b;text-transform:uppercase;margin-bottom:8px;opacity:.85}
.allerg-pills{display:flex;flex-wrap:wrap;gap:5px}
.allerg-pill{background:rgba(192,57,43,.1);border:1px solid rgba(192,57,43,.25);color:#c0392b;font-size:.74rem;padding:3px 10px;border-radius:11px;line-height:1.4}
.seo-catalog{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;pointer-events:none}
footer{text-align:center;padding:0 20px 40px;font-size:.6rem;color:var(--muted);opacity:.5}

/* ── MODAL NAV ── */
.modal-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(74,144,217,.15);border:1px solid rgba(74,144,217,.3);color:var(--cream);font-size:1.5rem;line-height:1;width:40px;height:40px;border-radius:50%;cursor:pointer;z-index:10;display:flex;align-items:center;justify-content:center;transition:background .2s;padding:0}
.modal-nav-btn:hover{background:rgba(74,144,217,.28)}
.modal-nav-prev{left:10px}
.modal-nav-next{right:10px}
.modal-nav-indicator{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);font-size:.58rem;color:rgba(0,0,0,.45);letter-spacing:.08em;background:rgba(255,255,255,.75);padding:2px 8px;border-radius:8px;pointer-events:none}
/* ── TUTORIAL ── */
#tutorial-overlay{position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:500;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;cursor:pointer}
#tutorial-overlay.show{opacity:1;pointer-events:all}
.tutorial-box{background:var(--modal-bg);border:1px solid rgba(74,144,217,.38);border-radius:16px;padding:32px 36px;text-align:center;max-width:300px}
.tutorial-icon{font-size:2rem;margin-bottom:12px;display:block}
#tutorial-text{font-size:.96rem;color:var(--cream);line-height:1.8;display:block;margin-bottom:14px;white-space:pre-line}
.tutorial-close-hint{font-size:.6rem;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}


/* ── DOT INDICATOR ── */
#modal-dots{display:flex;justify-content:center;gap:6px;padding:10px 0 2px;min-height:24px}
.modal-dot{width:6px;height:6px;border-radius:50%;background:rgba(0,0,0,.18);transition:background .25s,transform .25s;flex-shrink:0;cursor:pointer}
.modal-dot.active{background:var(--gold2);transform:scale(1.35)}

/* ── PEEK ANIMATION ── */
@keyframes modal-peek{
  0%  {transform:translateX(0) translateY(0)}
  25% {transform:translateX(-22px) translateY(0)}
  75% {transform:translateX(10px) translateY(0)}
  100%{transform:translateX(0) translateY(0)}
}
.modal.peek{animation:modal-peek .55s cubic-bezier(.25,.46,.45,.94) forwards}



/* ── LOADING ── */
.loading-msg{grid-column:1/-1;text-align:center;padding:80px 20px}
.loading-spinner{width:36px;height:36px;border:3px solid rgba(74,144,217,.2);border-top-color:var(--gold);border-radius:50%;animation:spin .8s linear infinite;margin:0 auto}
.loading-text{font-size:.72rem;color:var(--muted);margin-top:14px;letter-spacing:.12em}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── COLOR FILTER ── */
.color-filter-bar{position:sticky;top:0;z-index:200;overflow-anchor:none;background:rgba(240,246,255,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(74,144,217,.15);transition:padding .25s ease}
.color-filter-title{text-align:center;font-size:.6rem;letter-spacing:.18em;color:var(--muted);text-transform:uppercase;padding-top:10px;margin-bottom:0}
#color-filter{display:grid;grid-template-columns:repeat(5,auto);gap:8px 14px;padding:8px 16px 10px;justify-content:center}
.color-chip{display:flex;flex-direction:column;align-items:center;gap:4px;cursor:pointer;flex-shrink:0;opacity:.5;transition:opacity .2s;-webkit-tap-highlight-color:transparent}
.color-chip.active{opacity:1}
.color-chip-dot{width:30px;height:30px;border-radius:50%;border:2.5px solid transparent;transition:border-color .2s;transform:translateZ(0)}
.color-chip.active .color-chip-dot{border-color:var(--gold2)}
.color-chip-lbl{font-size:.52rem;color:var(--muted);white-space:nowrap;letter-spacing:.06em}
/* ── color bar 捲動後縮小 ── */
.color-filter-bar.scrolled .color-filter-title{display:none}
.color-filter-bar.scrolled #color-filter{padding:5px 16px 7px;gap:5px 12px}
.color-filter-bar.scrolled .color-chip-dot{width:22px;height:22px}
.color-filter-bar.scrolled .color-chip-lbl{display:none}
