:root {
  --bg-top: #120f12;
  --bg-bottom: #060607;
  --card: rgba(248, 243, 238, 0.9);
  --card-hover: rgba(255, 248, 244, 0.97);
  --card-border: rgba(255, 255, 255, 0.26);
  --card-strong: rgba(255, 243, 236, 0.94);
  --text: #ffffff;
  --text-soft: rgba(255, 255, 255, 0.72);
  --shadow: 0 26px 54px rgba(0, 0, 0, 0.3);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html,
body {
  margin: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  font-family: "Manrope", sans-serif;
  background: #050506;
  overflow: hidden;
  overscroll-behavior: none;
}

body {
  color: var(--text);
  position: relative;
}

.app-splash {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: grid;
  place-items: center;
  padding: 24px;
  background: #10001f;
  opacity: 1;
  visibility: visible;
  transition:
    opacity 820ms ease,
    visibility 820ms ease;
}

.app-splash.is-hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.app-splash-mark {
  display: grid;
  gap: 0;
  justify-items: center;
  text-align: center;
  animation: app-splash-float 1.6s ease-in-out infinite alternate;
}

.app-splash-wordmark {
  color: #ffffff;
  font-size: clamp(1.3rem, 4.5vw, 2.4rem);
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  line-height: 1.1;
}

@keyframes app-splash-float {
  from {
    transform: translateY(-4px) scale(0.992);
  }

  to {
    transform: translateY(4px) scale(1.008);
  }
}

button {
  font: inherit;
}

.hero-shell {
  position: relative;
  width: 100%;
  height: 100vh;
  min-height: 100vh;
  max-height: 100vh;
  overflow: hidden;
  background: #050506;
}

.hero-slideshow {
  position: absolute;
  inset: 0;
}

.appointment-day-html,
.appointment-day-page {
  height: auto;
  min-height: 100%;
  overflow: auto;
  overscroll-behavior: auto;
  background:
    radial-gradient(circle at top, rgba(123, 0, 231, 0.16), rgba(5, 5, 6, 0) 28%),
    linear-gradient(180deg, #110714 0%, #08070b 100%);
}

.appointment-day-page {
  color: #ffffff;
}

.appointment-day-shell {
  min-height: 100vh;
  display: grid;
  gap: 16px;
  align-content: start;
  width: min(100%, 760px);
  margin: 0 auto;
  padding: max(22px, env(safe-area-inset-top)) 18px max(28px, env(safe-area-inset-bottom) + 18px);
}

.appointment-day-card {
  display: grid;
  gap: 14px;
  padding: 20px 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 22px;
  background: rgba(19, 16, 24, 0.9);
  box-shadow: 0 24px 40px rgba(0, 0, 0, 0.22);
  backdrop-filter: blur(18px);
}

.appointment-day-eyebrow {
  margin: 0;
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.appointment-day-title {
  margin: 0;
  color: #ffffff;
  font-size: clamp(1.6rem, 7vw, 2.4rem);
  line-height: 1.04;
}

.appointment-day-copy,
.appointment-day-toolbar-copy,
.appointment-day-empty {
  margin: 0;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.92rem;
  line-height: 1.55;
}

.appointment-day-section-title {
  margin: 0;
  color: rgba(255, 255, 255, 0.86);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.appointment-day-auth-form,
.appointment-day-list,
.appointment-day-entry,
.appointment-day-entry-grid,
.appointment-day-dashboard {
  display: grid;
  gap: 14px;
}

.appointment-day-auth-form label {
  display: grid;
  gap: 8px;
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.84rem;
  font-weight: 600;
}

.appointment-day-auth-form input {
  width: 100%;
  min-height: 48px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.06);
  color: #ffffff;
  padding: 12px 14px;
  font: inherit;
}

.appointment-day-auth-form input::placeholder {
  color: rgba(255, 255, 255, 0.42);
}

.appointment-day-auth-form input:focus-visible {
  outline: 2px solid rgba(123, 0, 231, 0.46);
  outline-offset: 2px;
}

.appointment-day-primary,
.appointment-day-secondary {
  min-height: 46px;
  border-radius: 999px;
  border: 1px solid transparent;
  padding: 0 18px;
  font: inherit;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease,
    border-color 180ms ease,
    opacity 180ms ease;
}

.appointment-day-primary {
  background: linear-gradient(135deg, #7b00e7, #9c39ff);
  color: #ffffff;
  box-shadow: 0 16px 28px rgba(123, 0, 231, 0.28);
}

.appointment-day-secondary {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.14);
  color: #ffffff;
}

.appointment-day-primary:hover,
.appointment-day-primary:focus-visible,
.appointment-day-secondary:hover,
.appointment-day-secondary:focus-visible {
  transform: translateY(-1px);
  outline: none;
}

.appointment-day-primary:disabled,
.appointment-day-secondary:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.appointment-day-toolbar {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
  flex-wrap: wrap;
}

.appointment-day-toolbar-actions,
.appointment-day-entry-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.appointment-day-feedback {
  margin: 0;
  min-height: 1.25rem;
  color: rgba(255, 255, 255, 0.7);
  font-size: 0.86rem;
  line-height: 1.45;
}

.appointment-day-feedback.is-success {
  color: #8ef0bf;
}

.appointment-day-feedback.is-error {
  color: #ffb1c0;
}

.appointment-day-entry {
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.04);
}

.appointment-day-entry-topline,
.appointment-day-entry-row {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}

.appointment-day-entry-topline h2,
.appointment-day-entry-row strong {
  margin: 0;
  color: #ffffff;
  font-size: 0.95rem;
  font-weight: 700;
  text-align: right;
}

.appointment-day-entry-topline span,
.appointment-day-entry-row span {
  color: rgba(255, 255, 255, 0.62);
  font-size: 0.78rem;
  line-height: 1.45;
}

.appointment-day-entry-row-stack {
  display: grid;
}

.appointment-day-entry-row-stack strong {
  text-align: left;
}

.appointment-day-entry-row-highlight span,
.appointment-day-entry-row-highlight strong {
  color: #ffffff;
}

.appointment-day-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
}

.appointment-day-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.58);
  backdrop-filter: blur(4px);
}

.appointment-day-modal-card {
  position: relative;
  z-index: 1;
  width: min(calc(100% - 28px), 560px);
  max-height: calc(100vh - 40px);
  overflow: auto;
  margin: 20px auto;
  display: grid;
  gap: 16px;
  padding: 20px 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 24px;
  background: rgba(19, 16, 24, 0.96);
  box-shadow: 0 30px 52px rgba(0, 0, 0, 0.3);
}

.appointment-day-modal-topline {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 12px;
}

.appointment-day-modal-title {
  margin: 6px 0 0;
  color: #ffffff;
  font-size: 1.08rem;
  line-height: 1.2;
}

.appointment-day-modal-close {
  border: 0;
  background: rgba(255, 255, 255, 0.08);
  color: #ffffff;
  width: 38px;
  height: 38px;
  border-radius: 999px;
  font-size: 1.4rem;
  line-height: 1;
  cursor: pointer;
}

.appointment-day-modal-body,
.appointment-day-invoice-grid {
  display: grid;
  gap: 14px;
}

.appointment-day-edit-form,
.appointment-day-edit-addon-groups {
  display: grid;
  gap: 14px;
}

.appointment-day-edit-field {
  display: grid;
  gap: 8px;
}

.appointment-day-edit-field span {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.8rem;
  font-weight: 600;
}

.appointment-day-edit-field input,
.appointment-day-edit-field select {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.06);
  color: #ffffff;
  padding: 12px 14px;
  font: inherit;
}

.availability-day-shell {
  width: min(100%, 820px);
}

.availability-day-builder,
.availability-day-group {
  gap: 16px;
}

.availability-day-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.availability-day-delete {
  border-color: rgba(255, 113, 149, 0.28);
  color: #ffd6e1;
}

@media (max-width: 640px) {
  .availability-day-grid {
    grid-template-columns: 1fr;
  }

  .appointment-day-entry-topline,
  .appointment-day-entry-row {
    display: grid;
  }

  .appointment-day-entry-topline h2,
  .appointment-day-entry-row strong {
    text-align: left;
  }

  .appointment-day-toolbar-actions,
  .appointment-day-entry-actions {
    width: 100%;
  }

  .appointment-day-primary,
  .appointment-day-secondary {
    width: 100%;
  }
}

.hero-slideshow::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(
      circle at -6% 14%,
      rgba(92, 237, 170, 0.1) 0%,
      rgba(92, 237, 170, 0.07) 12%,
      rgba(16, 0, 31, 0.1) 32%,
      rgba(16, 0, 31, 0) 56%
    ),
    radial-gradient(
      circle at 108% 84%,
      rgba(92, 237, 170, 0.1) 0%,
      rgba(92, 237, 170, 0.07) 14%,
      rgba(16, 0, 31, 0.1) 34%,
      rgba(16, 0, 31, 0) 58%
    ),
    radial-gradient(
      circle at 92% -10%,
      rgba(92, 237, 170, 0.08) 0%,
      rgba(92, 237, 170, 0.05) 10%,
      rgba(16, 0, 31, 0.08) 28%,
      rgba(16, 0, 31, 0) 50%
    );
}

.hero-slide {
  position: absolute;
  inset: 0;
  background-repeat: no-repeat;
  background-size: cover;
  opacity: 0;
  transform: scale(1.03);
}

.hero-slide-1 {
  background-image:
    linear-gradient(90deg, rgba(5, 5, 6, 0.78) 0%, rgba(5, 5, 6, 0.42) 42%, rgba(5, 5, 6, 0.18) 100%),
    linear-gradient(180deg, rgba(5, 5, 6, 0.22), rgba(5, 5, 6, 0.44)),
    url("assets/background1.png");
  background-position: center center;
  animation: hero-fade-one 24s ease-in-out infinite;
}

.hero-slide-2 {
  background-image:
    linear-gradient(90deg, rgba(5, 5, 6, 0.8) 0%, rgba(5, 5, 6, 0.46) 42%, rgba(5, 5, 6, 0.2) 100%),
    linear-gradient(180deg, rgba(26, 8, 36, 0.18), rgba(5, 5, 6, 0.42)),
    url("assets/remyboho.png");
  background-position: 62% center;
  animation: hero-fade-two 24s ease-in-out infinite;
}

.hero-slide-3 {
  background-image:
    linear-gradient(90deg, rgba(5, 5, 6, 0.8) 0%, rgba(5, 5, 6, 0.44) 42%, rgba(5, 5, 6, 0.16) 100%),
    linear-gradient(180deg, rgba(14, 8, 24, 0.16), rgba(5, 5, 6, 0.46)),
    url("assets/Bbraids1.png");
  background-position: 70% center;
  animation: hero-fade-three 24s ease-in-out infinite;
}

@keyframes hero-fade-one {
  0%,
  30% {
    opacity: 1;
    transform: scale(1.08);
  }

  38%,
  92% {
    opacity: 0;
    transform: scale(1.1);
  }

  100% {
    opacity: 1;
    transform: scale(1.08);
  }
}

@keyframes hero-fade-two {
  0%,
  30% {
    opacity: 0;
    transform: scale(1.04);
  }

  38%,
  62% {
    opacity: 1;
    transform: scale(1.08);
  }

  70%,
  100% {
    opacity: 0;
    transform: scale(1.1);
  }
}

@keyframes hero-fade-three {
  0%,
  62% {
    opacity: 0;
    transform: scale(1.04);
  }

  70%,
  92% {
    opacity: 1;
    transform: scale(1.08);
  }

  100% {
    opacity: 0;
    transform: scale(1.1);
  }
}

.hero-overlay {
  position: absolute;
  inset: 0;
  background:
    linear-gradient(180deg, rgba(10, 8, 14, 0.08), rgba(10, 8, 14, 0.24)),
    radial-gradient(circle at center, transparent 28%, rgba(5, 5, 6, 0.28) 100%);
  transition: background 220ms ease, opacity 220ms ease;
}

body.contact-open .hero-overlay,
body.mobile-card-open .hero-overlay {
  background:
    linear-gradient(180deg, rgba(8, 8, 10, 0.34), rgba(8, 8, 10, 0.62)),
    radial-gradient(circle at center, rgba(24, 24, 28, 0.06) 12%, rgba(0, 0, 0, 0.48) 100%);
}

.hero-header,
.hero-content {
  position: relative;
  z-index: 1;
}

.hero-header {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 28px 34px 0;
}

.brand-mark {
  margin: 0;
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.admin-trigger {
  position: absolute;
  top: 30px;
  right: 34px;
  border: 0;
  background: transparent;
  padding: 0;
  color: rgba(255, 255, 255, 0.9);
  font: inherit;
  font-size: 0.74rem;
  font-weight: 400;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
}

.admin-trigger:hover,
.admin-trigger:focus-visible {
  color: #fff;
  outline: none;
}

.hero-content {
  min-height: calc(100vh - 72px);
  display: grid;
  grid-template-rows: 1fr auto auto;
  align-content: stretch;
  gap: 48px;
  padding: 34px 34px 26px;
}

.hero-content::before {
  content: "";
  position: absolute;
  inset: 6% 8% 10%;
  z-index: 0;
  border-radius: 32px;
  background:
    linear-gradient(180deg, rgba(176, 92, 255, 0.2), rgba(123, 0, 231, 0.08)),
    rgba(123, 0, 231, 0.16);
  border: 1px solid rgba(176, 92, 255, 0.24);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.12),
    0 28px 64px rgba(49, 0, 92, 0.22);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  pointer-events: none;
}

.hero-copy {
  max-width: 760px;
  align-self: center;
  justify-self: center;
  margin: 0 auto;
  text-align: center;
}

.hero-copy,
.menu-grid,
.hero-info-rail {
  position: relative;
  z-index: 1;
}

