/* ─── PUMP · bar website ─────────────────────────────────────────────────── */

:root {
  /* base palette */
  --ink: #272727;
  --paper: #EBEBEB;
  --white: #FFFFFF;
  --red: #FF3737;
  --orange: #F35E24;
  --pink: #F9C3DA;
  --yellow: #FEEC28;
  --green: #38B767;

  /* themed */
  --bg: var(--paper);
  --fg: var(--ink);
  --accent: #FF3737;
  --accent-2: #FEEC28;
  --accent-3: #38B767;
  --surface: #FFFFFF;

  /* type */
  --font-primary: 'Oswald', system-ui, sans-serif;
  --font-grunge: 'Rubik Wet Paint', 'Rubik Mono One', cursive;
  --font-hand: 'Barriecito', cursive;
  --font-body: 'Inter Tight', system-ui, sans-serif;

  /* layout */
  --pad-x: clamp(20px, 4vw, 64px);
  --row-gap: clamp(72px, 9vw, 140px);
  --rule: 1.5px solid var(--fg);

  /* texture intensity 0..1 */
  --tx: 0.35;
}

/* ── reset / base ── */
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-body);
  background: var(--bg);
  color: var(--fg);
  font-size: 16px;
  line-height: 1.4;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
  position: relative;
  letter-spacing: 0.005em;
}
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; border: 0; background: none; cursor: pointer; }
::selection { background: var(--accent); color: var(--white); }

img, svg { display: block; max-width: 100%; }

/* type helpers */
.display { font-family: var(--font-primary); font-weight: 600; text-transform: uppercase; letter-spacing: -0.005em; line-height: 0.92; }
.grunge  { font-family: var(--font-grunge); font-weight: 400; }
.hand    { font-family: var(--font-hand); font-weight: 400; }
.mono    { font-family: ui-monospace, 'JetBrains Mono', monospace; }
.meta    { font-family: var(--font-primary); font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase; font-weight: 500; }
.upper   { text-transform: uppercase; letter-spacing: 0.06em; }

em { font-style: italic; }
mark { background: var(--accent-2); color: var(--fg); padding: 0 4px; }

/* ── film grain texture overlay ── */
body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 100;
  opacity: calc(var(--tx) * 0.5);
  mix-blend-mode: multiply;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 200'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='1.4' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.55 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

/* ── reusable: textures as backgrounds ── */
.tx-brick {
  background-color: var(--surface);
  background-image:
    linear-gradient(transparent 0 49%, color-mix(in oklab, var(--fg) 14%, transparent) 49% 51%, transparent 51% 100%),
    linear-gradient(90deg, transparent 0 49%, color-mix(in oklab, var(--fg) 14%, transparent) 49% 51%, transparent 51% 100%),
    linear-gradient(90deg, transparent 0 49%, color-mix(in oklab, var(--fg) 14%, transparent) 49% 51%, transparent 51% 100%);
  background-size: 100% 36px, 80px 18px, 80px 18px;
  background-position: 0 0, 0 0, 40px 18px;
}
.tx-metal {
  background:
    repeating-linear-gradient(180deg,
      color-mix(in oklab, var(--fg) 10%, transparent) 0 1px,
      transparent 1px 3px),
    linear-gradient(180deg, color-mix(in oklab, var(--fg) 6%, transparent), transparent 70%);
  background-color: var(--surface);
}
.tx-film {
  position: relative;
}
.tx-film::before {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 120'><filter id='g'><feTurbulence baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 0  0 0 0 0 0  0 0 0 0 0  0 0 0 0.45 0'/></filter><rect width='100%25' height='100%25' filter='url(%23g)'/></svg>");
  mix-blend-mode: multiply;
  opacity: calc(var(--tx) * 0.7);
  pointer-events: none;
}

/* ── TOP BAR ── */
.topbar {
  position: sticky; top: 0; z-index: 60;
  background: var(--bg);
  border-bottom: var(--rule);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  padding: 12px var(--pad-x);
  gap: 24px;
  backdrop-filter: blur(6px);
}
.brand {
  display: inline-flex; align-items: center; gap: 12px;
}
.brand-logo { height: 34px; width: auto; display: block; }
.brand .dot {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 var(--accent);
  animation: pulse 1.6s infinite;
}
@keyframes pulse {
  0%,100% { box-shadow: 0 0 0 0 color-mix(in oklab, var(--accent) 70%, transparent); }
  70%     { box-shadow: 0 0 0 9px color-mix(in oklab, var(--accent) 0%, transparent); }
}
.brand .sub { font-family: var(--font-primary); opacity: .5; font-weight: 400; font-size: 12px; letter-spacing: 0.08em; text-transform: uppercase; }

.topbar nav {
  display: flex; justify-content: center; gap: 22px;
  font-family: var(--font-primary); font-weight: 500;
  font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
}
.topbar nav a { position: relative; padding: 6px 0; }
.topbar nav a:hover { color: var(--accent); }
.topbar .right { display: flex; gap: 14px; align-items: center; }
.pill-cta {
  background: var(--fg); color: var(--bg);
  padding: 10px 18px; border-radius: 999px;
  font-family: var(--font-primary); font-weight: 600;
  font-size: 13px; letter-spacing: 0.06em; text-transform: uppercase;
  transition: transform .2s, background .2s, color .2s;
}
.pill-cta:hover { background: var(--accent); color: var(--white); transform: translateY(-1px); }

/* ── HERO ── */
.hero {
  padding: clamp(28px, 5vw, 60px) var(--pad-x) 0;
  position: relative;
  border-bottom: var(--rule);
}
.hero-meta {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  border-bottom: var(--rule);
  padding-bottom: 22px;
  margin-bottom: clamp(20px, 4vw, 44px);
}
.hero-meta .cell { font-size: 12px; }
.hero-meta .cell .k { font-family: var(--font-primary); font-weight: 500; text-transform: uppercase; letter-spacing: 0.14em; font-size: 10px; opacity: 0.55; margin-bottom: 6px; }
.hero-meta .cell .v { font-weight: 500; }

