/* =========================================================================
   Bar Small Beer / Małe Piwo / "The Six-Tap Ticket"
   A hand-numbered craft-beer broadsheet. Warm newsprint + single stout-ochre.
   Display: Spline Sans Mono  ·  Body: IBM Plex Sans
   ========================================================================= */

:root{
  --canvas:#F4EFE3;
  --canvas-2:#EFE8D7;
  --ink:#1C1A17;
  --ink-soft:#3A352D;
  --ink-faint:#6B6155;
  --accent:#C77B2B;        /* stout ochre */
  --accent-deep:#A55F1B;
  --line:#1C1A17;
  --hair:rgba(28,26,23,.18);
  --hair-2:rgba(28,26,23,.10);
  --paper-grain: rgba(28,26,23,.035);

  --spine: 760px;          /* receipt-column width */
  --pad: clamp(18px, 4.4vw, 40px);

  --mono:"Spline Sans Mono", ui-monospace, "SFMono-Regular", Menlo, monospace;
  --sans:"IBM Plex Sans", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;

  --r: 2px;
}

/* ---------- reset ---------- */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0}
img{max-width:100%;display:block}
a{color:inherit}
button{font:inherit;color:inherit}
:focus-visible{outline:2.5px solid var(--accent);outline-offset:3px;border-radius:2px}

html,body{background:var(--canvas);color:var(--ink)}
body{
  font-family:var(--sans);
  font-size:clamp(15px,1.05vw + 11px,17px);
  line-height:1.62;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

/* paper grain + faint vertical print-registration */
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    radial-gradient(circle at 25% 15%, var(--paper-grain) 0 1px, transparent 1px),
    radial-gradient(circle at 70% 60%, var(--paper-grain) 0 1px, transparent 1px);
  background-size:7px 7px, 9px 9px;
  opacity:.9;
}

/* ---------- reveal contract (JS-gated only) ---------- */
html.js [data-reveal]{opacity:0;transform:translateY(16px);transition:opacity .7s ease,transform .7s ease}
html.js [data-reveal].in{opacity:1;transform:none}

/* =========================================================================
   PERFORATION SPINE / the tear-off stub running the full page edge
   ========================================================================= */
.page{
  position:relative;z-index:1;
  max-width:var(--spine);
  margin:0 auto;
  padding:0 var(--pad);
  background:var(--canvas);
  border-left:1px dashed var(--hair);
  border-right:1px dashed var(--hair);
}
/* dotted perforation columns just outside the receipt edges */
.page::before,.page::after{
  content:"";position:absolute;top:0;bottom:0;width:2px;
  background-image:radial-gradient(circle, var(--ink) 0 1.4px, transparent 1.6px);
  background-size:2px 12px;background-repeat:repeat-y;
  opacity:.32;
}
.page::before{left:-9px}
.page::after{right:-9px}

@media (max-width:520px){
  .page{border-left:none;border-right:none}
  .page::before,.page::after{display:none}
}

/* perforation divider between major blocks */
.perf{
  height:0;border:0;margin:0;
  border-top:2px dashed var(--hair);
  position:relative;
}
.perf::after{
  content:"✃";position:absolute;left:-2px;top:-12px;
  font-size:15px;color:var(--ink-faint);background:var(--canvas);
  padding-right:6px;transform:scaleX(-1);
}

/* =========================================================================
   HEADER (print masthead bar)
   ========================================================================= */
.site-header{
  position:sticky;top:0;z-index:40;
  background:color-mix(in srgb, var(--canvas) 88%, transparent);
  backdrop-filter:blur(6px);
  border-bottom:1px solid transparent;
  transition:border-color .3s ease, background .3s ease;
}
.site-header.scrolled{
  border-bottom:1px solid var(--hair);
  background:color-mix(in srgb, var(--canvas) 96%, transparent);
}
.header-inner{
  max-width:var(--spine);margin:0 auto;padding:12px var(--pad);
  display:flex;align-items:center;justify-content:space-between;gap:14px;
}
.brand{
  display:flex;align-items:center;gap:11px;text-decoration:none;letter-spacing:.02em;
}
.brand-mark{
  width:30px;height:30px;border-radius:50%;
  border:2px solid var(--ink);
  display:grid;place-items:center;flex:0 0 auto;
  background:var(--ink);
}
.brand-mark span{
  display:block;width:11px;height:11px;border-radius:50%;
  background:var(--canvas);
}
.brand-name{
  font-family:var(--mono);font-weight:600;font-size:15px;
  text-transform:uppercase;letter-spacing:.12em;line-height:1;color:var(--ink);
}
.brand-name small{display:block;font-size:9.5px;letter-spacing:.34em;color:var(--accent-deep);margin-top:3px;font-weight:500}