.hero-kicker {
  margin: 0 0 16px;
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.hero-title {
  margin: 0;
  max-width: 720px;
  color: #ffffff;
  font-size: clamp(1.3rem, 4.5vw, 2.4rem);
  font-weight: 600;
  line-height: 1.1;
  letter-spacing: 0;
}

.hero-subtitle {
  margin: 18px auto 0;
  max-width: 560px;
  color: rgba(255, 255, 255, 0.76);
  font-size: 0.92rem;
  line-height: 1.7;
}

.menu-grid {
  display: flex;
  flex-wrap: nowrap;
  gap: 8px;
  width: max-content;
  max-width: 100%;
  align-items: stretch;
  justify-content: center;
  justify-self: center;
  align-self: end;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: none;
}

.menu-grid::-webkit-scrollbar {
  display: none;
}

.hero-info-rail {
  width: min(980px, 100%);
  justify-self: center;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.hero-info-card {
  display: grid;
  gap: 8px;
  padding: 18px 18px 20px;
  border-radius: 22px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(18, 12, 23, 0.58), rgba(9, 8, 12, 0.42)),
    rgba(7, 7, 10, 0.2);
  box-shadow: 0 18px 36px rgba(0, 0, 0, 0.16);
  backdrop-filter: blur(12px);
}

.hero-info-label {
  color: rgba(255, 255, 255, 0.54);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
}

.hero-info-value {
  color: #ffffff;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1.2;
}

.hero-info-copy {
  color: rgba(255, 255, 255, 0.72);
  font-size: 0.78rem;
  line-height: 1.5;
}

@media (min-width: 901px) {
  .hero-content {
    min-height: calc(100vh - 84px);
    grid-template-columns: minmax(0, 1fr);
    grid-template-rows: minmax(0, 1fr) auto;
    align-items: end;
    column-gap: 0;
    row-gap: 18px;
    padding: 38px clamp(34px, 5vw, 74px) 36px;
    overflow: visible;
  }

  .hero-content::before {
    content: none;
  }

  .hero-content::after {
    content: "";
    position: absolute;
    inset: 16% auto auto 7%;
    width: clamp(120px, 11vw, 172px);
    height: clamp(120px, 11vw, 172px);
    border-radius: 999px;
    background:
      radial-gradient(circle at center, rgba(123, 0, 231, 0.16) 0%, rgba(123, 0, 231, 0.08) 34%, rgba(123, 0, 231, 0) 72%);
    filter: blur(10px);
    pointer-events: none;
    z-index: 0;
  }

  .hero-copy {
    width: 100%;
    max-width: 820px;
    justify-self: center;
    align-self: center;
    margin: 0 auto;
    padding: 0;
    text-align: center;
  }

  .hero-copy::before {
    content: "";
    display: block;
    width: clamp(82px, 7vw, 118px);
    height: 2px;
    margin-bottom: 28px;
    margin-left: auto;
    margin-right: auto;
    background: linear-gradient(90deg, rgba(123, 0, 231, 0.94), rgba(123, 0, 231, 0));
  }

  .hero-kicker {
    margin: 0 0 18px;
    color: rgba(255, 255, 255, 0.64);
    font-size: 0.68rem;
    font-weight: 600;
    letter-spacing: 0.34em;
  }

  .hero-title {
    font-size: clamp(4rem, 6vw, 6.8rem);
    line-height: 0.9;
    max-width: 760px;
    letter-spacing: -0.055em;
    text-wrap: balance;
    text-shadow: 0 20px 48px rgba(0, 0, 0, 0.24);
    margin-left: auto;
    margin-right: auto;
  }

  .hero-subtitle {
    margin: 26px 0 0;
    max-width: 360px;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.9rem;
    line-height: 1.7;
    margin-left: auto;
    margin-right: auto;
    text-align: center;
  }

  .menu-grid {
    grid-column: 1;
    grid-row: 2;
    width: min(980px, 100%);
    justify-self: center;
    justify-content: center;
    align-self: end;
    gap: 12px;
    padding: 0;
    border: 0;
    border-radius: 0;
    background: none;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    overflow-x: auto;
    overflow-y: visible;
  }

  .menu-grid::before {
    content: none;
  }

  .menu-card {
    flex-basis: 176px;
    width: 176px;
    min-height: 64px;
    padding: 12px 14px;
    border: 0;
    border-radius: 18px;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.7), rgba(255, 255, 255, 0.3)),
      rgba(248, 243, 238, 0.84);
    box-shadow:
      inset 0 0 0 1px rgba(92, 237, 170, 0.14),
      0 12px 24px rgba(0, 0, 0, 0.14);
  }

  .menu-card:hover,
  .menu-card:focus-visible {
    transform: translateY(-2px);
    box-shadow:
      inset 0 0 0 1px rgba(92, 237, 170, 0.24),
      0 18px 28px rgba(0, 0, 0, 0.16);
  }

  .menu-card-label {
    font-size: 0.78rem;
    letter-spacing: 0.12em;
  }

  .hero-info-label {
    color: rgba(255, 255, 255, 0.42);
    font-size: 0.58rem;
    letter-spacing: 0.18em;
  }

  .hero-info-value {
    font-size: 1rem;
    font-weight: 600;
  }

  .hero-info-copy {
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.74rem;
    line-height: 1.5;
  }
}

.site-footer {
  position: absolute;
  left: 50%;
  bottom: 18px;
  z-index: 2;
  transform: translateX(-50%);
  width: max-content;
  padding: 0 16px;
  text-align: center;
  pointer-events: none;
}

.site-footer-copy {
  margin: 0;
  color: rgba(255, 255, 255, 0.64);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.menu-card {
  flex: 0 0 180px;
  width: 180px;
  min-height: 68px;
  padding: 14px 16px;
  border: 1px solid rgba(92, 237, 170, 0.18);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.58), rgba(255, 255, 255, 0.18)),
    var(--card);
  color: #1c171d;
  text-align: left;
  font-size: 0.84rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.22);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  align-items: flex-start;
  transition:
    transform 180ms ease,
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease;
}

.menu-card-label {
  display: block;
}

.menu-card-meta {
  display: block;
  margin-top: 6px;
  color: rgba(28, 23, 29, 0.62);
  font-size: 0.62rem;
  font-weight: 500;
  letter-spacing: 0.08em;
  line-height: 1.45;
  text-transform: uppercase;
}

.menu-card-reveal {
  display: grid;
  gap: 18px;
  max-height: 0;
  margin-top: 0;
  opacity: 0;
  overflow: hidden;
  color: rgba(28, 23, 29, 0.72);
  font-size: 0.7rem;
  font-weight: 500;
  letter-spacing: 0.01em;
  line-height: 1.4;
  text-transform: none;
  transition:
    max-height 220ms ease,
    margin-top 220ms ease,
    opacity 180ms ease;
}

.contact-direct,
.contact-form-wrap {
  display: grid;
  gap: 8px;
  width: 100%;
  max-width: 100%;
}

.gallery-panel,
.gallery-grid,
.rewards-panel,
.rewards-form,
.rewards-profile,
.rewards-tier-list,
.about-panel,
.about-notes,
.policies-panel,
.policies-list {
  display: grid;
  width: 100%;
}

.gallery-panel {
  gap: 14px;
}

.rewards-panel {
  gap: 14px;
  min-height: 0;
}

.about-panel {
  gap: 14px;
}

.about-profile {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  align-items: center;
}

.about-profile-media {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  overflow: hidden;
  background: rgba(18, 15, 21, 0.08);
  box-shadow: inset 0 0 0 1px rgba(18, 15, 21, 0.06);
}

.about-profile-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.about-profile-main {
  display: grid;
  gap: 5px;
}

