@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho:wght@400;700&family=Noto+Serif+JP:wght@300;500;700&display=swap');
:root{--washi:#f3ede1;--washi2:#ece4d2;--sumi:#1b1a17;--sumi2:#3a3833;--red:#a93226;--gold:#b8923a;--line:#c8bfa8}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--washi);color:var(--sumi);font-family:'Shippori Mincho','Noto Serif JP',"Hiragino Mincho ProN",serif;font-size:17px;line-height:1.75;min-height:100%}
body{background-image:
 radial-gradient(ellipse at 20% 10%,rgba(184,146,58,.08),transparent 60%),
 radial-gradient(ellipse at 80% 90%,rgba(169,50,38,.06),transparent 60%),
 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='200' height='200'><filter id='n'><feTurbulence baseFrequency='0.9' seed='3'/><feColorMatrix values='0 0 0 0 0.1  0 0 0 0 0.1  0 0 0 0 0.07  0 0 0 0.06 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>")}
a{color:inherit;text-decoration:none}
.topbar{max-width:1200px;margin:0 auto;padding:26px 28px 14px;display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap;border-bottom:1px solid var(--line)}
.brand{display:flex;align-items:baseline;gap:14px}
.brand .kanji{font-size:36px;color:var(--red);font-weight:700;line-height:1}
.brand .roma{font-size:11px;letter-spacing:.4em;text-transform:uppercase;color:var(--sumi2);margin-top:8px}
.brand .name{font-size:22px;letter-spacing:.08em}
.topbar nav{display:flex;gap:28px;font-size:14px;padding-top:12px}
.topbar nav a{position:relative;padding-bottom:4px}
.topbar nav a::after{content:"";position:absolute;left:50%;bottom:0;width:0;height:1px;background:var(--red);transition:all .3s}
.topbar nav a:hover::after{left:0;width:100%}
.wrap{max-width:1200px;margin:0 auto;padding:40px 28px 80px}
.hero{display:grid;grid-template-columns:1fr 120px;gap:30px;padding:60px 0 50px;border-bottom:1px solid var(--line);margin-bottom:50px}
@media(max-width:700px){.hero{grid-template-columns:1fr}}
.hero h1{font-size:clamp(36px,6vw,68px);font-weight:500;line-height:1.15;letter-spacing:-.01em}
.hero h1 span{color:var(--red)}
.hero .lede{margin-top:24px;max-width:540px;color:var(--sumi2);font-size:17px}
.hero .no{text-align:center;border-left:1px solid var(--line);padding-left:20px}
.hero .no .jp{writing-mode:vertical-rl;font-size:26px;letter-spacing:.3em;color:var(--sumi2);margin:0 auto 14px;height:150px}
.hero .no .n{display:block;font-size:48px;color:var(--red);font-weight:700}
.hero .no .l{display:block;font-size:10px;letter-spacing:.25em;text-transform:uppercase;color:var(--sumi2);margin-top:6px}
/* section */
.sec{display:flex;align-items:baseline;gap:20px;margin:50px 0 24px}
.sec .mark{font-size:26px;color:var(--red);font-weight:700}
.sec h2{font-size:22px;letter-spacing:.04em;font-weight:500}
.sec .rom{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--sumi2);margin-left:auto}
/* beer grid */
.beers{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:2px;background:var(--line)}
.beer{background:var(--washi);padding:28px 24px 26px;display:block;position:relative;transition:background .3s}
.beer:hover{background:var(--washi2)}
.beer .num{position:absolute;top:14px;right:16px;font-size:11px;letter-spacing:.2em;color:var(--sumi2)}
.beer .ideo{font-size:40px;color:var(--red);font-weight:700;line-height:1;margin-bottom:16px}
.beer h3{font-size:22px;font-weight:500;letter-spacing:.02em;margin-bottom:4px}
.beer .sub{font-size:13px;color:var(--sumi2);letter-spacing:.05em;margin-bottom:14px}
.beer .foot{display:flex;justify-content:space-between;align-items:center;padding-top:14px;border-top:1px solid var(--line);font-size:13px;color:var(--sumi2)}
.beer .star{color:var(--gold)}
/* detail */
.crumb{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--sumi2);margin-bottom:20px}
.detail{display:grid;grid-template-columns:1fr 1.4fr;gap:50px;align-items:start}
@media(max-width:760px){.detail{grid-template-columns:1fr}}
.scroll{aspect-ratio:3/4;background:var(--washi2);border:1px solid var(--line);position:relative;padding:40px 30px;display:flex;flex-direction:column;justify-content:space-between}
.scroll::before{content:"";position:absolute;inset:12px;border:1px solid var(--line)}
.scroll .seal{position:absolute;top:28px;right:28px;width:56px;height:56px;background:var(--red);color:var(--washi);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;font-family:'Noto Serif JP',serif;border:2px solid #6a1a12;transform:rotate(3deg)}
.scroll .vert{writing-mode:vertical-rl;font-size:48px;letter-spacing:.15em;height:80%;font-weight:500;margin:auto 0 auto auto}
.scroll .bot{font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--sumi2);text-align:center}
.info h1{font-size:48px;font-weight:500;line-height:1.05;letter-spacing:-.01em}
.info .jp{font-size:18px;color:var(--red);margin-top:10px;letter-spacing:.1em}
.info .sub{font-size:16px;color:var(--sumi2);margin:6px 0 30px}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);margin-bottom:26px}
@media(max-width:520px){.stats{grid-template-columns:repeat(2,1fr)}}
.stats div{background:var(--washi);padding:18px 12px;text-align:center}
.stats b{display:block;font-size:28px;color:var(--red);font-weight:500;line-height:1}
.stats span{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--sumi2);margin-top:6px;display:block}
.info p{margin-bottom:16px}
.prices{margin-top:36px}
.prices h3,.reviews h3{font-size:14px;letter-spacing:.25em;text-transform:uppercase;color:var(--sumi2);margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between}
.prices h3::after,.reviews h3::after{content:"一";color:var(--red)}
.pr{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--line);font-size:15px}
.pr em{font-style:normal;color:var(--sumi2);font-size:13px;display:block}
.pr b{color:var(--red);font-weight:500;font-size:18px}
.reviews{margin-top:40px}
.review{padding:18px 0;border-bottom:1px solid var(--line)}
.review p{font-style:italic;line-height:1.8}
.review .who{font-size:12px;letter-spacing:.15em;text-transform:uppercase;color:var(--sumi2);margin-top:8px}
/* brewery */
.brew-hero{padding:50px 0;text-align:center;border-bottom:1px solid var(--line);margin-bottom:40px}
.brew-hero .kanji{font-size:70px;color:var(--red);font-weight:700;line-height:1;margin-bottom:18px}
.brew-hero h1{font-size:52px;font-weight:500}
.brew-hero .loc{color:var(--sumi2);margin-top:10px;font-size:16px}
/* map */
.map-shell{display:grid;grid-template-columns:300px 1fr;gap:2px;background:var(--line);min-height:560px}
@media(max-width:760px){.map-shell{grid-template-columns:1fr}}
.map-side{background:var(--washi);padding:26px 24px}
.map-side h2{font-size:14px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px;color:var(--sumi2);padding-bottom:10px;border-bottom:1px solid var(--line)}
.poi{padding:14px 0;border-bottom:1px solid var(--line);font-size:14px}
.poi b{display:block;font-weight:500}
.poi em{font-style:normal;color:var(--sumi2);font-size:12px}
.fake-map{background:var(--washi2);position:relative;min-height:560px;overflow:hidden;background-image:
 radial-gradient(circle at 30% 40%,rgba(169,50,38,.08),transparent 40%),
 radial-gradient(circle at 70% 60%,rgba(184,146,58,.1),transparent 40%)}
.fake-map::before{content:"東京 · 地図 · PARIS";position:absolute;top:20px;left:50%;transform:translateX(-50%);font-size:14px;letter-spacing:.3em;color:var(--sumi2)}
.fake-map svg{position:absolute;inset:0;width:100%;height:100%}
.pin{position:absolute;width:34px;height:34px;border-radius:50%;background:var(--washi);border:2px solid var(--red);color:var(--red);display:flex;align-items:center;justify-content:center;font-weight:700;transform:translate(-50%,-50%);cursor:pointer;font-family:'Noto Serif JP',serif}
.pin:hover{background:var(--red);color:var(--washi)}
footer{border-top:1px solid var(--line);margin-top:60px;padding:30px 0;text-align:center;color:var(--sumi2);font-size:12px;letter-spacing:.2em;text-transform:uppercase}
footer .jp{color:var(--red);font-size:18px;margin-bottom:10px;letter-spacing:.2em}