.hero-mark {
  margin: clamp(20px, 4vw, 48px) 0;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
  position: relative;
}
.hero-logo {
  width: clamp(260px, 70vw, 1100px);
  height: auto;
  display: block;
  transition: transform .3s;
}
.hero-logo:hover { transform: scale(1.02) rotate(-1deg); }
.hero-mark .glyph { display: inline-flex; }
.hero-mark .glyph {
  display: inline-block;
  position: relative;
}
.hero-mark .glyph[data-glitch]:hover::before,
.hero-mark .glyph[data-glitch]:hover::after {
  content: attr(data-text);
  position: absolute; inset: 0;
}
.hero-mark .glyph[data-glitch]:hover::before {
  color: var(--accent); transform: translate(-3px, 0); mix-blend-mode: multiply;
  clip-path: polygon(0 0, 100% 0, 100% 45%, 0 45%);
}
.hero-mark .glyph[data-glitch]:hover::after {
  color: var(--accent-3); transform: translate(3px, 0); mix-blend-mode: multiply;
  clip-path: polygon(0 55%, 100% 55%, 100% 100%, 0 100%);
}

.hero-mark .star {
  font-size: clamp(40px, 8vw, 130px);
  color: var(--accent);
  line-height: 1;
  transform-origin: center;
  display: inline-flex; align-items: center; justify-content: center;
  animation: spin 18s linear infinite;
}
@keyframes spin { to { transform: rotate(360deg); } }

.hero-tag {
  display: grid; grid-template-columns: 1.2fr 1fr;
  gap: 32px;
  margin-top: clamp(16px, 2.4vw, 28px);
  padding: 22px 0 clamp(40px, 6vw, 80px);
  border-top: var(--rule);
}
.hero-tag h1 {
  margin: 0;
  font-family: var(--font-primary); font-weight: 500;
  font-size: clamp(28px, 4.2vw, 64px);
  line-height: 1.0; letter-spacing: -0.01em;
  text-transform: uppercase; text-wrap: balance;
}
.hero-tag h1 .accent { color: var(--accent); font-style: italic; font-weight: 600; }
.hero-tag h1 .hand-accent { font-family: var(--font-hand); text-transform: none; color: var(--fg); font-weight: 400; font-size: 0.85em; letter-spacing: 0.01em; }
.hero-tag .sub {
  font-size: 16px; line-height: 1.55;
  align-self: end; max-width: 48ch;
  opacity: 0.78;
}

.hero-status {
  position: absolute; right: var(--pad-x); top: 50%;
  transform: translateY(-50%);
  background: var(--fg); color: var(--bg);
  padding: 14px 16px 14px 14px; border-radius: 14px;
  font-family: var(--font-primary); font-size: 12px;
  text-transform: uppercase; letter-spacing: 0.08em;
  display: none;
}
@media (min-width: 1280px) { .hero-status { display: flex; align-items: center; gap: 12px; } }
.eq {
  display: inline-flex; gap: 3px; align-items: flex-end; height: 22px;
}
.eq i {
  display: inline-block; width: 4px; background: var(--accent);
  animation: eq 1.1s ease-in-out infinite;
}
.eq i:nth-child(1){ height: 30%; animation-delay: -0.1s; }
.eq i:nth-child(2){ height: 70%; animation-delay: -0.3s; }
.eq i:nth-child(3){ height: 45%; animation-delay: -0.5s; }
.eq i:nth-child(4){ height: 90%; animation-delay: -0.2s; }
.eq i:nth-child(5){ height: 55%; animation-delay: -0.4s; }
@keyframes eq {
  0%,100% { transform: scaleY(0.4); transform-origin: bottom; }
  50%     { transform: scaleY(1); }
}

/* ── LOUD MARQUEE ── */
.loud {
  background: var(--accent);
  color: var(--fg);
  border-bottom: var(--rule);
  overflow: hidden; position: relative;
}
.marquee {
  display: flex; gap: 0;
  padding: 16px 0;
  white-space: nowrap;
  font-family: var(--font-primary); font-weight: 600;
  font-size: clamp(28px, 4.6vw, 56px);
  line-height: 1; text-transform: uppercase; letter-spacing: -0.005em;
  animation: scroll 28s linear infinite;
  will-change: transform;
}
.marquee > span { display: inline-flex; align-items: center; gap: 28px; padding-right: 28px; }
.marquee .dot { width: 12px; height: 12px; background: var(--fg); border-radius: 999px; flex: none; }
@keyframes scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ── SECTION SHELL ── */
section.block { padding: var(--row-gap) var(--pad-x); position: relative; }
section.block.bordered { border-bottom: var(--rule); }
section.block.alt { background: var(--surface); }

.eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  border: var(--rule); border-radius: 999px;
  padding: 6px 14px;
  font-family: var(--font-primary); font-size: 11px; font-weight: 600;
  text-transform: uppercase; letter-spacing: 0.16em;
}
.eyebrow .num { color: var(--accent); font-weight: 700; }

h2.section-title {
  font-family: var(--font-primary); font-weight: 600;
  font-size: clamp(42px, 7vw, 112px);
  line-height: 0.9; letter-spacing: -0.02em;
  text-transform: uppercase;
  margin: 18px 0 36px;
  text-wrap: balance;
}
h2.section-title em { color: var(--accent); font-style: italic; font-weight: 500; }
h2.section-title .hand-em { font-family: var(--font-hand); text-transform: none; font-weight: 400; font-size: 0.7em; letter-spacing: 0; color: var(--fg); }
h2.section-title .grunge-em { font-family: var(--font-grunge); font-weight: 400; font-size: 0.85em; color: var(--accent); }

