.visit {
  padding: 70px 0 50px;
  position: relative;
  z-index: 2;
}
@media (max-width: 720px) { .visit { padding: 50px 0 30px; } }

.visit__grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 32px;
  align-items: stretch;
}
@media (max-width: 820px) {
  .visit__grid { grid-template-columns: 1fr; }
}

.visit__card {
  display: block;
  position: relative;
  text-decoration: none;
  color: inherit;
  background: color-mix(in srgb, var(--ink) 6%, var(--paper));
  border: 1.5px solid color-mix(in srgb, var(--ink) 25%, transparent);
  border-radius: var(--radius);
  padding: 36px 36px 30px;
  transition:
    background-color .25s ease,
    border-color var(--fade) var(--ease);
}

.visit__name {
  font-family: var(--display);
  font-weight: 800;
  text-transform: uppercase;
  font-size: clamp(28px, 3.6vw, 40px);
  line-height: 1;
  margin: 0 0 14px;
  letter-spacing: -.01em;
}
.visit__addr {
  font-family: var(--display);
  font-size: clamp(17px, 1.5vw, 19px);
  font-weight: 600;
  letter-spacing: .03em;
  margin: 0 0 26px;
}
.visit__addr-link {
  color: inherit;
  text-decoration: none;
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
  transition: color .2s ease;
}
.visit__addr-link:hover { color: var(--p1); }
.visit__arrow {
  display: inline-block;
  margin-left: 4px;
  font-weight: 800;
  transition: transform .2s ease;
}
.visit__addr-link:hover .visit__arrow { transform: translate(3px, -3px); }

.visit__hours {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 12px 22px;
  margin: 0 0 28px;
  font-family: var(--display);
  font-size: clamp(18px, 1.6vw, 21px);
  font-variant-numeric: tabular-nums;
}
.visit__hours dt {
  text-transform: uppercase;
  letter-spacing: .06em;
  font-weight: 700;
  align-self: center;
  /* Slightly lighter so the time reads as the primary value. */
  opacity: .82;
}
.visit__hours dd {
  margin: 0;
  text-align: right;
  font-weight: 600;
}

/* Contact list — phone / email / instagram, each with an icon. */
.visit__contact {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.visit__contact-link {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  color: inherit;
  text-decoration: none;
  font-family: var(--display);
  font-size: clamp(17px, 1.5vw, 19px);
  font-weight: 700;
  letter-spacing: .02em;
  transition: color .2s ease, transform .2s ease;
}
.visit__contact-link:hover {
  color: var(--p1);
  transform: translateX(2px);
}
.visit__contact-link .icon {
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  color: var(--p2);
  transition: color var(--fade) var(--ease);
}
.visit__contact-link:hover .icon { color: var(--p1); }

.visit__map {
  border-radius: var(--radius);
  overflow: hidden;
  min-height: 360px;
  background: rgba(0,0,0,.05);
  border: 1.5px solid color-mix(in srgb, var(--ink) 25%, transparent);
}
.visit__map iframe {
  width: 100%;
  height: 100%;
  min-height: 360px;
  border: 0;
  display: block;
}

/* Happy-Hour playful module — sits below the hours/map grid, slightly
 * askew and overlapping into the row above so it feels stuck on the
 * page rather than blocked into a column. */
.visit__happy {
  position: relative;
  display: flex;
  justify-content: center;
  margin-top: -36px;
  pointer-events: none;
  z-index: 4;
}
.visit__happy-card {
  pointer-events: auto;
  position: relative;
  background: var(--p1);
  color: var(--on-p1);
  border: 3px solid var(--ink);
  padding: 22px 36px 24px;
  border-radius: 6px;
  rotate: -3deg;
  box-shadow: 8px 8px 0 0 var(--ink);
  max-width: min(520px, 92%);
  text-align: center;
  font-family: var(--display);
  text-transform: uppercase;
  letter-spacing: .04em;
  transition:
    rotate .4s cubic-bezier(.2,.7,.2,1),
    transform .4s cubic-bezier(.2,.7,.2,1),
    background-color var(--fade) var(--ease),
    color var(--fade) var(--ease);
}
.visit__happy-card:hover {
  rotate: 1deg;
  transform: translateY(-4px);
}
.visit__happy-card::before,
.visit__happy-card::after {
  content: "";
  position: absolute;
  width: 14px; height: 14px;
  background: var(--p3);
  border: 2px solid var(--ink);
  border-radius: 50%;
}
.visit__happy-card::before { top: -10px; left: -10px;  rotate: -10deg; }
.visit__happy-card::after  { bottom: -10px; right: -10px; rotate: 14deg; }

.visit__happy-line {
  margin: 4px 0;
  font-weight: 700;
  font-size: clamp(15px, 1.4vw, 18px);
  line-height: 1.15;
}
.visit__happy-line--lead {
  font-family: var(--hand);
  font-weight: 700;
  text-transform: none;
  letter-spacing: 0;
  font-size: clamp(28px, 4vw, 44px);
  margin-bottom: 4px;
  rotate: -2deg;
}

@media (max-width: 720px) {
  .visit__happy { margin-top: -18px; }
  .visit__happy-card { padding: 18px 22px 20px; }
}
@media (prefers-reduced-motion: reduce) {
  .visit__happy-card { rotate: 0deg; }
  .visit__happy-card::before,
  .visit__happy-card::after { rotate: 0deg; }
  .visit__happy-line--lead { rotate: 0deg; }
}
