/* ---------- LoBall service page — from new-sites/loball/service.html inline <style> ---------- */

/* Hero */
.svc-hero {
  border-bottom: 2px solid var(--ink);
  padding: 56px 0 48px;
}
.svc-hero__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 40px;
  align-items: end;
}
@media (max-width: 800px) {
  .svc-hero__grid { grid-template-columns: 1fr; }
}
.svc-hero h1 { margin-top: 14px; }
.svc-hero p { font-size: 15px; color: var(--steel); max-width: 44ch; }

/* Disclaimer strip */
.disclaimer-strip {
  background: var(--warm);
  color: var(--paper);
  padding: 14px 0;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  text-align: center;
}
.disclaimer-strip b { font-weight: 700; }

/* Service tier menu */
.menu {
  padding: 64px 0;
}
.menu__head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  margin-bottom: 28px;
  gap: 24px;
  flex-wrap: wrap;
}
.menu__grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
}
@media (max-width: 900px) {
  .menu__grid { grid-template-columns: 1fr; }
}

.tier {
  border: 2px solid var(--ink);
  padding: 28px 24px 24px;
  background: var(--paper);
  display: grid;
  align-content: start;
  gap: 14px;
  position: relative;
  transition: transform .15s ease, box-shadow .15s ease;
}
.tier:hover {
  transform: translate(-4px, -4px);
  box-shadow: 6px 6px 0 var(--ink);
}
.tier__num {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--steel);
}
.tier__title {
  font-family: var(--f-display);
  font-size: 32px;
  line-height: 1;
  letter-spacing: -0.02em;
  margin: 0;
}
.tier__price {
  font-family: var(--f-display);
  font-size: 44px;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--warm);
  margin: 4px 0 0;
}
.tier__price small {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--steel);
  display: block;
}
.tier__time {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink);
  margin-top: -4px;
}
.tier__includes {
  list-style: none;
  padding: 0;
  margin: 6px 0 0;
  display: grid;
  gap: 8px;
  font-size: 14px;
  color: var(--ink-soft);
  border-top: 1px dashed var(--hairline);
  padding-top: 14px;
}
.tier__includes li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.tier__includes li::before {
  content: "→";
  color: var(--warm);
  font-family: var(--f-display);
  flex-shrink: 0;
}
.tier__cta { margin-top: 8px; }

/* Featured/dark tier variant */
.tier--feature { background: var(--ink); color: var(--paper); }
.tier--feature .tier__num { color: var(--steel-soft); }
.tier--feature .tier__price { color: var(--warm); }
.tier--feature .tier__time { color: var(--paper); }
.tier--feature .tier__includes {
  color: var(--steel-soft);
  border-top-color: rgba(241, 235, 220, 0.25);
}

.tier__feature-flag {
  position: absolute;
  top: -12px;
  right: 16px;
  background: var(--warm);
  color: var(--paper);
  padding: 4px 8px;
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

/* À la carte */
.alacarte {
  padding: 56px 0;
  border-top: 2px solid var(--ink);
}
.alacarte h2 {
  font-family: var(--f-display);
  font-size: clamp(32px, 4vw, 52px);
  margin: 0 0 22px;
  letter-spacing: -0.025em;
  line-height: 0.95;
}
.alacarte__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0 40px;
  border-top: 2px solid var(--ink);
}
@media (max-width: 800px) {
  .alacarte__grid { grid-template-columns: 1fr; }
}
.alacarte__row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  padding: 16px 0;
  border-bottom: 1px dashed var(--hairline);
  font-size: 16px;
}
.alacarte__row b {
  font-family: var(--f-display);
  font-size: 18px;
  font-weight: 400;
}
.alacarte__row .price {
  font-family: var(--f-mono);
  font-size: 13px;
  letter-spacing: 0.1em;
  color: var(--ink);
  white-space: nowrap;
}
.alacarte__row .price b {
  font-family: var(--f-display);
  font-size: 20px;
  color: var(--warm);
}
.alacarte__row span {
  color: var(--steel);
  font-size: 12px;
  flex: 1;
  padding-left: 16px;
}

/* Booking section */
.booking {
  background: var(--paper-2);
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  padding: 64px 0;
}
.booking__head {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 24px;
  margin-bottom: 28px;
  flex-wrap: wrap;
}
.booking__head h2 {
  font-family: var(--f-display);
  font-size: clamp(32px, 4vw, 52px);
  margin: 0;
  letter-spacing: -0.025em;
  line-height: 0.95;
}
.booking__grid {
  display: grid;
  grid-template-columns: 1.5fr 1fr;
  gap: 32px;
}
@media (max-width: 900px) {
  .booking__grid { grid-template-columns: 1fr; }
}

