/* Components — strict B/W */

/* Buttons */
.btn {
  --pad-y: 1rem;
  --pad-x: 1.5rem;
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  padding: var(--pad-y) var(--pad-x);
  font-family: var(--ff-mono);
  font-size: 0.78rem;
  letter-spacing: 0.20em;
  text-transform: uppercase;
  color: var(--ink);
  background: transparent;
  border: 1px solid transparent;
  cursor: pointer;
  position: relative;
  isolation: isolate;
  transition: color .35s var(--ease), background-color .35s var(--ease), border-color .35s var(--ease);
  min-height: 48px;
}
.btn:focus-visible { outline-offset: 4px; }

.btn--primary {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.btn--primary::before {
  content: "";
  position: absolute; inset: 0;
  background: var(--paper);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .5s var(--ease);
  z-index: -1;
}
.btn--primary:hover {
  color: var(--ink);
  border-color: var(--ink);
}
.btn--primary:hover::before { transform: scaleX(1); }

.btn--ghost,
.btn--line {
  border-color: var(--ink);
  color: var(--ink);
  background: transparent;
}
.btn--ghost::after,
.btn--line::after {
  content: "";
  position: absolute;
  left: var(--pad-x); right: var(--pad-x);
  bottom: 0.55rem;
  height: 1px;
  background: var(--ink);
  transform: scaleX(0);
  transform-origin: left center;
  transition: transform .45s var(--ease);
}
.btn--ghost:hover,
.btn--line:hover {
  color: var(--paper);
  background: var(--ink);
  border-color: var(--ink);
}
.btn--ghost:hover::after,
.btn--line:hover::after { transform: scaleX(0); }

/* On black background (booking section) — invert */
.booking .btn--primary {
  background: var(--paper);
  color: var(--ink);
  border-color: var(--paper);
}
.booking .btn--primary::before { background: var(--ink); }
.booking .btn--primary:hover {
  color: var(--paper);
  border-color: var(--paper);
}
.booking .btn--line {
  color: var(--paper);
  border-color: rgba(244, 239, 227, 0.55);
}
.booking .btn--line:hover {
  color: var(--ink);
  background: var(--paper);
  border-color: var(--paper);
}
.booking .btn--line::after { display: none; }

.btn--xl {
  --pad-y: 1.35rem;
  --pad-x: 2.25rem;
  font-size: 0.85rem;
  letter-spacing: 0.22em;
}

.btn__mono { font-family: var(--ff-mono); letter-spacing: 0.14em; }

/* ----- PRICELIST ----- */
.pricelist {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid var(--rule-strong);
}
.pricelist__row {
  display: grid;
  grid-template-columns: 2.75rem minmax(0, 1.6fr) minmax(2rem, 1fr) auto auto;
  align-items: baseline;
  gap: 1rem;
  padding: clamp(1rem, 1.8vw, 1.5rem) 0;
  border-bottom: 1px solid var(--rule);
  transition: padding-left .35s var(--ease), background-color .35s var(--ease);
}
.pricelist__row:hover {
  background: linear-gradient(90deg, rgba(10, 10, 10, 0.05), transparent 70%);
  padding-left: 0.5rem;
}
.pricelist__num {
  font-family: var(--ff-mono);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  color: var(--grey-2);
}
.pricelist__name {
  font-family: var(--ff-display);
  font-size: clamp(1.35rem, 0.95rem + 1.6vw, 2.25rem);
  letter-spacing: -0.005em;
  color: var(--ink);
  line-height: 1.1;
}
.pricelist__rule {
  height: 1px;
  background: var(--rule);
  align-self: center;
  min-width: 1.5rem;
}
.pricelist__duration {
  color: var(--grey-1);
  font-family: var(--ff-mono);
  font-size: 0.74rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  white-space: nowrap;
}
.pricelist__price {
  font-family: var(--ff-display);
  font-weight: 500;
  font-size: clamp(1.3rem, 0.85rem + 1.4vw, 2.0rem);
  color: var(--ink);
  font-feature-settings: "tnum" 1;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .pricelist__row {
    grid-template-columns: 2.2rem 1fr auto;
    grid-template-rows: auto auto;
    column-gap: 0.85rem;
    row-gap: 0.25rem;
    padding: 1rem 0;
  }
  .pricelist__num {
    grid-row: 1 / span 2;
    align-self: start;
    padding-top: 0.35rem;
  }
  .pricelist__name { grid-column: 2; }
  .pricelist__price { grid-column: 3; grid-row: 1; align-self: start; }
  .pricelist__rule { display: none; }
  .pricelist__duration {
    grid-column: 2 / span 2;
    grid-row: 2;
    margin-top: 0.15rem;
  }
}