/* ── MANIFESTO ── */
.manifesto { display: grid; grid-template-columns: 1fr 1.3fr; gap: 64px; }
.manifesto .lead {
  font-size: clamp(20px, 1.9vw, 28px);
  line-height: 1.3; font-weight: 500;
  letter-spacing: -0.005em; text-wrap: balance;
  font-family: var(--font-body);
}
.manifesto .lead .strike { color: var(--accent); }
.principles { display: grid; grid-template-columns: 1fr 1fr; gap: 28px 40px; }
.principle { border-top: 1.5px solid var(--fg); padding-top: 14px; }
.principle .n { font-family: var(--font-primary); font-weight: 600; font-size: 12px; letter-spacing: 0.08em; }
.principle .t { font-family: var(--font-primary); font-weight: 600; font-size: 21px; margin: 4px 0 8px; text-transform: uppercase; letter-spacing: -0.005em; }
.principle .d { font-size: 14px; line-height: 1.5; opacity: 0.78; }
.principle .n .icon-vinyl { display: inline-block; width: 12px; height: 12px; border-radius: 999px; background: var(--fg); position: relative; vertical-align: -1px; margin-right: 6px; }
.principle .n .icon-vinyl::after { content:""; position:absolute; inset: 4px; border-radius: 999px; background: var(--accent); }

/* ── MENU ── */
.menu-head {
  display: flex; flex-wrap: wrap; align-items: flex-end; justify-content: space-between;
  gap: 24px;
}
.menu-tabs { display: flex; gap: 8px; flex-wrap: wrap; }
.menu-tabs button {
  border: 1.5px solid var(--fg); border-radius: 999px;
  padding: 10px 18px;
  font-family: var(--font-primary); font-weight: 500; font-size: 13px;
  letter-spacing: 0.06em; text-transform: uppercase;
  background: transparent;
  transition: background .15s, color .15s;
}
.menu-tabs button.on { background: var(--fg); color: var(--bg); }
.menu-tabs button:hover:not(.on) { background: color-mix(in oklab, var(--fg) 10%, transparent); }

.menu-tabs .download {
  border: 1.5px dashed var(--fg);
  background: var(--accent-2); color: var(--fg);
}
.menu-tabs .download:hover { background: var(--fg); color: var(--bg); }

.menu-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px 80px; margin-top: 48px; }
.menu-col h3 {
  font-family: var(--font-primary); font-weight: 600;
  font-size: 14px; text-transform: uppercase; letter-spacing: 0.18em;
  margin: 0 0 18px; padding-bottom: 12px;
  border-bottom: 1.5px solid var(--fg);
  display: flex; justify-content: space-between; align-items: baseline;
}
.menu-col h3 .pill {
  font-family: var(--font-primary); font-size: 10px; font-weight: 600;
  background: var(--accent); color: var(--white);
  padding: 4px 8px; border-radius: 999px; letter-spacing: 0.08em;
}
.menu-item {
  display: grid; grid-template-columns: 1fr auto;
  column-gap: 14px; padding: 14px 0;
  border-bottom: 1px dashed color-mix(in oklab, var(--fg) 28%, transparent);
}
.menu-item:last-child { border-bottom: 0; }
.menu-item .name {
  font-family: var(--font-primary); font-weight: 500; font-size: 18px;
  text-transform: uppercase; letter-spacing: 0.005em;
}
.menu-item .name .tag {
  display: inline-block; margin-left: 6px;
  font-family: var(--font-primary); font-size: 9px; font-weight: 600;
  padding: 2px 6px; border-radius: 4px;
  background: var(--accent-2); color: var(--fg);
  vertical-align: 3px; letter-spacing: 0.06em; text-transform: uppercase;
}
.menu-item .name .tag.hot { background: var(--accent); color: var(--white); }
.menu-item .name .tag.new { background: var(--accent-3); color: var(--white); }
.menu-item .desc { grid-column: 1; font-size: 13px; opacity: 0.7; margin-top: 4px; line-height: 1.45; font-family: var(--font-body); }
.menu-item .price { font-family: var(--font-primary); font-weight: 600; font-size: 18px; white-space: nowrap; align-self: start; }
.menu-item .price small { opacity: 0.55; font-weight: 400; font-size: 11px; margin-left: 4px; }
.menu-col h4.menu-sub {
  font-family: var(--font-primary); font-weight: 600;
  font-size: 11px; text-transform: uppercase; letter-spacing: 0.16em;
  margin: 22px 0 6px; opacity: 0.85;
}
.menu-col h4.menu-sub:first-child { margin-top: 0; }
.menu-col .section-note {
  font-size: 13px; opacity: 0.65; margin: -8px 0 14px;
  line-height: 1.45; font-family: var(--font-body);
}
.menu-col .sauce-list {
  font-family: var(--font-body); font-size: 14px; line-height: 1.85;
  margin: 0; padding: 0; list-style: none;
}

.menu-foot {
  margin-top: 56px; padding-top: 24px; border-top: var(--rule);
  display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
  font-family: var(--font-primary); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em; font-weight: 500;
}

/* ── ATMOSPHERE ── */
.atmos-grid {
  display: grid; grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: 110px; gap: 12px;
}
.tile {
  position: relative; overflow: hidden;
  display: flex; align-items: flex-end; padding: 16px;
  font-family: var(--font-primary);
  font-size: 12px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.1em;
  border: 1.5px solid var(--fg);
}
.tile.k1 { grid-column: span 5; grid-row: span 4; background: var(--accent); color: var(--white); }
.tile.k2 { grid-column: span 4; grid-row: span 2; }
.tile.k3 { grid-column: span 3; grid-row: span 2; background: var(--fg); color: var(--bg); }
.tile.k4 { grid-column: span 4; grid-row: span 2; background: var(--accent-2); }
.tile.k5 { grid-column: span 3; grid-row: span 2; }
.tile.k6 { grid-column: span 5; grid-row: span 3; background: var(--pink); }
.tile.k7 { grid-column: span 4; grid-row: span 3; background: var(--accent-3); color: var(--white); }
.tile.k8 { grid-column: span 3; grid-row: span 3; background: var(--orange); color: var(--white); }