.nav{display:flex;align-items:center;gap:6px}
.nav a{
  font-family:var(--mono);font-size:12.5px;text-decoration:none;
  padding:7px 10px;color:var(--ink-soft);letter-spacing:.04em;
  border-radius:var(--r);transition:color .2s, background .2s;
}
.nav a:hover{color:var(--ink);background:var(--canvas-2)}

.header-tools{display:flex;align-items:center;gap:12px}
.lang-toggle{display:inline-flex;border:1px solid var(--hair);border-radius:999px;overflow:hidden}
.lang-toggle button{
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;
  padding:5px 11px;background:transparent;border:0;cursor:pointer;color:var(--ink-faint);
}
.lang-toggle button[aria-pressed="true"]{background:var(--ink);color:var(--canvas)}

.nav-toggle{display:none}

/* =========================================================================
   MASTHEAD / HERO  (no photo, the printed ticket head)
   ========================================================================= */
.masthead{
  padding:clamp(34px,8vw,72px) 0 30px;
  position:relative;
}
.kicker-row{
  display:flex;align-items:center;gap:14px;
  font-family:var(--mono);font-size:11.5px;letter-spacing:.22em;
  text-transform:uppercase;color:var(--ink-faint);
}
.kicker-row::before,.kicker-row::after{content:"";flex:1;height:1px;background:var(--hair)}
.kicker-row span{white-space:nowrap}

/* the rubber-stamp arc */
.stamp{
  position:absolute;right:-4px;top:clamp(20px,5vw,44px);
  width:118px;height:118px;
  transform:rotate(-7deg);
  display:grid;place-items:center;
  color:var(--accent-deep);
  opacity:.92;
  filter:saturate(1.05);
}
.stamp svg{width:100%;height:100%}
.stamp .stamp-core{
  position:absolute;font-family:var(--mono);font-weight:600;font-size:10px;
  letter-spacing:.04em;text-align:center;line-height:1.25;text-transform:uppercase;
}
@media (max-width:520px){.stamp{width:90px;height:90px;top:10px}.stamp .stamp-core{font-size:8.5px}}

.masthead h1{
  font-family:var(--mono);font-weight:700;
  font-size:clamp(48px,15.5vw,138px);
  line-height:.86;letter-spacing:-.02em;
  text-transform:uppercase;margin:.28em 0 0;color:var(--ink);
}
.masthead h1 .l2{display:block;color:var(--ink)}
.subline{
  font-family:var(--mono);font-size:clamp(12px,2.4vw,15px);
  letter-spacing:.05em;color:var(--ink-soft);margin:18px 0 0;
}
.subline b{color:var(--accent-deep);font-weight:600}

/* foam bubble rule */
.foam{
  margin:24px 0 6px;display:flex;gap:5px;flex-wrap:wrap;line-height:1;
  color:var(--accent);font-size:13px;user-select:none;
}
.foam span{opacity:.85}
.foam span:nth-child(3n){opacity:.5}
.foam span:nth-child(4n){color:var(--accent-deep);opacity:.7}

.masthead-meta{
  margin-top:22px;display:flex;flex-wrap:wrap;gap:10px 26px;align-items:baseline;
  font-family:var(--mono);font-size:12.5px;letter-spacing:.03em;color:var(--ink-soft);
}
.masthead-meta .star{color:var(--accent-deep);font-weight:600}
.masthead-meta a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--accent);padding-bottom:1px}
.masthead-meta a:hover{color:var(--accent-deep)}

/* =========================================================================
   SECTION HEADS (line-item ledger heads)
   ========================================================================= */
.sec{padding:clamp(40px,8vw,64px) 0}
.sec-head{
  display:flex;align-items:baseline;justify-content:space-between;gap:16px;
  margin:0 0 6px;
}
.sec-head h2{
  font-family:var(--mono);font-weight:600;font-size:clamp(20px,4.4vw,28px);
  letter-spacing:.01em;text-transform:uppercase;margin:0;color:var(--ink);
}
.sec-head .idx{
  font-family:var(--mono);font-size:12px;letter-spacing:.18em;color:var(--ink-faint);
  text-transform:uppercase;white-space:nowrap;
}
.sec-lead{
  font-size:clamp(15px,2.6vw,17px);color:var(--ink-soft);max-width:54ch;margin:14px 0 0;
}

/* =========================================================================
   TAP LIST / six numbered line items with dotted leaders
   ========================================================================= */