/* Calendar widget */
.calendar {
  border: 2px solid var(--ink);
  background: var(--paper);
}
.calendar__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 2px solid var(--ink);
  background: var(--ink);
  color: var(--paper);
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.calendar__head h3 {
  font-family: var(--f-display);
  font-size: 18px;
  margin: 0;
  letter-spacing: 0;
  text-transform: none;
}
.calendar__nav { display: inline-flex; gap: 6px; }
.calendar__nav button {
  background: var(--paper);
  color: var(--ink);
  border: 0;
  padding: 6px 10px;
  font-family: var(--f-mono);
  font-size: 12px;
  cursor: pointer;
  font-weight: 600;
}
.calendar__week {
  display: grid;
  grid-template-columns: 80px repeat(5, 1fr);
  border-bottom: 2px solid var(--ink);
}
.calendar__week > div {
  padding: 14px 8px;
  text-align: center;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
  border-right: 1px solid var(--hairline);
}
.calendar__week > div:last-child { border-right: 0; }
.calendar__week > div b {
  display: block;
  font-family: var(--f-display);
  font-size: 20px;
  color: var(--ink);
  margin-top: 4px;
  letter-spacing: 0;
}
.calendar__week > div.is-today b { color: var(--warm); }
.calendar__week > div:first-child { background: var(--paper-2); }

.calendar__body {
  display: grid;
  grid-template-columns: 80px repeat(5, 1fr);
}
.calendar__body .timecol {
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  color: var(--steel);
  padding: 8px;
  text-align: right;
  border-right: 1px solid var(--hairline);
  background: var(--paper-2);
  display: flex;
  align-items: center;
  justify-content: flex-end;
  text-transform: uppercase;
  min-height: 44px;
}
.calendar__slot {
  border-right: 1px solid var(--hairline);
  border-bottom: 1px solid var(--hairline);
  padding: 4px;
  min-height: 44px;
  display: flex;
  align-items: stretch;
}
.calendar__slot:last-child { border-right: 0; }
.calendar__slot button {
  flex: 1;
  background: var(--paper);
  border: 1px solid var(--hairline);
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.1em;
  cursor: pointer;
  color: var(--ink);
  transition: all .12s ease;
}
.calendar__slot button:hover:not(:disabled) {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}
.calendar__slot button.is-selected {
  background: var(--warm);
  color: var(--paper);
  border-color: var(--warm);
  font-weight: 600;
}
.calendar__slot button:disabled {
  background: repeating-linear-gradient(45deg, var(--paper-2) 0 6px, transparent 6px 12px), var(--paper);
  color: var(--steel);
  cursor: not-allowed;
  border-style: dashed;
}

.calendar__legend {
  display: flex;
  gap: 18px;
  padding: 12px 20px;
  font-family: var(--f-mono);
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  border-top: 2px solid var(--ink);
}
.calendar__legend i {
  display: inline-block;
  width: 12px;
  height: 12px;
  border: 1px solid var(--ink);
  margin-right: 6px;
  vertical-align: -2px;
}
.calendar__legend i.taken {
  background: repeating-linear-gradient(45deg, var(--paper-2) 0 4px, transparent 4px 8px);
  border-style: dashed;
}
.calendar__legend i.sel { background: var(--warm); border-color: var(--warm); }

/* Intake form */
.intake {
  border: 2px solid var(--ink);
  background: var(--paper);
  padding: 24px;
  display: grid;
  gap: 16px;
  align-self: start;
  position: sticky;
  top: 100px;
}
.intake h3 {
  font-family: var(--f-display);
  font-size: 22px;
  margin: 0;
  line-height: 1;
}
.intake__sel {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border: 2px solid var(--warm);
  padding: 10px 14px;
  background: rgba(210, 74, 31, 0.08);
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.1em;
}
.intake__sel.is-empty {
  border-color: var(--hairline);
  background: var(--paper-2);
  color: var(--steel);
}
.intake__sel b {
  font-family: var(--f-display);
  font-size: 14px;
}
.intake__field { display: grid; gap: 6px; }
.intake__field label {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--steel);
}
.intake__field input,
.intake__field select,
.intake__field textarea {
  font-family: var(--f-body);
  font-size: 14px;
  padding: 10px 12px;
  border: 1.5px solid var(--ink);
  background: var(--paper);
  color: var(--ink);
  width: 100%;
  border-radius: 0;
}
.intake__field input:focus,
.intake__field select:focus,
.intake__field textarea:focus {
  outline: 2px solid var(--warm);
  outline-offset: 1px;
}
.intake__field textarea { min-height: 70px; resize: vertical; }
.intake__row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.intake__submit {
  background: var(--ink);
  color: var(--paper);
  border: 0;
  padding: 16px;
  font-family: var(--f-mono);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  cursor: pointer;
  font-weight: 600;
}
.intake__submit:hover { background: var(--warm); }
.intake__note {
  font-family: var(--f-mono);
  font-size: 10px;
  letter-spacing: 0.1em;
  color: var(--steel);
  line-height: 1.6;
}

/* FAQ */
.faq {
  padding: 64px 0;
}
.faq h2 {
  font-family: var(--f-display);
  font-size: clamp(32px, 4vw, 52px);
  margin: 0 0 28px;
  letter-spacing: -0.025em;
  line-height: 0.95;
}
.faq__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px 48px;
}
@media (max-width: 800px) {
  .faq__grid { grid-template-columns: 1fr; }
}
.faq__item {
  border-top: 2px solid var(--ink);
  padding-top: 14px;
}
.faq__item h3 {
  font-family: var(--f-display);
  font-size: 20px;
  margin: 0 0 6px;
  letter-spacing: -0.01em;
  line-height: 1.05;
}
.faq__item p {
  font-size: 14px;
  color: var(--ink-soft);
  margin: 0;
  line-height: 1.55;
}