.tile.k2.tx-brick { background-color: #d8b6a3; }
.tile.k3 { background-image: repeating-linear-gradient(180deg, color-mix(in oklab, var(--bg) 12%, transparent) 0 1px, transparent 1px 4px); }
.tile.k5 { background: var(--surface) repeating-linear-gradient(45deg, transparent 0 14px, color-mix(in oklab, var(--fg) 8%, transparent) 14px 15px); }

/* photo tiles */
.tile.photo { padding: 0; color: var(--white); }
.tile.photo > img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: contrast(1.05) saturate(1.05);
}
.tile.photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 40%, rgba(0,0,0,0.5));
  pointer-events: none;
}
.tile.photo .label-top,
.tile.photo > span { position: relative; z-index: 2; }
.tile.photo:hover > img { transform: scale(1.04); transition: transform .6s ease; }
.tile.photo > img { transition: transform .6s ease; }

/* sticker — circular rotating overlay */
.sticker {
  position: absolute;
  width: clamp(120px, 14vw, 200px);
  aspect-ratio: 1/1;
  animation: spin 14s linear infinite;
  filter: drop-shadow(0 8px 20px rgba(0,0,0,0.25));
  pointer-events: none;
  z-index: 4;
}
.sticker img { width: 100%; height: 100%; display: block; }

.sticker.sticker-hero {
  right: clamp(20px, 4vw, 80px);
  top: clamp(140px, 14vw, 220px);
  transform-origin: center;
}
.sticker.sticker-team {
  right: -30px; top: -30px;
  width: clamp(110px, 11vw, 160px);
}

.tile .label-top { position: absolute; top: 16px; left: 16px; font-size: 10px; opacity: 0.7; }
.tile .big-num { position: absolute; top: 14px; right: 14px; font-family: var(--font-primary); font-size: 30px; font-weight: 700; line-height: 1; letter-spacing: -0.03em; }
.tile.k1 .quote {
  position: absolute; left: 18px; right: 18px; top: 50%; transform: translateY(-50%);
  font-family: var(--font-primary); font-weight: 500;
  font-size: clamp(22px, 2.4vw, 38px);
  line-height: 1.0;
  letter-spacing: -0.005em;
  text-transform: uppercase; text-wrap: balance;
}
.tile.k1 .quote .hand-em { font-family: var(--font-hand); text-transform: none; color: var(--accent-2); font-size: 1em; font-weight: 400; letter-spacing: 0; }
.tile.k1 .signoff { position: absolute; left: 18px; bottom: 18px; }

/* ── EVENTS ── */
.events-row {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px;
}
.event-card {
  background: var(--surface);
  border: 1.5px solid var(--fg);
  padding: 22px;
  display: grid; gap: 14px;
  position: relative; overflow: hidden;
  transition: transform .2s, background .2s, color .2s;
}
.event-card:hover { transform: translateY(-3px); background: var(--fg); color: var(--bg); }
.event-card:hover .e-date { color: var(--accent-2); }
.event-card:hover .e-badge { background: var(--accent); }
.event-card .e-date {
  font-family: var(--font-primary); font-weight: 700;
  font-size: 56px; line-height: 0.9; letter-spacing: -0.04em;
  color: var(--accent);
}
.event-card .e-date .mo { font-size: 16px; opacity: 0.7; display: block; letter-spacing: 0.08em; }
.event-card .e-title { font-family: var(--font-primary); font-weight: 500; font-size: 20px; text-transform: uppercase; letter-spacing: -0.005em; }
.event-card .e-desc { font-size: 13px; opacity: 0.75; line-height: 1.45; }
.event-card .e-foot {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 14px; margin-top: 4px;
  border-top: 1px solid color-mix(in oklab, currentColor 22%, transparent);
  font-family: var(--font-primary); font-size: 12px; text-transform: uppercase; letter-spacing: 0.08em;
}
.event-card .e-badge { background: var(--accent-2); color: var(--fg); padding: 3px 8px; border-radius: 4px; font-size: 10px; font-weight: 600; letter-spacing: 0.08em; }
.event-card.afisha {
  background: var(--accent);
  color: var(--white);
}
.event-card.afisha .e-date { color: var(--white); }
.event-card.afisha:hover { background: var(--fg); }

/* ── SOUND / PLAYLIST ── */
.playlist-wrap {
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 60px; align-items: start;
}
.now-card {
  background: var(--fg); color: var(--bg);
  padding: 32px; border-radius: 24px;
  display: grid; gap: 22px;
  position: relative; overflow: hidden;
}
.now-card::before {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 120'><filter id='g'><feTurbulence baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.18 0'/></filter><rect width='100%25' height='100%25' filter='url(%23g)'/></svg>");
  mix-blend-mode: screen; opacity: calc(var(--tx) * 0.8); pointer-events: none;
}
.now-row { display: flex; gap: 22px; align-items: center; position: relative; }
.vinyl {
  width: 130px; height: 130px; border-radius: 50%; flex: none;
  background:
    radial-gradient(circle at center,
      var(--accent) 0 18px,
      var(--fg) 19px 20px,
      var(--bg) 20px 21px,
      var(--fg) 21px 32px,
      var(--bg) 32px 33px,
      var(--fg) 33px 100%);
  position: relative;
  animation: spin 5s linear infinite;
  box-shadow: 0 12px 24px rgba(0,0,0,0.25);
}
.vinyl::after { content:""; position: absolute; inset: 30px; border-radius: 50%; border: 1px dashed color-mix(in oklab, var(--bg) 25%, transparent); }
.now-meta .eyebrow-light { font-family: var(--font-primary); font-size: 11px; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase; color: var(--accent); margin-bottom: 8px; }
.now-meta .track { font-family: var(--font-primary); font-size: 30px; font-weight: 600; line-height: 1.0; text-transform: uppercase; letter-spacing: -0.005em; }
.now-meta .artist { font-size: 14px; opacity: 0.7; margin-top: 6px; }