.taplist{margin-top:30px;border-top:2px solid var(--ink)}
.tap{
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:start;column-gap:18px;
  padding:22px 0 20px;
  border-bottom:1px dashed var(--hair);
  position:relative;
}
.tap-no{
  font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.06em;
  color:var(--canvas);background:var(--ink);
  padding:5px 9px 4px;border-radius:var(--r);line-height:1;align-self:start;
  margin-top:4px;
}
.tap-main{min-width:0}
.tap-name-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.tap-name{
  font-family:var(--mono);font-weight:600;font-size:clamp(17px,3.2vw,21px);
  letter-spacing:.005em;color:var(--ink);
}
.tap-style{
  font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--accent-deep);border:1px solid currentColor;border-radius:999px;
  padding:2px 8px;line-height:1.4;white-space:nowrap;
}
.tap-desc{margin:7px 0 0;color:var(--ink-soft);font-size:14.5px;max-width:48ch;line-height:1.55}
.tap-brewer{
  display:block;margin-top:8px;font-family:var(--mono);font-size:11.5px;
  letter-spacing:.05em;color:var(--ink-faint);
}
.tap-brewer::before{content:"↳ ";color:var(--accent-deep)}

/* the hand-stamped ABV circle */
.abv{
  align-self:start;justify-self:end;
  position:relative;width:64px;height:64px;flex:0 0 auto;
  display:grid;place-items:center;text-align:center;
  border-radius:50%;
  border:1.5px solid var(--accent-deep);
  color:var(--accent-deep);
  font-family:var(--mono);line-height:1;
  overflow:hidden;
}
.abv .num{font-weight:700;font-size:16px;letter-spacing:-.02em}
.abv .lbl{font-size:8px;letter-spacing:.18em;margin-top:3px;text-transform:uppercase;opacity:.85}
/* slow ochre fill */
.abv::before{
  content:"";position:absolute;left:0;right:0;bottom:0;height:0;
  background:color-mix(in srgb, var(--accent) 16%, transparent);
  z-index:-1;
}
html.js .abv{--fill:0}
html.js [data-reveal].in .abv::before{height:var(--fill,46%)}
html.js .abv::before{transition:height 1.1s cubic-bezier(.4,0,.1,1) .25s}

.tap-foot{
  margin-top:8px;font-family:var(--mono);font-size:11px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--ink-faint);
}
.tap-foot .dotline{
  display:inline-block;width:54px;vertical-align:middle;margin:0 8px;
  border-bottom:1.5px dotted var(--hair);
}

.taplist-note{
  margin-top:18px;font-family:var(--mono);font-size:12px;letter-spacing:.04em;
  color:var(--ink-faint);display:flex;gap:8px;align-items:flex-start;
}
.taplist-note .pin{color:var(--accent-deep)}

@media (max-width:560px){
  .tap{grid-template-columns:auto 1fr;column-gap:14px}
  .abv{grid-column:2;justify-self:start;margin-top:12px;width:58px;height:58px}
}

/* =========================================================================
   PHOTO STRIP / the room, set as ticket exhibits
   ========================================================================= */
.exhibit{margin-top:30px}
.exhibit-figure{
  margin:0;border:1px solid var(--hair);background:#fff;
  padding:8px 8px 0;
}
.exhibit-figure img{
  width:100%;height:auto;aspect-ratio:3/2;object-fit:cover;
  filter:saturate(.96) contrast(1.02);
}
.exhibit-figure.tall img{aspect-ratio:4/5}
.exhibit-figure figcaption{
  font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-faint);
  padding:9px 2px 8px;display:flex;justify-content:space-between;gap:10px;
}
.exhibit-figure figcaption b{color:var(--ink);font-weight:600}

.exhibit-grid{
  display:grid;gap:16px;margin-top:16px;
  grid-template-columns:1.4fr 1fr;
}
.exhibit-col{display:grid;gap:16px;align-content:start}
@media (max-width:640px){.exhibit-grid{grid-template-columns:1fr}}

/* =========================================================================
   "THE ROOM" / text + chalk note
   ========================================================================= */
.room-grid{display:grid;gap:26px;grid-template-columns:1.1fr .9fr;align-items:start;margin-top:26px}
@media (max-width:700px){.room-grid{grid-template-columns:1fr}}
.room-copy p{margin:0 0 14px;color:var(--ink-soft)}
.room-copy p:last-child{margin-bottom:0}
.room-copy strong{color:var(--ink);font-weight:600}

.ledger{
  border:1px solid var(--ink);background:var(--canvas-2);
}
.ledger-head{
  font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  padding:10px 14px;border-bottom:1px dashed var(--hair);color:var(--ink-faint);
  display:flex;justify-content:space-between;
}
.ledger ul{list-style:none;margin:0;padding:6px 14px 12px}
.ledger li{
  display:flex;align-items:baseline;gap:8px;
  padding:9px 0;border-bottom:1px dotted var(--hair);
  font-family:var(--mono);font-size:13px;color:var(--ink-soft);
}
.ledger li:last-child{border-bottom:0}
.ledger li .lead{flex:1;border-bottom:1.5px dotted var(--hair);transform:translateY(-3px);margin:0 4px}
.ledger li b{color:var(--ink);font-weight:600;white-space:nowrap}

