﻿:root{--bg:#16100c;--card-bg:#241810;--gold:#c8a84b;--gold2:#e6c97a;--cream:#f4e8d0;--muted:#907060;--border:rgba(200,168,75,.2);--modal-bg:#1a120c}
*{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(200,168,75,.1),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(200,168,75,.2)}
.ui-btn{background:rgba(200,168,75,.05);border:1px solid rgba(200,168,75,.15);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(200,168,75,.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(200,168,75,.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(200,168,75,.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(255,255,255,.04);border:1px solid rgba(255,255,255,.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(200,168,75,.4);color:var(--cream)}
.fbtn.active{border-color:rgba(192,57,43,.5);background:rgba(192,57,43,.12);color:#e07060}
.fbtn.choco.active{border-color:rgba(200,168,75,.55);background:rgba(200,168,75,.14);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}
/* 手機・平板：強制 3 欄，桌機維持 auto-fill */
@media (max-width:1023px){
  .grid{grid-template-columns:repeat(2,1fr);gap:10px}
}
.pcard{background:var(--card-bg);border:1px solid rgba(200,168,75,.14);border-radius:10px;overflow:hidden;cursor:pointer;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(0,0,0,.5),0 0 0 1px rgba(200,168,75,.3);border-color:rgba(200,168,75,.3)}
.img-wrap{width:100%;aspect-ratio:1000/590;overflow:hidden;background:#1a130d;position:relative}
.img-wrap img{width:100%;height:100%;object-fit:contain;object-position:center;display:block}
.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(200,168,75,.1);border:1px solid rgba(200,168,75,.18);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,.76);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}
.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(22,16,12,.96);border-bottom:1px solid rgba(200,168,75,.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(255,255,255,.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(255,255,255,.15)}
.modal-img{width:100%;aspect-ratio:1000/590;overflow:hidden;border-radius:0}
.modal-img img{width:100%;height:100%;object-fit:cover;display:block}
.modal-img-ph{width:100%;height:230px;background:linear-gradient(135deg,#2a1a12,#1a100a);display:flex;align-items:center;justify-content:center;font-size:5rem;opacity:.18;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(200,168,75,.1);border:1px solid rgba(200,168,75,.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(200,168,75,.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(244,232,208,.78)}
.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(255,255,255,.05);border:1px solid rgba(255,255,255,.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(200,168,75,.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(255,255,255,.05);border:1px solid rgba(255,255,255,.08);color:rgba(244,232,208,.85);font-size:.74rem;padding:3px 10px;border-radius:11px;line-height:1.4}
.pill.ko{font-family:'Noto Sans KR',sans-serif;font-size:.7rem}
.pill.zh{font-family:'Noto Sans TC',sans-serif}
.pill.alert{background:rgba(192,57,43,.12);border-color:rgba(192,57,43,.28);color:#e07060}
.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(244,232,208,.82);margin-bottom:18px;padding:12px 14px;background:rgba(200,168,75,.05);border:1px solid rgba(200,168,75,.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:#e07060;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:#e07060;font-size:.74rem;padding:3px 10px;border-radius:11px;line-height:1.4}
.allerg-pill.zh{font-family:'Noto Sans TC',sans-serif}
.allerg-pill.ko{font-family:'Noto Sans KR',sans-serif;font-size:.7rem}
.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{position:relative}
.modal-nav-btn{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.52);border:1px solid rgba(200,168,75,.22);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(200,168,75,.2)}
.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(255,255,255,.5);letter-spacing:.08em;background:rgba(0,0,0,.35);padding:2px 8px;border-radius:8px;pointer-events:none}
.modal-img{position:relative}
/* ── TUTORIAL ── */
#tutorial-overlay{position:fixed;inset:0;background:rgba(0,0,0,.72);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(200,168,75,.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(255,255,255,.22);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}



@keyframes svFade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}


/* ── COLOR FILTER ── */
.color-filter-bar{position:sticky;top:0;z-index:200;overflow-anchor:none;background:rgba(22,16,12,.92);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid rgba(200,168,75,.12);box-shadow:0 4px 20px rgba(0,0,0,.4)}
.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}
.color-chip.active{opacity:1}
.color-chip-dot{width:30px;height:30px;border-radius:50%;border:2.5px solid transparent;transition:border-color .2s}
.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}