.progress { height: 4px; background: color-mix(in oklab, var(--bg) 22%, transparent); border-radius: 4px; overflow: hidden; }
.progress > i { display: block; width: 38%; height: 100%; background: var(--accent); }
.times { display: flex; justify-content: space-between; font-family: ui-monospace, monospace; font-size: 11px; opacity: 0.65; margin-top: 6px; }
.genres { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 4px; }
.genres span {
  border: 1px solid color-mix(in oklab, var(--bg) 30%, transparent);
  padding: 6px 12px; border-radius: 999px;
  font-family: var(--font-primary); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.06em;
}

.playlist-list { display: grid; gap: 0; }

/* spotify CTA */
.spotify-cta {
  margin-top: 22px;
  display: flex; align-items: center; gap: 16px;
  padding: 16px 20px; border-radius: 18px;
  background: var(--fg); color: var(--bg);
  transition: background .2s, color .2s, transform .2s;
}
.spotify-cta:hover { background: #1DB954; color: #000; transform: translateY(-1px); }
.spotify-cta .sp-icon { width: 36px; height: 36px; flex: none; }
.spotify-cta .sp-eyebrow {
  display: block;
  font-family: var(--font-primary); font-size: 11px; letter-spacing: 0.14em;
  text-transform: uppercase; font-weight: 500; opacity: 0.6; margin-bottom: 2px;
}
.spotify-cta .sp-title {
  display: block;
  font-family: var(--font-primary); font-size: 18px; text-transform: uppercase; letter-spacing: 0.005em; font-weight: 600;
}
.spotify-cta .sp-arrow {
  margin-left: auto;
  font-family: var(--font-primary); font-weight: 600; font-size: 26px;
}
.set-head {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 14px; border-bottom: var(--rule); margin-bottom: 4px;
}
.track-row {
  display: grid; grid-template-columns: 28px 1fr auto;
  gap: 18px; align-items: center; padding: 14px 0;
  border-bottom: 1px solid color-mix(in oklab, var(--fg) 18%, transparent);
  font-size: 14px;
  transition: background .15s, padding .15s, margin .15s;
}
.track-row:hover { background: var(--surface); padding-inline: 12px; margin-inline: -12px; }
.track-row .n { font-family: ui-monospace, monospace; font-size: 11px; opacity: 0.5; }
.track-row .ttl { font-family: var(--font-primary); font-weight: 500; font-size: 18px; text-transform: uppercase; letter-spacing: -0.005em; }
.track-row .art { font-size: 12px; opacity: 0.65; margin-top: 2px; }
.track-row .dur { font-family: ui-monospace, monospace; font-size: 12px; opacity: 0.6; }

/* ── TEAM ── */
.team-grid {
  display: grid; grid-template-columns: repeat(2, 1fr); gap: 28px;
}
.bartender {
  border: 1.5px solid var(--fg);
  background: var(--surface);
  padding: 0;
  overflow: hidden;
  display: grid; grid-template-rows: auto 1fr;
}
/* portrait — photo variant */
.bartender .portrait-photo {
  background: var(--fg);
  position: relative;
  overflow: hidden;
}
.bartender .portrait-photo img {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  filter: contrast(1.05) saturate(1.05);
  transition: transform .6s ease, filter .6s ease;
}
.bartender:hover .portrait-photo img {
  transform: scale(1.04);
  filter: contrast(1.1) saturate(0.6) sepia(0.15);
}
.bartender:nth-child(1) .portrait-photo,
.bartender:nth-child(2) .portrait-photo,
.bartender:nth-child(3) .portrait-photo { background: var(--fg); }
.bartender .portrait-photo::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,0.35));
  pointer-events: none;
}

/* placeholder portrait — empty 3rd slot */
.bartender.placeholder-card { opacity: 0.85; }
.bartender .portrait-empty {
  background: var(--surface);
  color: color-mix(in oklab, var(--fg) 35%, transparent);
  position: relative;
  aspect-ratio: 4/5;
  display: flex; align-items: center; justify-content: center;
  border-bottom: 1.5px dashed color-mix(in oklab, var(--fg) 35%, transparent);
  overflow: hidden;
}
.bartender .portrait-empty .stripes {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(45deg,
    transparent 0 14px,
    color-mix(in oklab, var(--fg) 6%, transparent) 14px 15px);
}
.bartender .portrait-empty .q {
  position: relative; z-index: 2;
  font-family: var(--font-primary); font-weight: 700;
  font-size: clamp(120px, 16vw, 240px); line-height: 1;
  letter-spacing: -0.04em;
  color: color-mix(in oklab, var(--fg) 25%, transparent);
}