/* =========================================================================
   VISIT / STUB FOOTER
   ========================================================================= */
.stub{padding:clamp(38px,7vw,60px) 0 0}
.stub-grid{display:grid;gap:26px;grid-template-columns:1fr 1fr;margin-top:26px}
@media (max-width:640px){.stub-grid{grid-template-columns:1fr}}

.stub-block h3{
  font-family:var(--mono);font-size:12px;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ink-faint);margin:0 0 12px;
}
.stub-block p{margin:0 0 6px;color:var(--ink-soft)}
.stub-block a{color:var(--ink);text-decoration:none;border-bottom:1px solid var(--accent)}
.stub-block a:hover{color:var(--accent-deep)}
.hours-row{display:flex;justify-content:space-between;font-family:var(--mono);font-size:13px;padding:7px 0;border-bottom:1px dotted var(--hair)}
.hours-row:last-child{border-bottom:0}
.hours-row .lead{flex:1;border-bottom:1.5px dotted var(--hair);margin:0 8px;transform:translateY(-3px)}
.hours-note{font-family:var(--mono);font-size:11px;color:var(--ink-faint);margin-top:10px;letter-spacing:.03em}

.map-wrap{margin-top:26px;border:1px solid var(--ink);background:#fff;padding:8px}
.map-wrap iframe{width:100%;height:340px;border:0;display:block;filter:grayscale(.18) contrast(1.02)}

.cta-row{display:flex;flex-wrap:wrap;gap:12px;margin-top:24px}
.btn{
  font-family:var(--mono);font-size:13px;letter-spacing:.06em;text-transform:uppercase;
  text-decoration:none;padding:13px 20px;border-radius:var(--r);
  display:inline-flex;align-items:center;gap:9px;transition:transform .15s ease, background .2s, color .2s;
}
.btn-primary{background:var(--ink);color:var(--canvas);border:2px solid var(--ink)}
.btn-primary:hover{background:var(--accent-deep);border-color:var(--accent-deep);transform:translateY(-1px)}
.btn-ghost{background:transparent;color:var(--ink);border:2px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--canvas);transform:translateY(-1px)}

/* =========================================================================
   FOOTER (printed colophon)
   ========================================================================= */
.colophon{
  margin-top:clamp(40px,7vw,64px);
  border-top:2px dashed var(--hair);
  padding:30px 0 46px;
}
.colophon-top{
  display:flex;flex-wrap:wrap;justify-content:space-between;gap:18px;align-items:flex-start;
}
.colophon-brand{display:flex;gap:11px;align-items:center}
.colophon .foam{margin:18px 0 10px}
.coltext{font-family:var(--mono);font-size:11.5px;letter-spacing:.03em;color:var(--ink-faint);line-height:1.7}
.coltext a{color:var(--ink-soft)}
.disclaimer{
  margin-top:20px;font-family:var(--mono);font-size:11px;letter-spacing:.02em;
  color:var(--ink-faint);line-height:1.7;border-top:1px dotted var(--hair);padding-top:16px;max-width:62ch;
}
.colophon-meta{
  margin-top:18px;display:flex;flex-wrap:wrap;gap:6px 22px;
  font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);
}

/* =========================================================================
   MOBILE NAV
   ========================================================================= */
@media (max-width:780px){
  .nav-toggle{
    display:inline-grid;place-items:center;width:38px;height:38px;
    border:1px solid var(--hair);border-radius:var(--r);background:transparent;cursor:pointer;
  }
  .nav-toggle span{display:block;width:18px;height:2px;background:var(--ink);position:relative}
  .nav-toggle span::before,.nav-toggle span::after{content:"";position:absolute;left:0;width:18px;height:2px;background:var(--ink)}
  .nav-toggle span::before{top:-6px}.nav-toggle span::after{top:6px}
  .nav{
    position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:0;
    background:var(--canvas);border-bottom:1px solid var(--hair);
    padding:8px var(--pad) 14px;
    max-height:0;overflow:hidden;opacity:0;pointer-events:none;
    transition:max-height .3s ease,opacity .2s ease;
  }
  .nav.open{max-height:340px;opacity:1;pointer-events:auto}
  .nav a{padding:11px 4px;border-bottom:1px dotted var(--hair)}
}

@media print{
  .site-header,.nav-toggle,.cta-row,.map-wrap{display:none}
  body::before{display:none}
}
