
:root{--bg:#0c0a08;--bg-2:#131110;--bg-card:#18140f;--bg-card-2:#1d1813;--fg:#ece8df;--fg-dim:#a39d8e;--fg-muted:#6b6558;--accent:#d4a548;--accent-soft:rgba(212,165,72,0.14);--accent-line:rgba(212,165,72,0.28);--rule:rgba(255,255,255,0.08);--grid:rgba(255,255,255,0.10);--radar-bg:rgba(255,255,255,0.025);--bar-bg:rgba(255,255,255,0.06);--ring-bg:rgba(255,255,255,0.08);--chip-bg:rgba(255,255,255,0.04);--chip-bg-on:rgba(212,165,72,0.16);--shadow:0 20px 60px rgba(0,0,0,0.5);--font-display:"Cormorant Garamond","Shippori Mincho B1","Noto Serif JP",Georgia,serif;--font-body:"Helvetica Neue","Noto Sans JP","Hiragino Kaku Gothic ProN","Yu Gothic",system-ui,sans-serif}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{font-family:var(--font-body);background:var(--bg);color:var(--fg);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-feature-settings:"palt" 1;letter-spacing:0.01em}
button{font:inherit;color:inherit;background:none;border:none;cursor:pointer;padding:0}a{color:inherit;text-decoration:none;cursor:pointer}input{font:inherit;color:inherit}
.dot-sep{color:var(--fg-muted);margin:0 0.45em}
.topbar{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--bg) 92%,transparent);backdrop-filter:blur(20px) saturate(1.2);-webkit-backdrop-filter:blur(20px) saturate(1.2);border-bottom:1px solid var(--rule)}
.topbar-inner{max-width:1240px;margin:0 auto;padding:14px 20px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:16px}
.brand{display:inline-flex;align-items:center;gap:10px;cursor:pointer}.brand-mark{width:12px;height:12px;background:var(--accent);transform:rotate(45deg);display:inline-block}.brand-name{font-family:var(--font-display);font-size:17px;font-weight:500;letter-spacing:0.01em}
.city-nav{display:flex;gap:4px;justify-self:center}.city-btn{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-muted);padding:8px 12px;border-radius:6px;transition:color .15s,background .15s}.city-btn:hover:not(:disabled){color:var(--fg-dim)}.city-btn.is-on{color:var(--fg);background:var(--bg-card-2)}.city-btn:disabled{opacity:0.4;cursor:not-allowed}
.lang-switch{display:inline-flex;gap:2px;padding:3px;background:var(--bg-card);border:1px solid var(--rule);border-radius:999px}.lang-btn{padding:4px 10px;font-size:11px;font-weight:500;letter-spacing:0.04em;color:var(--fg-muted);border-radius:999px;transition:color .15s,background .15s;text-align:center;white-space:nowrap;line-height:1.4}.lang-btn.is-on{background:var(--accent);color:#1a1612}.lang-btn:not(.is-on):hover{color:var(--fg)}
.hero-section{position:relative;padding:80px 20px 40px;text-align:center;border-bottom:1px solid var(--rule);overflow:hidden}.hero-section::before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 50% 20%,var(--accent-soft),transparent 60%);pointer-events:none;opacity:0.7}
.hero-inner{position:relative;max-width:720px;margin:0 auto}.hero-h1{font-family:var(--font-display);font-weight:400;font-size:clamp(38px,7vw,72px);line-height:1.05;letter-spacing:-0.01em;margin:0 0 18px;word-break:keep-all}.hero-h1-main{display:inline}.hero-h1-accent{display:block;font-style:italic;color:var(--accent);font-weight:400}
.hero-lede{font-size:15px;color:var(--fg-dim);max-width:480px;margin:0 auto 28px;line-height:1.6}.lede-num{color:var(--accent);font-weight:600;font-variant-numeric:tabular-nums}
.search-wrap{position:relative;max-width:480px;margin:0 auto 36px;display:flex;gap:0}.search-icon{position:absolute;left:18px;top:50%;transform:translateY(-50%);color:var(--fg-muted);pointer-events:none}.search-input{flex:1;min-width:0;padding:14px 18px 14px 44px;background:var(--bg-card);color:var(--fg);border:1px solid var(--rule);border-radius:999px 0 0 999px;font-size:14px;outline:none;transition:border-color .15s,background .15s}.search-input:focus{border-color:var(--accent-line);background:var(--bg-card-2)}.search-input::placeholder{color:var(--fg-muted)}.search-btn{padding:0 20px;background:var(--accent);color:#1a1612;font-size:13px;font-weight:600;letter-spacing:0.06em;border:none;border-radius:0 999px 999px 0;cursor:pointer;white-space:nowrap;transition:background .15s}.search-btn:hover{background:color-mix(in srgb,var(--accent) 85%,#fff)}
.stats-row{display:inline-flex;gap:0;align-items:stretch;padding:0;margin:0 auto}.stat{padding:0 28px;text-align:center}.stat-num{font-family:var(--font-display);font-size:32px;font-weight:500;color:var(--accent);line-height:1;font-variant-numeric:tabular-nums}.stat-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-muted);margin-top:6px}.stat-divider{width:1px;background:var(--rule)}
.filter-section{border-bottom:1px solid var(--rule);background:var(--bg-2)}.filter-bar{max-width:1240px;margin:0 auto;padding:14px 20px;display:grid;gap:8px}.filter-row{display:flex;align-items:center;gap:10px;min-width:0}.filter-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-muted);width:80px;flex-shrink:0}.chip-row{display:flex;gap:6px;overflow-x:auto;flex:1;padding-bottom:2px;scrollbar-width:none}.chip-row::-webkit-scrollbar{display:none}.chip{padding:6px 12px;font-size:12px;color:var(--fg-dim);background:var(--chip-bg);border:1px solid transparent;border-radius:999px;white-space:nowrap;transition:all .15s}.chip:hover{color:var(--fg)}.chip.is-on{background:var(--chip-bg-on);border-color:var(--accent-line);color:var(--accent)}
.podium-section{max-width:1240px;margin:0 auto;padding:40px 20px 16px}.section-head{display:flex;align-items:baseline;gap:14px;margin-bottom:20px;padding-bottom:14px;border-bottom:1px solid var(--rule)}.section-title{font-family:var(--font-display);font-weight:400;font-size:22px;margin:0;letter-spacing:0.01em}.section-sub{font-size:11px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-muted)}
.podium-grid{display:grid;gap:16px;grid-template-columns:1fr}@media(min-width:760px){.podium-grid{grid-template-columns:repeat(3,1fr)}}
.podium-cell{cursor:pointer}.hero-card{position:relative;background:var(--bg-card);border:1px solid var(--rule);border-radius:4px;padding:28px 24px;height:100%;display:flex;flex-direction:column;transition:border-color .2s,transform .2s}.hero-card:hover{border-color:var(--accent-line);transform:translateY(-2px)}
.hero-rank-1{border-color:var(--accent);background:linear-gradient(180deg,var(--accent-soft),transparent 60%),var(--bg-card)}.hero-rank-1::before{content:"";position:absolute;top:-1px;left:-1px;right:-1px;height:3px;background:var(--accent)}.hero-rank-2{border-color:color-mix(in srgb,var(--accent) 60%,var(--rule))}.hero-rank-3{border-color:color-mix(in srgb,var(--accent) 30%,var(--rule))}
.hero-rank-mark{position:absolute;top:14px;right:16px;display:flex;align-items:baseline;gap:8px}.hero-rank-num{font-family:var(--font-display);font-size:28px;font-weight:500;color:var(--fg-muted);line-height:1;font-variant-numeric:tabular-nums}.hero-rank-1 .hero-rank-num{color:var(--accent)}.hero-rank-label{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-muted)}
.hero-card-body{display:flex;flex-direction:column;gap:18px;flex:1}.hero-head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding-right:70px}.hero-name{font-family:var(--font-display);font-weight:500;font-size:28px;line-height:1.1;margin:0 0 6px;letter-spacing:0.01em}.hero-sub{font-size:12px;color:var(--fg-muted);letter-spacing:0.04em}.hero-meta{font-size:12px;color:var(--fg-dim)}
.hero-viz{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:16px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule)}.hero-score{text-align:right}.hero-score-num{font-family:var(--font-display);font-size:56px;font-weight:500;line-height:0.95;color:var(--fg);font-variant-numeric:tabular-nums}.hero-rank-1 .hero-score-num{color:var(--accent)}.hero-score-label{font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-muted);margin-top:4px}
.elite-pill{display:inline-block;margin-top:8px;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;padding:3px 8px;background:var(--accent);color:#1a1612;border-radius:2px;font-weight:600}
.hero-blurb{font-size:13px;line-height:1.6;color:var(--fg-dim);margin:0;text-wrap:pretty}
.m-badge{display:inline-flex;align-items:center;justify-content:center;height:22px;padding:0 8px;font-size:11px;letter-spacing:0.04em;background:var(--bg-card-2);border:1px solid var(--rule);border-radius:3px;color:var(--accent);flex-shrink:0}.m-badge-stars{color:var(--accent);letter-spacing:0.08em}.m-badge-sel{color:var(--fg-dim);font-size:10px;letter-spacing:0.15em;text-transform:uppercase}
.list-section{max-width:1240px;margin:0 auto;padding:32px 20px 60px}.list-head{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid var(--rule)}.list-count{font-size:12px;color:var(--fg-dim);letter-spacing:0.06em}.list-count strong{color:var(--fg);font-family:var(--font-display);font-size:18px;font-weight:500;margin-right:4px}
.list-grid{display:grid;gap:10px;grid-template-columns:1fr}@media(min-width:700px){.list-grid{grid-template-columns:repeat(2,1fr)}}@media(min-width:1080px){.list-grid{grid-template-columns:repeat(3,1fr)}}
.list-card{background:var(--bg-card);border:1px solid var(--rule);border-radius:3px;padding:14px;transition:border-color .15s,background .15s;cursor:pointer}.list-card:hover{border-color:var(--accent-line);background:var(--bg-card-2)}.list-card.is-high{border-left:2px solid var(--accent)}
.list-card-main{display:grid;grid-template-columns:auto 1fr auto;gap:12px;align-items:center}.list-card-hex{flex-shrink:0;opacity:0.95}.list-card-info{min-width:0}.list-name{font-family:var(--font-display);font-size:18px;font-weight:500;margin:0 0 4px;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.list-meta{font-size:11px;color:var(--fg-dim);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.list-tagline{font-size:12px;color:var(--fg-muted);font-style:italic;margin-top:4px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.list-score-block{text-align:right;flex-shrink:0}.list-score{font-family:var(--font-display);font-size:30px;font-weight:500;line-height:1;color:var(--fg);font-variant-numeric:tabular-nums}.list-score.is-high{color:var(--accent)}.list-score-label{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-muted);margin-top:3px}
.modal-shroud{position:fixed;inset:0;z-index:100;background:color-mix(in srgb,var(--bg) 70%,transparent);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;justify-content:center;align-items:flex-start;padding:24px;overflow-y:auto;animation:shroud-in .2s ease}@keyframes shroud-in{from{opacity:0}to{opacity:1}}
.modal-card{position:relative;width:100%;max-width:640px;background:var(--bg-card);border:1px solid var(--rule);border-radius:4px;padding:36px 32px 32px;box-shadow:var(--shadow);animation:card-in .25s cubic-bezier(.2,.8,.2,1)}@keyframes card-in{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-close{position:absolute;top:14px;right:14px;width:32px;height:32px;border-radius:999px;font-size:20px;line-height:1;color:var(--fg-dim);transition:background .15s,color .15s}.modal-close:hover{background:var(--bg-card-2);color:var(--fg)}
.modal-head{margin-bottom:24px}.modal-name{font-family:var(--font-display);font-size:36px;font-weight:500;margin:0;line-height:1.1}.modal-sub{font-size:13px;color:var(--fg-muted);margin-top:4px;letter-spacing:0.04em}.modal-meta{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;color:var(--fg-dim);flex-wrap:wrap}
.modal-score-block{display:grid;grid-template-columns:1fr;gap:16px;padding:24px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);align-items:center}@media(min-width:520px){.modal-score-block{grid-template-columns:auto 1fr;gap:24px}}
.modal-score-num-block{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.modal-score-label{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-muted)}.modal-score-num{font-family:var(--font-display);font-size:86px;font-weight:500;line-height:0.9;color:var(--accent);font-variant-numeric:tabular-nums}.modal-radar{display:flex;justify-content:center;align-items:center}
.modal-grades{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:24px 0}@media(min-width:520px){.modal-grades{grid-template-columns:repeat(3,1fr)}}.grade-cell{background:var(--bg-card-2);border:1px solid var(--rule);border-radius:3px;padding:10px 12px}.grade-label{font-size:10px;letter-spacing:0.18em;text-transform:uppercase;color:var(--fg-muted)}.grade-value{font-family:var(--font-display);font-size:24px;font-weight:600;color:var(--fg);margin:2px 0 6px;line-height:1.1}.grade-bar{height:3px;background:var(--bar-bg);border-radius:2px;overflow:hidden}.grade-fill{height:100%;border-radius:2px}
.modal-blurb{font-size:14px;line-height:1.7;color:var(--fg-dim);border-left:2px solid var(--accent);padding:4px 16px;margin:0 0 20px;background:var(--accent-soft);text-wrap:pretty}
.modal-prices{display:flex;gap:24px;flex-wrap:wrap;padding:14px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);margin-bottom:20px}.modal-prices>div{display:flex;flex-direction:column;gap:2px}.modal-price-label{font-size:10px;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-muted)}.modal-price-val{font-family:var(--font-display);font-size:16px;font-weight:500;color:var(--fg);font-variant-numeric:tabular-nums}
.modal-tags-label{font-size:10px;letter-spacing:0.22em;text-transform:uppercase;color:var(--fg-muted);margin-bottom:8px}.tag-row{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:20px}.tag{display:inline-flex;align-items:center;padding:5px 10px;font-size:11px;letter-spacing:0.04em;background:var(--accent-soft);color:var(--accent);border-radius:2px}
.modal-tags{margin-bottom:20px}.modal-links{margin-bottom:0}.link-row{display:flex;flex-wrap:wrap;gap:6px}.ext-link{padding:6px 12px;font-size:12px;background:var(--bg-card-2);border:1px solid var(--rule);border-radius:2px;color:var(--fg-dim);transition:border-color .15s,color .15s}.ext-link:hover{border-color:var(--accent-line);color:var(--accent)}
.page-main{padding:60px 20px 80px}.page-inner{max-width:760px;margin:0 auto}.back-link{font-size:12px;color:var(--fg-dim);margin-bottom:24px;display:inline-block;letter-spacing:0.06em;background:none;border:none}.back-link:hover{color:var(--fg)}.page-title{font-family:var(--font-display);font-size:clamp(34px,6vw,56px);font-weight:400;margin:0;letter-spacing:-0.005em}.page-rule{width:60px;height:2px;background:var(--accent);margin:18px 0 28px}.page-lede{font-size:17px;line-height:1.6;color:var(--fg-dim);margin-bottom:36px;text-wrap:pretty}.page-h2{font-family:var(--font-display);font-size:24px;font-weight:500;margin:36px 0 16px}.page-list{padding-left:18px;line-height:1.7;color:var(--fg-dim)}.page-list li{margin-bottom:8px}.page-list li::marker{color:var(--accent)}.page-note{padding:14px 16px;background:var(--bg-card);border:1px solid var(--rule);border-radius:3px;font-size:13px;color:var(--fg-dim);margin-top:24px}
.dim-grid{display:grid;gap:12px;grid-template-columns:1fr;margin-bottom:12px}@media(min-width:600px){.dim-grid{grid-template-columns:repeat(2,1fr)}}.dim-card{background:var(--bg-card);border:1px solid var(--rule);border-radius:3px;padding:16px}.dim-card-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}.dim-card-name{font-family:var(--font-display);font-size:18px;font-weight:500}.dim-card-key{font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--fg-muted)}.dim-card-desc{font-size:13px;line-height:1.6;color:var(--fg-dim);margin:0}
.band-row{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:12px}.band-cell{background:var(--bg-card);border:1px solid var(--rule);border-radius:3px;padding:14px;text-align:center}.band-letter{font-family:var(--font-display);font-size:32px;font-weight:600;line-height:1}.band-s .band-letter{color:var(--accent)}.band-range{font-size:11px;color:var(--fg-muted);margin:6px 0 4px;font-variant-numeric:tabular-nums;letter-spacing:0.08em}.band-label{font-size:11px;color:var(--fg-dim)}
.site-footer{border-top:1px solid var(--rule);padding:30px 20px;display:flex;flex-direction:column;gap:14px;align-items:center;justify-content:center;text-align:center}.footer-links{display:flex;gap:24px}.footer-links a{font-size:12px;color:var(--fg-dim);letter-spacing:0.06em}.footer-links a:hover{color:var(--accent)}.footer-mark{font-size:11px;color:var(--fg-muted);letter-spacing:0.06em}
@media(max-width:640px){.topbar-inner{grid-template-columns:1fr auto;gap:8px;padding:10px 14px}.city-nav{display:none}.brand-name{font-size:15px}.hero-section{padding:48px 18px 28px}.hero-h1{font-size:42px}.stat{padding:0 18px}.stat-num{font-size:26px}.filter-bar{padding:10px 14px}.filter-label{width:56px;font-size:9px;letter-spacing:0.16em}.podium-section{padding:28px 14px 8px}.list-section{padding:20px 14px 40px}.hero-card{padding:22px 18px}.hero-name{font-size:24px}.hero-score-num{font-size:44px}.hero-head{padding-right:56px}.modal-shroud{padding:0}.modal-card{border-radius:0;min-height:100vh;padding:24px 18px;max-width:100%}.modal-name{font-size:28px}.modal-score-num{font-size:64px}.filter-row{gap:8px}}