.bartender .portrait {
  aspect-ratio: 4/5;
  background: var(--fg);
  position: relative;
  display: flex; align-items: center; justify-content: center;
  color: var(--bg);
  font-family: var(--font-primary); font-weight: 700;
  font-size: clamp(80px, 14vw, 220px); line-height: 1;
  letter-spacing: -0.05em;
  overflow: hidden;
}
.bartender .portrait .stripes {
  position: absolute; inset: 0;
  background: repeating-linear-gradient(45deg,
    transparent 0 18px,
    color-mix(in oklab, var(--bg) 10%, transparent) 18px 19px);
  pointer-events: none;
}
.bartender:nth-child(1) .portrait { background: var(--accent); }
.bartender:nth-child(2) .portrait { background: var(--accent-3); }
.bartender:nth-child(3) .portrait { background: var(--orange); }
.bartender .info { padding: 20px; }
.bartender .name { font-family: var(--font-primary); font-weight: 600; font-size: 22px; text-transform: uppercase; letter-spacing: -0.005em; }
.bartender .role { font-family: var(--font-primary); font-size: 11px; opacity: 0.6; text-transform: uppercase; letter-spacing: 0.14em; margin-top: 4px; }
.bartender .bio { font-size: 13px; line-height: 1.5; opacity: 0.78; margin-top: 12px; }
.bartender .fav {
  margin-top: 14px; padding-top: 14px;
  border-top: 1px dashed color-mix(in oklab, var(--fg) 28%, transparent);
  font-size: 12px; display: flex; justify-content: space-between; gap: 10px;
}
.bartender .fav .k { opacity: 0.55; text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-primary); font-weight: 500; }
.bartender .fav .v { font-family: var(--font-primary); font-weight: 500; text-transform: uppercase; }

/* ── BOOKING ── */
.booking-shell {
  background: var(--surface);
  border: var(--rule);
  border-radius: 28px;
  overflow: hidden;
  display: grid;
  grid-template-columns: 1fr 1.2fr;
}
.booking-side {
  background: var(--fg); color: var(--bg);
  padding: clamp(28px, 4vw, 56px);
  position: relative;
}
.booking-side::after {
  content: ""; position: absolute; inset: 0;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 120 120'><filter id='g'><feTurbulence baseFrequency='0.9' numOctaves='2'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 0.18 0'/></filter><rect width='100%25' height='100%25' filter='url(%23g)'/></svg>");
  mix-blend-mode: screen; opacity: calc(var(--tx) * 0.6); pointer-events: none;
}
.booking-side h3 {
  font-family: var(--font-primary); font-weight: 500;
  font-size: clamp(28px, 3.2vw, 48px);
  margin: 18px 0 18px; text-transform: uppercase;
  line-height: 0.95; letter-spacing: -0.015em;
}
.booking-side h3 em { color: var(--accent); font-style: italic; }
.booking-side p { font-size: 14px; opacity: 0.8; max-width: 40ch; line-height: 1.55; }
.perks { padding: 0; list-style: none; display: grid; gap: 10px; margin-top: 24px; font-size: 13px; }
.perks li { display: flex; gap: 10px; align-items: flex-start; }
.perks li::before {
  content: ""; flex: none; width: 12px; height: 12px; margin-top: 4px;
  background: var(--accent); transform: rotate(45deg);
}

.booking-main {
  padding: clamp(28px, 4vw, 48px);
  position: relative;
}
.steps-rail {
  display: flex; gap: 0; align-items: stretch;
  border: 1.5px solid var(--fg); border-radius: 999px;
  padding: 4px; margin-bottom: 32px;
}
.steps-rail .step {
  flex: 1; padding: 8px 12px; border-radius: 999px;
  font-family: var(--font-primary); font-size: 11px; font-weight: 500;
  text-transform: uppercase; letter-spacing: 0.06em;
  display: flex; align-items: center; justify-content: center; gap: 8px;
  text-align: center;
  opacity: 0.5; transition: opacity .2s, background .2s, color .2s;
  white-space: nowrap;
}
.steps-rail .step.active { background: var(--fg); color: var(--bg); opacity: 1; }
.steps-rail .step.done { opacity: 0.9; color: var(--fg); }
.steps-rail .step .i { font-family: ui-monospace, monospace; font-weight: 700; font-size: 10px; }

.step-pane { display: none; }
.step-pane.on { display: block; animation: fadeup .25s ease-out; }
@keyframes fadeup { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: none; } }

.step-title {
  font-family: var(--font-primary); font-weight: 600;
  font-size: 24px; text-transform: uppercase; letter-spacing: -0.005em;
  margin: 0 0 8px;
}
.step-sub { font-size: 13px; opacity: 0.65; margin-bottom: 22px; }

/* date picker */
.cal-head {
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--font-primary); font-size: 13px; text-transform: uppercase; letter-spacing: 0.1em; font-weight: 500;
  margin-bottom: 12px;
}
.cal-head .navbtn {
  width: 32px; height: 32px; border-radius: 999px;
  border: 1.5px solid var(--fg);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700;
}
.cal-head .navbtn:hover { background: var(--fg); color: var(--bg); }
.cal-grid {
  display: grid; grid-template-columns: repeat(7, 1fr); gap: 4px;
}
.cal-grid .wd {
  font-family: var(--font-primary); font-size: 10px; text-align: center;
  opacity: 0.5; text-transform: uppercase; letter-spacing: 0.1em; padding: 4px 0;
}
.cal-grid .d {
  aspect-ratio: 1/1;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-primary); font-weight: 500; font-size: 15px;
  border: 1px solid transparent; border-radius: 12px;
  cursor: pointer;
}
.cal-grid .d:hover:not(.dis):not(.sel) { border-color: var(--fg); }
.cal-grid .d.sel { background: var(--fg); color: var(--bg); }
.cal-grid .d.dis { opacity: 0.22; cursor: not-allowed; }
.cal-grid .d.today { box-shadow: inset 0 0 0 1.5px var(--accent); }

/* time slots */
.times-grid {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px;
}
.times-grid button {
  border: 1.5px solid var(--fg);
  border-radius: 12px;
  padding: 12px 0;
  font-family: var(--font-primary); font-weight: 500; font-size: 15px;
  background: transparent;
  transition: background .15s, color .15s;
}
.times-grid button.on { background: var(--fg); color: var(--bg); }
.times-grid button.dis { opacity: 0.28; cursor: not-allowed; }
.times-grid button:hover:not(.on):not(.dis) { background: color-mix(in oklab, var(--fg) 10%, transparent); }

