:root {
  --paper: #f5efe7;
  --ink: #261d18;
  --tan: #d9bf9c;
  --brass: #9e7a47;
  --forest: #23493f;
  --cream: #fffaf4;
  --line: rgba(38, 29, 24, 0.14);
  --shadow: 0 24px 62px rgba(38, 29, 24, 0.14);
}
* { box-sizing: border-box; }
body {
  margin: 0;
  color: var(--ink);
  font-family: "Lucida Sans Unicode", "Lucida Grande", sans-serif;
  background:
    linear-gradient(180deg, #fcf8f2 0%, #efe4d5 46%, #e2d0bf 100%);
}
img { display: block; width: 100%; max-width: 100%; }
.page-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 1rem;
  padding: 1rem 1.2rem;
  background: rgba(252, 248, 242, 0.92);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(14px);
}
.back-link {
  text-decoration: none;
  color: var(--ink);
  padding: 0.85rem 1rem;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: #fff;
  font-weight: 700;
}
.switcher {
  display: grid;
  gap: 0.35rem;
  justify-items: end;
  font-size: 0.82rem;
}
.switcher span,
.marker,
.logo-card figcaption,
.detail-box figcaption {
  text-transform: uppercase;
  letter-spacing: 0.14em;
  font-weight: 800;
  color: var(--forest);
}
.switcher select {
  min-width: min(360px, 72vw);
  padding: 0.9rem 1rem;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: #fff;
  font: inherit;
}
.barber-page {
  width: min(1280px, calc(100% - 1rem));
  margin: 0 auto;
  padding: 1rem 0 2rem;
  display: grid;
  gap: 1rem;
}
.club-header,
.title-panel,
.hours-panel,
.logo-card,
.story-card,
.service-note,
.detail-box,
.contact-card,
.map-card {
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
}
.club-header,
.portrait-band,
.detail-column,
.footer-strip {
  display: grid;
  gap: 1rem;
}
.club-header { grid-template-columns: 1.2fr 0.8fr; }
.title-panel,
.service-note,
.contact-card {
  padding: 1.3rem;
  border-radius: 32px;
  background: rgba(255,250,244,0.86);
}
.title-panel {
  background:
    linear-gradient(135deg, rgba(255,250,244,0.94), rgba(222,206,184,0.86));
}
.hours-panel {
  padding: 1.2rem;
  border-radius: 32px;
  background: linear-gradient(180deg, rgba(35,73,63,0.96), rgba(20,39,34,0.96));
  color: #f4ede3;
}
.hours-panel .marker,
.hours-panel p { color: #f4ede3; }
h1,h2,strong { font-family: Georgia, "Times New Roman", serif; }
h1,h2,p,span,figcaption { overflow-wrap: anywhere; }
h1 { margin: 0 0 0.8rem; font-size: clamp(3.2rem, 7vw, 5.9rem); line-height: 0.9; max-width: 8ch; }
h2 { margin: 0 0 0.7rem; font-size: clamp(1.9rem, 3.8vw, 3rem); line-height: 0.95; }
p,span,figcaption { line-height: 1.7; }
.lead { margin: 0; max-width: 34rem; }
.portrait-band {
  grid-template-columns: 0.58fr 1.12fr 0.8fr;
  align-items: start;
}
.logo-card,
.detail-box {
  padding: 1rem;
  border-radius: 28px;
  background: rgba(255,250,244,0.88);
}
.logo-card img,
.detail-box img {
  min-height: 220px;
  object-fit: cover;
  border-radius: 18px;
  background: linear-gradient(135deg, #c9b49a, #f3e5d6);
}
.hero-photo {
  min-height: 520px;
  border-radius: 34px;
  object-fit: cover;
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  background: linear-gradient(135deg, #bca288, #f0e0cf);
}
.story-card {
  padding: 1.1rem;
  border-radius: 30px;
  background: linear-gradient(180deg, rgba(158,122,71,0.18), rgba(255,250,244,0.92));
}
.detail-column { grid-template-columns: 0.86fr 1.14fr; }
.service-note {
  background: linear-gradient(180deg, rgba(255,250,244,0.94), rgba(219,191,156,0.76));
}
.detail-stack {
  display: grid;
  gap: 1rem;
}
.offset { transform: translateX(-1.75rem); background: rgba(248,241,232,0.92); }
.slim { transform: translateX(1rem); background: linear-gradient(180deg, rgba(35,73,63,0.12), rgba(255,250,244,0.92)); }
.footer-strip { grid-template-columns: 0.9fr 1.1fr; }
.contact-card p { margin: 0.3rem 0; }
.map-card {
  position: relative;
  overflow: hidden;
  min-height: 320px;
  border-radius: 30px;
  background: linear-gradient(180deg, #f7f0e6, #e8d8c5);
}
.block-grid {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(90deg, transparent 0 17%, rgba(38,29,24,0.08) 17% 19%, transparent 19% 41%, rgba(35,73,63,0.16) 41% 44%, transparent 44% 73%, rgba(38,29,24,0.08) 73% 75%, transparent 75%),
    linear-gradient(transparent 0 23%, rgba(38,29,24,0.08) 23% 25%, transparent 25% 49%, rgba(158,122,71,0.16) 49% 52%, transparent 52% 79%, rgba(38,29,24,0.08) 79% 81%, transparent 81%);
}
.pin {
  position: absolute;
  left: 56%;
  top: 46%;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--forest);
  transform: translate(-50%, -50%);
}
.pin::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 68%;
  width: 18px;
  height: 18px;
  background: var(--forest);
  transform: translateX(-50%) rotate(45deg);
}
.map-pill {
  position: absolute;
  right: 1rem;
  bottom: 1rem;
  padding: 0.85rem 1rem;
  border-radius: 18px;
  background: rgba(255,255,255,0.88);
  font-weight: 700;
}
@media (max-width: 980px) {
  .club-header,.portrait-band,.detail-column,.footer-strip { grid-template-columns: 1fr; }
  .offset,.slim { transform: none; }
  .hero-photo { min-height: 320px; }
}
@media (max-width: 760px) {
  .page-header { position: static; display: grid; }
  .switcher { justify-items: start; }
  .barber-page { width: min(100% - 0.75rem, 1280px); }
}