/* Summary Block */
.modal-summary-block {
  margin: 24px 0;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.modal-summary-intro h4, .modal-summary-voice h4 {
  font-family: "Cormorant Garamond", "Shippori Mincho B1", Georgia, serif;
  font-size: 18px;
  color: var(--accent);
  margin-bottom: 8px;
  font-weight: 500;
  letter-spacing: 0.05em;
  border-left: 2px solid var(--accent);
  padding-left: 8px;
}
.modal-summary-intro p {
  font-size: 14px;
  line-height: 1.6;
  color: var(--text);
  opacity: 0.9;
}
.voice-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.voice-item {
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-muted);
  margin-bottom: 8px;
  display: flex;
  align-items: flex-start;
  gap: 6px;
}
.voice-icon {
  font-weight: bold;
  flex-shrink: 0;
}
.voice-col.positive .voice-icon { color: #5fb15f; }
.voice-col.negative .voice-icon { color: #d46a6a; }

@media (max-width: 600px) {
  .voice-grid { grid-template-columns: 1fr; }
}

.visually-hidden{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.brand-logo{width:28px;height:28px;display:block;flex-shrink:0}.brand{display:inline-flex!important;align-items:center;gap:12px}.city-card .city-card-michelin{display:flex;flex-direction:column;gap:6px;align-items:flex-end;justify-content:center;padding-left:20px;flex-shrink:0}.city-card .michelin-row{display:flex;align-items:baseline;gap:10px;white-space:nowrap}.city-card .michelin-stars{color:var(--accent);font-family:var(--font-display);font-size:20px;letter-spacing:0.04em;line-height:1}.city-card .michelin-num{font-family:var(--font-display);font-size:22px;font-weight:500;color:var(--fg);min-width:28px;text-align:right;font-variant-numeric:tabular-nums;line-height:1}.city-card:hover .michelin-stars{filter:brightness(1.15)}.modal-info{background:var(--bg-card);border:1px solid var(--rule);border-radius:8px;padding:20px;margin:24px 0}.info-list{display:grid;gap:14px;margin:0}.info-row{display:grid;grid-template-columns:96px 1fr;gap:16px;align-items:start}.info-row dt{font-size:11px;letter-spacing:0.15em;text-transform:uppercase;color:var(--fg-muted);font-weight:500;padding-top:3px;margin:0}.info-row dd{margin:0;font-size:14px;color:var(--fg-dim);line-height:1.55;word-break:break-word}.info-row dd a{color:var(--accent);text-decoration:none;border-bottom:1px solid var(--accent-line)}.info-row dd a:hover{border-bottom-color:var(--accent)}@media(max-width:480px){.info-row{grid-template-columns:1fr;gap:4px}}.list-card{content-visibility:auto;contain-intrinsic-size:auto 110px}