/* table picker — realistic floor plan */
.floor {
  background: var(--bg);
  border: 1.5px solid var(--fg);
  border-radius: 16px;
  padding: 20px;
  position: relative;
}
.floor-plan {
  position: relative;
  aspect-ratio: 6/5;
  color: var(--fg);
  background: var(--bg);
}
.floor-plan .floor-svg {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  pointer-events: none;
}
.floor-plan .seat {
  position: absolute;
  left: calc(var(--x) / 600 * 100%);
  top: calc(var(--y) / 500 * 100%);
  transform: translate(-50%, -50%);
  border: 1.5px solid var(--fg);
  background: var(--surface);
  font-family: var(--font-primary);
  font-weight: 600;
  letter-spacing: 0.005em;
  cursor: pointer;
  transition: background .15s, color .15s, border-color .15s, transform .15s;
  white-space: nowrap;
  z-index: 2;
}
.floor-plan .seat.stool {
  width: clamp(28px, 4.5%, 38px);
  aspect-ratio: 1/1;
  border-radius: 6px;
  background: var(--accent-2);
  font-size: 10px;
  display: flex; align-items: center; justify-content: center;
}
.floor-plan .seat.table-round {
  width: clamp(46px, 9%, 64px);
  aspect-ratio: 1/1;
  border-radius: 999px;
  font-size: 11px;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  line-height: 1.1;
}
.floor-plan .seat.sofa {
  width: clamp(70px, 14%, 100px);
  height: clamp(28px, 5%, 34px);
  border-radius: 6px;
  font-size: 10px;
  display: flex; align-items: center; justify-content: center;
}
.floor-plan .seat:hover:not(.busy):not(.sel) {
  background: color-mix(in oklab, var(--accent) 14%, var(--surface));
  transform: translate(-50%, -50%) scale(1.08);
  z-index: 3;
}
.floor-plan .seat.busy {
  background: color-mix(in oklab, var(--fg) 18%, var(--bg));
  opacity: 0.5; cursor: not-allowed;
  color: color-mix(in oklab, var(--fg) 50%, transparent);
}
.floor-plan .seat.busy::after {
  content: ""; position: absolute; inset: 4px; border-radius: inherit;
  background: repeating-linear-gradient(45deg, transparent 0 4px, color-mix(in oklab, var(--fg) 30%, transparent) 4px 5px);
  pointer-events: none;
}
.floor-plan .seat.sel {
  background: var(--accent); color: var(--white); border-color: var(--accent);
  z-index: 4;
}

.legend { display: flex; flex-wrap: wrap; gap: 14px; margin-top: 16px; font-size: 11px; font-family: var(--font-primary); text-transform: uppercase; letter-spacing: 0.1em; }
.legend .sw { display: inline-block; width: 14px; height: 14px; border: 1.5px solid var(--fg); border-radius: 999px; vertical-align: -3px; margin-right: 6px; }
.legend .sw.busy { background: color-mix(in oklab, var(--fg) 30%, var(--bg)); }
.legend .sw.sel { background: var(--accent); border-color: var(--accent); }
.legend .sw.stool { background: var(--accent-2); border-radius: 4px; }
.legend .sw.sofa { background: var(--surface); border-radius: 3px; width: 22px; }

/* booking form (contact step) */
.form { display: grid; gap: 14px; }
.form .row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.form label {
  display: grid; gap: 6px;
  font-family: var(--font-primary); font-size: 11px; font-weight: 500;
  letter-spacing: 0.14em; text-transform: uppercase;
}
.form input, .form textarea {
  font: inherit; font-family: var(--font-body);
  border: 1.5px solid var(--fg); background: transparent;
  padding: 14px 14px; border-radius: 12px;
  font-size: 15px; color: var(--fg); font-weight: 500;
  letter-spacing: normal; text-transform: none;
  transition: border-color .15s, background .15s;
}
.form input:focus, .form textarea:focus {
  outline: none; border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 6%, transparent);
}
.form textarea { resize: vertical; min-height: 72px; }
.form input.invalid, .form textarea.invalid {
  border-color: var(--accent);
  background: color-mix(in oklab, var(--accent) 8%, transparent);
}
.field-error {
  display: none;
  font-family: var(--font-primary); font-weight: 500;
  font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--accent);
  margin-top: 2px;
}
.form input.invalid ~ .field-error,
.form textarea.invalid ~ .field-error { display: block; }
.guests-row { display: flex; gap: 6px; flex-wrap: wrap; }
.guests-row button {
  flex: 1; min-width: 44px;
  border: 1.5px solid var(--fg); border-radius: 12px;
  padding: 12px 0; font-family: var(--font-primary); font-weight: 500; font-size: 15px;
  background: transparent;
}
.guests-row button.on { background: var(--fg); color: var(--bg); }

/* step nav */
.step-nav {
  display: flex; gap: 12px; justify-content: space-between;
  margin-top: 28px; padding-top: 22px;
  border-top: 1px solid color-mix(in oklab, var(--fg) 22%, transparent);
}
.step-nav .back { color: var(--fg); padding: 14px 18px; font-family: var(--font-primary); font-weight: 500; text-transform: uppercase; letter-spacing: 0.08em; font-size: 13px; }
.step-nav .back:hover { color: var(--accent); }
.step-nav .next, .step-nav .submit {
  background: var(--fg); color: var(--bg); padding: 16px 24px; border-radius: 999px;
  font-family: var(--font-primary); font-weight: 600; font-size: 13px;
  letter-spacing: 0.1em; text-transform: uppercase;
  display: inline-flex; align-items: center; gap: 12px;
  transition: background .15s, color .15s;
}
.step-nav .next:hover, .step-nav .submit:hover { background: var(--accent); color: var(--white); }
.step-nav button:disabled { opacity: 0.4; cursor: not-allowed; }

