@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,700;1,400&family=EB+Garamond:ital,wght@0,400;0,500;1,400&display=swap');
:root{--paper:#eae6d3;--paper2:#f0ecd8;--paper3:#ddd6b8;--ink:#2a2416;--sepia:#6a4a1e;--leaf:#4a5c22;--leaf-d:#2c3a10;--rust:#7a3808;--line:#9b8c60}
*{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--paper);color:var(--ink);font-family:'EB Garamond',Georgia,serif;font-size:18px;line-height:1.6;min-height:100%}
body{background-image:
 radial-gradient(ellipse at 20% 10%,rgba(74,92,34,.08),transparent 50%),
 radial-gradient(ellipse at 80% 90%,rgba(122,56,8,.08),transparent 50%),
 url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='300' height='300'><filter id='p'><feTurbulence baseFrequency='0.75' seed='7' numOctaves='2'/><feColorMatrix values='0 0 0 0 0.36  0 0 0 0 0.28  0 0 0 0 0.12  0 0 0 0.07 0'/></filter><rect width='100%25' height='100%25' filter='url(%23p)'/></svg>");
 background-attachment:fixed}
a{color:inherit;text-decoration:none}
.topbar{border-bottom:2px solid var(--ink);background:var(--paper2)}
.topbar .inner{max-width:1200px;margin:0 auto;padding:22px 28px;display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap}
.brand{display:flex;align-items:center;gap:16px}
.brand .mark{width:56px;height:56px;border:2px solid var(--ink);border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-style:italic;font-size:28px;color:var(--leaf)}
.brand .name{font-family:'Playfair Display',serif;font-size:26px;font-style:italic;line-height:1}
.brand .sub{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--sepia);margin-top:4px}
.topbar nav{display:flex;gap:24px;font-size:14px;font-style:italic}
.topbar nav a{padding-bottom:3px;border-bottom:1px solid transparent}
.topbar nav a:hover{border-color:var(--ink)}
.wrap{max-width:1200px;margin:0 auto;padding:50px 28px 80px}
/* hero */
.hero{text-align:center;padding:50px 20px 40px;position:relative;border-bottom:1px dashed var(--line);margin-bottom:40px}
.hero .plate-no{font-family:'Playfair Display',serif;font-style:italic;font-size:14px;color:var(--sepia);letter-spacing:.15em;text-transform:uppercase}
.hero h1{font-family:'Playfair Display',serif;font-size:clamp(42px,7vw,78px);font-weight:400;font-style:italic;line-height:1.05;margin:14px 0 10px}
.hero .latin{font-style:italic;color:var(--leaf);font-size:22px;letter-spacing:.04em}
.hero p{max-width:620px;margin:24px auto 0;color:var(--sepia);font-size:17px}
/* section */
.sec{margin:50px 0 26px;text-align:center;position:relative}
.sec::before,.sec::after{content:"";display:inline-block;width:80px;height:1px;background:var(--ink);vertical-align:middle;margin:0 20px}
.sec h2{display:inline-block;font-family:'Playfair Display',serif;font-style:italic;font-size:26px;vertical-align:middle}
.sec .sub{display:block;font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--sepia);margin-top:6px}
/* cards — herbarium plate */
.beers{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:32px}
.plate{background:var(--paper2);border:1px solid var(--ink);padding:0;position:relative;display:block;transition:transform .3s,box-shadow .3s}
.plate:hover{transform:translateY(-3px);box-shadow:4px 6px 0 rgba(42,36,22,.15)}
.plate::before{content:"";position:absolute;inset:6px;border:1px solid var(--line);pointer-events:none}
.plate .specimen{height:200px;background:var(--paper);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--ink);position:relative;overflow:hidden}
.plate .specimen svg{width:70%;height:80%}
.plate .specimen .label{position:absolute;top:10px;right:14px;font-family:'Playfair Display',serif;font-style:italic;font-size:12px;color:var(--sepia)}
.plate .info{padding:22px 22px 24px;text-align:center}
.plate .info h3{font-family:'Playfair Display',serif;font-size:22px;font-weight:500;font-style:italic}
.plate .info .latin{font-family:'EB Garamond',serif;font-style:italic;color:var(--leaf);font-size:14px;margin:3px 0 12px}
.plate .info .meta{font-size:13px;color:var(--sepia);text-transform:uppercase;letter-spacing:.1em;padding-top:12px;border-top:1px solid var(--line);display:flex;justify-content:space-between}
/* detail */
.crumb{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--sepia);font-style:italic;margin-bottom:20px}
.detail{display:grid;grid-template-columns:1fr 1.3fr;gap:50px;align-items:start}
@media(max-width:760px){.detail{grid-template-columns:1fr}}
.specimen-card{background:var(--paper2);border:1px solid var(--ink);padding:30px 30px 20px;position:relative;aspect-ratio:3/4}
.specimen-card::before{content:"";position:absolute;inset:10px;border:1px solid var(--line);pointer-events:none}
.specimen-card .plate-no{position:absolute;top:16px;right:20px;font-family:'Playfair Display',serif;font-style:italic;font-size:12px;color:var(--sepia);letter-spacing:.1em}
.specimen-card svg{width:100%;height:75%;display:block;margin:auto}
.specimen-card .tag{text-align:center;font-family:'Playfair Display',serif;font-style:italic;font-size:18px;color:var(--leaf-d);padding-top:14px;border-top:1px solid var(--line);margin:0 20px}
.info-col h1{font-family:'Playfair Display',serif;font-size:46px;font-style:italic;font-weight:400;line-height:1.05}
.info-col .latin{font-family:'EB Garamond',serif;font-style:italic;color:var(--leaf);font-size:22px;margin:8px 0 2px}
.info-col .loc{font-size:14px;color:var(--sepia);text-transform:uppercase;letter-spacing:.15em;margin-bottom:24px}
.fact-list{border-top:2px solid var(--ink);border-bottom:2px solid var(--ink);padding:20px 0;margin-bottom:24px;display:grid;grid-template-columns:repeat(2,1fr);gap:14px 30px}
.fact-list div{display:flex;justify-content:space-between;padding:4px 0;border-bottom:1px dotted var(--line);font-size:14px}
.fact-list dt{font-style:italic;color:var(--sepia);text-transform:uppercase;font-size:11px;letter-spacing:.15em}
.fact-list dd{font-weight:500;color:var(--ink)}
.info-col p{margin-bottom:16px;font-size:17px;line-height:1.75}
.info-col p::first-letter{font-family:'Playfair Display',serif;font-size:52px;float:left;line-height:.85;padding:4px 8px 0 0;color:var(--rust);font-style:italic}
.prices{margin-top:36px}
.prices h3,.reviews h3{font-family:'Playfair Display',serif;font-style:italic;font-size:22px;margin-bottom:14px;padding-bottom:6px;border-bottom:1px solid var(--ink)}
.pr{display:flex;justify-content:space-between;align-items:baseline;padding:12px 0;border-bottom:1px dotted var(--line)}
.pr em{font-style:italic;color:var(--sepia);font-size:13px;display:block}
.pr b{color:var(--rust);font-family:'Playfair Display',serif;font-style:italic;font-size:20px}
.reviews{margin-top:36px}
.review{padding:18px 0;border-bottom:1px dotted var(--line);position:relative;padding-left:30px}
.review::before{content:"❦";position:absolute;left:0;top:18px;color:var(--leaf);font-size:20px}
.review p{font-style:italic;font-size:16px;line-height:1.7}
.review .who{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--sepia);margin-top:8px}
/* brewery */
.brew-hero{text-align:center;padding:50px 20px;border:1px solid var(--ink);background:var(--paper2);margin-bottom:40px;position:relative}
.brew-hero::before{content:"";position:absolute;inset:8px;border:1px solid var(--line)}
.brew-hero .plate-no{font-family:'Playfair Display',serif;font-style:italic;font-size:12px;color:var(--sepia);letter-spacing:.2em;text-transform:uppercase}
.brew-hero h1{font-family:'Playfair Display',serif;font-size:54px;font-style:italic;margin:8px 0 6px;font-weight:400}
.brew-hero .latin{font-style:italic;color:var(--leaf);font-size:18px}
.brew-hero .loc{font-size:13px;color:var(--sepia);letter-spacing:.15em;text-transform:uppercase;margin-top:14px}
/* map */
.map-shell{display:grid;grid-template-columns:320px 1fr;gap:0;margin-top:20px;min-height:580px;border:2px solid var(--ink)}
@media(max-width:760px){.map-shell{grid-template-columns:1fr}}
.map-side{background:var(--paper2);padding:24px 22px;border-right:1px solid var(--ink)}
@media(max-width:760px){.map-side{border-right:none;border-bottom:1px solid var(--ink)}}
.map-side h2{font-family:'Playfair Display',serif;font-style:italic;font-size:22px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--ink)}
.poi{padding:12px 0;border-bottom:1px dotted var(--line)}
.poi b{font-family:'Playfair Display',serif;font-style:italic;font-size:17px;display:block;font-weight:500}
.poi em{font-style:italic;color:var(--sepia);font-size:13px}
.fake-map{background:var(--paper);position:relative;min-height:580px;overflow:hidden;background-image:
 radial-gradient(circle at 30% 40%,rgba(74,92,34,.1),transparent 40%),
 radial-gradient(circle at 70% 60%,rgba(122,56,8,.08),transparent 40%),
 repeating-linear-gradient(90deg,transparent,transparent 59px,rgba(155,140,96,.25) 60px),
 repeating-linear-gradient(0deg,transparent,transparent 59px,rgba(155,140,96,.25) 60px)
}
.fake-map::before{content:"PLANCHE XII · PLAN DES ADRESSES";position:absolute;top:20px;left:50%;transform:translateX(-50%);font-family:'Playfair Display',serif;font-style:italic;font-size:14px;color:var(--sepia);background:var(--paper);padding:4px 14px;border:1px solid var(--line);letter-spacing:.1em}
.fake-map svg{position:absolute;inset:0;width:100%;height:100%;opacity:.4}
.pin{position:absolute;width:30px;height:30px;background:var(--paper2);border:2px solid var(--rust);color:var(--rust);font-family:'Playfair Display',serif;font-style:italic;font-weight:700;font-size:14px;display:flex;align-items:center;justify-content:center;border-radius:50%;transform:translate(-50%,-50%);cursor:pointer}
.pin:hover{background:var(--rust);color:var(--paper)}
footer{border-top:2px double var(--ink);margin-top:60px;padding:30px 0;text-align:center;color:var(--sepia);font-style:italic;font-size:14px}
footer .sep{color:var(--leaf);margin:0 12px}