.about-profile-kicker {
  color: rgba(18, 15, 21, 0.48);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.about-profile-name {
  color: #120f15;
  font-size: 1rem;
  font-weight: 700;
  letter-spacing: 0.02em;
}

.about-profile-bio {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0.01em;
}

.about-profile-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.about-profile-stats span {
  display: grid;
  gap: 3px;
  min-height: 58px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: inset 0 0 0 1px rgba(18, 15, 21, 0.05);
  text-align: center;
}

.about-profile-stats strong {
  color: #120f15;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.about-profile-stats small {
  color: rgba(18, 15, 21, 0.54);
  font-size: 0.62rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.policies-panel {
  gap: 14px;
}

.about-copy {
  color: rgba(18, 15, 21, 0.7);
  font-size: 0.78rem;
  line-height: 1.6;
  text-transform: none;
  letter-spacing: 0.01em;
}

.rewards-copy,
.rewards-empty {
  color: rgba(18, 15, 21, 0.7);
  font-size: 0.78rem;
  line-height: 1.6;
  text-transform: none;
  letter-spacing: 0.01em;
}

.rewards-form {
  gap: 12px;
}

.rewards-form label {
  display: grid;
  gap: 6px;
}

.rewards-form label span {
  color: rgba(18, 15, 21, 0.74);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.rewards-form input {
  width: 100%;
  min-height: 48px;
  border: 1px solid rgba(18, 15, 21, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.76);
  color: #120f15;
  padding: 14px 16px;
  font: inherit;
  font-size: 0.82rem;
}

.rewards-form input:focus {
  outline: none;
  border-color: rgba(123, 0, 231, 0.32);
  box-shadow: 0 0 0 3px rgba(123, 0, 231, 0.08);
}

.rewards-submit {
  border: 0;
  border-radius: 999px;
  min-height: 46px;
  background: #161218;
  color: #fff;
  padding: 0 18px;
  font: inherit;
  font-size: 0.76rem;
  font-weight: 600;
  cursor: pointer;
}

.rewards-submit:hover,
.rewards-submit:focus-visible {
  background: #211827;
  outline: none;
}

.rewards-feedback {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.5;
}

.rewards-feedback.is-success {
  color: #1c6b46;
}

.rewards-feedback.is-error {
  color: #8d1a35;
}

.rewards-profile {
  min-height: 0;
  align-content: start;
  overflow-y: auto;
  padding-right: 4px;
}

.rewards-profile::-webkit-scrollbar {
  width: 6px;
}

.rewards-profile::-webkit-scrollbar-thumb {
  background: rgba(18, 15, 21, 0.18);
  border-radius: 999px;
}

.rewards-profile-card,
.rewards-tier {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.76);
}

.rewards-profile-topline {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.rewards-profile-name,
.rewards-profile-points,
.rewards-profile-code {
  color: #120f15;
  font-weight: 700;
}

.rewards-profile-name {
  font-size: 0.84rem;
}

.rewards-profile-points {
  color: #7b00e7;
  font-size: 0.78rem;
}

.rewards-profile-code-wrap {
  display: grid;
  gap: 6px;
}

.rewards-profile-code-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.rewards-profile-code-label {
  color: rgba(18, 15, 21, 0.6);
  font-size: 0.64rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.rewards-profile-code {
  font-size: 1rem;
  letter-spacing: 0.08em;
}

.rewards-copy-button,
.rewards-tier-action {
  border: 0;
  border-radius: 999px;
  min-height: 38px;
  padding: 0 14px;
  background: #161218;
  color: #fff;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}

.rewards-copy-button {
  min-height: 34px;
  background: rgba(18, 15, 21, 0.08);
  color: #120f15;
}

.rewards-profile-actions {
  display: flex;
  justify-content: flex-end;
}

.rewards-signout-button {
  border: 1px solid rgba(18, 15, 21, 0.1);
  border-radius: 999px;
  min-height: 36px;
  padding: 0 14px;
  background: rgba(18, 15, 21, 0.04);
  color: #120f15;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}

.rewards-stat-grid {
  display: grid;
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.rewards-stat-card,
.rewards-progress-card,
.rewards-history,
.rewards-history-item {
  display: grid;
  gap: 8px;
  width: 100%;
}

.rewards-stat-card,
.rewards-progress-card,
.rewards-history {
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.76);
}

.rewards-stat-card strong,
.rewards-progress-topline strong,
.rewards-history-title,
.rewards-history-copy strong {
  color: #120f15;
  font-size: 0.82rem;
  font-weight: 700;
}

.rewards-stat-card span,
.rewards-progress-topline span,
.rewards-history-copy span,
.rewards-history-empty {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.74rem;
  line-height: 1.5;
}

.rewards-progress-topline {
  display: grid;
  gap: 4px;
}

.rewards-progress-bar {
  position: relative;
  width: 100%;
  height: 10px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(18, 15, 21, 0.08);
}

.rewards-progress-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, #7b00e7, #b05cff);
}

.rewards-profile-note,
.rewards-tier span {
  color: rgba(18, 15, 21, 0.7);
  font-size: 0.76rem;
  line-height: 1.55;
}

.rewards-tier-list {
  gap: 10px;
}

.rewards-tier {
  align-content: start;
}

.rewards-tier strong {
  color: #7b00e7;
  font-size: 0.8rem;
  letter-spacing: 0.04em;
}

.rewards-tier-action {
  justify-self: start;
}

.rewards-copy-button:hover,
.rewards-copy-button:focus-visible,
.rewards-signout-button:hover,
.rewards-signout-button:focus-visible,
.rewards-tier-action:hover,
.rewards-tier-action:focus-visible {
  outline: none;
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(18, 15, 21, 0.08);
}

.rewards-tier-action:disabled {
  background: rgba(18, 15, 21, 0.08);
  color: rgba(18, 15, 21, 0.42);
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

.rewards-history-title {
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-size: 0.72rem;
}

.rewards-history-item {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  padding: 10px 0;
  border-top: 1px solid rgba(18, 15, 21, 0.08);
}

.rewards-history-item:first-of-type {
  border-top: 0;
  padding-top: 0;
}

.rewards-history-copy {
  display: grid;
  gap: 2px;
}

.rewards-history-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(18, 15, 21, 0.08);
  color: #120f15;
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.rewards-history-status.is-pending {
  background: rgba(123, 0, 231, 0.1);
  color: #7b00e7;
}

.rewards-history-status.is-fulfilled {
  background: rgba(4, 120, 87, 0.1);
  color: #047857;
}

.rewards-history-status.is-declined {
  background: rgba(180, 35, 24, 0.1);
  color: #b42318;
}

.about-notes {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.about-notes span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(18, 15, 21, 0.05);
  border: 1px solid rgba(18, 15, 21, 0.08);
  color: #120f15;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
}

.policies-copy {
  color: rgba(18, 15, 21, 0.7);
  font-size: 0.78rem;
  line-height: 1.6;
  text-transform: none;
  letter-spacing: 0.01em;
}

.policies-list {
  gap: 10px;
}

.policies-item {
  display: grid;
  gap: 4px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(18, 15, 21, 0.05);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.policies-item strong {
  color: #120f15;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.policies-item span {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
  line-height: 1.5;
}

.gallery-copy {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.78rem;
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0.01em;
}

.gallery-feedback,
.gallery-empty {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.76rem;
  line-height: 1.5;
}

.gallery-feedback:empty {
  display: none;
}

.gallery-feedback.is-error {
  color: #8d1a35;
}

.gallery-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.gallery-tile {
  position: relative;
  min-height: 260px;
  overflow: hidden;
  border-radius: 20px;
  background: rgba(18, 15, 21, 0.08);
  box-shadow: 0 16px 32px rgba(0, 0, 0, 0.12);
}

.gallery-tile img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  filter: saturate(1.02) contrast(1.02);
}

.gallery-tile::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(0, 0, 0, 0) 44%, rgba(0, 0, 0, 0.28) 100%);
  pointer-events: none;
}

.gallery-tile-feature {
  grid-column: span 1;
  grid-row: span 1;
}

.gallery-tile-wide {
  grid-column: span 1;
}

.gallery-tile-tall {
  grid-row: span 1;
}

.gallery-tile-label {
  position: absolute;
  left: 14px;
  bottom: 14px;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  max-width: calc(100% - 28px);
  padding: 8px 11px;
  border-radius: 999px;
  background: rgba(0, 0, 0, 0.88);
  color: #ffffff;
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  line-height: 1;
  text-transform: uppercase;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

@media (max-width: 1024px) and (min-width: 621px) {
  .gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }

  .gallery-tile {
    min-height: 220px;
  }
}

.services-panel,
.services-list,
.service-item {
  display: grid;
  width: 100%;
}

.services-panel {
  gap: 14px;
}

.services-browser,
.services-focus,
.services-focus-header,
.services-selected-detail {
  display: grid;
  gap: 14px;
  width: 100%;
}

.menu-card-services[data-services-view="browser"] .services-browser {
  display: grid !important;
}

.menu-card-services[data-services-view="browser"] .services-focus {
  display: none !important;
}

.menu-card-services[data-services-view="focus"] .services-browser {
  display: none !important;
}

.menu-card-services[data-services-view="focus"] .services-focus {
  display: grid !important;
}

.services-booking-summary {
  display: none;
  gap: 12px;
  align-content: start;
  padding: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.62);
}

.services-wizard-stage {
  position: relative;
  width: 100%;
  min-height: 620px;
}

.services-step {
  display: grid;
  gap: 14px;
  width: 100%;
  align-content: start;
  padding: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.5);
  min-height: 100%;
  max-height: 620px;
  overflow-y: auto;
}

.services-step-selected {
  gap: 10px;
  padding: 14px;
}

.services-wizard-stage .services-step[hidden] {
  display: none;
}

.services-wizard-stage .services-step {
  position: absolute;
  inset: 0;
  opacity: 0;
  transform: translateY(10px);
  pointer-events: none;
}

.services-wizard-stage .services-step.is-current,
.services-wizard-stage .services-step.is-entering,
.services-wizard-stage .services-step.is-exiting {
  display: grid;
}

.services-wizard-stage .services-step.is-current {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.services-wizard-stage.is-transitioning .services-step.is-entering {
  animation: servicesStepFadeIn 260ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

.services-wizard-stage.is-transitioning .services-step.is-exiting {
  animation: servicesStepFadeOut 260ms cubic-bezier(0.22, 1, 0.36, 1) forwards;
}

@keyframes servicesStepFadeIn {
  from {
    opacity: 0;
    transform: translateY(12px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
  }
}

@keyframes servicesStepFadeOut {
  from {
    opacity: 1;
    transform: translateY(0);
  }

  to {
    opacity: 0;
    transform: translateY(-10px);
  }
}

.services-step-label {
  color: rgba(18, 15, 21, 0.5);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.services-step-title {
  color: #120f15;
  font-size: 0.88rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.services-step.is-complete {
  border-color: rgba(123, 0, 231, 0.18);
  box-shadow: 0 12px 24px rgba(123, 0, 231, 0.06);
}

.services-booking-summary-eyebrow {
  color: rgba(18, 15, 21, 0.5);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.services-booking-summary-title {
  color: #120f15;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.35;
}

.services-booking-summary-section {
  display: grid;
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(18, 15, 21, 0.08);
}

.services-booking-summary-label {
  color: rgba(18, 15, 21, 0.56);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.services-booking-summary-copy,
.services-booking-summary-item-detail,
.services-booking-summary-footnote {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
  line-height: 1.55;
}

.services-booking-summary-copy {
  display: grid;
  gap: 4px;
}

.services-booking-summary-item {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
}

.services-booking-summary-item strong,
.services-booking-summary-copy strong {
  color: #120f15;
}

.services-step-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  width: 100%;
}

.services-step-button {
  min-height: 44px;
  border: 1px solid rgba(18, 15, 21, 0.1);
  border-radius: 999px;
  background: rgba(18, 15, 21, 0.04);
  color: #120f15;
  padding: 12px 18px;
  font: inherit;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease,
    opacity 180ms ease;
}

.services-step-button:hover,
.services-step-button:focus-visible {
  border-color: rgba(123, 0, 231, 0.2);
  background: rgba(255, 255, 255, 0.92);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(18, 15, 21, 0.08);
  outline: none;
}

.services-step-button:disabled {
  opacity: 0.42;
  cursor: not-allowed;
  transform: none;
  box-shadow: none;
}

.services-step-button-primary {
  background: #161218;
  border-color: transparent;
  color: #ffffff;
}

.services-step-button-primary:hover,
.services-step-button-primary:focus-visible {
  background: #7b00e7;
  border-color: transparent;
}

.services-panel-title {
  color: rgba(18, 15, 21, 0.86);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.services-list {
  gap: 12px;
}

.service-categories,
.service-category,
.service-category-panel {
  display: grid;
  width: 100%;
}

.service-category {
  gap: 0;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.56);
}

.service-category-trigger {
  width: 100%;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  border: 0;
  background: transparent;
  padding: 0;
  color: #120f15;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: left;
  cursor: pointer;
  transition:
    color 180ms ease,
    text-shadow 180ms ease;
}

.service-category-trigger:hover,
.service-category-trigger:focus-visible,
.service-category-trigger:active {
  color: #7b00e7;
  text-shadow: 0 0 18px rgba(123, 0, 231, 0.12);
  outline: none;
}

.service-category-symbol {
  color: #5cedaa;
  font-size: 1rem;
  line-height: 1;
  text-shadow: 0 0 10px rgba(92, 237, 170, 0.12);
  transition:
    transform 180ms ease,
    color 180ms ease;
}

.service-category.is-open .service-category-symbol {
  transform: rotate(45deg);
}

.service-category-panel {
  gap: 10px;
  max-height: 0;
  margin-top: 0;
  opacity: 0;
  overflow: hidden;
  transition:
    max-height 220ms ease,
    margin-top 220ms ease,
    opacity 180ms ease;
}

.service-category.is-open .service-category-panel {
  max-height: 1200px;
  margin-top: 14px;
  opacity: 1;
}

.service-option-row {
  display: grid;
  gap: 12px;
  width: 100%;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.76);
  padding: 12px 14px;
  overflow: hidden;
  color: rgba(18, 15, 21, 0.76);
  font-size: 0.82rem;
  line-height: 1.4;
  text-transform: none;
  text-align: left;
  cursor: pointer;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.service-option-row:hover,
.service-option-row:focus-visible,
.service-option-row:active {
  background: #7b00e7;
  border-color: #7b00e7;
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(18, 15, 21, 0.08);
  outline: none;
}

.service-option-row.is-selected {
  background: rgba(123, 0, 231, 0.08);
  border-color: rgba(123, 0, 231, 0.34);
  box-shadow: inset 0 0 0 1px rgba(123, 0, 231, 0.12);
}

.service-option-name {
  color: rgba(18, 15, 21, 0.82);
}

.service-category-coming-soon .service-category-panel {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.coming-soon-pill {
  display: inline-flex;
  align-items: center;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(123, 0, 231, 0.08);
  border: 1px solid rgba(123, 0, 231, 0.14);
  color: rgba(18, 15, 21, 0.82);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.services-selection {
  color: rgba(18, 15, 21, 0.82);
  font-size: 0.78rem;
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-config {
  display: grid;
  gap: 14px;
  width: 100%;
  padding: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.54);
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.78rem;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-availability,
.services-availability-grid,
.services-availability-card,
.services-customer,
.services-customer-form,
.services-deposit,
.services-deposit-summary {
  display: grid;
  width: 100%;
}

.services-availability {
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.54);
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.78rem;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0.01em;
}

.availability-calendar,
.availability-calendar-month,
.availability-calendar-weekdays,
.availability-calendar-grid {
  display: grid;
  width: 100%;
}

.availability-calendar {
  gap: 12px;
}

.availability-calendar-month {
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.7);
}

.availability-calendar-month-label {
  color: #120f15;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.availability-calendar-weekdays,
.availability-calendar-grid {
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 6px;
}

.availability-calendar-weekdays span {
  color: rgba(18, 15, 21, 0.54);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-align: center;
}

.calendar-day {
  min-height: 38px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  color: rgba(18, 15, 21, 0.36);
  font-size: 0.74rem;
  background: rgba(18, 15, 21, 0.03);
}

.calendar-day-empty {
  background: transparent;
}

.calendar-day-available {
  border: 1px solid rgba(18, 15, 21, 0.08);
  background: rgba(255, 255, 255, 0.9);
  color: rgba(18, 15, 21, 0.8);
  cursor: pointer;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.calendar-day-available:hover,
.calendar-day-available:focus-visible {
  background: rgba(255, 255, 255, 1);
  border-color: rgba(92, 237, 170, 0.28);
  transform: translateY(-1px);
  box-shadow: 0 8px 18px rgba(18, 15, 21, 0.08);
  outline: none;
}

.calendar-day-available.is-selected {
  background: rgba(92, 237, 170, 0.12);
  border-color: rgba(92, 237, 170, 0.45);
  box-shadow: 0 10px 20px rgba(92, 237, 170, 0.16);
}

.services-availability-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.services-availability-card {
  gap: 8px;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.78);
  color: rgba(18, 15, 21, 0.76);
  text-align: left;
  cursor: pointer;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.services-availability-card:hover,
.services-availability-card:focus-visible {
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(123, 0, 231, 0.18);
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(18, 15, 21, 0.08);
  outline: none;
}

.services-availability-card.is-selected {
  background: rgba(92, 237, 170, 0.12);
  border-color: rgba(92, 237, 170, 0.45);
  box-shadow: 0 12px 24px rgba(92, 237, 170, 0.16);
}

.services-availability-date {
  color: #120f15;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.services-availability-time {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.78rem;
}

.services-availability-note {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.5;
}

.services-availability-summary {
  color: rgba(18, 15, 21, 0.82);
  font-size: 0.78rem;
  line-height: 1.5;
}

.services-availability-summary strong {
  color: #120f15;
}

.services-customer {
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.58);
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.78rem;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-customer-note {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-customer-note strong {
  color: #120f15;
}

.services-customer-form {
  gap: 14px;
}

.services-customer-form label {
  display: grid;
  gap: 6px;
  width: 100%;
}

.services-returning-card {
  display: grid;
  width: 100%;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.76);
}

.services-customer-form label span {
  color: rgba(18, 15, 21, 0.74);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.services-customer-form input,
.services-customer-form textarea {
  width: 100%;
  min-height: 48px;
  border: 1px solid rgba(18, 15, 21, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.76);
  color: #120f15;
  padding: 14px 16px;
  font: inherit;
  font-size: 0.82rem;
}

.services-customer-form textarea {
  min-height: 110px;
  resize: vertical;
}

.services-customer-form input:focus,
.services-customer-form textarea:focus {
  outline: none;
  border-color: rgba(123, 0, 231, 0.32);
  box-shadow: 0 0 0 3px rgba(123, 0, 231, 0.08);
}

.services-intake-preview-list,
.services-turnstile-wrap {
  display: grid;
  gap: 12px;
}

.services-intake-preview-list {
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
}

.services-intake-preview-card {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background: rgba(255, 255, 255, 0.84);
}

.services-intake-preview-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.services-intake-remove {
  position: absolute;
  right: 10px;
  bottom: 10px;
  border: 0;
  border-radius: 999px;
  min-height: 32px;
  padding: 0 12px;
  background: rgba(18, 15, 21, 0.82);
  color: #fff;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  cursor: pointer;
}

.services-turnstile-wrap {
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.76);
}

.services-turnstile-wrap iframe {
  max-width: 100%;
}

.services-deposit {
  gap: 14px;
  padding: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.62);
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.78rem;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-deposit-note,
.services-deposit-footnote {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-deposit-note strong,
.services-deposit-footnote strong {
  color: #120f15;
}

.services-deposit-summary {
  gap: 8px;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.76);
}

.services-consent-card {
  display: grid;
  width: 100%;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.76);
}

.services-consent-control {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: flex-start;
}

.services-consent-control input {
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
  accent-color: #7b00e7;
}

.services-consent-copy {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-consent-copy strong {
  color: #120f15;
}

.services-deposit-line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
}

.services-deposit-line strong {
  color: #120f15;
  font-weight: 700;
}

.services-deposit-line-discount strong {
  color: #1c6b46;
}

.services-coupon-card {
  display: grid;
  gap: 10px;
  width: 100%;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background: rgba(255, 255, 255, 0.78);
}

.services-coupon-row {
  display: grid;
  gap: 10px;
  grid-template-columns: minmax(0, 1fr) auto;
}

.services-coupon-input {
  width: 100%;
  min-height: 46px;
  border: 1px solid rgba(18, 15, 21, 0.12);
  background: rgba(255, 255, 255, 0.92);
  color: #120f15;
  padding: 12px 14px;
  font: inherit;
  font-size: 0.82rem;
}

.services-coupon-input:focus-visible {
  outline: 2px solid rgba(123, 0, 231, 0.24);
  outline-offset: 2px;
}

.services-coupon-remove {
  grid-column: 1 / -1;
}

.services-coupon-applied,
.services-estimate-discount {
  color: #1c6b46;
  font-size: 0.76rem;
  line-height: 1.5;
}

.services-estimate-discount {
  display: inline-block;
  margin-left: 10px;
}

.services-deposit-button {
  border: 0;
  border-radius: 999px;
  background: #161218;
  color: #ffffff;
  padding: 14px 18px;
  font: inherit;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    opacity 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.services-deposit-button:hover,
.services-deposit-button:focus-visible {
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(18, 15, 21, 0.12);
  outline: none;
}

.services-deposit-checkout,
.services-deposit-methods,
.services-deposit-instructions {
  display: grid;
  gap: 12px;
  width: 100%;
}

.services-deposit-methods {
  grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
}

.services-deposit-method,
.services-deposit-method-link,
.services-deposit-secondary {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  border: 1px solid rgba(18, 15, 21, 0.1);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.76);
  color: #120f15;
  padding: 12px 14px;
  font: inherit;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  text-decoration: none;
  cursor: pointer;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.services-deposit-method {
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  gap: 6px;
}

.services-deposit-method small {
  color: rgba(18, 15, 21, 0.54);
  font-size: 0.68rem;
  letter-spacing: 0;
  text-transform: none;
  line-height: 1.4;
}

.services-deposit-method:hover,
.services-deposit-method:focus-visible,
.services-deposit-method-link:hover,
.services-deposit-method-link:focus-visible,
.services-deposit-secondary:hover,
.services-deposit-secondary:focus-visible {
  border-color: rgba(123, 0, 231, 0.2);
  background: rgba(255, 255, 255, 0.92);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(18, 15, 21, 0.08);
  outline: none;
}

.services-deposit-method.is-selected {
  border-color: rgba(123, 0, 231, 0.34);
  background: rgba(123, 0, 231, 0.08);
  box-shadow: 0 10px 20px rgba(123, 0, 231, 0.12);
}

.services-deposit-method.is-disabled {
  opacity: 0.52;
  cursor: not-allowed;
  box-shadow: none;
}

.services-deposit-reference {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.5;
}

.services-deposit-copy {
  margin: 0;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.78);
  color: #120f15;
  font: inherit;
  font-size: 0.76rem;
  line-height: 1.55;
  white-space: pre-wrap;
}

.services-deposit-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  width: 100%;
}

.services-deposit-actions-single {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.services-payment-trust,
.services-payment-powered,
.services-payment-brands,
.services-payment-brand {
  display: flex;
  align-items: center;
}

.services-payment-trust {
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 10px 14px;
  padding: 12px 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.74);
}

.services-payment-powered {
  gap: 10px;
  color: rgba(18, 15, 21, 0.76);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.services-payment-square-mark {
  width: 16px;
  height: 16px;
  border: 2px solid #120f15;
  border-radius: 4px;
  display: inline-block;
}

.services-payment-brands {
  flex-wrap: wrap;
  gap: 8px;
}

.services-payment-brand {
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(18, 15, 21, 0.06);
  color: #120f15;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.services-payment-brand-visa {
  color: #1434cb;
}

.services-payment-brand-mastercard {
  color: #231f20;
}

.services-payment-mastercard-mark {
  position: relative;
  width: 18px;
  height: 12px;
  display: inline-block;
}

.services-payment-mastercard-mark span {
  position: absolute;
  top: 0;
  width: 12px;
  height: 12px;
  border-radius: 999px;
}

.services-payment-mastercard-mark span:first-child {
  left: 0;
  background: #eb001b;
}

.services-payment-mastercard-mark span:last-child {
  right: 0;
  background: #f79e1b;
  opacity: 0.95;
}

.services-deposit-secondary {
  background: rgba(18, 15, 21, 0.04);
}

.services-deposit-feedback {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.5;
}

.services-deposit-feedback.is-success {
  color: #1c6b46;
}

.services-deposit-feedback.is-error {
  color: #8d1a35;
}

.services-confirmation,
.services-confirmation-summary,
.services-confirmation-list,
.services-confirmation-addons {
  display: grid;
  gap: 12px;
  width: 100%;
}

.services-confirmation {
  padding: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.62);
}

.services-confirmation-kicker {
  color: #120f15;
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.services-confirmation-copy,
.services-confirmation-note {
  color: rgba(18, 15, 21, 0.7);
  font-size: 0.78rem;
  line-height: 1.55;
  text-transform: none;
  letter-spacing: 0.01em;
}

.services-confirmation-copy strong,
.services-confirmation-note strong {
  color: #120f15;
}

.services-confirmation-summary,
.services-confirmation-list {
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.76);
}

.services-confirmation-line {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
}

.services-confirmation-line strong {
  color: #120f15;
  font-weight: 700;
  text-align: right;
}

.services-confirmation-feedback {
  color: rgba(18, 15, 21, 0.7);
  font-size: 0.76rem;
  line-height: 1.5;
}

.services-confirmation-feedback.is-success {
  color: #1c6b46;
}

.services-confirmation-feedback.is-error {
  color: #8d1a35;
}

.admin-coupon-active-toggle {
  width: 100%;
}

@media (max-width: 620px) {
  .services-coupon-row {
    grid-template-columns: 1fr;
  }
}

@media (min-width: 960px) {
  .services-focus {
    grid-template-columns: minmax(0, 1fr) 180px;
    grid-template-areas: "wizard summary";
    align-items: start;
  }

  .services-booking-summary {
    grid-area: summary;
    display: grid;
    position: sticky;
    top: 0;
    width: 180px;
    max-width: 180px;
    gap: 10px;
    padding: 12px;
  }

  .services-wizard-stage {
    grid-area: wizard;
    min-width: 0;
  }

  .services-booking-summary-title {
    font-size: 0.84rem;
  }

  .services-booking-summary-section {
    gap: 6px;
    padding-top: 10px;
  }

  .services-booking-summary-copy,
  .services-booking-summary-item-detail,
  .services-booking-summary-footnote,
  .services-booking-summary-item {
    font-size: 0.72rem;
  }
}

.services-config-header,
.services-config-group,
.services-config-options {
  display: grid;
  gap: 10px;
  width: 100%;
}

.services-config-title {
  color: #120f15;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.services-config-subtitle {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.74rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.services-config-estimate {
  color: rgba(18, 15, 21, 0.78);
  font-size: 0.76rem;
}

.services-config-estimate strong {
  color: #120f15;
}

.services-selected-next-available {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
  line-height: 1.5;
}

.services-selected-next-available strong {
  color: #120f15;
}

.services-config-options {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.services-config-option {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.76);
  color: rgba(18, 15, 21, 0.78);
  transition:
    border-color 180ms ease,
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.services-config-option:hover,
.services-config-option:focus-within,
.services-config-option:active {
  background: #7b00e7;
  border-color: #7b00e7;
  transform: translateY(-1px);
  box-shadow: 0 12px 24px rgba(18, 15, 21, 0.08);
}

.services-config-option input {
  accent-color: #7b00e7;
}

.services-config-option strong {
  color: #120f15;
  font-size: 0.76rem;
}

.services-config-note {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.55;
}

.services-config-color {
  display: grid;
  gap: 8px;
}

.services-config-color input {
  width: 100%;
  border: 1px solid rgba(18, 15, 21, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.82);
  color: #120f15;
  padding: 12px 14px;
  font: inherit;
  font-size: 0.8rem;
}

.services-config-color input:focus {
  outline: none;
  border-color: rgba(123, 0, 231, 0.28);
  box-shadow: 0 0 0 3px rgba(123, 0, 231, 0.08);
}

.services-selected-detail {
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.62);
}

.services-selected-name {
  color: #120f15;
  font-size: 0.9rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.services-selected-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.76rem;
}

.services-selected-meta strong {
  color: #120f15;
}

.services-selected-description {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.78rem;
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0.01em;
}

.service-item-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  color: #120f15;
  font-size: 0.76rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.service-item-top strong {
  font-size: 0.78rem;
  font-weight: 600;
}

.service-item-meta,
.services-panel-note {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.78rem;
  line-height: 1.5;
  text-transform: none;
  letter-spacing: 0.01em;
}

.contact-form-title {
  color: rgba(18, 15, 21, 0.86);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.contact-form {
  display: grid;
  gap: 14px;
  width: 100%;
  max-width: 100%;
}

.contact-honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}

.contact-form label {
  display: grid;
  gap: 6px;
  width: 100%;
  text-align: left;
}

.contact-form label span {
  color: rgba(18, 15, 21, 0.74);
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
  width: 100%;
  border: 1px solid rgba(18, 15, 21, 0.12);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.7);
  color: #120f15;
  padding: 14px 16px;
  font: inherit;
  font-size: 0.82rem;
  resize: none;
}

.contact-form input {
  min-height: 48px;
}

.contact-form select {
  min-height: 48px;
}

.contact-form textarea {
  min-height: 128px;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
  outline: none;
  border-color: rgba(123, 0, 231, 0.32);
  box-shadow: 0 0 0 3px rgba(123, 0, 231, 0.08);
}

.contact-form-copy {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.78rem;
  line-height: 1.55;
}

.waitlist-form-wrap {
  padding-top: 18px;
  border-top: 1px solid rgba(18, 15, 21, 0.08);
}

.contact-form label span small {
  font-size: 0.7em;
  letter-spacing: 0.04em;
  text-transform: none;
}

.contact-submit {
  border: 0;
  border-radius: 999px;
  background: #161218;
  color: #ffffff;
  padding: 12px 16px;
  margin-top: 8px;
  font: inherit;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    opacity 180ms ease,
    transform 180ms ease;
}

.contact-submit:disabled {
  opacity: 0.66;
  cursor: wait;
}

.contact-form-feedback {
  min-height: 16px;
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.72rem;
  line-height: 1.4;
  margin-bottom: 6px;
}

.contact-form-feedback.is-error {
  color: #8d1a35;
}

.contact-form-feedback.is-success {
  color: #1c6b46;
}

.menu-card-close {
  border: 0;
  background: transparent;
  padding: 0;
  max-height: 0;
  margin-top: 0;
  opacity: 0;
  overflow: hidden;
  color: rgba(28, 23, 29, 0.58);
  font-size: 0.64rem;
  font-weight: 500;
  letter-spacing: 0.02em;
  text-transform: none;
  cursor: pointer;
  transition:
    max-height 220ms ease,
    margin-top 220ms ease,
    opacity 180ms ease;
}

.menu-card:hover,
.menu-card:focus-visible {
  transform: translateY(-2px);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.3)),
    var(--card-hover);
  border-color: rgba(92, 237, 170, 0.34);
  box-shadow:
    0 18px 36px rgba(0, 0, 0, 0.28),
    0 0 0 1px rgba(92, 237, 170, 0.08);
}

.menu-card-primary {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.66), rgba(235, 225, 242, 0.88)),
    var(--card-strong);
  border-color: rgba(204, 180, 226, 0.54);
}

.menu-card-primary:hover,
.menu-card-primary:focus-visible {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(239, 230, 245, 0.96)),
    rgba(255, 248, 244, 0.98);
  border-color: rgba(214, 192, 234, 0.68);
}

.menu-card-contact {
  justify-content: flex-start;
}

.menu-card-contact.is-open,
.menu-card-about.is-open,
.menu-card-policies.is-open,
.menu-card-rewards.is-open,
.menu-card-services.is-open,
.menu-card-gallery.is-open,
.admin-overlay.is-open .admin-overlay-shell {
  position: fixed;
  top: 50%;
  left: 50%;
  z-index: 40;
  padding: 24px;
  border-radius: 24px;
  transform: translate(-50%, -50%);
  justify-content: center;
  background: #fcf8f4;
  border-color: rgba(255, 255, 255, 0.86);
  box-shadow: 0 38px 96px rgba(0, 0, 0, 0.26);
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
  isolation: isolate;
  max-height: calc(100vh - 40px);
  overflow-y: auto;
}

.menu-card-contact.is-open,
.menu-card-about.is-open,
.menu-card-policies.is-open,
.menu-card-rewards.is-open,
.menu-card-services.is-open,
.menu-card-gallery.is-open {
  width: min(440px, calc(100vw - 40px));
  min-height: 520px;
}

.admin-overlay {
  display: none;
}

.admin-overlay.is-open {
  display: block;
}

.admin-overlay.is-open .admin-overlay-shell {
  width: min(80vw, 1280px);
  min-height: 580px;
  align-items: stretch;
  justify-items: center;
  justify-content: flex-start;
  text-align: left;
}

.admin-overlay.is-open.is-locked .admin-overlay-shell {
  width: min(420px, calc(100vw - 40px));
  min-height: 420px;
  justify-items: center;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.menu-card-contact.is-open {
  align-items: center;
  justify-content: center;
  text-align: center;
}

.menu-card-about.is-open {
  align-items: stretch;
  justify-content: flex-start;
  text-align: left;
}

.menu-card-rewards.is-open {
  align-items: stretch;
  justify-content: flex-start;
  text-align: left;
}

.menu-card-policies.is-open {
  align-items: stretch;
  justify-content: flex-start;
  text-align: left;
}

.menu-card-services.is-open {
  align-items: stretch;
  justify-content: flex-start;
  text-align: left;
  overscroll-behavior: contain;
}

@media (min-width: 1025px) {
  .menu-card-services.is-open {
    width: min(1120px, calc(100vw - 56px));
    min-height: 620px;
  }
}

.menu-card-gallery.is-open {
  width: min(760px, calc(100vw - 40px));
  min-height: 560px;
  align-items: stretch;
  justify-content: flex-start;
  text-align: left;
}

.menu-card-services.is-open::-webkit-scrollbar {
  width: 8px;
}

.menu-card-services.is-open::-webkit-scrollbar-thumb {
  background: rgba(18, 15, 21, 0.18);
  border-radius: 999px;
}

.menu-card-contact.is-collapsing .menu-card-reveal,
.menu-card-contact.is-collapsing .menu-card-close,
.menu-card-about.is-collapsing .menu-card-reveal,
.menu-card-about.is-collapsing .menu-card-close,
.menu-card-rewards.is-collapsing .menu-card-reveal,
.menu-card-rewards.is-collapsing .menu-card-close,
.menu-card-policies.is-collapsing .menu-card-reveal,
.menu-card-policies.is-collapsing .menu-card-close,
.menu-card-gallery.is-collapsing .menu-card-reveal,
.menu-card-gallery.is-collapsing .menu-card-close,
.menu-card-services.is-collapsing .menu-card-reveal,
.menu-card-services.is-collapsing .menu-card-close {
  display: none;
}

.menu-card-contact.is-open .menu-card-reveal {
  max-height: 720px;
  margin-top: 16px;
  opacity: 1;
  width: 100%;
  justify-items: stretch;
}

.menu-card-services.is-open .menu-card-reveal {
  max-height: none;
  margin-top: 16px;
  opacity: 1;
  width: 100%;
  justify-items: stretch;
  overflow: visible;
}

.menu-card-gallery.is-open .menu-card-reveal {
  max-height: none;
  margin-top: 16px;
  opacity: 1;
  width: 100%;
  justify-items: stretch;
  overflow: visible;
}

.menu-card-about.is-open .menu-card-reveal {
  max-height: 720px;
  margin-top: 16px;
  opacity: 1;
  width: 100%;
  justify-items: stretch;
}

.menu-card-rewards.is-open .menu-card-reveal {
  max-height: 720px;
  margin-top: 16px;
  opacity: 1;
  width: 100%;
  justify-items: stretch;
  overflow-y: auto;
  overflow-x: hidden;
}

.menu-card-policies.is-open .menu-card-reveal {
  max-height: 720px;
  margin-top: 16px;
  opacity: 1;
  width: 100%;
  justify-items: stretch;
}

.menu-card-contact.is-open .menu-card-label {
  font-size: 0.9rem;
  color: #120f15;
}

.menu-card-services.is-open .menu-card-label {
  font-size: 0.9rem;
  color: #120f15;
}

.menu-card-gallery.is-open .menu-card-label {
  font-size: 0.9rem;
  color: #120f15;
}

.menu-card-about.is-open .menu-card-label {
  font-size: 0.9rem;
  color: #120f15;
}

.menu-card-rewards.is-open .menu-card-label {
  font-size: 0.9rem;
  color: #120f15;
}

.menu-card-policies.is-open .menu-card-label {
  font-size: 0.9rem;
  color: #120f15;
}

.menu-card-contact.is-open .menu-card-close,
.menu-card-about.is-open .menu-card-close,
.menu-card-rewards.is-open .menu-card-close,
.menu-card-policies.is-open .menu-card-close,
.menu-card-gallery.is-open .menu-card-close,
.menu-card-services.is-open .menu-card-close {
  max-height: 24px;
  margin-top: 28px;
  opacity: 1;
}

.menu-card-about.is-open .menu-card-close,
.menu-card-rewards.is-open .menu-card-close,
.menu-card-policies.is-open .menu-card-close,
.menu-card-gallery.is-open .menu-card-close,
.menu-card-services.is-open .menu-card-close {
  text-align: left;
}

.menu-card-contact.is-open .menu-card-reveal,
.menu-card-contact.is-open .menu-card-close,
.menu-card-about.is-open .menu-card-reveal,
.menu-card-about.is-open .menu-card-close,
.menu-card-rewards.is-open .menu-card-reveal,
.menu-card-rewards.is-open .menu-card-close,
.menu-card-policies.is-open .menu-card-reveal,
.menu-card-policies.is-open .menu-card-close,
.menu-card-gallery.is-open .menu-card-reveal,
.menu-card-gallery.is-open .menu-card-close,
.menu-card-services.is-open .menu-card-reveal,
.menu-card-services.is-open .menu-card-close {
  color: rgba(18, 15, 21, 0.76);
}

.admin-overlay-shell {
  display: grid;
  gap: 24px;
}

.admin-close {
  border: 0;
  background: transparent;
  padding: 0;
  color: rgba(18, 15, 21, 0.76);
  font: inherit;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  cursor: pointer;
  text-align: left;
}

.admin-close-icon {
  position: absolute;
  top: 18px;
  right: 18px;
  border: 0;
  background: transparent;
  padding: 0;
  color: rgba(18, 15, 21, 0.62);
  font: inherit;
  font-size: 1rem;
  font-weight: 500;
  line-height: 1;
  text-transform: none;
  cursor: pointer;
}

.admin-close-icon:hover,
.admin-close-icon:focus-visible {
  color: #120f15;
  outline: none;
}

.admin-panel,
.admin-panel-header,
.admin-auth,
.admin-dashboard,
.admin-calendar,
.admin-referrals,
.admin-rewards,
.admin-calendar-month,
.admin-calendar-weekdays,
.admin-calendar-grid,
.admin-bookings,
.admin-summary,
.admin-booking-card,
.admin-booking-grid,
.admin-referrals-panel,
.admin-referrals-header,
.admin-referrals-list,
.admin-referral-card,
.admin-rewards-panel,
.admin-rewards-header,
.admin-rewards-list,
.admin-reward-card {
  display: grid;
  gap: 14px;
}

.admin-panel {
  min-height: 100%;
  width: min(100%, 1040px);
  justify-self: center;
}

.admin-dashboard {
  min-height: 0;
  align-content: start;
}

@media (min-width: 1025px) {
  .admin-panel {
    width: 100%;
    max-width: none;
    grid-template-rows: auto minmax(0, 1fr);
  }

  .admin-panel-header {
    justify-items: center;
  }

  .admin-panel-header > * {
    width: 100%;
    max-width: none;
    justify-self: center;
  }

  .admin-dashboard {
    display: grid;
    grid-template-columns: minmax(300px, 360px) minmax(0, 1fr);
    grid-template-rows: auto auto minmax(0, 1fr);
    grid-template-areas:
      "toolbar toolbar"
      "search search"
      "calendar bookings";
    gap: 22px 26px;
    align-items: stretch;
    justify-items: stretch;
    min-height: 100%;
  }

  .admin-toolbar,
  .admin-toolbar-search,
  .admin-toolbar-overlays,
  .admin-calendar,
  .admin-bookings {
    width: 100%;
    max-width: none;
    justify-self: stretch;
  }

  .admin-toolbar {
    grid-area: toolbar;
  }

  .admin-toolbar-search {
    grid-area: search;
  }

  .admin-toolbar-overlays {
    grid-area: toolbar;
    align-self: start;
  }

  .admin-calendar {
    grid-area: calendar;
    position: sticky;
    top: 0;
    align-self: start;
  }

  .admin-bookings {
    grid-area: bookings;
    align-self: stretch;
    min-height: 100%;
    height: 100%;
    max-height: none;
    overflow: visible;
    padding-right: 0;
  }
}

.admin-summary {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-summary--bento {
  grid-template-columns: repeat(5, minmax(0, 1fr));
}

.admin-bento-grid {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  align-items: start;
}

.admin-bookings {
  align-content: start;
}

.admin-bento-grid-workflow,
.admin-bento-grid-records {
  align-content: start;
}

.admin-bento-span-12 {
  grid-column: span 12;
}

.admin-bento-span-8 {
  grid-column: span 8;
}

.admin-bento-span-7 {
  grid-column: span 7;
}

.admin-bento-span-6 {
  grid-column: span 6;
}

.admin-bento-span-5 {
  grid-column: span 5;
}

.admin-bento-span-4 {
  grid-column: span 4;
}

.admin-bento-feature {
  background:
    radial-gradient(circle at top left, rgba(123, 0, 231, 0.08), transparent 38%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(247, 241, 251, 0.9));
  box-shadow: 0 18px 30px rgba(18, 15, 21, 0.08);
}

.admin-sales-report,
.admin-sales-report-grid,
.admin-sales-report-filters {
  display: grid;
  gap: 12px;
}

.admin-sales-report-filters {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-sales-month-select-wrap {
  grid-column: 1 / -1;
}

.admin-sales-month-select {
  width: 100%;
  min-height: 44px;
  border: 1px solid rgba(18, 15, 21, 0.1);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.82);
  color: #120f15;
  padding: 0 14px;
  font: inherit;
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.04em;
}

.admin-sales-month-select:focus-visible {
  outline: 2px solid rgba(123, 0, 231, 0.24);
  outline-offset: 2px;
}

.admin-sales-report-grid {
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.admin-traffic-grid {
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
}

.admin-sales-report-card {
  min-height: 100%;
}

.admin-traffic-rates {
  display: grid;
  gap: 12px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.admin-traffic-rate {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-traffic-rate strong {
  color: #120f15;
  font-size: 1rem;
  font-weight: 700;
}

.admin-traffic-rate span {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.72rem;
  line-height: 1.45;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.admin-traffic-breakdown-grid {
  display: grid;
  gap: 14px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

.admin-traffic-breakdown-list {
  display: grid;
  gap: 10px;
}

.admin-traffic-breakdown-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-traffic-breakdown-row:first-child {
  padding-top: 0;
  border-top: 0;
}

.admin-traffic-breakdown-row span {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.78rem;
  line-height: 1.5;
}

.admin-traffic-breakdown-row strong {
  color: #120f15;
  font-size: 0.78rem;
  font-weight: 700;
  text-align: right;
  line-height: 1.45;
}

.admin-sales-filter {
  border: 1px solid rgba(18, 15, 21, 0.1);
  border-radius: 999px;
  min-height: 40px;
  padding: 0 14px;
  background: rgba(255, 255, 255, 0.82);
  color: #120f15;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    border-color 180ms ease,
    background 180ms ease,
    color 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.admin-sales-filter:hover,
.admin-sales-filter:focus-visible {
  outline: none;
  border-color: rgba(123, 0, 231, 0.28);
  background: rgba(255, 255, 255, 0.94);
  transform: translateY(-1px);
  box-shadow: 0 10px 20px rgba(18, 15, 21, 0.08);
}

.admin-sales-filter.is-active {
  border-color: rgba(123, 0, 231, 0.4);
  background: rgba(123, 0, 231, 0.1);
  color: #7b00e7;
  box-shadow: inset 0 0 0 1px rgba(123, 0, 231, 0.08);
}

.admin-availability-draft-list {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.admin-availability-draft-chip {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-height: 40px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-availability-draft-chip strong {
  color: #120f15;
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.admin-availability-draft-remove {
  border: 0;
  background: transparent;
  color: rgba(18, 15, 21, 0.56);
  padding: 0;
  font: inherit;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
}

.admin-availability-draft-remove:hover,
.admin-availability-draft-remove:focus-visible {
  color: #120f15;
  outline: none;
}

.admin-summary-card {
  display: grid;
  gap: 6px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-summary-card strong {
  color: #120f15;
  font-size: 1.2rem;
  font-weight: 700;
}

.admin-summary-card span {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.7rem;
  line-height: 1.4;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.admin-panel-copy,
.admin-auth-copy,
.admin-booking-empty,
.admin-booking-meta,
.admin-booking-note,
.admin-auth-feedback {
  color: rgba(18, 15, 21, 0.66);
  font-size: 0.76rem;
  line-height: 1.6;
}

.admin-auth-feedback:empty {
  display: none !important;
}

.admin-auth-form {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}

.admin-auth-form label {
  display: block;
}

.admin-auth-form input {
  min-height: 46px;
  border-radius: 12px;
  border: 1px solid rgba(18, 15, 21, 0.1);
  background: rgba(255, 255, 255, 0.84);
  padding: 0 14px;
  font: inherit;
  color: #120f15;
  text-align: center;
  font-size: 1rem;
}

.admin-auth-submit,
.admin-toolbar-button,
.admin-booking-release {
  border: 0;
  border-radius: 999px;
  min-height: 44px;
  padding: 0 18px;
  background: #161218;
  color: #fff;
  font: inherit;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}

.admin-toolbar {
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-wrap: wrap;
}

.admin-toolbar-search,
.admin-toolbar-overlays {
  width: 100%;
}

.admin-toolbar-search {
  display: grid;
  gap: 10px;
}

.admin-client-search-toolbar {
  padding: 14px 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(18, 15, 21, 0.08);
  box-shadow: 0 16px 38px rgba(18, 15, 21, 0.08);
}

.admin-search-results-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.86);
  border: 1px solid rgba(18, 15, 21, 0.08);
  box-shadow: 0 18px 40px rgba(18, 15, 21, 0.08);
}

.admin-search-result-card {
  width: 100%;
  border: 0;
  text-align: left;
  cursor: pointer;
}

.admin-search-result-card:hover,
.admin-search-result-card:focus-visible {
  box-shadow: 0 18px 42px rgba(123, 0, 231, 0.12);
  outline: none;
  transform: translateY(-1px);
}

.admin-search-results-header {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  color: rgba(18, 15, 21, 0.66);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-search-results-header strong {
  color: #120f15;
  font-size: 1rem;
  letter-spacing: 0.04em;
}

.admin-toolbar-overlays {
  position: relative;
  z-index: 20;
  pointer-events: none;
}

.admin-notifications-drawer {
  position: absolute;
  top: 0;
  right: 0;
  width: min(100%, 420px);
  pointer-events: none;
  opacity: 0;
  transform: translateY(-6px);
  transition: opacity 160ms ease, transform 160ms ease;
}

.admin-notifications-drawer.is-open {
  pointer-events: auto;
  opacity: 1;
  transform: translateY(0);
}

.admin-notifications-drawer-panel {
  margin-top: 58px;
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(18, 15, 21, 0.08);
  box-shadow: 0 26px 54px rgba(18, 15, 21, 0.18);
  pointer-events: auto;
}

.admin-notifications-drawer-header,
.admin-notifications-drawer-actions {
  display: flex;
  align-items: center;
  gap: 10px;
}

.admin-notifications-drawer-header {
  justify-content: space-between;
}

.admin-notifications-drawer-header strong {
  color: #120f15;
  font-size: 1rem;
}

.admin-notifications-drawer-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}

.admin-toolbar-button-icon {
  position: relative;
  min-width: 48px;
  padding-inline: 14px;
}

.admin-toolbar-bell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  font-size: 0;
}

.admin-toolbar-bell::before {
  content: "🔔";
  font-size: 1rem;
  line-height: 1;
}

.admin-toolbar-badge {
  position: absolute;
  top: -5px;
  right: -4px;
  min-width: 22px;
  height: 22px;
  padding: 0 6px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #e11d48;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.02em;
  box-shadow: 0 10px 18px rgba(225, 29, 72, 0.26);
}

.admin-toolbar-button-icon.is-alert {
  background: rgba(225, 29, 72, 0.1);
  color: #9f1239;
  box-shadow: inset 0 0 0 1px rgba(225, 29, 72, 0.16);
}

.admin-toolbar-button-muted {
  background: rgba(18, 15, 21, 0.08);
  color: #120f15;
}

.admin-dashboard-feedback {
  display: block;
  padding: 12px 14px;
  border-radius: 14px;
  background: rgba(18, 15, 21, 0.06);
  color: rgba(18, 15, 21, 0.74);
  font-size: 0.76rem;
  line-height: 1.5;
}

.admin-dashboard-feedback.is-success {
  background: rgba(4, 120, 87, 0.1);
  color: #047857;
}

.admin-dashboard-feedback.is-error {
  background: rgba(180, 35, 24, 0.1);
  color: #b42318;
}

.admin-booking-confirm {
  background: #7b00e7;
  color: #fff;
}

.admin-booking-secondary {
  background: rgba(18, 15, 21, 0.08);
  color: #120f15;
}

.admin-booking-cancel {
  background: #8f1d1d;
  color: #fff;
}

.admin-referrals-panel {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-referrals-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.admin-referrals-empty {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.76rem;
  line-height: 1.5;
}

.admin-referral-card {
  padding: 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-referral-points {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(123, 0, 231, 0.1);
  color: #7b00e7;
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-referral-adjust {
  background: #161218;
}

.admin-gallery-manager,
.admin-gallery-header,
.admin-gallery-actions,
.admin-gallery-grid {
  display: grid;
  gap: 12px;
}

.admin-gallery-manager {
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-gallery-upload {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  background: #161218;
  color: #fff;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  overflow: hidden;
}

.admin-gallery-upload input {
  position: absolute;
  inset: 0;
  opacity: 0;
  cursor: pointer;
}

.admin-gallery-hint,
.admin-gallery-empty,
.admin-gallery-feedback {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.74rem;
  line-height: 1.5;
}

.admin-gallery-feedback:empty {
  display: none;
}

.admin-gallery-feedback.is-error {
  color: #8d1a35;
}

.admin-gallery-feedback.is-success {
  color: #1c6b46;
}

.admin-gallery-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.admin-gallery-item {
  display: grid;
  gap: 10px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-gallery-item img {
  width: 100%;
  aspect-ratio: 3 / 4;
  object-fit: cover;
  border-radius: 12px;
  display: block;
}

.admin-gallery-delete {
  border: 1px solid rgba(18, 15, 21, 0.1);
  border-radius: 999px;
  min-height: 38px;
  background: rgba(18, 15, 21, 0.04);
  color: #120f15;
  font: inherit;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
}

.admin-calendar {
  gap: 16px;
}

.admin-calendar-empty {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.76rem;
  line-height: 1.5;
}

.admin-calendar-note {
  color: rgba(18, 15, 21, 0.66);
  font-size: 0.74rem;
  line-height: 1.5;
}

.admin-calendar-action-panel {
  display: grid;
  gap: 12px;
}

.admin-calendar-action-buttons {
  justify-content: flex-start;
}

.admin-calendar-modal-shell {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(18, 15, 21, 0.42);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.admin-calendar-modal-backdrop {
  position: absolute;
  inset: 0;
}

.admin-calendar-modal {
  position: relative;
  z-index: 1;
  width: min(720px, 100%);
  max-height: min(82vh, 920px);
  overflow-y: auto;
  display: grid;
  gap: 16px;
  padding: 22px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.96);
  border: 1px solid rgba(18, 15, 21, 0.08);
  box-shadow: 0 24px 70px rgba(18, 15, 21, 0.22);
}

.admin-calendar-modal-copy {
  color: rgba(18, 15, 21, 0.66);
  font-size: 0.78rem;
  line-height: 1.55;
}

.admin-calendar-modal-close {
  min-height: 38px;
  border: 0;
  background: rgba(18, 15, 21, 0.06);
  color: #120f15;
  padding: 0 14px;
  border-radius: 999px;
  font: inherit;
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  transition:
    background 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease;
}

.admin-calendar-modal-close:hover,
.admin-calendar-modal-close:focus-visible {
  background: rgba(18, 15, 21, 0.1);
  transform: translateY(-1px);
  box-shadow: 0 10px 18px rgba(18, 15, 21, 0.08);
  outline: none;
}

.admin-invoice-editor-modal {
  width: min(820px, 100%);
}

.admin-invoice-tax-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 52px;
}

.admin-invoice-tax-toggle input {
  width: 18px;
  height: 18px;
  accent-color: #7b00e7;
}

.admin-invoice-item-row {
  display: grid;
  grid-template-columns: minmax(0, 1.8fr) minmax(120px, 0.8fr) auto;
  gap: 12px;
  align-items: end;
}

.admin-invoice-item-row .admin-booking-reschedule-label {
  margin: 0;
}

@media (max-width: 720px) {
  .admin-invoice-item-row {
    grid-template-columns: 1fr;
  }
}

.admin-shop-preview-shell {
  position: fixed;
  inset: 0;
  z-index: 85;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(18, 15, 21, 0.48);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

.admin-shop-preview-modal {
  width: min(1240px, 100%);
  max-height: min(88vh, 980px);
  overflow-y: auto;
  display: grid;
  gap: 22px;
  padding: 28px;
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.99), rgba(247, 241, 251, 0.98)),
    rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(18, 15, 21, 0.08);
  box-shadow: 0 28px 80px rgba(18, 15, 21, 0.24);
}

.admin-shop-preview-header,
.admin-shop-preview-grid,
.admin-shop-preview-card,
.admin-shop-preview-details,
.admin-shop-preview-layout,
.admin-shop-preview-sidebar,
.admin-shop-preview-catalog,
.admin-shop-preview-summary-grid,
.admin-shop-preview-toolbar,
.admin-shop-preview-filters,
.admin-shop-preview-spotlight,
.admin-shop-preview-card-copy,
.admin-shop-preview-header-copy,
.admin-shop-preview-header-actions,
.admin-shop-preview-spotlight-copy,
.admin-shop-preview-details-panel {
  display: grid;
  gap: 14px;
}

.admin-shop-preview-header {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 18px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-shop-preview-header-copy {
  gap: 10px;
}

.admin-shop-preview-header-actions {
  grid-auto-flow: column;
  align-content: start;
  gap: 10px;
}

.admin-shop-preview-kicker,
.admin-shop-preview-group-title {
  color: #120f15;
  font-size: 0.76rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.admin-shop-preview-kicker {
  color: rgba(123, 0, 231, 0.78);
}

.admin-shop-preview-summary-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.admin-shop-summary-card {
  gap: 8px;
  min-height: 112px;
  justify-content: center;
}

.admin-shop-summary-card strong {
  font-size: 1.3rem;
}

.admin-shop-preview-toolbar {
  grid-template-columns: minmax(0, 1fr) minmax(260px, 320px);
  gap: 18px;
  align-items: start;
}

.admin-shop-preview-filters {
  grid-template-columns: repeat(auto-fit, minmax(150px, max-content));
  gap: 10px;
}

.admin-shop-filter-chip {
  min-width: 0;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background: rgba(255, 255, 255, 0.84);
  color: #120f15;
  font: inherit;
  cursor: pointer;
  transition:
    border-color 180ms ease,
    transform 180ms ease,
    box-shadow 180ms ease,
    background 180ms ease;
}

.admin-shop-filter-chip span,
.admin-shop-filter-chip strong {
  font-size: 0.76rem;
}

.admin-shop-filter-chip strong {
  color: rgba(18, 15, 21, 0.56);
  font-weight: 700;
}

.admin-shop-filter-chip:hover,
.admin-shop-filter-chip:focus-visible,
.admin-shop-filter-chip.is-active {
  border-color: rgba(123, 0, 231, 0.2);
  background: rgba(123, 0, 231, 0.08);
  box-shadow: 0 14px 26px rgba(123, 0, 231, 0.08);
  transform: translateY(-1px);
  outline: none;
}

.admin-shop-preview-search {
  display: grid;
  gap: 8px;
}

.admin-shop-preview-layout {
  grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
  align-items: start;
  gap: 22px;
}

.admin-shop-preview-catalog,
.admin-shop-preview-sidebar {
  align-content: start;
}

.admin-shop-preview-grid {
  grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
  align-content: start;
}

.admin-shop-preview-card {
  align-content: start;
  padding: 18px;
  border-radius: 20px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(247, 241, 251, 0.88)),
    rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 34px rgba(18, 15, 21, 0.08);
}

.admin-shop-preview-card-button {
  width: 100%;
  text-align: left;
  cursor: pointer;
  transition:
    transform 180ms ease,
    box-shadow 180ms ease,
    border-color 180ms ease;
}

.admin-shop-preview-card-button:hover,
.admin-shop-preview-card-button:focus-visible,
.admin-shop-preview-card-button.is-active {
  transform: translateY(-2px);
  border-color: rgba(123, 0, 231, 0.18);
  box-shadow: 0 20px 36px rgba(123, 0, 231, 0.12);
  outline: none;
}

.admin-shop-preview-card-copy {
  align-content: start;
}

.admin-shop-preview-topline {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.admin-shop-preview-name {
  color: #120f15;
  font-size: 0.92rem;
  font-weight: 700;
  line-height: 1.35;
}

.admin-shop-preview-copy {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.78rem;
  line-height: 1.6;
}

.admin-shop-preview-card-tags,
.admin-shop-preview-card-meta,
.admin-shop-preview-spotlight-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.admin-shop-preview-card-tags span,
.admin-shop-preview-card-meta span,
.admin-shop-preview-spotlight-tags span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(18, 15, 21, 0.05);
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
}

.admin-shop-preview-media-empty {
  display: grid;
  place-items: center;
  min-height: 180px;
  padding: 18px;
  border-radius: 18px;
  border: 1px dashed rgba(18, 15, 21, 0.12);
  background: rgba(18, 15, 21, 0.03);
  color: rgba(18, 15, 21, 0.48);
  font-size: 0.76rem;
  text-align: center;
}

.admin-shop-preview-spotlight {
  padding: 20px;
  border-radius: 24px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background:
    radial-gradient(circle at top left, rgba(123, 0, 231, 0.08), transparent 42%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(247, 241, 251, 0.94));
  box-shadow: 0 22px 44px rgba(18, 15, 21, 0.08);
}

.admin-shop-preview-spotlight-copy {
  align-content: start;
}

.admin-shop-preview-spotlight-media {
  display: block;
}

.admin-shop-preview-spotlight-media .admin-product-media-preview {
  border-radius: 22px;
}

.admin-shop-preview-details-panel {
  padding: 20px;
  border-radius: 22px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background: rgba(255, 255, 255, 0.9);
}

.admin-shop-preview-details-panel-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.admin-shop-preview-details {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 14px;
}

.admin-shop-preview-details span {
  display: grid;
  gap: 4px;
}

.admin-shop-preview-details strong {
  color: rgba(18, 15, 21, 0.54);
  font-size: 0.62rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.admin-shop-preview-details span span {
  color: #120f15;
  font-size: 0.78rem;
  line-height: 1.45;
}

.admin-product-media-preview-card {
  overflow: hidden;
  border-radius: 18px;
}

.admin-product-media-preview-card img,
.admin-product-media-preview-card video,
.admin-shop-preview-spotlight-media img,
.admin-shop-preview-spotlight-media video {
  width: 100%;
  max-height: 280px;
  object-fit: cover;
  display: block;
}

@media (max-width: 980px) {
  .admin-shop-preview-summary-grid,
  .admin-shop-preview-toolbar,
  .admin-shop-preview-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .admin-shop-preview-modal {
    padding: 20px;
  }

  .admin-shop-preview-header {
    grid-template-columns: 1fr;
  }

  .admin-shop-preview-header-actions {
    grid-auto-flow: row;
  }

  .admin-shop-preview-summary-grid,
  .admin-shop-preview-details {
    grid-template-columns: 1fr;
  }

  .admin-shop-preview-grid {
    grid-template-columns: 1fr;
  }
}

.admin-calendar-month {
  gap: 12px;
  padding: 16px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-calendar-month-label {
  color: #120f15;
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-calendar-weekdays,
.admin-calendar-grid {
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
}

.admin-calendar-weekdays span {
  color: rgba(18, 15, 21, 0.5);
  font-size: 0.64rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  text-align: center;
}

.admin-calendar-day {
  min-height: 44px;
  display: grid;
  place-items: center;
  gap: 2px;
  padding: 6px;
  border: 0;
  border-radius: 12px;
  background: rgba(18, 15, 21, 0.04);
  color: rgba(18, 15, 21, 0.72);
  font: inherit;
  text-align: center;
}

button.admin-calendar-day {
  cursor: pointer;
  transition:
    background 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

button.admin-calendar-day:hover,
button.admin-calendar-day:focus-visible {
  background: rgba(123, 0, 231, 0.08);
  box-shadow: inset 0 0 0 1px rgba(123, 0, 231, 0.16);
  transform: translateY(-1px);
  outline: none;
}

.admin-calendar-day-empty {
  background: transparent;
}

.admin-calendar-day.is-booked {
  background: rgba(92, 237, 170, 0.22);
  color: #0f3b2d;
  box-shadow: inset 0 0 0 1px rgba(92, 237, 170, 0.4);
}

.admin-calendar-day.is-blocked {
  background: rgba(214, 54, 56, 0.88);
  color: #fff;
  box-shadow: inset 0 0 0 1px rgba(160, 16, 18, 0.42);
}

.admin-calendar-day.is-booked.is-blocked {
  background: rgba(214, 54, 56, 0.9);
  color: #fff;
}

.admin-calendar-day.is-unavailable {
  background: rgba(18, 15, 21, 0.06);
  color: rgba(18, 15, 21, 0.34);
  box-shadow: inset 0 0 0 1px rgba(18, 15, 21, 0.04);
}

.admin-calendar-day-number {
  font-size: 0.78rem;
  font-weight: 600;
  line-height: 1;
}

.admin-calendar-day-count {
  font-size: 0.58rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  line-height: 1;
}

.admin-calendar-day-status {
  font-size: 0.5rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  line-height: 1.1;
}

.admin-rewards-panel {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-rewards-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.admin-rewards-empty {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.76rem;
  line-height: 1.5;
}

.admin-reward-card {
  padding: 16px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-reward-topline {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.admin-reward-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(18, 15, 21, 0.08);
  color: #120f15;
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-reward-status.is-pending {
  background: rgba(123, 0, 231, 0.1);
  color: #7b00e7;
}

.admin-reward-status.is-fulfilled {
  background: rgba(4, 120, 87, 0.1);
  color: #047857;
}

.admin-reward-status.is-declined {
  background: rgba(180, 35, 24, 0.1);
  color: #b42318;
}

.admin-reward-approve {
  background: #161218;
}

.admin-reward-decline {
  background: rgba(18, 15, 21, 0.08);
  color: #120f15;
}

.admin-bookings {
  max-height: 420px;
  overflow-y: auto;
  padding-right: 4px;
}

.admin-archive-list {
  display: grid;
  gap: 12px;
}

.admin-archive-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-summary-card-action {
  width: 100%;
  text-align: left;
  cursor: pointer;
  font: inherit;
}

.admin-summary-card-action:hover,
.admin-summary-card-action:focus-visible {
  outline: none;
  border-color: rgba(123, 0, 231, 0.24);
  box-shadow: inset 0 0 0 1px rgba(123, 0, 231, 0.12);
}

.admin-booking-card {
  padding: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(18, 15, 21, 0.08);
}

@media (min-width: 1025px) {
  .admin-archive-list-appointments {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: start;
  }

  .admin-archive-list-appointments > .admin-booking-card,
  .admin-archive-list-appointments > .admin-archive-card {
    min-width: 0;
  }

  .admin-archive-list-appointments > .admin-booking-card.is-expanded,
  .admin-archive-list-appointments > .admin-archive-card.is-expanded {
    grid-column: span 2;
  }

  .admin-archive-list-appointments > .admin-booking-card:not(.is-expanded) .admin-client-record-toggle,
  .admin-archive-list-appointments > .admin-archive-card:not(.is-expanded) .admin-client-record-toggle {
    width: 100%;
  }

  .admin-archive-list-appointments > .admin-booking-card:not(.is-expanded) .admin-booking-topline,
  .admin-archive-list-appointments > .admin-archive-card:not(.is-expanded) .admin-booking-topline {
    display: grid;
    gap: 10px;
    justify-items: start;
    align-items: start;
  }

  .admin-archive-list-appointments > .admin-booking-card:not(.is-expanded) .admin-booking-title,
  .admin-archive-list-appointments > .admin-archive-card:not(.is-expanded) .admin-booking-title {
    display: block;
    width: 100%;
    line-height: 1.45;
    white-space: normal;
    overflow-wrap: anywhere;
  }

  .admin-archive-list-appointments > .admin-booking-card:not(.is-expanded) .admin-booking-status,
  .admin-archive-list-appointments > .admin-archive-card:not(.is-expanded) .admin-booking-status {
    justify-self: start;
    max-width: 100%;
  }
}

.admin-collapsible-section {
  gap: 0;
}

.admin-section-toggle {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.admin-section-toggle-static {
  cursor: default;
}

.admin-section-toggle:focus-visible {
  outline: 2px solid rgba(123, 0, 231, 0.4);
  outline-offset: 6px;
}

.admin-section-toggle-copy {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-width: 0;
  flex: 1;
}

.admin-section-toggle-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: rgba(18, 15, 21, 0.06);
  color: rgba(18, 15, 21, 0.72);
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  flex: 0 0 auto;
}

.admin-collapsible-section-body {
  display: grid;
  gap: 12px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-client-search {
  display: grid;
  gap: 8px;
}

.admin-expense-form,
.admin-expense-field {
  display: grid;
  gap: 8px;
}

.admin-expense-form-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.admin-service-description {
  min-height: 110px;
  resize: vertical;
  padding: 12px 14px;
}

.admin-expense-field.is-hidden {
  display: none;
}

.admin-product-media-upload,
.admin-product-media-preview {
  display: grid;
  gap: 10px;
}

.admin-product-media-upload {
  padding: 14px;
  border: 1px dashed rgba(18, 15, 21, 0.18);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  cursor: pointer;
}

.admin-product-media-upload input {
  display: none;
}

.admin-product-media-upload-copy {
  color: #120f15;
  font-size: 0.78rem;
  font-weight: 600;
}

.admin-product-media-upload-note {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.72rem;
  line-height: 1.5;
}

.admin-product-media-preview {
  width: 100%;
}

.admin-product-media-preview-card {
  margin-bottom: 2px;
}

.admin-product-media-preview-asset {
  width: 100%;
  max-height: 320px;
  object-fit: cover;
  border-radius: 18px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background: rgba(18, 15, 21, 0.04);
}

.admin-client-search-label {
  color: rgba(18, 15, 21, 0.62);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-client-search-input {
  width: 100%;
  padding: 11px 14px;
  border-radius: 14px;
  border: 1px solid rgba(18, 15, 21, 0.1);
  background: rgba(255, 255, 255, 0.84);
  color: #120f15;
  font: inherit;
}

.admin-client-search-input:focus {
  outline: 2px solid rgba(123, 0, 231, 0.18);
  border-color: rgba(123, 0, 231, 0.28);
}

.admin-booking-topline,
.admin-booking-line {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
}

.admin-booking-title,
.admin-booking-line strong {
  color: #120f15;
  font-size: 0.82rem;
  font-weight: 600;
}

.admin-booking-line span,
.admin-booking-line-full span,
.admin-booking-line-stack span {
  color: rgba(18, 15, 21, 0.68);
  font-size: 0.76rem;
  line-height: 1.5;
}

.admin-booking-line-stack {
  align-items: flex-start;
}

.admin-booking-line-stack strong {
  max-width: 58%;
  text-align: right;
  white-space: normal;
}

.admin-booking-line-full {
  align-items: flex-start;
}

.admin-booking-line-full strong {
  max-width: 58%;
  text-align: right;
  white-space: normal;
}

.admin-booking-upload-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
  gap: 10px;
  width: 100%;
  margin-top: 10px;
}

.admin-booking-upload-card {
  overflow: hidden;
  border-radius: 14px;
  border: 1px solid rgba(18, 15, 21, 0.08);
  background: rgba(255, 255, 255, 0.84);
}

.admin-booking-upload-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.admin-client-record-toggle {
  padding: 0;
  border: 0;
  background: transparent;
  color: #120f15;
  font: inherit;
  font-size: 0.82rem;
  font-weight: 600;
  text-align: left;
  cursor: pointer;
}

.admin-client-record-toggle:hover,
.admin-client-record-toggle:focus-visible {
  color: #7b00e7;
  outline: none;
}

.admin-booking-status {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: rgba(123, 0, 231, 0.1);
  color: #7b00e7;
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-booking-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.admin-booking-actions-inline {
  justify-content: flex-start;
}

.admin-booking-reschedule-panel {
  display: grid;
  gap: 10px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid rgba(18, 15, 21, 0.08);
}

.admin-booking-reschedule-label {
  color: rgba(18, 15, 21, 0.72);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.admin-booking-reschedule-select {
  width: 100%;
  min-height: 46px;
  padding: 0 14px;
  border-radius: 16px;
  border: 1px solid rgba(18, 15, 21, 0.1);
  background: rgba(255, 255, 255, 0.92);
  color: #120f15;
  font: inherit;
}

.admin-booking-reschedule-textarea {
  min-height: 104px;
  padding: 12px 14px;
  resize: vertical;
}

.admin-manual-service-config {
  display: grid;
  gap: 12px;
}

.admin-booking-awarded {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 16px;
  border-radius: 999px;
  background: rgba(123, 0, 231, 0.08);
  color: #7b00e7;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

@media (max-width: 1024px) {
  .admin-bento-grid,
  .admin-summary--bento {
    grid-template-columns: 1fr;
  }

  .admin-bento-span-12,
  .admin-bento-span-8,
  .admin-bento-span-7,
  .admin-bento-span-6,
  .admin-bento-span-5,
  .admin-bento-span-4 {
    grid-column: span 1;
  }
}

@media (min-width: 1025px) {
  .admin-bento-grid-overview {
    grid-auto-rows: minmax(98px, auto);
    align-items: stretch;
  }

  .admin-bento-grid-overview > * {
    height: 100%;
  }

  .admin-summary--bento {
    min-height: 124px;
  }

  .admin-bento-grid-overview .admin-collapsible-section {
    min-height: 128px;
  }

  .admin-bento-grid-overview .admin-bento-feature {
    grid-row: span 2;
    min-height: 276px;
  }

  .admin-bento-grid-overview .admin-bento-span-5,
  .admin-bento-grid-overview .admin-bento-span-4 {
    min-height: 152px;
  }

  .admin-bento-grid-overview .admin-bento-span-6 {
    min-height: 168px;
  }

  .admin-bento-grid-overview .admin-section-toggle {
    min-height: 100%;
    align-items: flex-start;
  }

  .admin-bento-grid-overview .admin-section-toggle-copy {
    align-items: flex-start;
    min-height: 100%;
  }
}

.admin-auth-feedback.is-error {
  color: #b42318;
}

.admin-auth-feedback.is-success {
  color: #047857;
}

.admin-overlay.is-locked .admin-panel {
  min-height: 420px;
  width: min(320px, 100%);
  margin: 0 auto;
  justify-items: center;
  align-content: center;
}

.admin-overlay.is-locked .admin-panel-header,
.admin-overlay.is-locked .admin-close {
  display: none !important;
}

.admin-overlay.is-locked .admin-auth {
  min-height: 100%;
  align-content: center;
  justify-items: center;
  text-align: center;
  gap: 18px;
  width: 100%;
  margin: auto;
}

.admin-overlay.is-locked .admin-auth-form {
  width: min(320px, 100%);
  grid-template-columns: 1fr;
  justify-items: center;
}

.admin-overlay.is-locked .admin-auth-form label {
  width: 100%;
}

.admin-overlay.is-locked .admin-auth-submit {
  width: 100%;
}

@media (max-width: 1024px) {
  .hero-slide-1 {
    background-position: 62% center;
  }

  .hero-slide-2 {
    background-position: 66% center;
  }

  .hero-slide-3 {
    background-position: 72% center;
  }

  .hero-title {
    max-width: 560px;
  }

  .menu-grid {
    max-width: min(100%, 100%);
  }

  .hero-info-rail {
    width: min(880px, 100%);
  }
}

@media (max-width: 1024px) and (min-width: 621px) {
  .menu-grid {
    width: 100%;
    justify-self: stretch;
    justify-content: flex-start;
    padding-inline: 20px;
    scroll-padding-inline: 20px;
  }
}

@media (max-width: 900px) {
  .hero-content {
    gap: 32px;
    padding: 24px 20px 24px;
  }

  .hero-content::before {
    inset: 7% 5% 8%;
    border-radius: 28px;
  }

  .hero-header {
    padding: 22px 20px 0;
  }

  .hero-kicker,
  .hero-subtitle {
    display: none;
  }

  .admin-trigger {
    top: 24px;
    right: 20px;
  }

  .menu-grid {
    max-width: min(100%, 100%);
  }
  .hero-info-rail {
    grid-template-columns: 1fr;
    width: min(460px, 100%);
    gap: 10px;
  }

  .hero-info-card {
    padding: 16px;
  }

  .menu-card {
    flex-basis: 170px;
    width: 170px;
    min-height: 76px;
  }

  .menu-card-contact.is-open {
    width: min(420px, calc(100vw - 36px));
    min-height: 500px;
  }

  .menu-card-about.is-open {
    width: min(420px, calc(100vw - 36px));
    min-height: 500px;
  }

  .menu-card-rewards.is-open {
    width: min(420px, calc(100vw - 36px));
    min-height: 500px;
  }

  .menu-card-policies.is-open {
    width: min(420px, calc(100vw - 36px));
    min-height: 500px;
  }

  .menu-card-gallery.is-open {
    width: min(680px, calc(100vw - 36px));
    min-height: 540px;
  }

  .menu-card-services.is-open {
    width: min(520px, calc(100vw - 36px));
    min-height: 560px;
  }

  .admin-overlay.is-open .admin-overlay-shell {
    width: min(860px, calc(100vw - 48px));
    min-height: 580px;
  }

  .admin-overlay.is-open.is-locked .admin-overlay-shell {
    width: min(420px, calc(100vw - 36px));
    min-height: 420px;
  }
}

@media (max-width: 620px) {
  .menu-card-contact.is-open,
  .menu-card-about.is-open,
  .menu-card-rewards.is-open,
  .menu-card-policies.is-open,
  .menu-card-gallery.is-open,
  .menu-card-services.is-open,
  .admin-overlay.is-open .admin-overlay-shell {
    top: calc(env(safe-area-inset-top) + 12px);
    right: 10px;
    bottom: calc(env(safe-area-inset-bottom) + 12px);
    left: 10px;
    position: fixed !important;
    width: auto !important;
    transform: none !important;
    max-height: none !important;
    min-height: 0 !important;
    border-radius: 20px;
    overflow: hidden;
    overscroll-behavior: contain;
    display: grid;
    grid-template-rows: auto minmax(0, 1fr) auto;
    align-content: start;
  }

  .hero-slide-1 {
    background-position: 68% center;
  }

  .hero-slide-2 {
    background-position: 72% center;
  }

  .hero-slide-3 {
    background-position: 76% center;
  }

  .hero-content {
    min-height: calc(100vh - 58px);
    grid-template-rows: 1fr auto auto;
    gap: 20px;
    padding: calc(env(safe-area-inset-top) + 18px) 16px calc(env(safe-area-inset-bottom) + 18px);
  }

  .hero-content::before {
    content: none;
  }

  .hero-header {
    padding: calc(env(safe-area-inset-top) + 18px) 16px 0;
  }

  .admin-trigger {
    top: calc(env(safe-area-inset-top) + 20px);
    right: 16px;
    font-size: 0.68rem;
  }

  .brand-mark {
    font-size: 0.72rem;
    letter-spacing: 0.18em;
  }

  .hero-copy {
    max-width: 100%;
    align-self: center;
    text-align: center;
  }

  .hero-kicker {
    display: block;
    margin: 0 0 12px;
    color: rgba(255, 255, 255, 0.62);
    font-size: 0.62rem;
    font-weight: 600;
    letter-spacing: 0.26em;
    text-transform: uppercase;
  }

  .hero-title {
    max-width: none;
    font-size: clamp(1.95rem, 8.2vw, 3rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
    text-wrap: balance;
  }

  .hero-subtitle {
    display: block;
    margin: 14px auto 0;
    max-width: 280px;
    color: rgba(255, 255, 255, 0.68);
    font-size: 0.8rem;
    line-height: 1.6;
  }

  .menu-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    width: 100%;
    max-width: 100%;
    gap: 10px;
    justify-self: stretch;
    align-self: end;
    overflow: visible;
  }

  .hero-info-rail {
    display: none;
  }

  .menu-card {
    flex: none;
    width: 100%;
    min-height: 62px;
    padding: 13px 14px;
    border-radius: 16px;
    font-size: 0.76rem;
    letter-spacing: 0.07em;
  }

  .menu-card-services {
    grid-column: 1 / -1;
  }

  .menu-card-contact.is-open {
    min-height: 0;
    padding: 18px;
    align-items: stretch;
    justify-content: flex-start;
    text-align: left;
  }

  .menu-card-about.is-open {
    min-height: 0;
    padding: 18px;
  }

  .menu-card-rewards.is-open {
    min-height: 0;
    padding: 18px;
  }

  .menu-card-policies.is-open {
    min-height: 0;
    padding: 18px;
  }

  .menu-card-gallery.is-open {
    min-height: 0;
    padding: 18px;
  }

  .menu-card-services.is-open {
    min-height: 0;
    padding: 18px;
  }

  .admin-overlay.is-open .admin-overlay-shell {
    min-height: 0;
    gap: 14px;
    padding: 14px;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .admin-overlay.is-open.is-locked .admin-overlay-shell {
    top: calc(env(safe-area-inset-top) + 20px);
    right: 16px;
    bottom: calc(env(safe-area-inset-bottom) + 20px);
    left: 16px;
    min-height: 0;
  }

  .services-wizard-stage {
    min-height: 420px;
  }

  .services-step {
    max-height: none;
  }

  .services-customer-form input,
  .admin-auth-form input,
  .admin-booking-reschedule-select,
  .contact-form input,
  .contact-form textarea {
    font-size: 1rem;
  }

  .admin-panel {
    min-height: 0;
    grid-template-rows: auto;
    gap: 12px;
  }

  .admin-dashboard {
    min-height: auto;
    overflow: visible;
    padding-right: 0;
    gap: 12px;
  }

  .admin-bookings {
    max-height: none;
    gap: 12px;
    align-content: start;
  }

  .admin-summary {
    gap: 8px;
  }

  .admin-sales-report-filters {
    gap: 8px;
  }

  .admin-sales-report-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .admin-summary-card {
    padding: 12px;
  }

  .admin-calendar-modal-shell {
    padding: 14px;
  }

  .admin-calendar-modal {
    padding: 16px;
    border-radius: 18px;
    max-height: 86vh;
  }

  .admin-summary-card strong {
    font-size: 1rem;
  }

  .admin-summary-card span {
    font-size: 0.64rem;
  }

  .admin-sales-filter {
    min-height: 38px;
    padding: 0 12px;
    font-size: 0.64rem;
  }

  .admin-toolbar {
    gap: 8px;
  }

  .admin-toolbar-button {
    min-height: 40px;
    padding: 0 14px;
    font-size: 0.68rem;
  }

  .admin-calendar-month {
    gap: 8px;
    padding: 12px;
  }

  .admin-calendar-note {
    font-size: 0.7rem;
    line-height: 1.45;
  }

  .admin-calendar-weekdays,
  .admin-calendar-grid {
    gap: 4px;
  }

  .admin-calendar-day {
    min-height: 32px;
    padding: 3px;
  }

  .admin-calendar-day-number {
    font-size: 0.7rem;
  }

  .admin-calendar-day-count,
  .admin-calendar-day-status {
    font-size: 0.45rem;
  }

  .services-config-options,
  .services-availability-grid,
  .services-deposit-methods,
  .services-deposit-actions,
  .gallery-grid {
    grid-template-columns: 1fr;
  }

  .gallery-grid {
    grid-auto-rows: auto;
  }

  .gallery-tile-feature,
  .gallery-tile-wide,
  .gallery-tile-tall {
    grid-column: span 1;
    grid-row: span 1;
  }

  .gallery-tile {
    min-height: 220px;
  }

  .services-step-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .services-step-button {
    width: 100%;
  }

  .menu-card-contact.is-open .menu-card-reveal,
  .menu-card-about.is-open .menu-card-reveal,
  .menu-card-rewards.is-open .menu-card-reveal,
  .menu-card-policies.is-open .menu-card-reveal,
  .menu-card-gallery.is-open .menu-card-reveal,
  .menu-card-services.is-open .menu-card-reveal {
    min-height: 0;
    max-height: none;
    overflow-y: auto;
    overscroll-behavior: contain;
  }

  .menu-card-contact.is-open .menu-card-close,
  .menu-card-about.is-open .menu-card-close,
  .menu-card-rewards.is-open .menu-card-close,
  .menu-card-policies.is-open .menu-card-close,
  .menu-card-gallery.is-open .menu-card-close,
  .menu-card-services.is-open .menu-card-close {
    margin-top: 16px;
  }

  .admin-auth-form {
    grid-template-columns: 1fr;
  }

  .admin-booking-topline,
  .admin-booking-line {
    flex-direction: column;
    align-items: flex-start;
  }

  .admin-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .admin-calendar-weekdays,
  .admin-calendar-grid {
    gap: 6px;
  }

  .admin-gallery-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .about-profile {
    grid-template-columns: 1fr;
    justify-items: center;
    text-align: center;
  }

  .about-profile-main {
    justify-items: center;
  }

  .about-profile-stats {
    grid-template-columns: 1fr;
  }

  .about-notes {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 420px) {
  .hero-slide-1 {
    background-position: 72% center;
  }

  .hero-slide-2 {
    background-position: 76% center;
  }

  .hero-slide-3 {
    background-position: 80% center;
  }

  .hero-title {
    font-size: clamp(1.15rem, 5vw, 2rem);
  }

  .menu-grid {
    grid-template-columns: 1fr;
    max-width: 100%;
  }

  .menu-card-services {
    grid-column: auto;
  }

  .menu-card {
    min-height: 60px;
    padding: 12px 14px;
  }

  .menu-card-contact.is-open,
  .menu-card-about.is-open,
  .menu-card-rewards.is-open,
  .menu-card-policies.is-open,
  .menu-card-gallery.is-open,
  .menu-card-services.is-open,
  .admin-overlay.is-open .admin-overlay-shell {
    top: calc(env(safe-area-inset-top) + 10px);
    right: 8px;
    bottom: calc(env(safe-area-inset-bottom) + 10px);
    left: 8px;
    transform: none !important;
    border-radius: 18px;
  }

  .admin-overlay.is-open.is-locked .admin-overlay-shell {
    top: calc(env(safe-area-inset-top) + 16px);
    right: 12px;
    bottom: calc(env(safe-area-inset-bottom) + 16px);
    left: 12px;
  }
}

@media (max-width: 620px) {
  .menu-card.is-open {
    position: fixed !important;
    inset: calc(env(safe-area-inset-top) + 18px) 14px calc(env(safe-area-inset-bottom) + 18px) 14px !important;
    width: auto !important;
    min-height: 0 !important;
    max-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 36px) !important;
    margin: 0 !important;
    transform: none !important;
    border-radius: 22px !important;
    overflow: hidden !important;
    z-index: 60 !important;
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) auto !important;
    align-content: start !important;
    justify-content: flex-start !important;
    align-items: stretch !important;
    text-align: left !important;
  }

  .menu-card-services.is-open {
    inset: calc(env(safe-area-inset-top) + 16px) 12px calc(env(safe-area-inset-bottom) + 16px) 12px !important;
    border-radius: 24px !important;
  }

  .menu-card.is-open .menu-card-reveal {
    min-height: 0 !important;
    max-height: none !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch;
  }

  .menu-card.is-open .menu-card-close {
    margin-top: 14px !important;
  }
}

.mobile-menu-toggle {
  display: none;
}

@media (max-width: 620px) {
  .menu-card-services.is-open[data-services-view="browser"] .services-browser {
    display: grid !important;
    gap: 18px;
  }

  .menu-card-services.is-open[data-services-view="browser"] .services-focus,
  .menu-card-services.is-open[data-services-view="browser"] .services-step,
  .menu-card-services.is-open[data-services-view="browser"] .services-wizard-stage {
    display: none !important;
  }

  .menu-card-services.is-open .menu-card-reveal {
    font-size: 0.94rem;
    line-height: 1.55;
  }

  .menu-card-services.is-open .services-panel-title {
    font-size: 0.92rem;
    letter-spacing: 0.1em;
  }

  .menu-card-services.is-open .services-panel-note {
    font-size: 0.94rem;
    line-height: 1.6;
  }

  .menu-card-services.is-open .service-category {
    padding: 16px;
    border-radius: 18px;
  }

  .menu-card-services.is-open .service-category-trigger {
    font-size: 0.92rem;
    letter-spacing: 0.06em;
  }

  .menu-card-services.is-open .service-option-row {
    padding: 14px 16px;
    font-size: 0.94rem;
    line-height: 1.55;
  }

  .menu-card-services.is-open .service-option-name {
    font-size: 0.98rem;
  }

  .hero-shell {
    height: 100dvh;
    min-height: 100dvh;
    max-height: 100dvh;
  }

  .hero-header {
    padding: calc(env(safe-area-inset-top) + 18px) 18px 0;
  }

  .hero-content {
    min-height: calc(100dvh - 72px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding:
      calc(env(safe-area-inset-top) + 24px)
      18px
      calc(env(safe-area-inset-bottom) + 96px);
  }

  .hero-copy {
    width: 100%;
    max-width: 342px;
    margin: 0 auto;
    align-self: auto;
    text-align: center;
    transition:
      max-width 220ms ease,
      transform 220ms ease,
      opacity 220ms ease;
  }

  .hero-title {
    max-width: none;
    text-align: center;
    transition:
      font-size 220ms ease,
      line-height 220ms ease,
      letter-spacing 220ms ease;
  }

  body.mobile-menu-open .hero-content,
  body.mobile-card-open .hero-content {
    align-items: flex-start;
    justify-content: flex-start;
    padding-top: calc(env(safe-area-inset-top) + 18px);
  }

  body.mobile-menu-open .hero-copy,
  body.mobile-card-open .hero-copy {
    max-width: none;
    width: 100%;
    margin: 0 auto;
    transform: translateY(-18px);
    text-align: center;
  }

  body.mobile-menu-open .hero-kicker,
  body.mobile-card-open .hero-kicker {
    opacity: 0.84;
  }

  body.mobile-menu-open .hero-title,
  body.mobile-card-open .hero-title {
    max-width: none;
    font-size: clamp(1.65rem, 6vw, 2.5rem);
    line-height: 1.02;
    letter-spacing: -0.03em;
    text-align: center;
  }

  body.mobile-menu-open .hero-subtitle,
  body.mobile-card-open .hero-subtitle {
    max-width: 300px;
    margin-top: 12px;
  }

  .menu-grid {
    position: fixed;
    right: 12px;
    bottom: calc(env(safe-area-inset-bottom) + 66px);
    left: 12px;
    z-index: 70;
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
    width: auto;
    max-width: none;
    max-height: min(72dvh, 640px);
    padding: 14px;
    border: 1px solid rgba(255, 255, 255, 0.1);
    border-radius: 26px;
    background:
      linear-gradient(180deg, rgba(255, 251, 248, 0.9), rgba(248, 243, 238, 0.84)),
      rgba(252, 248, 244, 0.88);
    box-shadow: 0 18px 44px rgba(0, 0, 0, 0.24);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    overflow-y: auto;
    overflow-x: hidden;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(24px);
    transition:
      opacity 220ms ease,
      transform 220ms ease,
      visibility 220ms ease;
  }

  body.mobile-menu-open .menu-grid {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: translateY(0);
  }

  body.mobile-card-open .menu-grid {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none !important;
    padding: 0;
    border-color: transparent;
    background: transparent;
    box-shadow: none;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
    overflow: visible;
  }

  body.mobile-card-open .menu-card:not(.is-open) {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transform: translateY(12px);
  }

  .menu-card,
  .menu-card-services {
    grid-column: auto;
  }

  .menu-card {
    width: 100%;
    min-height: 78px;
    padding: 18px 18px 17px;
    border-radius: 20px;
    font-size: 0.8rem;
    letter-spacing: 0.08em;
  }

  .mobile-menu-toggle {
    position: fixed;
    left: 50%;
    bottom: calc(env(safe-area-inset-bottom) + 18px);
    z-index: 80;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    background: rgba(252, 248, 244, 0.92);
    box-shadow: 0 18px 42px rgba(0, 0, 0, 0.28);
    transform: translateX(-50%);
    cursor: pointer;
    transition:
      transform 180ms ease,
      background 180ms ease,
      opacity 180ms ease;
  }

  .mobile-menu-toggle-lines {
    display: inline-grid;
    gap: 5px;
  }

  .mobile-menu-toggle-lines span {
    display: block;
    width: 22px;
    height: 2px;
    border-radius: 999px;
    background: #161118;
  }

  body.mobile-menu-open .mobile-menu-toggle {
    background: rgba(123, 0, 231, 0.92);
  }

  body.mobile-menu-open .mobile-menu-toggle-lines span {
    background: #fff;
  }

  body.mobile-card-open .mobile-menu-toggle {
    opacity: 0;
    pointer-events: none;
    transform: translate(-50%, 18px);
  }

  .menu-card.is-open {
    z-index: 120 !important;
    pointer-events: auto !important;
    min-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 12px) !important;
  }

  .services-panel,
  .services-browser,
  .services-focus {
    min-height: 0;
  }

  .menu-card-services.is-open .menu-card-reveal {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr);
    align-content: stretch !important;
    height: 100% !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
  }

  .menu-card-services.is-open .services-panel {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr);
    min-height: 100%;
    height: 100%;
  }

  .menu-card-services.is-open[data-services-view="browser"] .services-browser {
    display: grid !important;
    grid-template-rows: auto minmax(0, 1fr) auto;
    align-content: stretch;
    min-height: 100%;
    height: 100%;
    overflow: hidden;
  }

  .menu-card-services.is-open[data-services-view="browser"] .services-list {
    min-height: 0;
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
  }

  .menu-card-services.is-open[data-services-view="focus"] .services-focus {
    display: grid !important;
    grid-template-rows: minmax(0, 1fr);
    min-height: 100%;
    height: 100%;
  }

  .menu-card-services.is-open[data-services-view="focus"] .services-wizard-stage {
    min-height: 0 !important;
    height: 100% !important;
  }

  .menu-card-services.is-open[data-services-view="focus"] .services-step {
    min-height: 0;
    height: 100%;
    max-height: none !important;
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
  }

  .menu-card-services.is-open[data-services-view="focus"] .services-step-label {
    font-size: 0.74rem;
  }

  .menu-card-services.is-open[data-services-view="focus"] .services-step-title {
    font-size: 1rem;
  }

  .menu-card-services.is-open[data-services-view="focus"] .services-selected-name {
    font-size: 1rem;
  }

  .menu-card-services.is-open[data-services-view="focus"] .services-selected-meta,
  .menu-card-services.is-open[data-services-view="focus"] .services-selected-description,
  .menu-card-services.is-open[data-services-view="focus"] .services-config,
  .menu-card-services.is-open[data-services-view="focus"] .services-availability,
  .menu-card-services.is-open[data-services-view="focus"] .services-selection {
    font-size: 0.92rem;
  }
}

@media (max-width: 900px) {
  .hero-content {
    min-height: calc(100vh - 72px);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    padding: calc(env(safe-area-inset-top) + 28px) 24px calc(env(safe-area-inset-bottom) + 30px);
  }

  .hero-content::before,
  .hero-content::after {
    content: none;
  }

  .hero-copy {
    width: 100%;
    max-width: 680px;
    margin: 0 auto;
    align-self: center;
    text-align: center;
  }

  .hero-copy::before {
    content: "";
    display: block;
    width: 84px;
    height: 2px;
    margin: 0 auto 24px;
    background: linear-gradient(90deg, rgba(123, 0, 231, 0.94), rgba(123, 0, 231, 0));
  }

  .hero-title {
    max-width: 640px;
    margin: 0 auto;
    font-size: clamp(2.65rem, 9vw, 5rem);
    line-height: 0.92;
    letter-spacing: -0.05em;
    text-align: center;
    text-wrap: balance;
  }

  .hero-subtitle {
    display: block;
    max-width: 340px;
    margin: 18px auto 0;
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.88rem;
    line-height: 1.65;
    text-align: center;
  }
}

@media (max-width: 620px) {
  .hero-header {
    padding: calc(env(safe-area-inset-top) + 18px) 18px 0;
  }

  .brand-mark {
    font-size: 0.7rem;
    letter-spacing: 0.2em;
  }

  .hero-content {
    min-height: calc(100dvh - 72px);
    padding:
      calc(env(safe-area-inset-top) + 22px)
      18px
      calc(env(safe-area-inset-bottom) + 96px);
  }

  .hero-copy {
    max-width: 360px;
  }

  .hero-copy::before {
    width: 72px;
    margin-bottom: 20px;
  }

  .hero-title {
    font-size: clamp(2.05rem, 9.6vw, 3.35rem);
    line-height: 0.94;
    letter-spacing: -0.045em;
  }

  .hero-subtitle {
    max-width: 292px;
    margin-top: 14px;
    font-size: 0.8rem;
    line-height: 1.58;
  }

  body.mobile-menu-open .hero-content,
  body.mobile-card-open .hero-content {
    align-items: flex-start;
    justify-content: flex-start;
    padding-top: calc(env(safe-area-inset-top) + 20px);
  }

  body.mobile-menu-open .hero-copy,
  body.mobile-card-open .hero-copy {
    max-width: 360px;
    transform: translateY(-12px);
  }

  body.mobile-menu-open .hero-title,
  body.mobile-card-open .hero-title {
    font-size: clamp(1.85rem, 7.2vw, 2.8rem);
    line-height: 0.98;
    letter-spacing: -0.035em;
  }

  body.mobile-menu-open .hero-subtitle,
  body.mobile-card-open .hero-subtitle {
    max-width: 300px;
    margin-top: 12px;
  }

  .menu-grid {
    right: 12px;
    left: 12px;
    bottom: calc(env(safe-area-inset-bottom) + 66px);
    padding: 12px;
    border-radius: 24px;
    background:
      linear-gradient(180deg, rgba(255, 251, 248, 0.88), rgba(248, 243, 238, 0.8)),
      rgba(252, 248, 244, 0.84);
    box-shadow: 0 18px 38px rgba(0, 0, 0, 0.2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
  }

  .menu-card {
    min-height: 74px;
    padding: 17px 17px 16px;
    border-radius: 18px;
    background:
      linear-gradient(180deg, rgba(255, 255, 255, 0.74), rgba(255, 255, 255, 0.34)),
      rgba(248, 243, 238, 0.88);
    box-shadow: 0 12px 24px rgba(0, 0, 0, 0.14);
  }
}

body.admin-page-open {
  overflow: hidden;
}

.admin-overlay.is-open {
  position: fixed;
  inset: 0;
  z-index: 120;
  display: block;
  background:
    linear-gradient(180deg, rgba(252, 248, 255, 0.98), rgba(244, 236, 250, 0.98)),
    rgba(249, 244, 252, 0.98);
  overflow: hidden;
}

.admin-overlay.is-open .admin-overlay-shell {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 100dvh;
  max-width: none;
  padding: 22px;
  gap: 0;
  overflow-y: auto;
  overflow-x: hidden;
  align-items: stretch;
  justify-items: stretch;
  justify-content: stretch;
  text-align: left;
}

.admin-overlay.is-open .admin-panel {
  width: 100%;
  max-width: none;
  min-height: calc(100dvh - 44px);
  padding: 56px 0 0;
}

.admin-overlay.is-open .admin-close {
  display: none !important;
}

.admin-overlay.is-open .admin-close-icon {
  position: sticky;
  top: 0;
  justify-self: end;
  z-index: 5;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  display: inline-grid;
  place-items: center;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 12px 30px rgba(35, 20, 50, 0.12);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

.admin-overlay.is-open .admin-dashboard {
  width: 100%;
  max-width: none;
}

.admin-overlay.is-open .admin-bookings {
  max-height: none;
  min-height: calc(100dvh - 220px);
  overflow: visible;
}

.admin-overlay.is-open.is-locked .admin-overlay-shell {
  padding: 24px;
  place-items: center;
}

.admin-overlay.is-open.is-locked .admin-panel {
  width: min(520px, 100%);
  min-height: min(460px, calc(100dvh - 48px));
  padding: 32px;
  border-radius: 32px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(18, 15, 21, 0.08);
  box-shadow: 0 24px 60px rgba(34, 20, 48, 0.14);
}

.admin-overlay.is-open.is-locked .admin-close-icon {
  position: absolute;
  top: 18px;
  right: 18px;
}

@media (min-width: 1025px) {
  .admin-overlay.is-open .admin-overlay-shell {
    padding: 28px 32px;
  }

  .admin-overlay.is-open .admin-panel {
    min-height: calc(100dvh - 56px);
    padding-top: 62px;
  }

  .admin-overlay.is-open .admin-dashboard {
    min-height: 100%;
    align-content: stretch;
  }

  .admin-overlay.is-open .admin-bento-grid-overview {
    grid-auto-rows: minmax(132px, auto);
  }

  .admin-overlay.is-open .admin-summary--bento {
    min-height: 156px;
  }

  .admin-overlay.is-open .admin-bento-grid-overview .admin-collapsible-section {
    min-height: 168px;
  }

  .admin-overlay.is-open .admin-bento-grid-overview .admin-bento-feature {
    min-height: 384px;
  }

  .admin-overlay.is-open .admin-bento-grid-overview .admin-bento-span-5,
  .admin-overlay.is-open .admin-bento-grid-overview .admin-bento-span-4 {
    min-height: 220px;
  }

  .admin-overlay.is-open .admin-bento-grid-overview .admin-bento-span-6 {
    min-height: 240px;
  }
}

@media (max-width: 620px) {
  .admin-overlay.is-open .admin-overlay-shell {
    min-height: 100dvh;
    padding: calc(env(safe-area-inset-top) + 12px) 12px calc(env(safe-area-inset-bottom) + 14px);
  }

  .admin-overlay.is-open .admin-panel {
    min-height: calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 26px);
    padding-top: 54px;
  }

  .admin-overlay.is-open.is-locked .admin-panel {
    min-height: min(420px, calc(100dvh - env(safe-area-inset-top) - env(safe-area-inset-bottom) - 32px));
    padding: 28px 20px;
  }
}