.confirm-row {
  display: grid; gap: 14px;
  padding: 22px; border: 1.5px dashed var(--fg); border-radius: 18px;
  margin-bottom: 22px;
  background: color-mix(in oklab, var(--accent-2) 30%, transparent);
}
.confirm-row .item {
  display: grid; grid-template-columns: 140px 1fr; gap: 14px; align-items: baseline;
  font-size: 14px;
}
.confirm-row .item .k { font-family: var(--font-primary); font-size: 11px; text-transform: uppercase; letter-spacing: 0.12em; opacity: 0.6; }
.confirm-row .item .v { font-family: var(--font-primary); font-weight: 500; font-size: 16px; text-transform: uppercase; }

.success {
  text-align: center; padding: 40px 24px;
}
.success .check {
  width: 64px; height: 64px; border-radius: 999px;
  background: var(--accent-3); color: var(--white);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 32px; margin-bottom: 18px;
}
.success h4 { font-family: var(--font-primary); font-weight: 600; font-size: 28px; text-transform: uppercase; letter-spacing: -0.005em; margin: 0 0 8px; }
.success p { font-size: 14px; opacity: 0.7; }

/* ── FOOTER ── */
footer.foot {
  background: var(--fg); color: var(--bg);
  padding: clamp(40px, 6vw, 96px) var(--pad-x) 24px;
  position: relative;
}
.foot-grid {
  display: grid; grid-template-columns: 1.6fr 1fr 1fr 1fr;
  gap: 40px; align-items: start;
}
.foot h4 { font-family: var(--font-primary); font-size: 11px; font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; margin: 0 0 14px; opacity: 0.5; }
.foot a { display: block; padding: 4px 0; font-size: 15px; font-weight: 500; }
.foot a:hover { color: var(--accent); }
.foot .big {
  margin: 60px 0 0;
  display: flex; align-items: center; gap: 28px;
}
.foot .big img {
  width: clamp(280px, 60vw, 1000px); height: auto; display: block;
}
.foot .big .star { color: var(--accent); font-size: clamp(64px, 10vw, 160px); line-height: 1; animation: spin 18s linear infinite; display: inline-block; }
.foot .tag-line { font-size: 14px; margin-top: 16px; opacity: 0.65; max-width: 34ch; }
.foot-bottom {
  margin-top: 40px; padding-top: 20px;
  border-top: 1px solid color-mix(in oklab, var(--bg) 18%, transparent);
  display: flex; flex-wrap: wrap; justify-content: space-between; gap: 16px;
  font-family: var(--font-primary); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; opacity: 0.55;
}

/* ── responsive ── */
@media (max-width: 1100px) {
  .events-row { grid-template-columns: 1fr 1fr; }
  .team-grid  { grid-template-columns: 1fr 1fr; }
  .booking-shell { grid-template-columns: 1fr; }
  .playlist-wrap { grid-template-columns: 1fr; }
  .manifesto { grid-template-columns: 1fr; gap: 36px; }
  .menu-grid { grid-template-columns: 1fr; gap: 36px; }
  .principles { grid-template-columns: 1fr; }
  .topbar nav { display: none; }
  .foot-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .hero-meta { grid-template-columns: 1fr 1fr; }
  .events-row { grid-template-columns: 1fr; }
  .team-grid  { grid-template-columns: 1fr; }
  .atmos-grid { grid-template-columns: repeat(6, 1fr); }
  .tile.k1 { grid-column: span 6; grid-row: span 3; }
  .tile.k2,.tile.k3,.tile.k4,.tile.k5,.tile.k6,.tile.k7,.tile.k8 { grid-column: span 3; grid-row: span 2; }
  .times-grid { grid-template-columns: repeat(3, 1fr); }
  .foot-grid { grid-template-columns: 1fr; }
}

/* ── mood presets (data-mood on <body>) ──
   Mood "минимал": white paper + red accent only.
   Mood "зин":     paper + multi-accent stamps + heavier texture (texture intensity bumped).
   Mood "плакат":  ink background + bright accents reversed. */

body[data-mood="zine"] {
  --tx: 0.55;
}
body[data-mood="poster"] {
  --bg: #FFFFFF;
  --surface: #EBEBEB;
}
body[data-mood="poster"] section.block.alt { background: var(--bg); }
body[data-mood="poster"] .topbar { background: #FFFFFF; }

/* ── Sticky bottom action bar (mobile-first FAB) ── */
.fab {
  position: fixed;
  left: 50%;
  bottom: clamp(12px, 2.5vw, 24px);
  transform: translateX(-50%);
  z-index: 50;
  display: flex;
  gap: 8px;
  padding: 8px;
  background: color-mix(in oklab, var(--fg) 92%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-radius: 999px;
  box-shadow: 0 8px 24px rgba(0,0,0,.18), 0 2px 6px rgba(0,0,0,.12);
}
.fab-btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--font-primary);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  padding: 12px 22px;
  border-radius: 999px;
  text-decoration: none;
  white-space: nowrap;
  transition: transform .15s, background .15s, color .15s;
}
.fab-btn:hover { transform: translateY(-1px); }
.fab-primary { background: var(--accent); color: #fff; }
.fab-primary:hover { background: color-mix(in oklab, var(--accent) 85%, #000); }
.fab-ghost { background: transparent; color: var(--bg); }
.fab-ghost:hover { background: color-mix(in oklab, var(--bg) 18%, transparent); }
/* don't let last footer line hide behind the FAB */
.foot-bottom { padding-bottom: clamp(72px, 8vw, 96px); }
@media (max-width: 480px) {
  .fab-btn { font-size: 13px; padding: 11px 18px; letter-spacing: 0.06em; }
}
