:root {
  --bg: #ffffff;
  --bg-soft: #ffffff;
  --bg-warm: #f7f7f8;
  --text: #111111;
  --muted: #6b7280;
  --accent: #4b5563;
  --accent-deep: #111827;
  --sage: #6b7280;
  --line: rgba(17, 24, 39, 0.12);
  --white: #ffffff;
  --shadow: 0 18px 42px rgba(17, 24, 39, 0.08);
  --content-max: 1360px;
  --radius: 6px;
}

html[data-theme="dark"] {
  color-scheme: dark;
  --bg: #050505;
  --bg-soft: #0f1012;
  --bg-warm: #17191d;
  --text: #f7f7f8;
  --muted: #a1a1aa;
  --accent: #d1d5db;
  --accent-deep: #ffffff;
  --sage: #9ca3af;
  --line: rgba(255, 255, 255, 0.14);
  --white: #0f1012;
  --shadow: 0 18px 42px rgba(0, 0, 0, 0.38);
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

html {
  scroll-behavior: smooth;
}

html:has(.message-chat-page),
body:has(.message-chat-page) {
  height: 100%;
  width: 100%;
  max-width: 100vw;
  overflow: hidden;
  overscroll-behavior: none;
}

html:has(.message-chat-page) {
  background: var(--bg);
}

[id] {
  scroll-margin-top: 96px;
}

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: "Inter", Arial, sans-serif;
  overflow-x: hidden;
  text-rendering: optimizeLegibility;
}

html,
body,
main,
.next-route-shell {
  max-width: 100vw;
}

main,
.next-route-shell {
  min-width: 0;
}

@supports (overflow-x: clip) {
  html,
  body {
    overflow-x: clip;
  }
}

img {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

button,
input,
select,
textarea {
  font: inherit;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

@media (max-width: 960px) {
  input,
  select,
  textarea {
    font-size: 16px !important;
  }

  button,
  a,
  input,
  select,
  textarea {
    touch-action: manipulation;
  }
}

:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 4px;
}

.theme-toggle {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 6px 10px 6px 7px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--line);
  border-radius: 999px;
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.1);
  font-size: 0.72rem;
  font-weight: 850;
  letter-spacing: 0;
}

.theme-toggle span {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  color: #fff;
  background: #111827;
  border-radius: 50%;
  font-size: 0.72rem;
}

.theme-toggle em {
  font-style: normal;
}

html[data-theme="dark"] .theme-toggle {
  background: rgba(15, 16, 18, 0.9);
  box-shadow: 0 12px 32px rgba(0, 0, 0, 0.34);
}

html[data-theme="dark"] .theme-toggle span {
  color: #111827;
  background: #f7f7f8;
}

/* App-quality interaction layer: keeps the existing brand visuals while adding consumer-app motion. */
.app-route-enter {
  opacity: 0;
  transform: none;
}

.app-route-enter.app-route-enter-active {
  opacity: 1;
  transform: none;
  transition: opacity 180ms ease;
}

.app-route-leave {
  opacity: 0;
  transform: none;
  transition: opacity 140ms ease;
}

::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 180ms;
  animation-timing-function: cubic-bezier(0.2, 0.8, 0.2, 1);
}

button,
.btn,
a,
[data-app-pressable] {
  -webkit-tap-highlight-color: transparent;
}

button,
.btn,
.service-hero-action,
.bridal-vendor-link,
.mobile-bottom-nav a,
.message-section-tab {
  transition: transform 160ms ease, box-shadow 180ms ease, background-color 180ms ease, border-color 180ms ease, color 180ms ease;
  touch-action: manipulation;
}

button.is-pressing,
.btn.is-pressing,
a.is-pressing,
[data-app-pressable].is-pressing {
  transform: scale(0.97);
}

.bridal-vendor,
.service-team-card,
.catalog-card,
.booking-card,
.message-thread-card,
.order-card,
.recommendation-card {
  will-change: transform;
}

.bridal-vendor:hover,
.service-team-card:hover,
.catalog-card:hover,
.booking-card:hover,
.message-thread-card:hover,
.order-card:hover,
.recommendation-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 18px 45px rgba(36, 24, 21, 0.12);
}

.app-reveal {
  opacity: 0;
  transform: translateY(14px);
}

.app-reveal.is-visible {
  opacity: 1;
  transform: translateY(0);
  transition: opacity 280ms ease, transform 320ms cubic-bezier(0.2, 0.8, 0.2, 1);
  transition-delay: calc(var(--reveal-index, 0) * 24ms);
}

.app-img-loading {
  opacity: 0;
  filter: blur(8px);
  transform: scale(1.01);
  background: linear-gradient(90deg, rgba(255,255,255,0.45), rgba(255,255,255,0.85), rgba(255,255,255,0.45));
}

.app-img-loading.is-loaded {
  opacity: 1;
  filter: blur(0);
  transform: scale(1);
  transition: opacity 260ms ease, filter 320ms ease, transform 320ms ease;
}

/* Skeleton loaders appear only while async catalog/message containers are empty. */
.app-skeleton-host {
  min-height: 180px;
}

.app-skeleton-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  min-height: 126px;
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.72);
  overflow: hidden;
}

.app-skeleton-card span,
.app-skeleton-card strong,
.app-skeleton-card small {
  display: block;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(17, 24, 39, 0.08), rgba(255, 255, 255, 0.85), rgba(17, 24, 39, 0.08));
  background-size: 220% 100%;
  animation: milaashesSkeleton 1.25s ease-in-out infinite;
}

.app-skeleton-card span {
  width: 72px;
  height: 72px;
  border-radius: 50%;
}

.app-skeleton-card strong {
  width: 70%;
  height: 16px;
}

.app-skeleton-card small {
  width: 46%;
  height: 12px;
}

@keyframes milaashesSkeleton {
  0% { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

.service-detail-skeleton-page {
  overflow-x: clip;
}

.service-detail-skeleton {
  pointer-events: none;
  user-select: none;
}

.service-skeleton-line,
.service-skeleton-pill,
.service-skeleton-avatar,
.service-skeleton-photo,
.service-skeleton-card-media {
  display: block;
  color: transparent;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(17, 24, 39, 0.08), rgba(255, 255, 255, 0.92), rgba(17, 24, 39, 0.08));
  background-size: 220% 100%;
  animation: milaashesSkeleton 1.25s ease-in-out infinite;
}

.service-skeleton-line {
  width: 64%;
  height: 12px;
}

.service-skeleton-line.is-title {
  width: min(78%, 320px);
  height: 22px;
}

.service-skeleton-line.is-short {
  width: 36%;
}

.service-skeleton-line.is-wide {
  width: 88%;
}

.service-skeleton-line.is-breadcrumb {
  width: 180px;
  height: 14px;
}

.service-skeleton-pill {
  width: 132px;
  min-height: 34px;
}

.service-skeleton-pill.is-button {
  width: 100%;
  min-height: 42px;
  border-radius: 999px;
}

.service-skeleton-avatar {
  width: 88px;
  height: 88px;
  border-radius: 50%;
  box-shadow: 0 0 0 3px #fff, 0 0 0 4px rgba(17, 24, 39, 0.1);
}

.service-skeleton-stats em {
  display: block;
  width: 42px;
  height: 10px;
  margin: 4px auto 0;
  border-radius: 999px;
  background: rgba(17, 24, 39, 0.08);
}

.service-skeleton-grid {
  min-height: 360px;
}

.service-skeleton-photo {
  aspect-ratio: 3 / 4;
  border-radius: 0;
}

.service-skeleton-card-media {
  aspect-ratio: 3 / 4;
  width: 100%;
  border-radius: 10px;
}

.service-skeleton-team-grid .native-vendor-card {
  gap: 12px;
}

.service-detail-content {
  animation: serviceDetailContentIn 180ms ease-out both;
}

@keyframes serviceDetailContentIn {
  from {
    opacity: 0;
    filter: blur(3px);
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    filter: blur(0);
    transform: translateY(0);
  }
}

.bridal-vendor,
.service-team-card,
.catalog-card {
  position: relative;
}

.app-bottom-sheet {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  align-items: end;
  pointer-events: none;
}

.app-bottom-sheet-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(36, 24, 21, 0.28);
  opacity: 0;
  transition: opacity 180ms ease;
}

.app-bottom-sheet-panel {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 12px;
  width: min(680px, calc(100% - 20px));
  margin: 0 auto max(10px, env(safe-area-inset-bottom));
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 22px 22px 14px 14px;
  background: rgba(255, 250, 246, 0.96);
  box-shadow: 0 -24px 70px rgba(36, 24, 21, 0.22);
  transform: translateY(105%);
  transition: transform 260ms cubic-bezier(0.2, 0.8, 0.2, 1);
  pointer-events: auto;
  backdrop-filter: blur(18px);
}

.app-bottom-sheet.is-open {
  pointer-events: auto;
}

.app-bottom-sheet.is-open .app-bottom-sheet-backdrop {
  opacity: 1;
}

.app-bottom-sheet.is-open .app-bottom-sheet-panel {
  transform: translateY(0);
}

.app-bottom-sheet.is-closing .app-bottom-sheet-backdrop {
  opacity: 0;
}

.app-bottom-sheet.is-closing .app-bottom-sheet-panel {
  transform: translateY(105%);
}

.app-sheet-handle {
  justify-self: center;
  width: 48px;
  height: 5px;
  padding: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(36, 24, 21, 0.18);
}

.app-sheet-media img {
  width: 100%;
  max-height: 280px;
  object-fit: cover;
  border-radius: 14px;
}

.app-bottom-sheet-panel h2 {
  margin: 0;
  font-size: 1.1rem;
}

.app-bottom-sheet-panel p {
  margin: 0;
  color: var(--muted);
}

.pull-refresh-indicator {
  position: fixed;
  top: calc(12px + env(safe-area-inset-top));
  left: 50%;
  z-index: 1300;
  transform: translate(-50%, calc(-120% + var(--pull, 0px)));
  padding: 9px 14px;
  border-radius: 999px;
  background: rgba(36, 24, 21, 0.86);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 800;
  opacity: 0;
  pointer-events: none;
  transition: opacity 140ms ease;
}

.pull-refresh-indicator.is-visible {
  opacity: 1;
}

.pull-refresh-indicator.is-ready {
  background: var(--accent);
}

body.is-swipe-peeking::before {
  content: "";
  position: fixed;
  inset: 0 auto 0 0;
  z-index: 1400;
  width: 5px;
  background: var(--accent);
  box-shadow: 0 0 28px rgba(17, 24, 39, 0.55);
  pointer-events: none;
}

.virtual-list {
  position: relative;
  overflow: auto;
  contain: layout paint;
}

.virtual-list-viewport {
  position: absolute;
  inset: 0 0 auto 0;
  will-change: transform;
}

.app-fab {
  position: fixed;
  right: 18px;
  bottom: calc(88px + env(safe-area-inset-bottom));
  z-index: 900;
  display: none;
  justify-items: end;
  gap: 10px;
}

.app-fab-main {
  width: 52px;
  height: 52px;
  border: 0;
  border-radius: 50%;
  background: var(--accent);
  color: #fff;
  font-size: 1.65rem;
  line-height: 1;
  box-shadow: 0 16px 34px rgba(94, 36, 53, 0.28);
}

.app-fab.is-open .app-fab-main {
  transform: rotate(45deg);
}

.app-fab-menu {
  display: grid;
  gap: 8px;
  margin-bottom: 2px;
}

.app-fab-menu a {
  min-width: 116px;
  padding: 10px 12px;
  border-radius: 999px;
  background: rgba(255, 250, 246, 0.94);
  color: var(--accent-deep);
  font-size: 0.82rem;
  font-weight: 800;
  text-align: center;
  text-decoration: none;
  box-shadow: 0 12px 28px rgba(36, 24, 21, 0.13);
  backdrop-filter: blur(14px);
}

@media (max-width: 760px) {
  .app-fab {
    display: grid;
  }
}

.message-bubble {
  animation: messageBubbleIn 220ms cubic-bezier(0.2, 0.8, 0.2, 1);
}

.message-bubble.is-pending {
  opacity: 0.72;
  filter: saturate(0.85);
}

.message-bubble.is-mine {
  transform-origin: right bottom;
}

.message-bubble:not(.is-mine) {
  transform-origin: left bottom;
}

@keyframes messageBubbleIn {
  from {
    opacity: 0;
    transform: translateY(8px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.typing-indicator {
  margin: -4px 0 8px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.offline-shell {
  min-height: 100svh;
  display: grid;
  place-items: center;
  padding: 24px;
}

.offline-card {
  width: min(560px, 100%);
  display: grid;
  gap: 14px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 250, 246, 0.9);
  box-shadow: var(--shadow);
}

.offline-card h1,
.offline-card p {
  margin: 0;
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }

  .app-route-enter,
  .app-route-leave,
  .app-reveal,
  .app-img-loading {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
  }
}

.sr-only,
.hidden-field {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}

.skip-link {
  position: fixed;
  top: 14px;
  left: 14px;
  z-index: 3000;
  transform: translateY(-140%);
  background: var(--text);
  color: var(--white);
  padding: 12px 16px;
  text-decoration: none;
}

.skip-link:focus {
  transform: translateY(0);
}

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 1000;
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid rgba(17, 24, 39, 0.08);
  box-shadow: 0 10px 30px rgba(17, 24, 39, 0.035);
  backdrop-filter: blur(14px);
  transition: background 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease;
}

.site-header.is-scrolled,
.site-header.is-open {
  background: rgba(255, 255, 255, 0.98);
  border-bottom: 1px solid var(--line);
  box-shadow: 0 10px 30px rgba(17, 24, 39, 0.04);
  backdrop-filter: blur(14px);
}

.nav-shell {
  width: min(100% - 48px, var(--content-max));
  min-height: 86px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
}

.logo {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 2rem;
  font-weight: 500;
  color: var(--text);
  text-decoration: none;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 18px;
}

.nav-links a {
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 500;
  letter-spacing: 0.1em;
  text-decoration: none;
  text-transform: uppercase;
  transition: color 0.2s ease;
}

.nav-links a:hover {
  color: var(--accent);
}

.nav-social-link {
  width: 38px;
  height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.5);
}

.nav-social-link svg {
  width: 18px;
  height: 18px;
  fill: none;
  stroke: currentColor;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 1.8;
}

.nav-toggle {
  display: none;
  width: 44px;
  height: 44px;
  border: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.55);
  border-radius: var(--radius);
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 5px;
  cursor: pointer;
}

.nav-toggle span:not(.sr-only) {
  width: 18px;
  height: 1px;
  background: var(--text);
  display: block;
}

.section-band,
.section-block,
.form-section,
.lead-module,
.campaign-banner {
  width: min(100% - 72px, var(--content-max));
  margin: 0 auto;
}

.campaign-banner {
  display: grid;
  grid-template-columns: minmax(380px, 1.08fr) minmax(250px, 0.62fr) minmax(250px, 0.62fr);
  gap: 8px;
  margin-top: 100px;
  overflow: hidden;
  border-radius: var(--radius);
  box-shadow: 0 14px 34px rgba(36, 24, 21, 0.055);
}

.campaign-tile {
  min-height: 238px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 24px;
  background: var(--bg-warm);
  border: 1px solid rgba(36, 24, 21, 0.08);
  position: relative;
}

.campaign-tile::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.45;
  pointer-events: none;
}

.campaign-tile > * {
  position: relative;
}

.campaign-tile-large {
  background: #efe4d8;
}

.campaign-tile-large::before {
  background:
    radial-gradient(circle at 84% 18%, rgba(17, 24, 39, 0.1), transparent 112px),
    linear-gradient(135deg, rgba(255, 255, 255, 0.34), transparent 45%);
}

.campaign-tile-picks {
  background: #f3ebe4;
}

.campaign-tile-picks::before {
  background:
    radial-gradient(circle at 82% 22%, rgba(17, 24, 39, 0.12), transparent 118px),
    linear-gradient(135deg, rgba(255, 255, 255, 0.3), transparent 42%);
}

.campaign-tile-stories {
  background: #e6ddd3;
}

.campaign-tile-stories::before {
  background:
    radial-gradient(circle at 82% 20%, rgba(104, 114, 97, 0.12), transparent 118px),
    linear-gradient(135deg, rgba(255, 255, 255, 0.28), transparent 44%);
}

.campaign-kicker {
  margin-bottom: 10px;
  color: var(--accent-deep);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  line-height: 1.2;
  text-transform: uppercase;
}

.trust-promise {
  display: grid;
  grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
  gap: clamp(28px, 6vw, 96px);
  align-items: start;
  margin-top: 72px;
  padding: clamp(30px, 5vw, 54px);
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
  box-shadow: 0 16px 44px rgba(36, 24, 21, 0.05);
}

.trust-promise h2 {
  max-width: 560px;
  margin: 0;
  font-size: clamp(2.2rem, 5vw, 4.7rem);
  line-height: 0.95;
}

.trust-promise-copy {
  display: grid;
  gap: 18px;
}

.trust-promise-copy p {
  margin: 0;
  color: var(--text);
  font-size: clamp(1rem, 1.35vw, 1.18rem);
  line-height: 1.65;
}

.campaign-tile h2,
.campaign-tile h3 {
  max-width: 580px;
  margin-bottom: 10px;
}

.campaign-tile h2 {
  font-size: 2.65rem;
}

.campaign-tile h3 {
  font-size: 1.85rem;
}

.campaign-tile p:not(.campaign-kicker) {
  max-width: 540px;
  margin-bottom: 16px;
  color: rgba(36, 24, 21, 0.78);
  line-height: 1.55;
}

.campaign-tile a {
  width: fit-content;
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.13em;
  text-decoration: none;
  text-transform: uppercase;
}

.hero {
  width: 100%;
  max-width: none;
  margin: 0;
  min-height: 100vh;
  padding: 132px max(24px, calc((100vw - var(--content-max)) / 2)) 72px;
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(520px, 1.1fr);
  align-items: center;
  gap: clamp(48px, 5vw, 96px);
}

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

.eyebrow {
  margin: 0 0 18px;
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

h1,
h2,
h3,
p,
figure,
blockquote {
  margin-top: 0;
}

h1,
h2,
h3 {
  font-family: "Cormorant Garamond", Georgia, serif;
  font-weight: 500;
}

h1 {
  margin-bottom: 26px;
  font-size: 6rem;
  line-height: 0.92;
}

h2 {
  margin-bottom: 24px;
  font-size: 4rem;
  line-height: 1;
}

h3 {
  margin-bottom: 14px;
  font-size: 1.8rem;
  line-height: 1.05;
}

p {
  color: var(--muted);
  line-height: 1.85;
}

.hero-lede {
  max-width: 510px;
  font-size: 1rem;
}

.button-row,
.form-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
}

.button-row {
  margin-top: 38px;
}

.btn {
  border: 1px solid transparent;
  border-radius: var(--radius);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 52px;
  padding: 15px 28px;
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 600;
  letter-spacing: 0.14em;
  line-height: 1.2;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  transition: transform 0.2s ease, background 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.btn-primary {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--white);
}

.btn-primary:hover {
  background: var(--accent-deep);
  border-color: var(--accent-deep);
  box-shadow: 0 12px 24px rgba(17, 24, 39, 0.14);
  transform: translateY(-2px);
}

.btn-outline {
  background: transparent;
  border-color: rgba(36, 24, 21, 0.2);
}

.btn-outline:hover {
  background: var(--white);
  border-color: rgba(36, 24, 21, 0.3);
}

.hero-image,
.split-image,
.gallery-card {
  margin: 0;
  overflow: hidden;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.hero-image {
  width: 100%;
  height: min(760px, 80vh);
  min-height: 600px;
  box-shadow: var(--shadow);
}

.hero-image img,
.split-image img,
.gallery-card img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.hero-image picture,
.split-image picture,
.gallery-card picture {
  display: block;
  width: 100%;
  height: 100%;
}

.milaashes-responsive-picture {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: #f3f4f6;
  background-position: center;
  background-size: cover;
}

.milaashes-responsive-picture img {
  opacity: 0;
  transition: opacity 180ms ease;
}

.milaashes-responsive-picture.is-loaded img {
  opacity: 1;
}

.availability-band {
  background: var(--bg-warm);
  border-block: 1px solid var(--line);
  padding: 62px 24px;
  text-align: center;
}

.narrow-copy {
  max-width: 820px;
  margin: 0 auto;
}

.availability-band h2 {
  color: var(--accent);
  font-size: 3.25rem;
}

.availability-date {
  margin-bottom: 10px;
  color: var(--text);
  font-weight: 600;
}

.split-section {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  min-height: 760px;
}

.split-content {
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 90px max(48px, calc((100vw - var(--content-max)) / 2)) 90px 72px;
  background: var(--bg-soft);
}

.split-about .split-content {
  padding-left: max(48px, calc((100vw - var(--content-max)) / 2));
  padding-right: 72px;
  background: var(--bg);
}

.split-content p {
  max-width: 540px;
}

.split-image {
  min-height: 620px;
  border-radius: 0;
}

.portrait-crop img {
  object-position: center 22%;
}

.section-block {
  padding: 112px 0;
}

.section-heading {
  max-width: 680px;
}

.section-heading h2 {
  margin-bottom: 22px;
}

.page-hero {
  padding-top: 150px;
  padding-bottom: 36px;
}

.page-hero h1 {
  margin-bottom: 24px;
}

.service-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 22px;
  margin-top: 52px;
}

.service-card {
  min-height: 220px;
  padding: 34px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.service-card p {
  min-height: 92px;
  margin-bottom: 0;
}

.service-card a {
  width: fit-content;
  display: inline-flex;
  margin-top: 24px;
  color: var(--accent);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-decoration: none;
  text-transform: uppercase;
}

.home-shop-section {
  padding-top: 72px;
  padding-bottom: 58px;
}

.home-shop-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 34px;
}

.home-shop-card {
  min-height: 240px;
  display: grid;
  align-content: end;
  overflow: hidden;
  position: relative;
  color: var(--white);
  background: var(--text);
  border-radius: var(--radius);
  text-decoration: none;
}

.home-shop-card picture,
.home-shop-card img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.home-shop-card img {
  object-fit: cover;
  opacity: 0.82;
  transition: transform 0.25s ease, opacity 0.25s ease;
}

.home-shop-card::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, transparent 18%, rgba(36, 24, 21, 0.72));
}

.home-shop-card:hover img {
  opacity: 0.92;
  transform: scale(1.04);
}

.home-shop-card span,
.home-shop-card strong {
  position: relative;
  z-index: 1;
}

.home-shop-card > span,
.home-shop-card-text strong {
  padding: 18px;
  font-size: 0.82rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.home-shop-card-text {
  padding: 22px;
  align-content: center;
  gap: 12px;
  color: var(--text);
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(239, 228, 216, 0.96)),
    var(--bg-warm);
  border: 1px solid var(--line);
}

.home-shop-card-text strong {
  padding: 0;
  color: var(--accent);
}

.home-shop-card-text span {
  color: var(--muted);
  font-size: 0.96rem;
  line-height: 1.7;
}

.home-section-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 28px;
}

.destination-home-panel,
.destination-shop-strip {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(150px, 240px) auto;
  gap: 18px;
  align-items: center;
  min-width: 0;
  width: min(1120px, calc(100% - 32px));
  margin-inline: auto;
  padding: 20px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 18px 44px rgba(36, 24, 21, 0.08);
}

.destination-shop-strip {
  grid-template-columns: minmax(0, 1fr) auto;
  margin-top: 16px;
}

.destination-home-copy,
.destination-shop-strip > div {
  min-width: 0;
}

.destination-home-panel h2,
.destination-shop-strip h2 {
  margin: 4px 0 8px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.7rem, 4vw, 3rem);
  line-height: 0.98;
  letter-spacing: 0;
}

.destination-shop-strip h2 {
  font-family: "Inter", Arial, sans-serif;
  font-size: clamp(1.15rem, 3vw, 1.65rem);
  line-height: 1.08;
  font-weight: 700;
}

.destination-home-panel p,
.destination-shop-strip p {
  max-width: 720px;
  margin: 0;
  color: #111;
  line-height: 1.55;
}

.destination-home-photo {
  width: 100%;
  margin: 0;
  overflow: hidden;
  background: #f7f7f8;
  border-radius: 8px;
}

.destination-home-photo img {
  width: 100%;
  aspect-ratio: 4 / 3;
  display: block;
  object-fit: cover;
  filter: saturate(0.92) brightness(1.08);
}

.destination-home-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

.home-bridal-section {
  padding-top: 72px;
  padding-bottom: 82px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.42), rgba(239, 228, 216, 0.35));
  border-block: 1px solid var(--line);
}

.home-bridal-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 34px;
}

.home-bridal-grid a {
  min-height: 168px;
  display: grid;
  align-content: space-between;
  gap: 18px;
  padding: 18px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.64);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  text-decoration: none;
  transition: transform 0.2s ease, background 0.2s ease, border-color 0.2s ease;
}

.home-bridal-grid a:hover {
  background: var(--white);
  border-color: rgba(17, 24, 39, 0.24);
  transform: translateY(-2px);
}

.home-bridal-grid strong {
  color: var(--accent);
  font-size: 1.1rem;
}

.home-bridal-grid span {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.55;
}

.recommendations-section {
  padding-top: 40px;
}

.affiliate-disclosure {
  max-width: 760px;
  margin: 26px 0 0;
  color: var(--muted);
  font-size: 0.86rem;
}

.recommendations-grid {
  display: grid;
  gap: 24px;
  margin-top: 48px;
}

.recommendations-section .recommendations-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.recommendation-card {
  display: grid;
  grid-template-columns: minmax(210px, 0.75fr) minmax(280px, 0.85fr) minmax(320px, 1fr);
  gap: 28px;
  align-items: center;
  padding: 30px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.recommendation-card[hidden] {
  display: none;
}

.recommendation-shelf-item {
  display: grid;
  grid-template-columns: minmax(250px, 0.42fr) minmax(0, 1fr);
  gap: 26px;
  align-items: center;
  padding: 24px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.recommendation-shelf-copy h3 {
  font-size: 2rem;
}

.recommendation-shelf-copy p:last-child {
  margin-bottom: 0;
}

.recommendation-copy h3,
.recommendation-video h3 {
  font-size: 2rem;
}

.recommendation-copy p:last-child,
.recommendation-video p:last-of-type {
  margin-bottom: 0;
}

.recommendation-label {
  margin-bottom: 12px;
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.2em;
  text-transform: uppercase;
}

.recommendation-product {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
}

.recommendation-product iframe {
  display: block;
  width: 280px;
  max-width: 100%;
  height: 360px;
  border: 0;
  background: var(--white);
}

.recommendation-order-link {
  width: min(100%, 280px);
  min-height: 44px;
  padding: 13px 18px;
  text-align: center;
}

.recommendation-video {
  min-width: 0;
}

.recommendation-video .eyebrow {
  margin-bottom: 12px;
}

.youtube-frame {
  position: relative;
  overflow: hidden;
  width: 100%;
  margin-top: 22px;
  aspect-ratio: 16 / 9;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.youtube-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.recommendation-video-link {
  width: fit-content;
  min-width: 180px;
  margin-top: 22px;
}

.recommendations-actions {
  display: flex;
  justify-content: center;
  margin-top: 32px;
}

.recommendations-toggle {
  min-width: 260px;
}

.recommendations-page-section {
  padding-top: 28px;
}

.shop-hero {
  padding-top: 150px;
  padding-bottom: 34px;
}

.region-switch,
.category-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.region-switch button,
.category-tabs button {
  min-height: 44px;
  padding: 12px 18px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.56);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  cursor: pointer;
}

.region-switch button.is-active,
.category-tabs button.is-active {
  color: var(--white);
  background: var(--accent);
  border-color: var(--accent);
}

.shop-shell {
  padding-top: 34px;
  padding-bottom: 132px;
}

.shop-shell,
.bridal-shell,
.catalog-grid,
.catalog-card,
.bridal-grid,
.bridal-card,
.bridal-card-summary,
.bridal-card-panel,
.bridal-card-media,
.bridal-vendors,
.bridal-vendor,
.bridal-vendor-media,
.bridal-vendor-body {
  min-width: 0;
  max-width: 100%;
}

.shop-shell,
.bridal-shell {
  width: 100%;
  overflow-x: hidden;
}

@supports (overflow-x: clip) {
  .shop-shell,
  .bridal-shell,
  .bridal-card {
    overflow-x: clip;
  }
}

.shop-toolbar {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 28px;
}

.shop-toolbar h2 {
  margin-bottom: 0;
}

.shop-note,
.catalog-empty {
  max-width: 760px;
  margin: 28px 0 0;
  color: var(--muted);
}

.bridal-status {
  max-width: 760px;
  margin: 16px 0 0;
  padding: 12px 14px;
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.08);
  border: 1px solid rgba(17, 24, 39, 0.16);
  border-radius: var(--radius);
}

.bridal-status[data-mode="soft"] {
  color: var(--sage);
  background: rgba(104, 114, 97, 0.1);
  border-color: rgba(104, 114, 97, 0.18);
}

.catalog-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 34px;
}

.catalog-card {
  display: grid;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.catalog-card-image {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--bg-warm);
}

.catalog-card-image picture,
.catalog-card-image img {
  display: block;
  width: 100%;
  height: 100%;
}

.catalog-card-image img {
  object-fit: cover;
}

.catalog-main-image,
.catalog-photo-thumb,
.bridal-vendor-main-image,
.bridal-vendor-thumb {
  width: 100%;
  height: 100%;
  padding: 0;
  display: block;
  overflow: hidden;
  background: transparent;
  border: 0;
  border-radius: var(--radius);
  cursor: zoom-in;
}

.catalog-main-image picture,
.catalog-main-image img,
.catalog-photo-thumb picture,
.catalog-photo-thumb img,
.bridal-vendor-main-image picture,
.bridal-vendor-main-image img,
.bridal-vendor-thumb picture,
.bridal-vendor-thumb img {
  display: block;
  width: 100%;
  height: 100%;
}

.catalog-main-image img,
.catalog-photo-thumb img,
.bridal-vendor-main-image img,
.bridal-vendor-thumb img {
  object-fit: cover;
  transition: transform 0.2s ease;
}

.catalog-main-image:hover img,
.catalog-photo-thumb:hover img,
.bridal-vendor-main-image:hover img,
.bridal-vendor-thumb:hover img {
  transform: scale(1.03);
}

.catalog-card-body {
  display: flex;
  flex-direction: column;
  padding: 20px;
}

.catalog-card-region {
  margin-bottom: 10px;
  color: var(--accent);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.catalog-card-body h3 {
  margin-bottom: 10px;
  font-size: 1.85rem;
}

.catalog-card-body h3 a {
  color: inherit;
  text-decoration: none;
}

.catalog-card-price {
  margin-bottom: 12px;
  color: var(--text);
  font-weight: 700;
}

.catalog-card-owner {
  margin-bottom: 6px;
  color: var(--muted);
  font-size: 0.82rem;
}

.catalog-card-location {
  margin-bottom: 10px;
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 700;
}

.catalog-card-note {
  margin-bottom: 18px;
  color: var(--muted);
  font-size: 0.94rem;
}

.catalog-photo-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 16px;
}

.catalog-photo-strip picture {
  aspect-ratio: 1 / 1;
  display: block;
  overflow: hidden;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.catalog-photo-thumb {
  aspect-ratio: 1 / 1;
}

.catalog-profile-link {
  width: fit-content;
  display: inline-flex;
  margin-bottom: 16px;
  color: var(--accent);
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-decoration: none;
  text-transform: uppercase;
}

.catalog-direct {
  width: 100%;
  margin-top: auto;
}

.bridal-hero {
  padding-top: 150px;
  padding-bottom: 36px;
}

.bridal-hero .section-heading {
  max-width: 820px;
}

.bridal-hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 34px;
}

.bridal-shell {
  padding-top: 36px;
  padding-bottom: 132px;
}

.bridal-search {
  width: min(100%, 430px);
  display: block;
}

.bridal-pincode {
  width: min(100%, 180px);
}

.bridal-search input {
  width: 100%;
  min-height: 50px;
  padding: 13px 16px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.bridal-filter-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 10px;
  overflow: visible;
  margin-top: 28px;
  padding: 4px 2px 8px;
  scrollbar-width: none;
}

.bridal-filter-row::-webkit-scrollbar {
  height: 5px;
}

.bridal-filter-row button {
  width: 100%;
  min-height: 42px;
  padding: 10px 8px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 0.84rem;
}

.bridal-filter-row button.is-active {
  color: var(--white);
  background: var(--accent);
  border-color: var(--accent);
}

.bridal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  margin-top: 34px;
}

.bridal-card {
  padding: 22px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.bridal-card-disabled {
  opacity: 0.76;
}

.bridal-card-summary {
  display: grid;
  gap: 16px;
  color: inherit;
  text-decoration: none;
}

.bridal-card-summary[aria-disabled="true"] {
  cursor: default;
}

.bridal-card-media {
  position: relative;
  aspect-ratio: 4 / 3;
  margin: -10px -10px 0;
  overflow: hidden;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.bridal-card-media picture,
.bridal-card-media img {
  display: block;
  width: 100%;
  height: 100%;
}

.bridal-card-media img {
  object-fit: cover;
  transition: transform 0.24s ease;
}

.bridal-card-summary:hover .bridal-card-media img {
  transform: scale(1.04);
}

.bridal-card-disabled .bridal-card-summary:hover .bridal-card-media img {
  transform: none;
}

.bridal-card-preview {
  position: absolute;
  left: 10px;
  right: 10px;
  bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px;
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: var(--radius);
  backdrop-filter: blur(10px);
  min-width: 0;
}

.bridal-card-preview-thumb {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  overflow: hidden;
  border: 2px solid var(--white);
  border-radius: calc(var(--radius) - 2px);
  box-shadow: 0 6px 14px rgba(36, 24, 21, 0.12);
}

.bridal-card-preview-thumb picture,
.bridal-card-preview-thumb img {
  display: block;
  width: 100%;
  height: 100%;
}

.bridal-card-preview-thumb img {
  object-fit: cover;
}

.bridal-card-preview-label {
  min-width: 0;
  margin-left: auto;
  color: var(--accent-deep);
  font-size: 0.64rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.bridal-card-open {
  width: fit-content;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 14px;
  color: var(--white);
  background: var(--accent);
  border-radius: var(--radius);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.bridal-card-panel {
  display: grid;
  gap: 18px;
  margin-top: 18px;
}

.bridal-card-top h3 {
  margin-bottom: 10px;
}

.bridal-card-group,
.bridal-card-range,
.bridal-card-count {
  width: fit-content;
  padding: 6px 10px;
  color: var(--accent);
  background: rgba(17, 24, 39, 0.08);
  border: 1px solid rgba(17, 24, 39, 0.14);
  border-radius: var(--radius);
  font-size: 0.68rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.bridal-card-short {
  margin-bottom: 14px;
}

.bridal-card-range {
  color: var(--text);
  background: rgba(104, 114, 97, 0.1);
  border-color: rgba(104, 114, 97, 0.16);
}

.bridal-card-count {
  margin-top: 10px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.68);
  border-color: var(--line);
}

.bridal-card-details {
  display: grid;
  gap: 10px;
}

.bridal-detail {
  display: grid;
  gap: 4px;
  padding: 0;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.58);
}

.bridal-detail summary {
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 12px;
  color: var(--text);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  list-style: none;
}

.bridal-detail summary::-webkit-details-marker {
  display: none;
}

.bridal-detail summary::after {
  content: "+";
  color: var(--accent-deep);
  font-size: 1rem;
  line-height: 1;
}

.bridal-detail[open] summary::after {
  content: "-";
}

.bridal-detail span {
  display: block;
  padding: 0 12px 12px;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.65;
}

.service-check-list {
  display: grid;
  gap: 10px;
  padding: 0 12px 12px;
}

.service-check-list p {
  display: grid;
  gap: 3px;
  margin: 0;
}

.service-check-list strong,
.service-check-list span {
  padding: 0;
}

.service-check-list strong {
  color: var(--text);
  font-size: 0.82rem;
  font-weight: 900;
}

.service-check-list span {
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.55;
}

.bridal-vendors {
  display: grid;
  gap: 12px;
}

.bridal-vendor {
  display: grid;
  grid-template-columns: minmax(120px, 0.34fr) minmax(0, 0.66fr);
  gap: 14px;
  padding: 12px;
  background: rgba(247, 241, 235, 0.76);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.bridal-vendor-placeholder {
  background: rgba(255, 255, 255, 0.44);
}

.bridal-vendor-media {
  min-height: 156px;
  display: grid;
  gap: 8px;
}

.bridal-vendor-main-image {
  aspect-ratio: 4 / 5;
  background: var(--bg-warm);
}

.bridal-vendor-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.bridal-vendor-thumb {
  aspect-ratio: 1 / 1;
  background: var(--bg-warm);
}

.bridal-vendor-empty {
  min-height: 156px;
  display: grid;
  place-items: center;
  padding: 16px;
  color: var(--muted);
  background:
    linear-gradient(135deg, rgba(17, 24, 39, 0.06), rgba(104, 114, 97, 0.07)),
    var(--bg-warm);
  border: 1px dashed rgba(36, 24, 21, 0.2);
  border-radius: var(--radius);
  font-size: 0.82rem;
  text-align: center;
}

.bridal-vendor-body h4 {
  margin: 0 0 6px;
  font-size: 1rem;
}

.bridal-vendor-area,
.bridal-vendor-note {
  margin-bottom: 8px;
  font-size: 0.84rem;
  line-height: 1.55;
}

.bridal-vendor-rate {
  margin-bottom: 8px;
  color: var(--text);
  font-size: 0.86rem;
  font-weight: 800;
}

.bridal-vendor-coverage {
  margin-bottom: 8px;
  padding: 8px 10px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.55);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 0.78rem;
  line-height: 1.45;
}

.bridal-vendor-coverage-available {
  color: #35543a;
  background: rgba(104, 114, 97, 0.12);
  border-color: rgba(104, 114, 97, 0.22);
}

.bridal-vendor-coverage-outside,
.bridal-vendor-coverage-unknown {
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.08);
  border-color: rgba(17, 24, 39, 0.18);
}

.bridal-vendor.is-outside-coverage {
  opacity: 0.86;
}

.bridal-vendor-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.bridal-vendor-link {
  min-height: 40px;
  padding: 10px 12px;
  font-size: 0.66rem;
  letter-spacing: 0.1em;
}

.bridal-vendor-actions > :only-child {
  grid-column: 1 / -1;
}

.media-lightbox[hidden] {
  display: none;
}

body.is-lightbox-open {
  overflow: hidden;
}

.media-lightbox {
  position: fixed;
  inset: 0;
  z-index: 4000;
  display: grid;
  place-items: center;
  padding: 20px;
}

.media-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(36, 24, 21, 0.78);
  border: 0;
  cursor: pointer;
}

.media-lightbox-dialog {
  position: relative;
  width: min(100%, 960px);
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) 58px;
  align-items: center;
  gap: 12px;
}

.media-lightbox figure {
  margin: 0;
  overflow: hidden;
  background: var(--bg);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}

.media-lightbox picture {
  display: block;
  height: min(76vh, 760px);
  background: var(--bg-warm);
}

.media-lightbox img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.media-lightbox figcaption {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 16px;
  color: var(--text);
  background: var(--white);
  font-size: 0.86rem;
}

.media-lightbox-product {
  display: grid;
  gap: 8px;
  padding: 14px 16px 16px;
  color: var(--text);
  background: #fff;
  border-top: 1px solid rgba(17, 24, 39, 0.1);
}

.media-lightbox-product[hidden] {
  display: none;
}

.media-lightbox-product strong {
  font-size: 1rem;
  font-weight: 900;
}

.media-lightbox-product p {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

.media-lightbox-product .btn {
  width: 100%;
  min-height: 42px;
}

.media-lightbox-close,
.media-lightbox-nav {
  min-height: 48px;
  color: var(--white);
  background: rgba(255, 255, 255, 0.14);
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: var(--radius);
  cursor: pointer;
}

.media-lightbox-close {
  position: absolute;
  top: -58px;
  right: 0;
  padding: 10px 16px;
}

.vendor-photo-lightbox {
  padding: max(16px, env(safe-area-inset-top)) max(12px, env(safe-area-inset-right)) max(16px, env(safe-area-inset-bottom)) max(12px, env(safe-area-inset-left));
}

.vendor-photo-lightbox-dialog {
  width: min(100%, 1120px);
  max-height: calc(100dvh - 32px);
}

.vendor-photo-lightbox-figure {
  max-height: calc(100dvh - 72px);
}

.vendor-photo-lightbox-figure picture {
  height: min(78dvh, 760px);
  background: #050505;
}

.vendor-photo-lightbox-figure figcaption {
  min-height: 44px;
  align-items: center;
  font-weight: 800;
}

.vendor-photo-lightbox .media-lightbox-nav {
  width: 52px;
  height: 52px;
  align-self: center;
  border-radius: 999px;
  font-size: 1.35rem;
  font-weight: 900;
}

.vendor-photo-lightbox-close {
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.service-detail-page {
  padding-top: 122px;
  padding-bottom: 36px;
}

.service-detail-hero {
  max-width: 860px;
  display: grid;
  gap: 18px;
}

.service-detail-hero h1 {
  margin-bottom: 0;
}

.service-breadcrumbs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-bottom: 18px;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.service-breadcrumbs a {
  color: var(--accent-deep);
  text-decoration: none;
}

.service-breadcrumbs a:hover {
  text-decoration: underline;
}

.service-breadcrumbs strong {
  color: var(--text);
}

.vendor-instagram-profile {
  max-width: 980px;
  margin: 0 auto;
  padding: 20px 0 14px;
  background: #fff;
  border-bottom: 1px solid rgba(17, 24, 39, 0.1);
}

.vendor-ig-header {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 24px;
  align-items: center;
}

.vendor-ig-avatar-shell {
  display: grid;
  place-items: center;
}

.vendor-ig-avatar {
  width: 116px;
  height: 116px;
  display: grid;
  place-items: center;
  padding: 0;
  overflow: hidden;
  color: #111;
  background: #f3f4f6;
  border: 3px solid #fff;
  border-radius: 50%;
  box-shadow: 0 0 0 2px rgba(17, 24, 39, 0.12);
  font-size: 2.5rem;
  font-weight: 900;
  cursor: default;
}

.vendor-ig-avatar picture,
.vendor-ig-avatar img,
.vendor-ig-photo-tile picture,
.vendor-ig-photo-tile img {
  width: 100%;
  height: 100%;
  display: block;
}

.vendor-ig-avatar img,
.vendor-ig-photo-tile img {
  object-fit: cover;
}

.vendor-ig-summary {
  min-width: 0;
  display: grid;
  gap: 12px;
}

.vendor-ig-title-row h1 {
  margin: 2px 0 0;
  font-family: "Inter", Arial, sans-serif;
  font-size: clamp(1.45rem, 4.8vw, 2.45rem);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: 0;
  overflow-wrap: anywhere;
}

.verified-badge {
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  margin-left: 7px;
  translate: 0 -1px;
  color: #7b5200;
  background: linear-gradient(135deg, #fff4b8, #d6a21e);
  border: 1px solid #b8860b;
  border-radius: 999px;
  box-shadow: 0 1px 4px rgba(123, 82, 0, 0.22);
  font-family: "Inter", Arial, sans-serif;
  font-size: 0.72rem;
  font-weight: 1000;
  line-height: 1;
  vertical-align: middle;
}

.vendor-ig-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.vendor-ig-stats span {
  display: grid;
  gap: 2px;
  color: var(--text);
  text-align: center;
}

.vendor-ig-stats strong {
  font-size: 1.05rem;
  font-weight: 900;
  line-height: 1;
}

.vendor-ig-stats em {
  color: var(--text);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 700;
}

.vendor-ig-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.is-owner-profile .vendor-ig-actions {
  grid-template-columns: 1fr;
}

.vendor-ig-actions .btn {
  min-height: 42px;
  border-radius: 8px;
}

.vendor-owner-profile-tools,
.vendor-owner-shop-tools {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(17, 24, 39, 0.1);
}

.vendor-owner-profile-tools > span,
.vendor-owner-shop-tools > span {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.vendor-owner-profile-tools strong,
.vendor-owner-shop-tools strong {
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 900;
}

.vendor-owner-profile-tools em,
.vendor-owner-shop-tools em {
  color: var(--text);
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 650;
  line-height: 1.25;
}

.vendor-owner-inline-buttons {
  flex: 0 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 7px;
}

.vendor-owner-icon-link,
.vendor-owner-chip-link {
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: #111;
  background: #f3f4f6;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 900;
  text-decoration: none;
  white-space: nowrap;
}

.vendor-owner-icon-link {
  min-width: 58px;
  padding: 0 13px;
}

.vendor-owner-chip-link {
  padding: 0 12px;
}

.vendor-instagram-profile .eyebrow,
.vendor-ig-tabs-shell .eyebrow,
.vendor-ig-tabs-shell .reviews-empty {
  color: var(--text);
}

.vendor-ig-bio {
  display: grid;
  gap: 6px;
  margin-top: 14px;
  color: var(--text);
}

.vendor-ig-bio strong,
.vendor-ig-bio p {
  margin: 0;
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.45;
}

.vendor-ig-bio a {
  width: fit-content;
  color: #1d4ed8;
  font-size: 0.92rem;
  font-weight: 800;
  text-decoration: none;
}

.vendor-ig-highlight-row {
  display: flex;
  gap: 10px;
  margin-top: 14px;
  padding-bottom: 4px;
  overflow-x: auto;
  scrollbar-width: none;
}

.vendor-ig-highlight-row::-webkit-scrollbar {
  display: none;
}

.vendor-ig-highlight-row span {
  min-width: 86px;
  min-height: 74px;
  display: grid;
  place-items: center;
  padding: 10px;
  color: var(--text);
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 999px;
  box-shadow: inset 0 0 0 6px #f3f4f6;
  font-size: 0.72rem;
  font-weight: 850;
  line-height: 1.25;
  text-align: center;
  white-space: normal;
}

.vendor-ig-meta-line {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  gap: 7px 14px;
  margin-top: 12px;
  color: var(--text);
  font-size: 0.86rem;
  font-weight: 760;
  line-height: 1.35;
}

.vendor-ig-meta-line > span {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-width: 0;
}

.vendor-ig-meta-line > span:not(:last-child)::after {
  content: "";
  width: 4px;
  height: 4px;
  margin-left: 14px;
  background: rgba(17, 24, 39, 0.28);
  border-radius: 999px;
}

.vendor-ig-location-meta {
  flex-wrap: wrap;
  gap: 4px;
  color: var(--text);
}

.vendor-ig-location-more {
  min-width: 44px;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 6px;
  color: var(--accent);
  background: transparent;
  border: 0;
  font: inherit;
  font-weight: 900;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.vendor-ig-location-notes {
  position: absolute;
  left: 0;
  top: calc(100% + 8px);
  z-index: 1301;
  width: min(280px, 84vw);
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 8px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 10px;
  box-shadow: 0 14px 34px rgba(17, 24, 39, 0.14);
}

.vendor-ig-location-notes[hidden] {
  display: none;
}

.vendor-ig-location-notes em {
  padding: 5px 8px;
  color: var(--text);
  background: #f3f4f6;
  border-radius: 999px;
  font-size: 0.74rem;
  font-style: normal;
  font-weight: 850;
}

.vendor-ig-costs {
  margin-top: 8px;
}

.vendor-ig-tabs-shell {
  max-width: 980px;
  margin: 0 auto;
  background: #fff;
}

.vendor-ig-tabbar {
  position: sticky;
  top: 0;
  z-index: 1180;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  background: rgba(255, 255, 255, 0.96);
  border-bottom: 1px solid rgba(17, 24, 39, 0.12);
  backdrop-filter: blur(14px);
}

.vendor-ig-tab-button {
  min-height: 48px;
  color: var(--muted);
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.vendor-ig-tab-button.is-active {
  color: var(--text);
  border-bottom-color: var(--text);
}

.vendor-ig-tab-panel[hidden] {
  display: none;
}

.vendor-ig-photo-panel,
.vendor-ig-video-panel {
  display: grid;
  gap: 14px;
}

.vendor-ig-photo-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 3px;
}

.vendor-ig-photo-cell {
  position: relative;
  aspect-ratio: 3 / 4;
  min-width: 0;
  overflow: hidden;
  background: #f3f4f6;
}

.vendor-ig-photo-tile {
  width: 100%;
  height: 100%;
  padding: 0;
  overflow: hidden;
  background: #f3f4f6;
  border: 0;
  border-radius: 0;
  cursor: zoom-in;
}

.vendor-ig-forward-photo {
  position: absolute;
  right: 6px;
  bottom: 6px;
  z-index: 2;
  min-height: 28px;
  padding: 6px 9px;
  color: #fff;
  background: rgba(17, 24, 39, 0.82);
  border: 0;
  border-radius: 999px;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.24);
  font-size: 0.68rem;
  font-weight: 850;
}

.vendor-ig-forward-photo[hidden] {
  display: none;
}

.vendor-ig-video-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 12px;
  padding: 14px 0 0;
}

.vendor-ig-video-card {
  background: #fff;
}

.vendor-ig-shop-panel {
  display: grid;
  gap: 16px;
  padding-top: 14px;
}

.vendor-ig-shop-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 14px;
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
}

.vendor-ig-shop-intro h2,
.vendor-ig-shop-intro p {
  margin: 0;
}

.vendor-ig-shop-actions {
  display: flex;
  gap: 8px;
}

.vendor-panel-footer {
  display: grid;
  gap: 14px;
  padding: 14px 12px 18px;
  border-top: 1px solid rgba(17, 24, 39, 0.08);
}

.vendor-panel-order {
  width: 100%;
}

.vendor-related-options {
  display: grid;
  gap: 8px;
}

.vendor-related-options .eyebrow {
  margin: 0;
}

.vendor-related-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.vendor-related-card {
  min-width: 0;
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  padding: 8px;
  color: var(--text);
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
  text-decoration: none;
}

.vendor-related-image {
  width: 68px;
  aspect-ratio: 4 / 3;
  display: block;
  overflow: hidden;
  background: #f3f4f6;
  border-radius: 6px;
}

.vendor-related-empty {
  display: grid;
  place-items: center;
  color: var(--muted);
  font-weight: 900;
}

.vendor-related-image picture,
.vendor-related-image img {
  width: 100%;
  height: 100%;
  display: block;
}

.vendor-related-image img {
  object-fit: cover;
}

.vendor-related-copy {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.vendor-related-copy strong,
.vendor-related-copy em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.vendor-related-copy strong {
  font-size: 0.82rem;
  font-weight: 900;
}

.vendor-related-copy em {
  color: var(--text);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 760;
}

.vendor-browse-link {
  justify-self: start;
  color: var(--text);
  font-size: 0.88rem;
  font-weight: 900;
  text-decoration: none;
}

.vendor-forward-sheet {
  position: fixed;
  inset: 0;
  z-index: 1200;
  display: grid;
  align-items: end;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.18s ease;
}

.vendor-forward-sheet.is-open {
  opacity: 1;
  pointer-events: auto;
}

.vendor-forward-sheet.is-closing {
  opacity: 0;
}

.vendor-forward-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 24, 39, 0.44);
  border: 0;
}

.vendor-forward-panel {
  position: relative;
  z-index: 1;
  width: min(520px, 100%);
  max-height: min(82vh, 680px);
  margin: 0 auto;
  display: grid;
  gap: 12px;
  padding: 14px;
  overflow-y: auto;
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 18px 18px 0 0;
  box-shadow: 0 -22px 60px rgba(17, 24, 39, 0.24);
  transform: translateY(18px);
  transition: transform 0.2s ease;
}

.vendor-forward-sheet.is-open .vendor-forward-panel {
  transform: translateY(0);
}

.vendor-forward-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: start;
}

.vendor-forward-head strong,
.vendor-forward-head p {
  margin: 0;
}

.vendor-forward-head p {
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.vendor-forward-close {
  min-height: 36px;
  padding: 8px 10px;
  color: var(--text);
  background: #f3f4f6;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 850;
}

.vendor-forward-preview {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: #f3f4f6;
  border-radius: 10px;
}

.vendor-forward-preview picture,
.vendor-forward-preview img {
  width: 100%;
  height: 100%;
  display: block;
}

.vendor-forward-preview img {
  object-fit: cover;
}

.vendor-forward-quick {
  display: grid;
}

.vendor-forward-thread-list {
  display: grid;
  gap: 8px;
}

.vendor-forward-thread {
  display: grid;
  gap: 4px;
  width: 100%;
  padding: 12px;
  color: var(--text);
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 10px;
  text-align: left;
}

.vendor-forward-thread strong {
  font-size: 0.94rem;
}

.vendor-forward-thread span {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
}

.vendor-forward-toast {
  position: fixed;
  left: 50%;
  bottom: calc(86px + env(safe-area-inset-bottom));
  z-index: 1300;
  max-width: min(340px, calc(100vw - 32px));
  padding: 10px 14px;
  color: #fff;
  background: rgba(17, 24, 39, 0.92);
  border-radius: 999px;
  box-shadow: 0 12px 36px rgba(0, 0, 0, 0.22);
  font-size: 0.82rem;
  font-weight: 800;
  text-align: center;
  opacity: 0;
  transform: translate(-50%, 10px);
  transition: opacity 0.18s ease, transform 0.18s ease;
}

.vendor-forward-toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

.vendor-owner-fab {
  position: fixed;
  right: max(18px, env(safe-area-inset-right));
  bottom: calc(92px + env(safe-area-inset-bottom));
  z-index: 1250;
  display: grid;
  gap: 10px;
  justify-items: end;
}

.vendor-owner-fab-main {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  color: #fff;
  background: var(--accent);
  border: 0;
  border-radius: 999px;
  box-shadow: 0 14px 36px rgba(128, 36, 72, 0.3);
  font-size: 2rem;
  font-weight: 700;
  line-height: 1;
}

.vendor-owner-fab.is-open .vendor-owner-fab-main {
  transform: rotate(45deg);
}

.vendor-owner-fab-menu {
  width: min(230px, calc(100vw - 32px));
  display: grid;
  gap: 8px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 14px;
  box-shadow: 0 18px 44px rgba(17, 24, 39, 0.18);
}

.vendor-owner-fab-menu[hidden] {
  display: none;
}

.vendor-owner-fab-menu a {
  min-height: 42px;
  display: flex;
  align-items: center;
  padding: 10px 12px;
  color: var(--text);
  background: #f8fafc;
  border-radius: 9px;
  font-size: 0.86rem;
  font-weight: 850;
  text-decoration: none;
}

.vendor-profile-panel {
  display: grid;
  grid-template-columns: minmax(220px, 0.34fr) minmax(0, 0.42fr) minmax(230px, 0.24fr);
  gap: 18px;
  align-items: stretch;
  padding: 16px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.vendor-profile-media,
.vendor-profile-actions {
  min-height: 100%;
}

.vendor-profile-media {
  display: grid;
  gap: 10px;
  align-content: start;
}

.vendor-profile-photo {
  width: 100%;
  height: auto;
  min-height: 330px;
  aspect-ratio: 4 / 5;
  padding: 0;
  overflow: hidden;
  background: var(--bg-warm);
  border: 0;
  border-radius: var(--radius);
  cursor: zoom-in;
}

.vendor-profile-photo picture,
.vendor-profile-photo img,
.vendor-profile-thumb picture,
.vendor-profile-thumb img {
  display: block;
  width: 100%;
  height: 100%;
}

.vendor-profile-photo img,
.vendor-profile-thumb img {
  object-fit: cover;
}

.vendor-profile-summary {
  display: grid;
  align-content: start;
  gap: 12px;
}

.vendor-profile-summary h1 {
  margin: 0;
  font-size: clamp(2.7rem, 5vw, 5.4rem);
  line-height: 0.9;
}

.vendor-profile-intro {
  margin: 0;
  color: var(--text);
  font-size: 1rem;
  line-height: 1.65;
}

.vendor-profile-facts {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.vendor-profile-facts span {
  padding: 8px 10px;
  color: var(--text);
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.78rem;
  font-weight: 800;
}

.vendor-profile-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 4px;
}

.vendor-profile-thumb {
  aspect-ratio: 1;
  width: 100%;
  padding: 0;
  overflow: hidden;
  background: var(--bg-warm);
  border: 0;
  border-radius: var(--radius);
  cursor: zoom-in;
}

.vendor-profile-actions {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  background: var(--bg-warm);
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: var(--radius);
}

.vendor-profile-actions p {
  margin: 0;
  color: var(--muted);
  font-size: 0.92rem;
  line-height: 1.55;
}

.vendor-back-link {
  color: var(--accent-deep);
  font-size: 0.82rem;
  font-weight: 900;
  text-decoration: none;
}

.service-detail-info {
  max-width: 960px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin-top: 34px;
}

.service-team-grid,
.car-rental-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 34px;
}

.service-location-filter {
  max-width: 340px;
  display: grid;
  gap: 8px;
  margin-top: 18px;
  color: var(--accent-deep);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.service-location-filter select {
  width: 100%;
  padding: 11px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font: inherit;
  letter-spacing: 0;
  text-transform: none;
}

.service-team-card,
.car-rental-card {
  display: grid;
  grid-template-columns: minmax(180px, 0.42fr) minmax(0, 0.58fr);
  gap: 18px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.64);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.service-team-card {
  cursor: pointer;
}

.service-team-card:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 3px;
}

.service-team-media,
.car-rental-image {
  min-height: 240px;
  overflow: hidden;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.service-team-media picture,
.service-team-media img,
.car-rental-image picture,
.car-rental-image img {
  width: 100%;
  height: 100%;
}

.service-team-media img,
.car-rental-image img {
  object-fit: cover;
}

.service-team-body,
.car-rental-body {
  display: flex;
  flex-direction: column;
  align-items: start;
}

.service-preview {
  display: grid;
  gap: 8px;
  margin: 6px 0 10px;
}

.service-preview-strip {
  display: flex;
  gap: 7px;
  overflow-x: auto;
  padding-bottom: 2px;
  scrollbar-width: thin;
}

.service-preview-thumb {
  display: block;
  width: 46px;
  height: 46px;
  flex: 0 0 46px;
  padding: 0;
  overflow: hidden;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  cursor: pointer;
  scroll-snap-align: start;
}

.filter-helper {
  margin: 8px 0 0;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.service-preview-thumb picture,
.service-preview-thumb img {
  display: block;
  width: 100%;
  height: 100%;
}

.service-preview-thumb img {
  object-fit: cover;
}

.service-preview-label {
  margin: 0;
  color: var(--accent-deep);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.service-brand-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.service-brand-row span {
  padding: 5px 8px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.68rem;
  font-weight: 700;
}

.service-team-card .bridal-vendor-main-image {
  cursor: pointer;
}

.service-team-body h3 a {
  color: inherit;
  text-decoration: none;
}

.service-team-body h3 .verified-badge {
  width: 15px;
  height: 15px;
  margin-left: 5px;
  font-size: 0.62rem;
}

.service-team-body h3 a:hover {
  color: var(--accent-deep);
}

.vendor-rating-summary {
  margin: 2px 0 10px;
  color: #9b6b2f;
  font-size: 0.82rem;
  font-weight: 800;
}

.popularity-meter {
  width: 100%;
  display: grid;
  gap: 6px;
  margin: 4px 0 12px;
}

.popularity-meter-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.popularity-meter-label strong {
  color: var(--accent-deep);
  letter-spacing: 0;
}

.popularity-track {
  height: 8px;
  overflow: hidden;
  background: rgba(36, 24, 21, 0.1);
  border-radius: 999px;
}

.popularity-track span {
  display: block;
  height: 100%;
  min-width: 18%;
  background: linear-gradient(90deg, var(--sage), var(--accent));
  border-radius: inherit;
}

.popularity-meter p {
  margin: 0;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.popularity-follow {
  width: max-content;
  padding: 7px 12px;
  color: var(--accent-deep);
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid rgba(17, 24, 39, 0.22);
  border-radius: var(--radius);
  font-size: 0.76rem;
  font-weight: 900;
  text-decoration: none;
}

.mehendi-pricing-panel {
  display: grid;
  grid-template-columns: minmax(220px, 0.8fr) minmax(250px, 0.65fr);
  gap: 16px;
  margin-top: 28px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.mehendi-pricing-intro {
  grid-column: 1 / -1;
  max-width: 780px;
}

.mehendi-pricing-intro h2 {
  margin: 0 0 8px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(2rem, 4vw, 3.8rem);
  font-weight: 500;
  line-height: 0.95;
}

.mehendi-pricing-intro p:not(.eyebrow) {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.mehendi-hand-selector {
  grid-column: 1 / -1;
  display: grid;
  gap: 10px;
}

.mehendi-diagram-stack {
  display: grid;
  gap: 8px;
  height: 100%;
  align-self: start;
}

.mehendi-visual-rate-row {
  display: grid;
  grid-template-columns: minmax(150px, 0.42fr) minmax(190px, 0.58fr);
  gap: 10px;
  align-items: start;
}

.mehendi-diagram {
  height: 100%;
  min-height: 360px;
  display: grid;
  place-items: center;
  background: #fff;
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
  overflow: hidden;
  position: relative;
}

.mehendi-diagram img {
  width: min(100%, 560px);
  height: auto;
  object-fit: contain;
}

.mehendi-side-grid,
.mehendi-coverage-grid {
  display: grid;
  gap: 8px;
}

.mehendi-hand-selector > .mehendi-side-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.mehendi-side-button,
.mehendi-coverage-card {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: #fffaf7;
  color: var(--text);
  cursor: pointer;
  text-align: left;
  transition: border-color 0.2s ease, background 0.2s ease, transform 0.2s ease;
}

.mehendi-side-button {
  padding: 12px;
  font-size: 0.86rem;
  font-weight: 800;
}

.mehendi-side-button.is-selected,
.mehendi-coverage-card.is-selected {
  background: #f1e2df;
  border-color: rgba(17, 24, 39, 0.55);
}

.mehendi-side-button:hover,
.mehendi-coverage-card:hover {
  transform: translateY(-1px);
}

.mehendi-coverage-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.mehendi-coverage-card {
  display: grid;
  gap: 5px;
  padding: 12px;
}

.mehendi-coverage-card:last-child:nth-child(odd) {
  grid-column: 1 / -1;
}

.mehendi-coverage-card strong,
.mehendi-selection-summary strong {
  color: var(--accent-deep);
}

.mehendi-coverage-card span,
.mehendi-coverage-card em,
.mehendi-selection-summary p {
  color: var(--muted);
  font-size: 0.82rem;
  font-style: normal;
  font-weight: 700;
}

.mehendi-leg-toggle {
  align-self: start;
  width: max-content;
}

.mehendi-leg-panel {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: minmax(160px, 0.35fr) minmax(220px, 0.65fr);
  gap: 12px;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.mehendi-leg-panel[hidden] {
  display: none;
}

.mehendi-leg-head {
  grid-column: 1 / -1;
  display: grid;
  gap: 4px;
}

.mehendi-leg-head strong {
  color: var(--text);
  font-size: 1rem;
}

.mehendi-leg-head span {
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
}

.mehendi-leg-panel .btn {
  grid-column: 1 / -1;
  width: max-content;
}

.mehendi-selection-summary {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  background: var(--bg-warm);
  border: 1px solid rgba(17, 24, 39, 0.16);
  border-radius: var(--radius);
}

.mehendi-selection-summary p {
  margin: 0 auto 0 0;
}

.bridal-package-panel {
  display: grid;
  gap: 14px;
  margin-top: 28px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.bridal-package-intro {
  max-width: 820px;
}

.bridal-package-intro h2 {
  margin: 0 0 8px;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(2rem, 4vw, 3.8rem);
  font-weight: 500;
  line-height: 0.95;
}

.bridal-package-intro p:not(.eyebrow),
.bridal-addon-panel p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

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

.bridal-package-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  color: var(--text);
  text-align: left;
  background: #fffaf7;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  cursor: pointer;
}

.bridal-package-card.is-selected {
  background: #f1e2df;
  border-color: rgba(17, 24, 39, 0.55);
}

.bridal-package-name {
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.bridal-package-card strong,
.bridal-package-summary strong {
  color: var(--accent-deep);
}

.bridal-package-card ul {
  margin: 0;
  padding-left: 18px;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.5;
}

.bridal-common-inclusions,
.bridal-addon-panel {
  padding: 12px;
  background: rgba(255, 255, 255, 0.64);
  border: 1px solid rgba(36, 24, 21, 0.1);
  border-radius: var(--radius);
}

.bridal-common-inclusions summary,
.bridal-addon-panel h3 {
  color: var(--text);
  font-weight: 900;
}

.bridal-chip-list,
.bridal-addon-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.bridal-chip-list span,
.bridal-addon-option {
  padding: 8px 10px;
  background: #fffaf7;
  border: 1px solid rgba(17, 24, 39, 0.14);
  border-radius: var(--radius);
  font-size: 0.84rem;
  font-weight: 800;
}

.bridal-addon-option {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.bridal-addon-option strong {
  color: var(--accent-deep);
}

.bridal-package-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px;
  background: var(--bg-warm);
  border: 1px solid rgba(17, 24, 39, 0.16);
  border-radius: var(--radius);
}

.bridal-package-summary p {
  margin: 0 auto 0 0;
  color: var(--muted);
  font-size: 0.86rem;
  font-weight: 700;
}

.account-help-panel {
  display: grid;
  gap: 12px;
  padding: 16px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.account-help-head h2 {
  margin: 0;
  font-family: "Inter", Arial, sans-serif;
  font-size: 1.25rem;
  font-weight: 900;
  letter-spacing: 0;
}

.account-help-list {
  display: grid;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.account-help-list details {
  border-bottom: 1px solid var(--line);
}

.account-help-list details:last-child {
  border-bottom: 0;
}

.account-help-list summary {
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 0 14px;
  color: var(--text);
  cursor: pointer;
  font-size: 0.94rem;
  font-weight: 900;
  list-style: none;
}

.account-help-list summary::-webkit-details-marker {
  display: none;
}

.account-help-list summary::after {
  content: ">";
  color: var(--muted);
  font-size: 1.2rem;
  font-weight: 800;
  transition: transform 0.2s ease;
}

.account-help-list details[open] summary::after {
  transform: rotate(90deg);
}

.account-help-list p {
  margin: -2px 14px 14px;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.55;
}

.account-dashboard {
  width: min(100%, 760px);
  display: grid;
  gap: 14px;
  margin: 0 auto;
}

.account-profile-card {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  padding: 16px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.05);
}

.account-profile-avatar {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  color: #fff;
  background: var(--text);
  border: 1px solid rgba(17, 24, 39, 0.18);
  border-radius: 50%;
  font-size: 1.4rem;
  font-weight: 900;
}

.account-profile-copy {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.account-profile-copy h1 {
  margin: 0;
  overflow: hidden;
  color: var(--text);
  font-family: "Inter", Arial, sans-serif;
  font-size: 1.35rem;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-profile-copy p:last-child {
  margin: 0;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-profile-edit {
  min-height: 38px;
  padding: 0 14px;
  color: var(--text);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  cursor: pointer;
}

.account-menu-card {
  display: grid;
  overflow: hidden;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.account-menu-section {
  min-width: 0;
  border-bottom: 1px solid var(--line);
}

.account-menu-section:last-child {
  border-bottom: 0;
}

.account-menu-details {
  min-width: 0;
}

.account-menu-details > summary::-webkit-details-marker {
  display: none;
}

.account-menu-row {
  min-height: 74px;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) auto 18px;
  gap: 12px;
  align-items: center;
  padding: 12px 14px;
  color: var(--text);
  text-decoration: none;
  list-style: none;
}

.account-menu-details > summary {
  cursor: pointer;
}

.account-menu-link {
  cursor: pointer;
}

.account-row-icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  color: var(--text);
  background: #f7f7f7;
  border: 1px solid var(--line);
  border-radius: 50%;
  font-size: 0.66rem;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.account-row-copy {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.account-row-copy strong {
  overflow: hidden;
  color: var(--text);
  font-size: 0.98rem;
  font-weight: 900;
  letter-spacing: 0;
  line-height: 1.2;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-row-copy small {
  overflow: hidden;
  color: var(--muted);
  font-size: 0.82rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1.25;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-row-meta {
  max-width: 28vw;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.76rem;
  font-style: normal;
  font-weight: 900;
  text-align: right;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-row-chevron {
  color: var(--muted);
  font-size: 1.18rem;
  font-weight: 900;
  transition: transform 0.18s ease;
}

.account-menu-details[open] > summary .account-row-chevron {
  transform: rotate(90deg);
}

.account-menu-body {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 0 14px 14px 70px;
}

.account-menu-body .booking-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.account-menu-note {
  padding: 14px;
  color: var(--muted);
  font-size: 0.86rem;
}

.account-service-card-panel {
  gap: 16px;
}

.account-collapsible {
  min-width: 0;
  overflow: hidden;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.account-collapsible + .account-collapsible {
  margin-top: 10px;
}

.account-collapsible summary {
  min-height: 58px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  color: var(--text);
  cursor: pointer;
  list-style: none;
}

.account-collapsible summary::-webkit-details-marker {
  display: none;
}

.account-collapsible summary::after {
  content: ">";
  color: var(--muted);
  font-size: 1.1rem;
  font-weight: 900;
  transition: transform 0.2s ease;
}

.account-collapsible[open] summary::after {
  transform: rotate(90deg);
}

.account-collapsible summary span {
  min-width: 0;
  display: grid;
  gap: 2px;
  font-weight: 900;
  overflow-wrap: anywhere;
}

.account-collapsible summary small {
  color: var(--accent-deep);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.account-collapsible summary em {
  max-width: 44vw;
  overflow: hidden;
  color: var(--muted);
  font-size: 0.78rem;
  font-style: normal;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-collapsible-body {
  display: grid;
  gap: 12px;
  min-width: 0;
  padding: 0 12px 12px;
}

.account-quick-action-list {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}

.account-business-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.account-business-card strong,
.account-business-card span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-business-card strong {
  color: var(--text);
  font-size: 0.96rem;
}

.account-business-card span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
}

.business-status-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.business-status-grid span {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.business-status-grid small {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.business-status-grid strong {
  color: var(--text);
  font-size: 0.95rem;
}

.service-card-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
}

.service-card-stat {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 12px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.service-card-stat span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.service-card-stat strong {
  color: var(--accent-deep);
  font-size: 1.02rem;
}

.service-card-activity {
  display: grid;
  gap: 8px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.service-card-activity p {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
}

.service-card-activity em {
  flex: 0 0 auto;
  color: var(--accent-deep);
  font-style: normal;
  font-weight: 800;
}

.user-service-card-list,
.user-service-card-mount {
  display: grid;
  gap: 14px;
}

.user-service-card {
  display: grid;
  grid-template-columns: minmax(220px, 0.45fr) minmax(0, 1fr);
  gap: 14px;
  padding: 14px;
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.16);
  border-radius: var(--radius);
  box-shadow: 0 14px 30px rgba(36, 24, 21, 0.06);
}

.user-service-card-media {
  min-height: 210px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  overflow: hidden;
  border-radius: 8px;
  background: var(--bg-warm);
}

.user-service-card-media img,
.user-service-card-media span {
  width: 100%;
  height: 100%;
  min-height: 100px;
  object-fit: cover;
}

.user-service-card-media span {
  display: grid;
  place-items: center;
  grid-column: 1 / -1;
  color: var(--muted);
  font-size: 0.85rem;
  font-weight: 800;
}

.user-service-card-body,
.service-card-editor {
  min-width: 0;
  display: grid;
  gap: 12px;
}

.service-card-title-row,
.service-card-editor-head,
.service-card-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.service-card-chip {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 10px;
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.08);
  border: 1px solid rgba(17, 24, 39, 0.14);
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.user-service-card h3,
.service-card-editor h3 {
  margin: 0;
  font-family: "Inter", Arial, sans-serif;
  font-size: 1.35rem;
  line-height: 1.12;
  letter-spacing: 0;
}

.user-service-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.service-card-meta-list,
.service-card-item-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.service-card-meta-list span,
.service-card-item-preview span {
  min-width: 0;
  display: grid;
  gap: 2px;
  padding: 8px 10px;
  background: rgba(247, 241, 235, 0.78);
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 0.8rem;
}

.service-card-item-preview strong {
  color: var(--ink);
}

.service-card-item-preview em {
  color: var(--accent-deep);
  font-style: normal;
  font-weight: 800;
}

.service-card-edit-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.service-card-wide-field {
  grid-column: 1 / -1;
}

.service-card-edit-section {
  display: grid;
  gap: 10px;
  padding: 12px;
  background: rgba(247, 241, 235, 0.72);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.service-card-section-head span {
  color: var(--text);
  font-size: 0.82rem;
}

.service-card-location-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(165px, 1fr));
  gap: 8px;
}

.service-card-location-grid label,
.service-card-photo-grid label {
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 9px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 0.82rem;
  font-weight: 800;
}

.service-card-upload-button {
  width: fit-content;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 14px;
  color: #fff;
  cursor: pointer;
  background: var(--accent-deep);
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 900;
}

.service-card-upload-button input {
  position: absolute;
  inline-size: 1px;
  block-size: 1px;
  opacity: 0;
  pointer-events: none;
}

.sc-profile-photo-preview {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.sc-profile-photo-preview img {
  width: 54px;
  height: 54px;
  flex: 0 0 auto;
  object-fit: cover;
  border-radius: 50%;
}

.sc-profile-photo-preview span {
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 850;
}

.sc-photo-action-panel {
  display: grid;
  gap: 10px;
  min-width: 0;
  padding: 10px;
  background: rgba(247, 241, 235, 0.68);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.sc-photo-action-panel strong {
  color: var(--text);
  font-size: 0.95rem;
  line-height: 1.2;
}

.sc-photo-action-panel p {
  margin: 3px 0 0;
  color: var(--text);
  font-size: 0.8rem;
  line-height: 1.4;
}

.sc-selected-files {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 9px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.sc-selected-files strong {
  color: var(--accent-deep);
  font-size: 0.78rem;
  text-transform: uppercase;
}

.sc-selected-files span {
  min-width: 0;
  color: var(--text);
  font-size: 0.84rem;
  line-height: 1.25;
  overflow-wrap: anywhere;
}

.sc-selected-photo-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.sc-selected-photo-thumb {
  position: relative;
  min-width: 0;
  aspect-ratio: 3 / 4;
  display: block;
  overflow: hidden;
  background: #f3f4f6;
  border-radius: 7px;
}

.sc-selected-photo-thumb img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

.sc-selected-photo-thumb em {
  position: absolute;
  left: 5px;
  bottom: 5px;
  padding: 3px 6px;
  color: #fff;
  background: rgba(17, 24, 39, 0.78);
  border-radius: 999px;
  font-size: 0.62rem;
  font-style: normal;
  font-weight: 900;
}

.sc-upload-progress {
  display: grid;
  gap: 7px;
  padding: 9px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.sc-upload-progress[hidden] {
  display: none;
}

.sc-upload-progress span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
}

.sc-upload-progress em {
  min-width: 0;
  overflow: hidden;
  color: var(--text);
  font-style: normal;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.sc-upload-progress strong {
  color: #168447;
  font-size: 0.76rem;
}

.sc-upload-progress i {
  height: 8px;
  overflow: hidden;
  background: rgba(17, 24, 39, 0.08);
  border-radius: 999px;
}

.sc-upload-progress b {
  width: 0%;
  height: 100%;
  display: block;
  background: #168447;
  border-radius: inherit;
  transition: width 180ms ease;
}

.service-card-photo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(126px, 1fr));
  gap: 8px;
}

.service-card-photo-grid.sc-photo-delete-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.service-card-photo-grid label {
  display: grid;
  align-items: stretch;
  padding: 7px;
}

.service-card-photo-grid img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 6px;
}

.service-card-photo-grid span {
  display: flex;
  align-items: center;
  gap: 6px;
  min-width: 0;
  overflow-wrap: anywhere;
  line-height: 1.25;
}

.service-card-item-editor-list {
  display: grid;
  gap: 10px;
}

.service-card-edit-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: end;
  padding: 10px;
  background: #fff;
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
}

.sc-package-edit-row {
  grid-template-columns: 1fr;
  align-items: stretch;
  padding: 12px;
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(17, 24, 39, 0.18);
  box-shadow: 0 10px 24px rgba(36, 24, 21, 0.04);
}

.sc-package-edit-head {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: space-between;
  min-width: 0;
  padding-bottom: 2px;
}

.sc-package-edit-head strong {
  color: var(--accent-deep);
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sc-package-edit-head span {
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
}

.sc-package-core-fields {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 130px 90px;
  gap: 10px;
  align-items: end;
  min-width: 0;
}

.sc-package-edit-row .sc-package-core-fields {
  grid-template-columns: minmax(0, 1fr) 132px;
}

.sc-catalog-edit-row {
  grid-template-columns: 104px minmax(0, 1fr);
  align-items: start;
}

.sc-catalog-edit-row .sc-package-edit-head,
.sc-catalog-edit-row .service-card-wide-field,
.sc-catalog-edit-row .booking-save-profile,
.sc-catalog-edit-row .sc-row-actions {
  grid-column: 1 / -1;
}

.sc-catalog-photo-field {
  display: grid;
  gap: 7px;
  min-width: 0;
}

.sc-catalog-photo-preview {
  width: 100%;
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: var(--muted);
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 0.76rem;
  font-weight: 800;
  text-align: center;
}

.sc-catalog-photo-preview img,
.sc-product-preview-grid img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sc-selected-file {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  overflow-wrap: anywhere;
}

.sc-catalog-edit-row .service-card-upload-button {
  min-height: 36px;
  padding: 8px;
  font-size: 0.72rem;
}

.sc-catalog-edit-row .sc-package-core-fields {
  grid-template-columns: 1fr;
}

.sc-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.sc-delete-product-btn {
  color: #8b1e3f;
  background: #fff;
  border-color: rgba(139, 30, 63, 0.26);
}

.service-card-edit-row.is-marked-delete {
  opacity: 0.62;
  background: rgba(139, 30, 63, 0.06);
}

.service-card-edit-row.is-marked-delete input:not(.sc-delete-input),
.service-card-edit-row.is-marked-delete textarea {
  text-decoration: line-through;
}

.sc-product-preview-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sc-product-preview-grid span {
  align-content: start;
}

.sc-product-preview-grid img,
.sc-product-preview-grid i {
  width: 100%;
  aspect-ratio: 1 / 1;
  display: grid;
  place-items: center;
  overflow: hidden;
  margin-bottom: 6px;
  color: var(--muted);
  background: var(--bg-warm);
  border-radius: 6px;
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 800;
}

@media (max-width: 430px) {
  .sc-catalog-edit-row {
    grid-template-columns: 88px minmax(0, 1fr);
    gap: 8px;
    padding: 8px;
  }

  .sc-catalog-edit-row .sc-package-core-fields {
    gap: 7px;
  }
}

.service-card-addon-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 120px auto;
  gap: 8px;
  align-items: end;
  padding-top: 8px;
}

.service-card-edit-page {
  width: min(100%, 760px);
  min-height: calc(100svh - 96px);
  margin: 0 auto;
  padding: 10px 12px calc(var(--bottom-nav-height, 76px) + 16px);
  overflow-x: hidden;
}

.service-card-app-shell {
  display: grid;
  gap: 12px;
  min-width: 0;
}

.service-card-app-header {
  position: sticky;
  top: 0;
  z-index: 8;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 10px 0;
  background: rgba(252, 248, 243, 0.96);
  border-bottom: 1px solid rgba(17, 24, 39, 0.1);
  backdrop-filter: blur(14px);
}

.service-card-app-header h1 {
  margin: 4px 0 2px;
  overflow-wrap: anywhere;
  font-family: "Inter", Arial, sans-serif;
  font-size: 1.05rem;
  line-height: 1.16;
  letter-spacing: 0;
}

.service-card-app-header p,
.sc-section-title p {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.45;
}

.sc-card-switcher,
.sc-compact-form label {
  min-width: 0;
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sc-card-switcher select,
.sc-compact-form input,
.sc-compact-form select,
.sc-compact-form textarea,
.service-card-edit-row input,
.service-card-edit-row textarea,
.sc-mehendi-row input {
  width: 100%;
  min-width: 0;
  padding: 11px 12px;
  color: var(--text);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  font: inherit;
  font-size: 0.95rem;
  letter-spacing: 0;
  text-transform: none;
}

.sc-compact-form textarea,
.service-card-edit-row textarea {
  resize: vertical;
}

.sc-edit-tabs {
  position: sticky;
  top: 70px;
  z-index: 7;
  display: flex;
  gap: 7px;
  max-width: 100%;
  padding: 6px 0 8px;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scrollbar-width: none;
  background: rgba(252, 248, 243, 0.96);
}

.sc-edit-tabs::-webkit-scrollbar {
  display: none;
}

.sc-edit-tabs a {
  flex: 0 0 auto;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  color: var(--muted);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 900;
  text-decoration: none;
}

.sc-edit-tabs a.is-active {
  color: #fff;
  background: var(--accent-deep);
  border-color: var(--accent-deep);
}

.sc-edit-content {
  min-width: 0;
}

.service-card-page-card {
  min-width: 0;
  display: grid;
  gap: 12px;
  padding: 12px;
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.14);
  border-radius: 8px;
  box-shadow: 0 12px 24px rgba(36, 24, 21, 0.06);
}

.sc-compact-form {
  grid-template-columns: 1fr;
}

.sc-section-title {
  display: grid;
  gap: 4px;
  min-width: 0;
}

.sc-section-title h2 {
  margin: 0;
  font-family: "Inter", Arial, sans-serif;
  font-size: 1.12rem;
  line-height: 1.15;
  letter-spacing: 0;
}

.sc-section-title h3 {
  margin: 0;
  font-size: 0.98rem;
  line-height: 1.2;
  letter-spacing: 0;
}

.sc-two-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.sc-rental-window-editor {
  grid-column: 1 / -1;
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 12px;
  background: rgba(248, 250, 252, 0.82);
}

.sc-rental-preset-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.sc-rental-preset-grid button {
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid rgba(17, 24, 39, 0.16);
  border-radius: 10px;
  background: #fff;
  color: var(--text);
  font: inherit;
  font-size: 0.86rem;
  font-weight: 800;
}

.sc-rental-preset-grid button.is-selected {
  border-color: var(--accent);
  background: rgba(143, 36, 77, 0.08);
  color: var(--accent-deep);
}

.sc-rental-window-preview {
  margin: 0;
  color: var(--muted);
  font-size: 0.88rem;
  line-height: 1.45;
}

.sc-location-picker {
  grid-template-columns: repeat(auto-fit, minmax(142px, 1fr));
}

.sc-location-picker label {
  min-width: 0;
}

.sc-location-picker span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.sc-photo-manager {
  grid-template-columns: repeat(auto-fit, minmax(112px, 1fr));
}

.sc-mehendi-list,
.sc-request-list {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.sc-mehendi-group-title {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 900;
}

.sc-mehendi-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 10px;
  align-items: end;
  min-width: 0;
  padding: 10px;
  background: rgba(247, 241, 235, 0.7);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.sc-mehendi-leg-row {
  background: #fff;
}

.sc-mehendi-leg-enable {
  grid-column: 1 / -1;
}

.sc-mehendi-name,
.sc-side-preview {
  grid-column: 1 / -1;
}

.sc-mehendi-name {
  display: grid;
  gap: 4px;
}

.sc-mehendi-name span {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.sc-mehendi-name strong {
  color: var(--text);
  font-size: 1rem;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.sc-side-preview {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.sc-side-preview span,
.sc-amount-box span,
.sc-money-summary span {
  min-width: 0;
  display: grid;
  gap: 3px;
  padding: 8px;
  color: var(--muted);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  font-size: 0.72rem;
  font-weight: 900;
  text-transform: uppercase;
}

.sc-side-preview strong,
.sc-amount-box strong,
.sc-money-summary strong {
  color: var(--accent-deep);
  font-size: 0.88rem;
  line-height: 1.15;
  overflow-wrap: anywhere;
  text-transform: none;
}

.sc-request-card,
.sc-money-card {
  display: grid;
  gap: 8px;
  min-width: 0;
  padding: 10px;
  background: rgba(247, 241, 235, 0.65);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.sc-request-card p,
.sc-money-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.45;
  overflow-wrap: anywhere;
}

.sc-booking-topline {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  justify-content: space-between;
  min-width: 0;
}

.sc-booking-topline strong {
  min-width: 0;
  overflow-wrap: anywhere;
}

.sc-booking-topline span {
  flex: 0 0 auto;
  padding: 5px 8px;
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.08);
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 900;
}

.sc-amount-box,
.sc-money-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.sc-money-summary {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.sc-triple-summary {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

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

.partner-order-card {
  background: #fff;
}

.sc-booking-actions {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
  gap: 8px;
}

.destination-page {
  position: relative;
  min-height: 100svh;
  padding-bottom: calc(var(--bottom-nav-height, 76px) + 24px);
  background: #f8fbf7;
  overflow-x: hidden;
}

.destination-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.72), rgba(255, 255, 255, 0.9)),
    url("https://upload.wikimedia.org/wikipedia/commons/3/38/A_Houseboat_in_Backwaters_of_Kerala.jpg") center / cover;
  opacity: 0.46;
}

.destination-page > * {
  position: relative;
  z-index: 1;
}

.destination-breadcrumbs {
  position: absolute;
  top: max(16px, env(safe-area-inset-top));
  left: max(14px, calc((100vw - 1120px) / 2));
  z-index: 3;
  display: flex;
  max-width: min(440px, calc(100vw - 28px));
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  color: rgba(17, 24, 39, 0.7);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 999px;
  box-shadow: 0 14px 34px rgba(17, 24, 39, 0.14);
  font-size: 0.78rem;
  font-weight: 900;
  backdrop-filter: blur(14px);
}

.destination-breadcrumbs a {
  min-width: 44px;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  color: var(--accent-deep);
  text-decoration: none;
}

.destination-breadcrumbs strong {
  min-width: 0;
  overflow: hidden;
  color: #111827;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.destination-hero {
  min-height: min(78svh, 760px);
  display: grid;
  align-items: end;
  padding: 96px max(18px, calc((100vw - 1120px) / 2)) 34px;
  color: #fff;
  background:
    linear-gradient(180deg, rgba(36, 24, 21, 0.18), rgba(36, 24, 21, 0.72)),
    url("https://upload.wikimedia.org/wikipedia/commons/3/38/A_Houseboat_in_Backwaters_of_Kerala.jpg") center / cover;
}

.destination-hero-copy {
  width: min(720px, 100%);
  display: grid;
  gap: 14px;
}

.destination-hero .eyebrow,
.destination-hero h1,
.destination-hero p {
  color: #fff;
}

.destination-hero h1 {
  margin: 0;
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(3rem, 12vw, 6.8rem);
  line-height: 0.86;
  letter-spacing: 0;
}

.destination-hero p {
  max-width: 620px;
  margin: 0;
  font-size: clamp(1rem, 2.4vw, 1.22rem);
  line-height: 1.55;
}

.destination-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.destination-coming-soon {
  width: fit-content;
  padding: 8px 12px;
  color: #fff;
  background: rgba(17, 24, 39, 0.72);
  border: 1px solid rgba(255, 255, 255, 0.34);
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  backdrop-filter: blur(12px);
}

.destination-section,
.destination-source {
  width: min(1120px, calc(100% - 32px));
  margin: 0 auto;
}

.destination-section {
  display: grid;
  gap: 18px;
  padding: 36px 0 0;
}

.destination-section-head {
  display: grid;
  gap: 4px;
}

.destination-section h2 {
  margin: 0;
  font-family: "Inter", Arial, sans-serif;
  font-size: clamp(1.5rem, 4vw, 2.5rem);
  line-height: 1.05;
  letter-spacing: 0;
}

.destination-location-grid,
.destination-service-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.destination-location-grid article,
.destination-service-grid a,
.destination-planner,
.destination-source {
  min-width: 0;
  padding: 16px;
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 16px 38px rgba(17, 24, 39, 0.08);
  backdrop-filter: blur(12px);
}

.destination-location-grid span {
  color: var(--accent-deep);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.destination-location-grid h3 {
  margin: 8px 0;
  font-family: "Inter", Arial, sans-serif;
  font-size: 1.05rem;
  line-height: 1.2;
}

.destination-location-grid p,
.destination-service-grid span,
.destination-source p {
  margin: 0;
  color: var(--text);
  line-height: 1.5;
}

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

.destination-service-grid a {
  display: grid;
  gap: 8px;
  color: var(--text);
  text-decoration: none;
}

.destination-service-grid a:hover {
  border-color: rgba(17, 24, 39, 0.38);
  transform: translateY(-1px);
}

.destination-service-grid strong {
  color: var(--accent-deep);
  font-size: 1rem;
}

.destination-planner {
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1.2fr);
  align-items: start;
}

.destination-planner ol {
  display: grid;
  gap: 10px;
  margin: 0;
  padding-left: 22px;
}

.destination-planner li {
  color: var(--text);
  line-height: 1.5;
}

.destination-source {
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
  margin-top: 28px;
}

.destination-source a {
  flex: 0 0 auto;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  color: var(--accent-deep);
  font-weight: 900;
}

@media (max-width: 760px) {
  .destination-home-panel,
  .destination-shop-strip,
  .destination-location-grid,
  .destination-service-grid,
  .destination-planner {
    grid-template-columns: 1fr;
  }

  .destination-home-panel,
  .destination-shop-strip {
    align-items: stretch;
    padding: 16px;
  }

  .destination-home-actions,
  .destination-actions {
    display: grid;
    grid-template-columns: 1fr;
    justify-content: stretch;
  }

  .destination-hero {
    min-height: 72svh;
    padding-top: 86px;
  }

  .destination-hero h1 {
    font-size: clamp(2.7rem, 15vw, 4.4rem);
  }

  .destination-section {
    padding-top: 28px;
  }

  .destination-source {
    display: grid;
    align-items: stretch;
  }
}

.unified-inbox-tabs {
  margin-bottom: 10px;
}

.unified-inbox-tabs button {
  appearance: none;
  border: 0;
  cursor: pointer;
  font: inherit;
}

.review-average {
  margin: 0;
  color: #9b6b2f;
  font-size: 0.88rem;
  font-weight: 800;
}

.review-sort-label {
  max-width: 260px;
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 0.74rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.review-sort-label select {
  padding: 10px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font: inherit;
  letter-spacing: 0;
  text-transform: none;
}

.service-detail-gallery {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 34px;
}

.service-detail-photo {
  aspect-ratio: 4 / 5;
  width: 100%;
  padding: 0;
  overflow: hidden;
  background: var(--bg-warm);
  border: 0;
  border-radius: var(--radius);
  cursor: zoom-in;
}

.service-detail-photo picture,
.service-detail-photo img {
  width: 100%;
  height: 100%;
}

.service-detail-photo img {
  object-fit: cover;
}

.service-coming-soon,
.reviews-panel,
.review-card {
  padding: 18px;
  background: rgba(255, 255, 255, 0.64);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.service-coming-soon {
  max-width: 760px;
  display: grid;
  gap: 8px;
  margin-top: 34px;
}

.reviews-section {
  padding-top: 32px;
  padding-bottom: 48px;
}

.reviews-heading {
  max-width: 820px;
  display: grid;
  gap: 10px;
  margin-bottom: 24px;
}

.reviews-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
  align-items: start;
  max-width: 900px;
}

.review-auth {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-bottom: 16px;
}

.reviews-user {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
}

.review-form {
  display: grid;
  gap: 14px;
}

.review-form label {
  display: grid;
  gap: 8px;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.review-form textarea {
  width: 100%;
  resize: vertical;
  padding: 12px 14px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font: inherit;
  letter-spacing: 0;
  text-transform: none;
}

.review-rating-input {
  display: flex;
  gap: 4px;
}

.review-rating-input button {
  min-height: 36px;
  padding: 4px 5px;
  color: rgba(17, 24, 39, 0.28);
  background: transparent;
  border: 0;
  font-size: 1.5rem;
  cursor: pointer;
}

.review-rating-input button.is-active,
.review-stars {
  color: #9b6b2f;
}

.review-status {
  margin: 14px 0 0;
  padding: 10px 12px;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 0.86rem;
}

.review-status[data-mode="warn"] {
  color: var(--accent-deep);
  border-color: rgba(17, 24, 39, 0.22);
}

.review-status[data-mode="success"] {
  color: #35543a;
  border-color: rgba(104, 114, 97, 0.28);
}

.review-status[data-mode="cart-success"] {
  color: var(--text);
  border-color: var(--line);
}

.review-status.is-cart-success-flash {
  animation: cartStatusTextFlash 2.1s ease-out forwards;
}

@keyframes cartStatusTextFlash {
  0%,
  58% {
    color: #168447;
    border-color: rgba(22, 132, 71, 0.36);
    box-shadow: 0 8px 22px rgba(22, 132, 71, 0.12);
  }

  100% {
    color: var(--text);
    border-color: var(--line);
    box-shadow: none;
  }
}

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

.review-card {
  display: grid;
  gap: 10px;
  min-width: 0;
  overflow-wrap: anywhere;
}

.review-card-top {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 12px;
}

.review-stars {
  letter-spacing: 0.06em;
}

.reviews-empty,
.review-admin-meta {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
}

.reviews-admin-page {
  padding-top: 150px;
}

.booking-widget-section {
  padding-top: 0;
  padding-bottom: 40px;
}

.booking-panel,
.booking-group,
.booking-card {
  padding: 14px;
  background: rgba(255, 255, 255, 0.64);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.booking-panel .reviews-heading {
  margin-bottom: 12px;
}

.booking-panel .reviews-heading h2 {
  font-size: clamp(1.8rem, 3vw, 3rem);
}

.booking-panel .reviews-heading p {
  max-width: 900px;
  margin-bottom: 6px;
  font-size: 0.9rem;
}

.account-missing-note {
  padding: 10px 12px;
  color: var(--accent-deep) !important;
  background: rgba(17, 24, 39, 0.08);
  border: 1px solid rgba(17, 24, 39, 0.18);
  border-radius: var(--radius);
}

.account-missing-note a {
  font-weight: 800;
}

.booking-form {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.booking-form label {
  display: grid;
  gap: 8px;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.booking-form label span {
  color: var(--muted);
  font-size: 0.68rem;
  letter-spacing: 0.08em;
}

.booking-form > label:nth-of-type(4),
.booking-address-panel {
  grid-column: 1 / -1;
}

.booking-address-panel {
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.58);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.booking-address-panel summary {
  cursor: pointer;
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.booking-address-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.booking-address-grid label:first-child {
  grid-column: span 2;
}

.booking-address-grid label:nth-child(3) {
  grid-column: span 3;
}

.booking-form input,
.booking-form textarea,
.booking-form select {
  width: 100%;
  padding: 10px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font: inherit;
  letter-spacing: 0;
  text-transform: none;
}

.phone-field {
  display: grid;
  grid-template-columns: minmax(112px, 0.46fr) minmax(0, 0.54fr);
  gap: 8px;
}

.booking-estimate {
  grid-column: span 2;
  padding: 10px 12px;
  color: var(--accent-deep);
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(17, 24, 39, 0.16);
  border-radius: var(--radius);
  font-size: 0.9rem;
  font-weight: 700;
}

.booking-cost-list,
.vendor-cost-list {
  display: grid;
  gap: 6px;
  padding: 10px 12px;
  background: rgba(255, 255, 255, 0.62);
  border: 1px solid rgba(36, 24, 21, 0.1);
  border-radius: var(--radius);
}

.booking-cost-list {
  grid-column: 1 / -1;
}

.booking-cost-list strong,
.vendor-cost-list strong {
  color: var(--text);
}

.booking-cost-list p,
.vendor-cost-list p {
  margin: 0;
  font-size: 0.86rem;
  line-height: 1.55;
}

.booking-cost-list span {
  display: inline-block;
  min-width: 112px;
  color: var(--accent-deep);
  font-weight: 800;
  text-transform: capitalize;
}

.booking-save-profile,
.booking-location-confirmation {
  grid-column: 1 / -1;
  display: flex !important;
  grid-template-columns: none !important;
  align-items: center;
  gap: 10px !important;
  color: var(--muted) !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.booking-location-confirmation {
  align-items: flex-start;
  padding: 10px 12px;
  color: var(--accent-deep) !important;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(17, 24, 39, 0.22);
  border-radius: var(--radius);
}

.booking-location-confirmation.is-nudging {
  animation: booking-confirmation-nudge 0.9s ease both;
  border-color: var(--accent);
  background: rgba(143, 36, 77, 0.1);
  box-shadow: 0 0 0 4px rgba(143, 36, 77, 0.1);
}

@keyframes booking-confirmation-nudge {
  0%,
  100% {
    transform: translateX(0);
  }
  16% {
    transform: translateX(-5px);
  }
  32% {
    transform: translateX(5px);
  }
  48% {
    transform: translateX(-4px);
  }
  64% {
    transform: translateX(4px);
  }
  82% {
    transform: translateX(-2px);
  }
}

.booking-rental-window {
  grid-column: 1 / -1;
  display: grid;
  gap: 4px;
  padding: 10px 12px;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: var(--radius);
  background: #fff;
}

.booking-rental-window span {
  color: var(--accent-deep);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.booking-rental-window strong {
  color: var(--text);
  font-size: 0.98rem;
}

.booking-rental-window p {
  margin: 0;
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

.booking-save-profile input,
.booking-location-confirmation input {
  width: auto;
}

.booking-list {
  display: grid;
  gap: 16px;
}

.portal-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid rgba(36, 24, 21, 0.1);
  backdrop-filter: blur(14px);
}

.portal-shell {
  width: min(1180px, calc(100% - 32px));
  min-height: 68px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.portal-logo {
  color: var(--text);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(1.35rem, 2.2vw, 2rem);
  font-weight: 700;
}

.portal-chip {
  padding: 7px 10px;
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.08);
  border: 1px solid rgba(17, 24, 39, 0.18);
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.booking-table-title {
  margin: 18px 0 4px;
  font-size: 1rem;
}

.dashboard-overview {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: 8px;
}

.dashboard-metric,
.dashboard-panel {
  border: 1px solid rgba(36, 24, 21, 0.12);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
}

.dashboard-metric {
  min-height: 78px;
  display: grid;
  align-content: start;
  gap: 4px;
  padding: 10px;
}

.dashboard-metric-label,
.dashboard-metric-note {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.dashboard-metric-label {
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.dashboard-metric strong {
  color: var(--text);
  font-size: 1.38rem;
  line-height: 1;
}

.dashboard-metric-note {
  line-height: 1.25;
}

.dashboard-panel {
  padding: 14px;
}

.dashboard-panel-heading {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
}

.dashboard-panel-heading h2,
.dashboard-panel-heading p {
  margin: 0;
}

.dashboard-panel-heading h2 {
  font-size: 1.05rem;
}

.dashboard-panel-heading p {
  max-width: 620px;
  color: var(--muted);
  font-size: 0.82rem;
}

.dashboard-step-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
}

.dashboard-step {
  min-height: 92px;
  display: grid;
  align-content: start;
  gap: 6px;
  padding: 10px;
  border: 1px solid rgba(36, 24, 21, 0.1);
  border-radius: var(--radius);
  background: rgba(247, 241, 235, 0.46);
}

.dashboard-step-live {
  border-color: rgba(17, 24, 39, 0.32);
  background: rgba(17, 24, 39, 0.08);
}

.dashboard-step strong,
.dashboard-step p {
  margin: 0;
}

.dashboard-step strong {
  color: var(--accent-deep);
  font-size: 0.82rem;
}

.dashboard-step p {
  color: var(--muted);
  font-size: 0.78rem;
}

.dashboard-queue-details summary {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  cursor: pointer;
}

.dashboard-queue-details summary span {
  color: var(--muted);
  font-size: 0.78rem;
}

.dashboard-queue-details .dashboard-step-list {
  margin-top: 12px;
}

.dashboard-calendar-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.dashboard-calendar-item {
  min-height: 92px;
  display: grid;
  align-content: start;
  gap: 6px;
  padding: 10px;
  border: 1px solid rgba(36, 24, 21, 0.1);
  border-radius: var(--radius);
  background: #ffffff;
}

.dashboard-calendar-item strong,
.dashboard-calendar-item span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.dashboard-calendar-item strong {
  color: var(--accent-deep);
  font-size: 0.84rem;
}

.dashboard-calendar-item span {
  color: var(--text);
  font-size: 0.8rem;
  font-weight: 700;
}

.onboarding-page .reviews-heading {
  margin-bottom: 16px;
}

.onboarding-workspace {
  display: grid;
  gap: 16px;
}

.onboarding-shell {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}

.onboarding-sidebar,
.onboarding-editor,
.onboarding-preview,
.onboarding-submissions {
  padding: 14px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(36, 24, 21, 0.12);
  border-radius: var(--radius);
}

.onboarding-sidebar {
  position: sticky;
  top: 86px;
  display: grid;
  gap: 12px;
}

.onboarding-sidebar h2,
.onboarding-editor h2,
.onboarding-preview h2,
.onboarding-submissions h2 {
  margin: 0;
  font-size: 1.05rem;
}

.onboarding-form {
  display: grid;
  gap: 14px;
}

.onboarding-grid,
.onboarding-triple {
  display: grid;
  gap: 10px;
}

.onboarding-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.onboarding-triple {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.onboarding-form label,
.onboarding-sidebar label {
  display: grid;
  gap: 7px;
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 900;
  letter-spacing: 0.07em;
  text-transform: uppercase;
}

.onboarding-form label span,
.onboarding-sidebar label span {
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: none;
}

.onboarding-form input,
.onboarding-form textarea,
.onboarding-form select,
.onboarding-sidebar select,
.onboarding-sidebar input {
  width: 100%;
  padding: 10px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font: inherit;
  letter-spacing: 0;
  text-transform: none;
}

.onboarding-form textarea {
  min-height: 88px;
  resize: vertical;
}

.onboarding-check {
  display: flex !important;
  grid-template-columns: none !important;
  flex-direction: row;
  align-items: flex-start;
  gap: 10px !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}

.onboarding-check input {
  width: auto;
  margin-top: 3px;
}

.onboarding-panel {
  display: grid;
  gap: 12px;
  padding: 12px;
  background: rgba(247, 241, 235, 0.54);
  border: 1px solid rgba(36, 24, 21, 0.1);
  border-radius: var(--radius);
}

.onboarding-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: start;
}

.onboarding-repeat-list {
  display: grid;
  gap: 10px;
}

.onboarding-repeat-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.onboarding-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.onboarding-preview {
  display: grid;
  gap: 12px;
}

.onboarding-preview-card {
  display: grid;
  gap: 8px;
  padding: 12px;
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.onboarding-preview-images {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.onboarding-preview-images img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--radius);
  background: var(--bg-warm);
}

.onboarding-status {
  margin: 0;
  color: var(--accent-deep);
  font-size: 0.82rem;
  font-weight: 850;
}

.onboarding-submission-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 120px 150px auto;
  gap: 10px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--line);
}

.onboarding-submission-row:last-child {
  border-bottom: 0;
}

.onboarding-submission-row strong,
.onboarding-submission-row span {
  min-width: 0;
  overflow-wrap: anywhere;
}

.onboarding-sql {
  min-height: 240px;
  font-family: Consolas, "Courier New", monospace;
  font-size: 0.76rem;
  line-height: 1.45;
  white-space: pre;
}

.onboarding-mode-panel[hidden] {
  display: none !important;
}

.dashboard-tabs {
  display: grid;
  gap: 12px;
}

.dashboard-tab-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px;
  border: 1px solid rgba(36, 24, 21, 0.12);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.76);
}

.dashboard-tab {
  min-height: 38px;
  padding: 8px 12px;
  color: var(--text);
  background: transparent;
  border: 1px solid transparent;
  border-radius: var(--radius);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 900;
  cursor: pointer;
}

.dashboard-tab.is-active {
  color: var(--white);
  background: var(--accent-deep);
  border-color: var(--accent-deep);
}

.dashboard-tab-panel {
  display: grid;
  gap: 14px;
}

.dashboard-tab-panel.is-hidden {
  display: none;
}

.message-page .reviews-heading {
  max-width: 720px;
}

.message-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 14px;
  align-items: start;
}

.message-thread-list,
.message-panel-card {
  display: grid;
  gap: 10px;
}

.message-section-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  margin-bottom: 8px;
  padding: 4px;
  background: rgba(36, 24, 21, 0.05);
  border-radius: var(--radius);
}

.message-section-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  min-height: 42px;
  color: var(--muted);
  border-radius: calc(var(--radius) - 2px);
  font-size: 0.82rem;
  font-weight: 900;
}

.message-section-tab-count {
  min-width: 19px;
  display: inline-grid;
  place-items: center;
  padding: 2px 6px;
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.1);
  border-radius: 999px;
  font-size: 0.68rem;
  font-style: normal;
  line-height: 1.2;
}

.message-section-tab.is-active {
  color: var(--text);
  background: #fff;
  box-shadow: 0 6px 16px rgba(36, 24, 21, 0.07);
}

.message-section-tab.is-active .message-section-tab-count {
  color: #fff;
  background: var(--accent);
}

.message-section-tab-count.has-unread,
.message-section-tab.is-active .message-section-tab-count.has-unread {
  color: #fff;
  background: #168447;
}

.message-thread-card {
  width: 100%;
  display: grid;
  grid-template-columns: 66px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  padding: 12px 4px;
  color: var(--text);
  background: transparent;
  border: 0;
  border-bottom: 1px solid rgba(36, 24, 21, 0.07);
  border-radius: 0;
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease, background 180ms ease;
}

.message-thread-card:hover {
  background: rgba(17, 24, 39, 0.035);
}

.message-thread-card.is-active {
  background: rgba(17, 24, 39, 0.045);
}

.message-thread-card.has-unread {
  background: rgba(239, 247, 239, 0.55);
}

.message-thread-avatar {
  width: 60px;
  height: 60px;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: var(--accent-deep);
  background: #ffffff;
  border: 2px solid rgba(17, 24, 39, 0.12);
  border-radius: 50%;
  font-weight: 900;
}

.message-thread-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.message-thread-body {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.message-thread-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.message-thread-top-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  min-width: 0;
}

.message-thread-status {
  max-width: 92px;
  padding: 3px 7px;
  overflow: hidden;
  color: #4b5563;
  background: rgba(17, 24, 39, 0.08);
  border-radius: 999px;
  font-size: 0.62rem;
  font-weight: 900;
  line-height: 1.15;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.message-thread-status-pending,
.message-thread-status-enquiry {
  color: #6b4b00;
  background: rgba(251, 191, 36, 0.18);
}

.message-thread-status-approved {
  color: #0f7a3f;
  background: rgba(22, 132, 71, 0.14);
}

.message-thread-status-rejected,
.message-thread-status-cancelled {
  color: #b42318;
  background: rgba(180, 35, 24, 0.12);
}

.message-thread-preview,
.message-bubble p {
  margin: 0;
  overflow-wrap: anywhere;
  white-space: pre-wrap;
}

.message-chat-page .message-bubble p {
  font-size: 1rem;
  line-height: 1.34;
}

.message-chat-page .message-bubble .booking-code {
  font-size: 0.68rem;
  line-height: 1.2;
  opacity: 0.78;
}

.message-thread-preview {
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.45;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.message-thread-package {
  color: rgba(70, 57, 52, 0.58);
  font-size: 0.76rem;
  font-weight: 600;
  line-height: 1.35;
}

.message-thread-time {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
}

.message-unread-dot,
.mobile-nav-unread-dot {
  display: inline-grid;
  place-items: center;
  color: #fff;
  background: #168447;
  border-radius: 999px;
  font-style: normal;
  font-weight: 900;
}

.message-unread-dot {
  min-width: 20px;
  padding: 3px 7px;
  font-size: 0.62rem;
  text-transform: uppercase;
}

.mobile-nav-unread-dot {
  min-width: 16px;
  height: 16px;
  margin-left: 6px;
  vertical-align: middle;
  padding: 0 4px;
  font-size: 0.58rem;
  line-height: 1;
}

.message-panel-card {
  padding: 14px;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.message-chat-page {
  position: fixed;
  top: var(--chat-viewport-top, 0);
  right: auto;
  bottom: auto;
  left: var(--chat-viewport-left, 0);
  z-index: 30;
  width: var(--chat-viewport-width, 100vw);
  max-width: 100vw;
  height: min(var(--chat-viewport-height, 100dvh), calc(100vh - var(--chat-viewport-top, 0px)));
  min-height: 0;
  background: #ffffff;
  overflow: hidden;
  touch-action: manipulation;
}

.message-chat-page .message-panel-card {
  width: 100%;
  min-height: 100%;
  height: 100%;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: #ffffff;
  overflow: hidden;
}

.message-panel-head {
  position: sticky;
  top: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 58px;
  padding: 10px 14px;
  background: rgba(255, 250, 246, 0.96);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(36, 24, 21, 0.08);
}

.message-panel-title {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.message-profile-link {
  color: var(--text);
  font-weight: 900;
}

.message-profile-link:hover {
  color: var(--accent-deep);
}

.message-back {
  width: 44px;
  min-width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  color: var(--accent-deep);
  border-radius: 999px;
  font-size: 1.9rem;
  font-weight: 700;
  line-height: 1;
}

.message-stream {
  display: grid;
  gap: 8px;
  align-content: end;
  max-height: min(56vh, 520px);
  overflow: auto;
  padding: 14px;
  scroll-behavior: smooth;
}

.message-chat-page .message-stream {
  display: flex;
  flex-direction: column;
  max-height: none;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
}

.message-order-strip {
  justify-self: center;
  width: min(92%, 560px);
  padding: 8px 12px;
  color: rgba(36, 24, 21, 0.68);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: 999px;
  font-size: 0.8rem;
  font-weight: 800;
  text-align: center;
}

.message-bubble {
  width: fit-content;
  max-width: min(78%, 520px);
  display: grid;
  gap: 4px;
  padding: 10px 14px;
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: 22px 22px 22px 6px;
  animation: messageIn 160ms ease both;
}

.message-bubble.can-unsend {
  cursor: pointer;
}

@keyframes messageIn {
  from {
    opacity: 0;
    transform: translateY(4px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

.message-bubble.is-mine {
  justify-self: end;
  align-self: flex-end;
  color: #ffffff;
  background: #3797f0;
  border-color: #3797f0;
  border-radius: 22px 22px 6px 22px;
  box-shadow: 0 8px 18px rgba(55, 151, 240, 0.16);
}

.message-bubble.is-mine .booking-code {
  color: rgba(255, 255, 255, 0.84);
}

.message-bubble.is-mine p {
  color: #fff;
}

.message-bubble.is-system {
  justify-self: center;
  align-self: center;
  width: fit-content;
  max-width: min(86%, 560px);
  color: rgba(36, 24, 21, 0.62);
  background: rgba(36, 24, 21, 0.045);
  border-color: rgba(36, 24, 21, 0.06);
  border-radius: 18px;
  text-align: center;
}

.message-bubble.is-system .booking-code {
  color: rgba(36, 24, 21, 0.52);
}

.message-bubble.is-unsent {
  color: rgba(36, 24, 21, 0.52);
  background: rgba(17, 24, 39, 0.045);
  border-color: rgba(17, 24, 39, 0.06);
  box-shadow: none;
}

.message-bubble.is-unsent p {
  color: inherit;
  font-style: italic;
}

body[data-private-portal="vendor"] .message-bubble {
  color: rgba(36, 24, 21, 0.76);
  background: #ffffff;
}

body[data-private-portal="vendor"] .message-bubble.is-mine {
  color: #ffffff;
  background: #3797f0;
}

body[data-private-portal="vendor"] .message-bubble.is-mine p {
  color: #fff;
}

body[data-private-portal="vendor"] .message-bubble.is-system {
  color: rgba(36, 24, 21, 0.58);
  background: rgba(36, 24, 21, 0.04);
}

.message-bubble a {
  color: inherit;
  font-weight: 800;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.message-photo {
  display: block;
  overflow: hidden;
  border-radius: 18px;
  border: 0;
  text-decoration: none;
}

.message-photo img {
  width: min(260px, 100%);
  max-height: 340px;
  object-fit: cover;
}

.message-unsend-action {
  display: flex;
  justify-content: flex-end;
}

.message-unsend-button {
  min-height: 30px;
  padding: 6px 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.92);
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 999px;
  font-size: 0.72rem;
  font-weight: 900;
}

.message-payment-box {
  width: min(92%, 560px);
  display: grid;
  gap: 8px;
  justify-self: center;
  padding: 12px;
  background: #fff;
  border: 1px solid rgba(137, 48, 79, 0.22);
  border-radius: var(--radius);
  box-shadow: 0 10px 24px rgba(36, 24, 21, 0.08);
}

.message-compose {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: end;
  gap: 8px;
  padding: 8px 14px max(6px, env(safe-area-inset-bottom));
  background: rgba(255, 250, 246, 0.96);
  border-top: 1px solid rgba(36, 24, 21, 0.08);
  overflow: hidden;
}

.message-compose label {
  display: grid;
  gap: 6px;
  color: var(--accent-deep);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.message-compose input,
.message-compose textarea,
.message-compose select {
  width: 100%;
  padding: 10px 12px;
  color: var(--text);
  background: #ffffff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font: inherit;
  font-size: 16px !important;
  line-height: 1.4;
  letter-spacing: 0;
  text-transform: none;
  touch-action: manipulation;
  resize: vertical;
}

.message-chat-page .message-compose textarea {
  min-height: 44px;
  max-height: 112px;
  border-radius: 22px;
  resize: none;
}

.message-chat-page .message-compose label > span {
  display: none;
}

.message-chat-page .message-compose .btn,
.message-chat-page .message-compose button[type="submit"] {
  min-height: 44px;
  min-width: auto;
  padding: 0 18px;
  border-radius: 999px;
  letter-spacing: 0;
}

body:has(.message-chat-page) .mobile-bottom-nav {
  display: none !important;
}

body.react-chat-shell,
body.react-chat-active {
  position: fixed;
  inset: 0;
  top: var(--chat-scroll-lock-top, 0);
  right: auto;
  left: var(--chat-viewport-left, 0);
  width: var(--chat-viewport-width, 100vw);
  max-width: 100vw;
  height: 100%;
  padding-bottom: 0 !important;
  overflow: hidden !important;
  overscroll-behavior: none;
  background: #ffffff;
}

body.react-chat-shell main,
body.react-chat-active main,
body.react-chat-shell .next-route-shell,
body.react-chat-active .next-route-shell,
body.react-chat-shell .message-chat-page,
body.react-chat-active .message-chat-page {
  width: var(--chat-viewport-width, 100vw);
  max-width: 100%;
  min-width: 0;
  height: 100%;
  overflow: hidden;
}

body.react-chat-shell .message-chat-page,
body.react-chat-active .message-chat-page {
  height: min(var(--chat-viewport-height, 100dvh), calc(100vh - var(--chat-viewport-top, 0px)));
}

body.react-chat-shell .mobile-bottom-nav,
body.react-chat-shell .app-fab,
body.react-chat-active .mobile-bottom-nav,
body.react-chat-active .app-fab {
  display: none !important;
}

.message-chat-page [data-react-messaging-root],
.react-chat-screen {
  width: var(--chat-viewport-width, 100vw);
  max-width: 100vw;
  min-width: 0;
  overflow-x: clip;
}

.react-chat-screen {
  position: absolute;
  inset: 0;
  height: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  grid-template-rows: auto minmax(0, 1fr) auto auto auto;
  background: #ffffff;
  overflow: hidden;
  transform: translateZ(0);
  contain: layout paint size;
}

.react-chat-screen > * {
  min-width: 0;
  max-width: 100%;
}

.react-chat-head {
  position: relative;
  top: auto;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  padding-top: calc(10px + env(safe-area-inset-top));
}

.react-chat-head > * {
  min-width: 0;
}

.react-chat-head .message-panel-title strong,
.react-chat-head .message-panel-title span,
.react-chat-head .message-profile-link {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.react-chat-stream {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  min-height: 0;
  height: auto;
  max-height: none;
  align-content: end;
  padding-bottom: 14px;
  overflow-x: hidden;
  overscroll-behavior: contain;
  touch-action: pan-y;
}

.react-chat-stream > * {
  min-width: 0;
}

.react-chat-stream .message-bubble {
  max-width: min(82%, calc(var(--chat-viewport-width, 100vw) - 32px), 520px);
}

.react-chat-stream .message-bubble.is-mine {
  max-width: min(78%, calc(var(--chat-viewport-width, 100vw) - 32px), 520px);
}

.react-chat-stream .message-bubble.is-system {
  align-self: center;
  margin-inline: auto;
  max-width: calc(var(--chat-viewport-width, 100vw) - 32px);
}

.react-chat-stream .message-bubble p,
.react-chat-stream .message-bubble .booking-code,
.react-chat-stream .message-payment-box,
.react-chat-stream .message-order-strip {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.react-chat-screen > .message-payment-box,
.react-chat-screen > .react-payment-box {
  width: calc(var(--chat-viewport-width, 100vw) - 20px);
  max-width: 560px;
  min-width: 0;
  justify-self: center;
  margin: 0 auto 8px;
  overflow: hidden;
}

.react-payment-box > * {
  min-width: 0;
}

.react-payment-box a {
  overflow-wrap: anywhere;
  word-break: break-word;
}

.react-payment-actions {
  width: 100%;
  min-width: 0;
}

.react-payment-actions .btn,
.react-payment-actions button,
.react-payment-actions a {
  min-width: 0;
  flex: 1 1 140px;
  justify-content: center;
  text-align: center;
  white-space: normal;
}

.react-chat-compose {
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: end;
  justify-self: stretch;
  gap: 8px;
  padding: 6px 10px max(5px, env(safe-area-inset-bottom));
  width: 100%;
  max-width: var(--chat-viewport-width, 100vw);
  min-width: 0;
  overflow: hidden;
  transform: translateZ(0);
  contain: layout paint;
}

.message-attach-button {
  width: 44px;
  height: 44px;
  display: inline-grid;
  place-items: center;
  flex: 0 0 44px;
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.06);
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 999px;
  font-size: 1.7rem;
  line-height: 1;
}

.react-chat-compose label {
  min-width: 0;
}

.react-chat-compose label span {
  display: none;
}

.react-chat-compose textarea {
  width: 100%;
  max-width: 100%;
  min-width: 0;
  min-height: 44px;
  max-height: 112px;
  resize: none;
  border-radius: 22px;
  padding: 11px 14px;
}

.react-chat-compose .btn {
  min-height: 44px;
  min-width: 64px;
  max-width: 28vw;
  border-radius: 999px;
  padding-inline: 14px;
  white-space: nowrap;
}

.react-message-list-app {
  width: min(100%, 760px);
  margin: 0 auto;
}

.react-message-desktop-shell {
  width: min(100%, 1180px);
}

.react-message-workspace {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  min-height: min(74vh, 760px);
  overflow: hidden;
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.08);
  border-radius: 0;
}

.react-message-sidebar {
  min-width: 0;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 12px;
  padding: 14px;
  border-right: 1px solid rgba(17, 24, 39, 0.08);
  overflow: hidden;
}

.react-message-pane {
  min-width: 0;
  min-height: 0;
  display: grid;
  background: #ffffff;
}

.react-message-pane .react-chat-screen {
  position: relative;
  inset: auto;
  min-height: min(74vh, 760px);
  height: 100%;
  z-index: 1;
}

.react-message-pane .react-chat-head {
  padding-top: 10px;
}

.react-message-pane .message-back {
  display: none;
}

.react-app-footer-nav {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0;
  padding: 6px 5px calc(6px + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid rgba(36, 24, 21, 0.1);
  box-shadow: 0 -10px 24px rgba(36, 24, 21, 0.07);
}

.react-app-footer-nav a {
  min-height: 46px;
  display: grid;
  gap: 2px;
  place-items: center;
  color: var(--muted);
  font-size: 0.62rem;
  font-weight: 800;
  text-decoration: none;
}

.react-app-footer-nav svg {
  width: 22px;
  height: 22px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.react-app-footer-nav a[aria-current="page"] {
  color: var(--accent-deep);
}

body.react-chat-keyboard-open .react-app-footer-nav {
  display: none;
}

.react-chat-screen > .react-app-footer-nav,
.react-message-list-app > .react-app-footer-nav,
.react-message-workspace + .react-app-footer-nav {
  position: fixed;
  inset: auto 0 0;
  z-index: 2200;
  border-top: 1px solid var(--line);
  box-shadow: 0 -12px 28px rgba(36, 24, 21, 0.08);
}

.react-message-pane .react-app-footer-nav {
  display: none;
}

.react-message-search {
  display: block;
  margin: 0 0 14px;
}

.react-message-search input {
  width: 100%;
  min-height: 44px;
  padding: 11px 14px;
  color: var(--text);
  background: rgba(17, 24, 39, 0.05);
  border: 1px solid rgba(17, 24, 39, 0.06);
  border-radius: 999px;
  font: inherit;
  font-size: 16px !important;
}

.react-message-list {
  display: grid;
  gap: 8px;
  align-content: start;
  overflow: auto;
  min-height: 0;
  padding-right: 2px;
}

.react-thread-card {
  text-decoration: none;
}

.react-message-empty {
  display: grid;
  gap: 10px;
  justify-items: start;
  padding: 18px;
  color: rgba(36, 24, 21, 0.72);
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
}

.react-message-empty-state {
  min-height: min(74vh, 760px);
  display: grid;
  place-items: center;
  align-content: center;
  justify-items: center;
  gap: 10px;
  color: rgba(36, 24, 21, 0.72);
  text-align: center;
}

.react-message-empty-icon {
  width: 74px;
  height: 74px;
  display: grid;
  place-items: center;
  color: var(--accent-deep);
  border: 2px solid rgba(94, 36, 53, 0.28);
  border-radius: 999px;
  font-size: 2rem;
}

.react-message-empty-state strong,
.react-message-empty-state p {
  margin: 0;
}

.react-message-empty-state p {
  max-width: 280px;
  color: var(--muted);
  font-size: 0.9rem;
}

.react-message-skeleton {
  display: grid;
  gap: 8px;
}

.react-message-skeleton span {
  min-height: 72px;
  border-radius: 18px;
  background: linear-gradient(100deg, rgba(36, 24, 21, 0.05), rgba(255, 255, 255, 0.86), rgba(36, 24, 21, 0.05));
  background-size: 220% 100%;
  animation: skeletonShimmer 1.25s ease-in-out infinite;
}

.react-payment-box {
  margin: 0 auto 8px;
}

.react-payment-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.react-typing-line {
  justify-self: start;
  padding: 4px 10px;
  color: rgba(36, 24, 21, 0.46);
  font-size: 0.78rem;
  font-weight: 800;
}

.react-message-bubble p {
  white-space: pre-wrap;
  word-break: break-word;
}

.react-message-bubble.is-pending {
  opacity: 0.74;
}

@media (max-width: 720px) {
  .message-page .reviews-heading {
    margin-bottom: 16px;
  }

  .react-message-list-app {
    width: 100%;
  }

  .react-message-workspace {
    display: block;
    min-height: 0;
    border: 0;
    background: transparent;
  }

  .react-message-sidebar {
    display: grid;
    padding: 0;
    border-right: 0;
    overflow: visible;
  }

  .react-message-pane {
    display: none;
  }

  .react-message-workspace + .react-app-footer-nav {
    position: fixed;
    inset: auto 0 0;
    z-index: 2200;
    margin-top: 0;
    border-right: 0;
    border-bottom: 0;
    border-left: 0;
    border-radius: 0;
  }

  .react-message-list-app {
    padding-bottom: calc(74px + env(safe-area-inset-bottom));
  }

  .react-chat-stream {
    padding: 12px 10px;
  }

  .react-chat-compose {
    padding-inline: 10px;
  }

  .react-chat-compose .btn {
    min-width: auto;
    padding-inline: 16px;
  }
}

.admin-flow-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.admin-flow-step {
  position: relative;
  min-height: 118px;
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 12px;
  border: 1px solid rgba(36, 24, 21, 0.1);
  border-radius: var(--radius);
  background: rgba(247, 241, 235, 0.5);
}

.admin-flow-step-live {
  border-color: rgba(17, 24, 39, 0.34);
  background: rgba(17, 24, 39, 0.08);
}

.admin-flow-number {
  width: 28px;
  height: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  background: var(--accent-deep);
  border-radius: 50%;
  font-size: 0.75rem;
  font-weight: 900;
}

.admin-flow-step strong,
.admin-flow-step p {
  margin: 0;
}

.admin-flow-step strong {
  color: var(--accent-deep);
  font-size: 0.84rem;
}

.admin-flow-step p {
  color: var(--muted);
  font-size: 0.78rem;
}

.dashboard-subtitle {
  margin: 18px 0 4px;
  color: var(--text);
  font-size: 0.95rem;
}

.booking-table-shell {
  overflow-x: auto;
  border: 1px solid rgba(36, 24, 21, 0.12);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.82);
}

.booking-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
  font-size: 0.8rem;
}

.booking-table th,
.booking-table td {
  padding: 7px 8px;
  border-bottom: 1px solid rgba(36, 24, 21, 0.1);
  text-align: left;
  vertical-align: top;
}

.booking-table td:last-child {
  min-width: 168px;
}

.booking-next-step-cell {
  min-width: 150px;
  color: var(--accent-deep);
  font-weight: 800;
}

.booking-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  color: var(--accent-deep);
  background: #fff8f4;
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.booking-table tr:last-child td {
  border-bottom: 0;
}

.booking-table-actions {
  gap: 6px;
}

.booking-table-actions .btn {
  min-height: 30px;
  padding: 6px 9px;
  font-size: 0.74rem;
  letter-spacing: 0;
  text-transform: none;
}

@media (max-width: 980px) {
  .onboarding-shell {
    grid-template-columns: 1fr;
  }

  .onboarding-sidebar {
    position: static;
  }

  .onboarding-submission-row {
    grid-template-columns: minmax(0, 1fr) auto;
  }

  .dashboard-overview {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dashboard-step-list,
  .dashboard-calendar-list,
  .admin-flow-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 640px) {
  .onboarding-grid,
  .onboarding-triple,
  .onboarding-submission-row {
    grid-template-columns: 1fr;
  }

  .onboarding-panel-head {
    display: grid;
  }

  .onboarding-preview-images {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-overview,
  .dashboard-step-list,
  .dashboard-calendar-list,
  .admin-flow-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .dashboard-panel-heading {
    display: grid;
    align-items: start;
  }

  .dashboard-metric {
    min-height: 70px;
    padding: 9px;
  }

  .dashboard-metric strong {
    font-size: 1.18rem;
  }

  .booking-table-shell {
    overflow: visible;
  }

  .booking-table,
  .booking-table tbody,
  .booking-table tr,
  .booking-table td {
    display: block;
    width: 100%;
  }

  .booking-table thead {
    display: none;
  }

  .booking-table tr {
    padding: 10px;
    border-bottom: 1px solid var(--line);
  }

  .booking-table td {
    padding: 5px 0;
    border: 0;
  }

  .booking-table-actions {
    display: grid;
    grid-template-columns: 1fr;
  }
}

.booking-group,
.booking-card {
  display: grid;
  gap: 10px;
}

.booking-group h2,
.booking-card p {
  margin: 0;
}

.booking-page-actions {
  margin-top: 18px;
}

.booking-history-heading {
  margin-top: 46px;
}

.portal-follow-section {
  padding-top: 24px;
}

.portal-tabs {
  position: sticky;
  top: 76px;
  z-index: 20;
  display: flex;
  gap: 8px;
  max-width: var(--max-width);
  margin: 0 auto;
  padding: 10px var(--page-pad);
  overflow-x: auto;
  background: rgba(247, 241, 235, 0.96);
  border-bottom: 1px solid rgba(36, 24, 21, 0.08);
}

.portal-tabs a {
  position: relative;
  flex: 0 0 auto;
  padding: 9px 12px;
  color: var(--ink);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  text-decoration: none;
  background: rgba(255, 255, 255, 0.76);
  border: 1px solid var(--line);
  border-radius: 999px;
}

.portal-tabs a[aria-current="page"] {
  color: #fff;
  background: var(--accent-deep);
  border-color: var(--accent-deep);
}

.storefront-card-head {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 14px;
}

.storefront-card-head > div {
  min-width: 0;
}

.storefront-card-head .btn {
  width: auto;
  white-space: nowrap;
}

.storefront-module-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.storefront-youtube-list {
  display: grid;
  gap: 10px;
}

.storefront-module-card {
  display: grid;
  gap: 8px;
  min-height: 112px;
  padding: 14px;
  color: var(--ink);
  text-decoration: none;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.storefront-module-card strong {
  color: var(--accent-deep);
  font-size: 1rem;
}

.storefront-module-card span {
  color: var(--muted);
  font-size: 0.86rem;
  line-height: 1.45;
}

.storefront-editor-form {
  display: grid;
  gap: 14px;
}

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

.storefront-rate-list {
  display: grid;
  gap: 10px;
  padding: 12px;
  background: rgba(247, 241, 235, 0.74);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.storefront-rate-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 130px auto;
  gap: 10px;
  align-items: center;
  padding: 8px;
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
}

.storefront-addon-row,
.storefront-location-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.storefront-location-grid label {
  display: flex;
  gap: 8px;
  align-items: center;
  padding: 10px;
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 0.84rem;
  font-weight: 800;
}

.storefront-wide-field {
  grid-column: 1 / -1;
}

.storefront-wide-field textarea {
  min-height: 82px;
}

.storefront-rate-row span {
  min-width: 0;
  font-weight: 800;
}

.storefront-rate-row em {
  color: var(--muted);
  font-size: 0.78rem;
  font-style: normal;
}

.storefront-media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 10px;
}

.storefront-media-tile {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 8px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.storefront-media-tile img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 6px;
}

.photo-package-builder {
  display: grid;
  gap: 12px;
}

.photo-package-row,
.photo-custom-event,
.photo-deliverable-row {
  display: grid;
  gap: 10px;
  padding: 10px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
}

.photo-package-row,
.photo-custom-event {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: end;
}

.photo-package-row > strong,
.photo-package-row > span {
  align-self: center;
}

.photo-deliverables-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 8px;
}

.photo-deliverable-row {
  grid-template-columns: minmax(0, 1fr) 110px;
  align-items: center;
}

.photo-grand-total {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  padding: 14px;
  background: var(--ink);
  color: #fff;
  border-radius: var(--radius);
}

.photo-grand-total strong {
  color: #fff;
  font-size: 1.05rem;
}

.storefront-media-tile span,
.storefront-review-check {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--ink);
  font-size: 0.84rem;
  font-weight: 700;
}

.storefront-review-check {
  margin: 0;
  padding: 8px 0;
}

.storefront-review-summary {
  background: rgba(255, 255, 255, 0.82);
}

.storefront-review-line {
  margin: 0;
  color: var(--muted);
  line-height: 1.45;
}

.storefront-review-line strong {
  color: var(--ink);
}

.storefront-review-details {
  padding: 8px 0;
  border-top: 1px solid rgba(36, 24, 21, 0.08);
}

.storefront-review-details summary {
  cursor: pointer;
  color: var(--accent-deep);
  font-weight: 800;
}

.venue-pricing-panel {
  margin-top: 18px;
}

[data-cart-page] {
  padding-bottom: calc(var(--bottom-nav-height, 76px) + 28px);
}

.cart-summary {
  display: grid;
  gap: 10px;
  margin-top: 12px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(17, 24, 39, 0.16);
  border-radius: var(--radius);
}

.cart-summary-head {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
}

.cart-summary h2,
.cart-summary p {
  margin: 0;
}

.cart-summary-total {
  color: var(--accent-deep);
  font-weight: 800;
}

.cart-checkout-button {
  width: 100%;
  margin-top: 0;
  border-radius: var(--radius);
}

.cart-summary-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  align-items: center;
}

.cart-summary-actions .btn {
  width: 100%;
  min-height: 48px;
  padding: 12px 14px;
  border-radius: var(--radius);
  font-size: 0.74rem;
  letter-spacing: 0.08em;
}

.cart-summary-actions .btn-primary {
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.08);
  border-color: rgba(17, 24, 39, 0.26);
  box-shadow: none;
}

.cart-summary-actions .btn-primary:hover {
  color: var(--accent-deep);
  background: rgba(255, 255, 255, 0.92);
  border-color: rgba(17, 24, 39, 0.34);
  box-shadow: none;
  transform: none;
}

.cart-checkout-step,
.cart-final-action {
  display: grid;
  gap: 6px;
  padding: 12px;
  background: rgba(22, 132, 71, 0.08);
  border: 1px solid rgba(22, 132, 71, 0.22);
  border-radius: var(--radius);
}

.cart-checkout-step strong,
.cart-final-action p {
  margin: 0;
  color: #168447;
  font-weight: 900;
}

.cart-checkout-step span {
  color: var(--text);
  font-size: 0.84rem;
  font-weight: 700;
  line-height: 1.45;
}

.cart-final-action {
  margin-top: 12px;
  background: #ffffff;
  border-color: rgba(17, 24, 39, 0.16);
}

.cart-final-action .btn {
  width: 100%;
  min-height: 52px;
}

.cart-summary-list {
  display: grid;
  gap: 6px;
  margin: 8px 0 0;
  padding-left: 18px;
  color: var(--muted);
}

.booking-page-actions[data-cart-actions] {
  position: static;
  width: 100%;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  margin-top: 10px;
  padding: 0;
  background: rgba(255, 250, 246, 0.96);
  border: 0;
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: none;
}

.booking-page-actions[data-cart-actions][hidden] {
  display: none;
}

.cart-approval-summary {
  display: grid;
  gap: 2px;
  min-width: 0;
}

.cart-approval-summary strong {
  color: var(--accent-deep);
  font-size: 0.98rem;
  line-height: 1.1;
}

.cart-approval-summary span {
  color: var(--muted);
  font-size: 0.76rem;
  font-weight: 800;
  line-height: 1.2;
}

.booking-page-actions[data-cart-actions] .btn {
  width: 100%;
  min-height: 48px;
  padding-inline: 14px;
  white-space: normal;
}

.cart-item-card {
  display: block;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  overflow: hidden;
}

.cart-item-card summary {
  list-style: none;
}

.cart-item-card summary::-webkit-details-marker {
  display: none;
}

.cart-item-summary {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 9px;
  cursor: pointer;
}

.cart-item-summary-meta {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.cart-item-summary-meta strong,
.cart-item-summary-meta span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.cart-item-summary-meta span {
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
}

.cart-item-media {
  min-height: 74px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.cart-item-media img {
  width: 100%;
  height: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
}

.cart-item-media span {
  color: var(--accent);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 3rem;
}

.cart-item-body {
  display: grid;
  gap: 8px;
  padding: 0 12px 12px 94px;
}

.cart-item-price {
  color: var(--text) !important;
  font-size: 1rem;
  font-weight: 900;
}

.cart-item-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.cart-item-actions .btn {
  min-height: 40px;
  padding: 9px 16px;
  letter-spacing: 0.04em;
  text-transform: none;
}

.cart-popular-section {
  display: grid;
  gap: 10px;
  margin-top: 18px;
  padding-top: 16px;
  border-top: 1px solid var(--line);
}

.cart-popular-section h2 {
  margin: 0;
  color: var(--text);
  font-size: 1rem;
}

.cart-popular-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.cart-popular-link,
.cart-recent-more {
  min-height: 44px;
  display: grid;
  place-items: center;
  color: var(--text);
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 0.78rem;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-decoration: none;
}

.cart-recent-more {
  margin-top: 4px;
}

.orders-list {
  gap: 12px;
}

.order-filter-controls {
  display: grid;
  justify-items: end;
  margin: -2px 0 12px;
}

.order-filter-label {
  width: min(100%, 280px);
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 8px;
  align-items: center;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.order-filter-label select {
  width: 100%;
  min-height: 42px;
  padding: 8px 34px 8px 10px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.84);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0;
  text-transform: none;
}

.order-card {
  display: grid;
  grid-template-columns: 148px minmax(0, 1fr);
  gap: 14px;
  padding: 12px;
  background: rgba(255, 255, 255, 0.82);
  border: 1px solid rgba(36, 24, 21, 0.12);
  border-radius: var(--radius);
}

.order-card-compact {
  display: block;
  padding: 8px;
}

.order-card-summary {
  min-height: 74px;
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  cursor: pointer;
  list-style: none;
}

.order-card-summary::-webkit-details-marker {
  display: none;
}

.order-card-summary::after {
  content: "See more";
  align-self: center;
  justify-self: end;
  padding: 6px 8px;
  color: var(--accent-deep);
  border: 1px solid rgba(17, 24, 39, 0.18);
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.order-card-compact[open] .order-card-summary::after {
  content: "Hide";
}

.order-card-summary > .order-lifecycle-compact {
  grid-column: 2 / -1;
  margin: 2px 0 0;
}

.order-card-summary > .order-lifecycle-compact .order-lifecycle-dot {
  width: 24px;
  height: 24px;
  font-size: 0.54rem;
}

.order-card-summary > .order-lifecycle-compact .order-lifecycle-step strong {
  max-width: 64px;
  font-size: 0.6rem;
}

.order-card-summary .order-card-media {
  width: 72px;
  min-height: 72px;
}

.order-card-summary .order-card-media img {
  min-height: 72px;
}

.order-card-summary-meta {
  min-width: 0;
  display: grid;
  gap: 4px;
}

.order-card-summary-meta strong {
  overflow: hidden;
  color: var(--text);
  font-size: 0.95rem;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.order-payment-summary {
  color: var(--accent-deep);
  font-size: 0.76rem;
  font-weight: 900;
  line-height: 1.35;
}

.order-card-summary-status {
  display: grid;
  justify-items: end;
  align-self: start;
  gap: 0;
}

.order-card-summary-status .cart-item-price {
  font-size: 0.92rem;
}

.order-card-compact .order-card-body {
  margin: 10px 0 2px 84px;
  padding: 12px 0 2px;
  border-top: 1px solid var(--line);
}

.order-card-media {
  min-height: 132px;
  display: grid;
  place-items: center;
  overflow: hidden;
  color: var(--accent-deep);
  background: rgba(247, 241, 235, 0.82);
  border: 1px solid rgba(36, 24, 21, 0.08);
  border-radius: var(--radius);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 2.4rem;
  font-weight: 700;
}

.order-card-media img {
  width: 100%;
  height: 100%;
  min-height: 132px;
  object-fit: cover;
}

.order-card-body {
  display: grid;
  align-content: start;
  gap: 7px;
}

.order-card-body p {
  margin: 0;
}

.order-card-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}

.order-card-header strong {
  color: var(--text);
  font-size: 1rem;
}

.order-status-pill {
  flex: 0 0 auto;
  padding: 6px 8px;
  color: var(--accent-deep);
  background: rgba(17, 24, 39, 0.08);
  border: 1px solid rgba(17, 24, 39, 0.18);
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 900;
}

.order-status-stack {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.order-card-header .order-status-stack {
  justify-content: flex-start;
}

.order-status-pill-payment {
  color: var(--sage);
  background: rgba(104, 114, 97, 0.1);
  border-color: rgba(104, 114, 97, 0.22);
}

.order-status-pill-pending,
.order-status-pill-needs-admin-review {
  color: #9a6700;
  background: rgba(245, 158, 11, 0.14);
  border-color: rgba(217, 119, 6, 0.32);
}

.order-status-pill-approved {
  color: #0f7a3f;
  background: rgba(22, 132, 71, 0.13);
  border-color: rgba(22, 132, 71, 0.28);
}

.order-status-pill-rejected,
.order-status-pill-cancelled,
.order-status-pill-cancellation-requested,
.order-status-pill-cancellation-admin-review,
.order-status-pill-cancellation-vendor-due {
  color: #b42318;
  background: rgba(180, 35, 24, 0.12);
  border-color: rgba(180, 35, 24, 0.28);
}

.order-lifecycle {
  --lifecycle-green: #168447;
  --lifecycle-soft: rgba(22, 132, 71, 0.14);
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0;
  margin: 4px 0 6px;
  padding: 0;
  list-style: none;
}

.order-lifecycle-step {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 6px;
  min-width: 0;
  color: var(--muted);
  text-align: center;
}

.order-lifecycle-step::before {
  content: "";
  position: absolute;
  top: 13px;
  left: -50%;
  width: 100%;
  height: 3px;
  background: rgba(17, 24, 39, 0.12);
  z-index: 0;
}

.order-lifecycle-step:first-child::before {
  display: none;
}

.order-lifecycle-step.line-complete::before {
  background: var(--lifecycle-green);
}

.order-lifecycle-dot {
  position: relative;
  z-index: 1;
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  color: var(--muted);
  background: #fff;
  border: 2px solid rgba(17, 24, 39, 0.18);
  border-radius: 50%;
  font-size: 0.58rem;
  font-weight: 900;
  letter-spacing: 0;
}

.order-lifecycle-step strong {
  max-width: 76px;
  color: inherit;
  font-size: 0.66rem;
  font-weight: 900;
  line-height: 1.1;
}

.order-lifecycle-step.is-complete {
  color: var(--lifecycle-green);
}

.order-lifecycle-step.is-complete .order-lifecycle-dot {
  color: #fff;
  background: var(--lifecycle-green);
  border-color: var(--lifecycle-green);
}

.order-lifecycle-step.is-active .order-lifecycle-dot {
  color: var(--lifecycle-green);
  background: var(--lifecycle-soft);
  border-color: var(--lifecycle-green);
}

.order-lifecycle-step.is-failed {
  color: #b42318;
}

.order-lifecycle-step.is-failed .order-lifecycle-dot {
  color: #fff;
  background: #b42318;
  border-color: #b42318;
}

.order-lifecycle-compact {
  margin-top: 10px;
}

.order-help-text,
.order-payment-box {
  color: var(--accent-deep);
  font-size: 0.82rem;
  font-weight: 800;
}

.order-payment-box {
  display: grid;
  gap: 8px;
  margin-top: 4px;
  padding: 12px;
  background: rgba(17, 24, 39, 0.08);
  border: 1px solid rgba(17, 24, 39, 0.22);
  border-radius: var(--radius);
}

.order-payment-box p {
  color: var(--text);
  font-weight: 700;
}

.order-payment-url {
  display: block;
  width: 100%;
  overflow-wrap: anywhere;
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 900;
}

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

  .order-card-summary {
    grid-template-columns: 58px minmax(0, 1fr);
    gap: 10px;
  }

  .order-card-summary::after {
    grid-column: 2;
    justify-self: start;
  }

  .order-card-summary-status {
    grid-column: 2;
    justify-items: start;
  }

  .order-card-summary-status .order-status-stack,
  .order-card-header .order-status-stack {
    justify-content: flex-start;
  }

  .order-card-summary .order-card-media,
  .order-card-summary .order-card-media img {
    width: 58px;
    min-height: 58px;
  }

  .order-card-compact .order-card-body {
    margin-left: 0;
  }

  .order-card-media,
  .order-card-media img {
    min-height: 190px;
  }

  .order-card-summary .order-card-media,
  .order-card-summary .order-card-media img {
    min-height: 58px;
  }

  .order-card-header {
    display: grid;
  }
}

@supports (-webkit-touch-callout: none) {
  @media (max-width: 960px) {
    .site-header,
    .site-header.is-scrolled,
    .site-header.is-open {
      -webkit-backdrop-filter: none;
      backdrop-filter: none;
    }
  }
}

.cart-tabs,
.global-account {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}

.cart-tabs {
  margin: 18px 0;
}

.cart-tabs a,
.global-account-link,
.global-account-button {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 8px 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font: inherit;
  font-size: 0.78rem;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
  text-transform: none;
  letter-spacing: 0;
}

.global-account {
  margin-left: 4px;
  padding-left: 14px;
  border-left: 1px solid var(--line);
}

.global-account-user,
.booking-code {
  color: var(--accent-deep);
  font-size: 0.78rem;
  font-weight: 800;
}

.global-account-user {
  min-height: 38px;
  display: inline-flex;
  align-items: center;
}

.nav-links .global-account-link {
  letter-spacing: 0;
  text-transform: none;
}

.service-hero-actions {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  width: 100%;
}

.service-hero-action {
  min-height: 74px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  color: var(--text);
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  font-size: 0.88rem;
  font-weight: 800;
  text-decoration: none;
  text-align: center;
}

.service-hero-action-primary {
  color: var(--white);
  background: var(--accent-deep);
  border-color: var(--accent-deep);
}

.car-rental-card {
  grid-template-columns: 1fr;
  gap: 12px;
  padding: 12px;
}

.car-rental-image {
  min-height: 190px;
  aspect-ratio: 4 / 3;
  width: 100%;
  padding: 0;
  border: 0;
  cursor: zoom-in;
}

.car-rental-body h3 {
  font-size: 1.55rem;
}

.car-rental-body .bridal-vendor-note {
  font-size: 0.86rem;
}

.product-catalog-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.product-catalog-card {
  gap: 10px;
}

.product-catalog-card .car-rental-image {
  min-height: 0;
  aspect-ratio: 1 / 1;
}

.product-catalog-card .car-rental-body h3 {
  font-size: 1.1rem;
  line-height: 1.12;
}

.car-rental-meta {
  width: 100%;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 8px 14px;
  margin: 8px 0 18px;
  padding: 12px;
  background: rgba(247, 241, 235, 0.8);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.car-rental-meta dt,
.car-rental-meta dd {
  margin: 0;
  font-size: 0.84rem;
}

.car-rental-meta dt {
  color: var(--muted);
}

.car-rental-meta dd {
  color: var(--text);
  font-weight: 800;
}

.testimonials-page-section {
  padding-top: 24px;
}

.testimonials-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 24px;
}

.testimonial-card {
  padding: 20px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.testimonial-card h3 {
  margin: 18px 0 0;
  font-size: 1.6rem;
}

.testimonial-location {
  margin: 8px 0 10px;
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.testimonial-description {
  margin-bottom: 18px;
  color: var(--muted);
}

.testimonial-link {
  width: fit-content;
  min-width: 170px;
}

.shorts-frame {
  position: relative;
  overflow: hidden;
  width: min(100%, 360px);
  margin: 0 auto;
  aspect-ratio: 9 / 16;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.shorts-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.service-video-section {
  margin-top: 34px;
  padding: 28px 0;
  border-top: 1px solid var(--line);
}

.service-video-section h2 {
  margin: 0 0 18px;
  font-size: clamp(1.4rem, 2.3vw, 2rem);
}

.service-video-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 180px));
  gap: 14px;
}

.service-video-card {
  display: grid;
  gap: 10px;
}

.service-video-card strong {
  font-size: 0.86rem;
  line-height: 1.35;
}

.service-shorts-frame {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 9 / 16;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.service-shorts-frame iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
}

.portfolio-section {
  padding-top: 120px;
}

[data-portfolio-artist] {
  color: var(--accent);
  font-weight: 600;
}

.artist-profile {
  display: grid;
  grid-template-columns: minmax(280px, 0.7fr) minmax(0, 1.3fr);
  align-items: center;
  gap: 42px;
  padding-top: 56px;
}

.artist-profile + .artist-profile {
  border-top: 1px solid var(--line);
}

.artist-profile-copy {
  max-width: 520px;
}

.artist-location {
  margin-bottom: 18px;
  color: var(--accent);
  font-weight: 700;
}

.artist-gallery {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.artist-gallery picture {
  aspect-ratio: 4 / 5;
  display: block;
  overflow: hidden;
  background: var(--bg-warm);
  border-radius: var(--radius);
}

.artist-gallery img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.artist-videos {
  padding-top: 36px;
}

.artist-video-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  margin-top: 34px;
}

.artist-video-card {
  padding: 16px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.artist-video-card h3 {
  margin: 14px 0 0;
  font-size: 1.35rem;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  grid-auto-rows: 270px;
  gap: 24px;
  margin-top: 64px;
}

.gallery-card {
  grid-column: span 4;
  min-height: 0;
}

.gallery-card-featured {
  grid-column: span 5;
  grid-row: span 2;
}

.gallery-card-wide {
  grid-column: span 7;
}

.gallery-card img {
  transition: transform 0.55s ease;
}

.gallery-card:hover img {
  transform: scale(1.035);
}

.quote-section {
  padding: 150px 24px;
  background:
    linear-gradient(135deg, rgba(36, 24, 21, 0.92), rgba(94, 36, 53, 0.86)),
    var(--text);
  text-align: center;
}

.quote-section blockquote {
  max-width: 1060px;
  margin: 0 auto;
}

.page-first-section {
  padding-top: 132px;
}

.quote-section p {
  margin-bottom: 28px;
  color: var(--white);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: clamp(3.2rem, 7vw, 7rem);
  line-height: 0.98;
}

.quote-section cite {
  color: var(--muted);
  font-size: 0.72rem;
  font-style: normal;
  font-weight: 600;
  letter-spacing: 0.24em;
  text-transform: uppercase;
}

.booking-section .split-content {
  padding-right: max(48px, calc((100vw - var(--content-max)) / 2));
}

.contact-cta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  max-width: 460px;
  margin-top: 24px;
}

.cta-link-primary {
  max-width: 460px;
  margin-top: 24px;
  background: var(--accent);
  border-color: var(--accent);
  color: var(--white);
}

.more-contact-details {
  max-width: 460px;
  margin-top: 14px;
}

.more-contact-details summary {
  cursor: pointer;
  color: var(--muted);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.more-contact-details .contact-cta-grid {
  margin-top: 12px;
}

.cta-link {
  min-height: 54px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.55);
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-decoration: none;
  text-transform: uppercase;
  transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease;
}

.cta-link:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--white);
}

.form-section {
  display: grid;
  grid-template-columns: minmax(0, 0.75fr) minmax(560px, 1fr);
  gap: 56px;
  padding: 112px 0;
  align-items: start;
}

.form-copy {
  position: sticky;
  top: 120px;
}

.contact-form,
.lead-form {
  display: grid;
  gap: 18px;
}

.contact-form {
  padding: 34px;
  background: rgba(255, 255, 255, 0.52);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

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

label {
  display: grid;
  gap: 8px;
  color: var(--text);
  font-size: 0.86rem;
  font-weight: 500;
}

input,
select,
textarea {
  width: 100%;
  border: 1px solid rgba(36, 24, 21, 0.18);
  border-radius: var(--radius);
  background: rgba(255, 255, 255, 0.78);
  color: var(--text);
  min-height: 48px;
  padding: 13px 14px;
}

textarea {
  resize: vertical;
}

input[aria-invalid="true"],
select[aria-invalid="true"],
textarea[aria-invalid="true"] {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(17, 24, 39, 0.1);
}

.consent-row {
  grid-template-columns: 18px 1fr;
  align-items: start;
  gap: 12px;
}

.consent-row input {
  width: 18px;
  min-height: 18px;
  margin-top: 3px;
  accent-color: var(--accent);
}

.form-status {
  min-height: 22px;
  margin: 0;
  color: var(--sage);
  font-size: 0.9rem;
}

.lead-module {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 0.8fr);
  align-items: center;
  gap: 42px;
  margin-bottom: 104px;
  padding: 42px;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: var(--radius);
}

.lead-module h2 {
  margin-bottom: 12px;
  font-size: 3rem;
}

.lead-form {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
}

.lead-form .form-status {
  grid-column: 1 / -1;
}

.site-footer {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 38px max(24px, calc((100vw - var(--content-max)) / 2));
  border-top: 1px solid var(--line);
}

.site-footer p {
  margin: 0;
  font-size: 0.9rem;
}

.site-footer a {
  min-width: 44px;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.mobile-sticky-cta {
  display: none;
}

.mobile-storefront {
  display: none;
}

.mobile-bottom-nav {
  display: none;
}

body.app-shell-has-bottom-nav {
  padding-bottom: calc(78px + env(safe-area-inset-bottom));
}

body.app-keyboard-open:not(.app-shell-has-bottom-nav) {
  padding-bottom: max(12px, env(safe-area-inset-bottom));
}

body.app-keyboard-open.app-shell-has-bottom-nav {
  padding-bottom: calc(78px + var(--app-keyboard-inset, 0px) + env(safe-area-inset-bottom));
}

body.app-keyboard-open .app-shell-bottom-nav {
  bottom: var(--app-keyboard-inset, 0px);
  display: grid;
}

.app-shell-bottom-nav.mobile-bottom-nav {
  position: fixed;
  inset: auto 0 0;
  z-index: 2200;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0;
  padding: 6px 5px calc(6px + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid var(--line);
  box-shadow: 0 -12px 28px rgba(36, 24, 21, 0.08);
}

.app-shell-bottom-nav a {
  position: relative;
  min-height: 46px;
  display: grid;
  gap: 2px;
  place-items: center;
  color: #111;
  font-size: 0.62rem;
  font-weight: 800;
  letter-spacing: 0;
  text-align: center;
  text-decoration: none;
}

.app-shell-bottom-nav svg {
  width: 21px;
  height: 21px;
  fill: none;
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.app-shell-bottom-nav span {
  display: block;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.app-shell-bottom-nav a[aria-current="page"] {
  color: #111;
}

.mobile-bottom-nav a.has-cart-items,
.mobile-bottom-nav a.has-cart-items svg,
.mobile-bottom-nav a.has-cart-items span,
.global-account-link.has-cart-items,
.cart-tabs a.has-cart-items {
  color: #168447;
}

.mobile-bottom-nav a.has-cart-items .mobile-nav-count {
  color: #fff;
  background: #168447;
}

.mobile-bottom-nav a.is-cart-bump {
  animation: cartNavBump 0.72s cubic-bezier(0.22, 1, 0.36, 1);
}

.global-account-link.is-cart-bump {
  animation: cartNavBump 0.72s cubic-bezier(0.22, 1, 0.36, 1), cartNavTextFlash 0.72s ease-out;
}

.mobile-bottom-nav a.is-cart-bump svg,
.mobile-bottom-nav a.is-cart-bump span {
  animation: cartNavColorFlash 0.72s ease-out;
}

.mobile-bottom-nav a.is-cart-bump .mobile-nav-count {
  animation: cartBadgePop 0.72s cubic-bezier(0.2, 1.4, 0.34, 1);
  background: #168447;
}

@keyframes cartNavBump {
  0% {
    transform: translateY(0) scale(1);
  }

  34% {
    transform: translateY(-5px) scale(1.08);
  }

  66% {
    transform: translateY(1px) scale(0.98);
  }

  100% {
    transform: translateY(0) scale(1);
  }
}

@keyframes cartNavColorFlash {
  0%,
  72% {
    color: #168447;
  }

  100% {
    color: inherit;
  }
}

@keyframes cartNavTextFlash {
  0%,
  72% {
    color: #168447;
  }

  100% {
    color: inherit;
  }
}

@keyframes cartBadgePop {
  0% {
    transform: scale(0.82);
    box-shadow: 0 0 0 0 rgba(22, 132, 71, 0.3);
  }

  42% {
    transform: scale(1.24);
    box-shadow: 0 0 0 7px rgba(22, 132, 71, 0.12);
  }

  100% {
    transform: scale(1);
    box-shadow: 0 0 0 0 rgba(22, 132, 71, 0);
  }
}

.shop-sheet-open {
  overflow: hidden;
}

.shop-category-sheet {
  position: fixed;
  inset: 0;
  z-index: 2600;
  display: grid;
  align-items: end;
}

.shop-category-backdrop {
  position: absolute;
  inset: 0;
  border: 0;
  background: rgba(17, 24, 39, 0.34);
}

.shop-category-panel {
  position: relative;
  width: 100%;
  max-height: min(76vh, 640px);
  display: grid;
  gap: 12px;
  padding: 16px 14px calc(16px + env(safe-area-inset-bottom));
  overflow: auto;
  background: #fff;
  border-radius: 16px 16px 0 0;
  box-shadow: 0 -18px 42px rgba(17, 24, 39, 0.18);
}

.shop-category-panel header {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 44px;
  align-items: center;
}

.shop-category-panel h2 {
  grid-column: 2;
  margin: 0;
  font-size: 1.05rem;
  font-weight: 900;
  text-align: center;
}

.shop-category-panel header button {
  grid-column: 3;
  width: 42px;
  height: 42px;
  border: 0;
  background: transparent;
  color: var(--text);
  font-size: 1.9rem;
  line-height: 1;
}

.shop-category-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.shop-category-grid a {
  min-height: 64px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 32px;
  align-items: center;
  gap: 6px;
  padding: 10px 8px;
  color: var(--text);
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
  box-shadow: 0 6px 16px rgba(17, 24, 39, 0.06);
  text-decoration: none;
}

.shop-category-grid span {
  font-size: 0.78rem;
  font-weight: 900;
}

.shop-category-grid svg {
  width: 30px;
  height: 30px;
  fill: none;
  stroke: var(--accent);
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.mobile-search-pill {
  position: relative;
  flex: 1 1 auto;
  min-height: 56px;
  display: flex;
  align-items: center;
  gap: 12px;
  color: rgba(255, 255, 255, 0.9);
  background: rgba(255, 255, 255, 0.16);
  border: 0;
  border-radius: 999px;
  padding: 0 18px;
  text-decoration: none;
}

.mobile-search-pill input {
  min-width: 0;
  width: 100%;
  color: #fff;
  background: transparent;
  border: 0;
  outline: 0;
  font: inherit;
  font-weight: 700;
  letter-spacing: 0;
}

.mobile-search-pill input::placeholder {
  color: rgba(255, 255, 255, 0.74);
}

.mobile-search-pill > span {
  width: 16px;
  height: 16px;
  display: inline-block;
  border: 2px solid currentColor;
  border-radius: 50%;
  position: relative;
}

.mobile-search-pill > span::after {
  content: "";
  width: 7px;
  height: 2px;
  position: absolute;
  right: -6px;
  bottom: -3px;
  background: currentColor;
  transform: rotate(45deg);
}

.mobile-service-search-results {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  z-index: 5;
  display: grid;
  gap: 4px;
  padding: 8px;
  background: rgba(255, 255, 255, 0.98);
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 18px;
  box-shadow: 0 18px 40px rgba(17, 24, 39, 0.18);
}

.mobile-service-search-results[hidden] {
  display: none;
}

.mobile-service-search-results a {
  display: grid;
  gap: 2px;
  padding: 10px 12px;
  color: #111;
  border-radius: 12px;
  text-decoration: none;
}

.mobile-service-search-results a:hover,
.mobile-service-search-results a:focus-visible {
  background: #f3f4f6;
}

.mobile-service-search-results strong {
  font-size: 0.88rem;
}

.mobile-service-search-results span {
  color: #4b5563;
  font-size: 0.75rem;
}

.mobile-round-action {
  width: 56px;
  height: 56px;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--white);
  background: rgba(255, 255, 255, 0.18);
  border-radius: 50%;
  font-size: 0.78rem;
  font-weight: 700;
  text-decoration: none;
}

.shop-search-row {
  display: flex;
  gap: 10px;
  max-width: 620px;
}

.mobile-search-pill-light {
  flex: 1;
  color: var(--muted);
  background: rgba(255, 255, 255, 0.68);
  border: 1px solid var(--line);
}

.mobile-round-action-light {
  color: var(--text);
  background: rgba(255, 255, 255, 0.7);
  border: 1px solid var(--line);
}

@media (max-width: 1120px) {
  :root {
    --content-max: 1180px;
  }

  h1 {
    font-size: 5rem;
  }

  h2 {
    font-size: 3.4rem;
  }

  .hero {
    grid-template-columns: minmax(0, 1fr) minmax(360px, 0.9fr);
    gap: 36px;
  }

  .hero-image {
    min-height: 520px;
  }

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

  .service-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .home-shop-grid,
  .home-bridal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 960px) {
  body {
    padding-bottom: calc(78px + env(safe-area-inset-bottom));
  }

  .site-header {
    transition: none;
  }

  .nav-shell {
    width: min(100% - 32px, var(--content-max));
    min-height: 76px;
  }

  .nav-toggle {
    display: inline-flex;
  }

  .nav-links {
    position: absolute;
    top: 76px;
    left: 16px;
    right: 16px;
    display: none;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    padding: 10px;
    background: rgba(247, 241, 235, 0.98);
    border: 1px solid var(--line);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
  }

  .nav-links.is-open {
    display: flex;
  }

  .nav-links a {
    padding: 16px;
  }

  .nav-links .theme-toggle {
    width: 100%;
    justify-content: space-between;
    margin-top: 6px;
    padding: 12px 14px;
    border-radius: 10px;
  }

  .global-account {
    width: 100%;
    margin-left: 0;
    padding: 10px 6px 4px;
    border-left: 0;
    border-top: 1px solid var(--line);
  }

  .global-account > * {
    flex: 1 1 140px;
    min-height: 36px;
    padding: 7px 10px;
    font-size: 0.72rem;
  }

  .global-account-user {
    flex-basis: 100%;
    justify-content: flex-start;
    padding: 4px 8px;
  }

  .nav-social-link {
    width: 100%;
    height: 50px;
    border-radius: var(--radius);
  }

  .section-band,
  .section-block,
  .form-section,
  .lead-module,
  .campaign-banner {
    width: min(100% - 32px, var(--content-max));
  }

  .mobile-storefront {
    display: block;
    padding: 94px 0 26px;
    background: transparent;
    color: var(--text);
  }

  .mobile-storefront-top,
  .mobile-category-strip {
    width: min(100% - 32px, var(--content-max));
    margin: 0 auto;
  }

  .mobile-storefront-top {
    display: flex;
    align-items: center;
    gap: 10px;
  }

  .mobile-search-pill {
    flex: 1;
  }

  .mobile-storefront h2 {
    width: min(100% - 32px, var(--content-max));
    margin: 28px auto 22px;
    color: var(--text);
    font-family: "Inter", Arial, sans-serif;
    font-size: 2rem;
    font-weight: 800;
    line-height: 1.05;
  }

  .mobile-storefront .mobile-search-pill {
    color: #111;
    background: rgba(255, 255, 255, 0.76);
    border: 1px solid var(--line);
  }

  .mobile-storefront .mobile-round-action {
    color: var(--text);
    background: rgba(255, 255, 255, 0.74);
    border: 1px solid var(--line);
  }

  .mobile-sale-card {
    width: 100%;
    min-height: 246px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
    padding: 34px 28px;
    background:
      linear-gradient(135deg, rgba(17, 24, 39, 0.58), rgba(124, 50, 70, 0.5)),
      url("/assets/images/vendors/milaashes-by-milu/profile/client-look-2.webp") center 32% / cover;
    color: var(--white);
    text-align: center;
    text-decoration: none;
  }

  .mobile-sale-card span {
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.16em;
    text-transform: uppercase;
  }

  .mobile-sale-card strong {
    max-width: 520px;
    margin: 0 auto;
    font-family: "Cormorant Garamond", Georgia, serif;
    font-size: 2.55rem;
    font-weight: 600;
    line-height: 0.98;
  }

  .mobile-sale-card em {
    font-style: normal;
    font-size: 0.9rem;
  }

  .mobile-category-strip {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    padding: 22px 0 4px;
    overflow: visible;
  }

  .mobile-category-strip a {
    color: var(--text);
    text-align: center;
    text-decoration: none;
  }

  .mobile-category-strip picture {
    aspect-ratio: 1 / 1;
    display: block;
    overflow: hidden;
    background: var(--white);
    border-radius: var(--radius);
  }

  .mobile-category-strip img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .mobile-category-strip span {
    display: block;
    margin-top: 10px;
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
  }

  .campaign-banner {
    display: none;
  }

  .campaign-tile {
    min-height: auto;
    padding: 18px;
  }

  .campaign-tile-picks,
  .campaign-tile-stories {
    display: none;
  }

  .campaign-tile h2 {
    font-size: 1.95rem;
  }

  .campaign-tile h3 {
    font-size: 1.55rem;
  }

  .campaign-tile p:not(.campaign-kicker) {
    max-width: 100%;
    margin-bottom: 12px;
    line-height: 1.45;
  }

  .trust-promise {
    grid-template-columns: 1fr;
    gap: 20px;
    margin-top: 26px;
    padding: 26px 20px;
  }

  .trust-promise h2 {
    font-size: 2.35rem;
  }

  .trust-promise-copy {
    gap: 14px;
  }

  .hero {
    min-height: auto;
    grid-template-columns: 1fr;
    padding: 48px 0 56px;
  }

  h1 {
    font-size: 4rem;
  }

  h2 {
    font-size: 3rem;
  }

  .hero-image {
    height: 58vh;
    min-height: 430px;
  }

  .availability-band {
    padding: 50px 16px;
  }

  .availability-band h2 {
    font-size: 2.5rem;
  }

  .split-section,
  .form-section,
  .lead-module {
    grid-template-columns: 1fr;
  }

  .split-section {
    min-height: auto;
  }

  .split-content,
  .split-about .split-content,
  .booking-section .split-content {
    padding: 72px 24px;
  }

  .split-image {
    min-height: 520px;
  }

  .service-grid,
  .form-grid {
    grid-template-columns: 1fr;
  }

  .home-shop-section,
  .home-bridal-section {
    padding-top: 54px;
    padding-bottom: 58px;
  }

  .home-shop-grid,
  .home-bridal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 24px;
  }

  .home-shop-card {
    min-height: 180px;
  }

  .home-shop-card-text {
    min-height: 180px;
    padding: 18px;
  }

  .home-bridal-grid a {
    min-height: 150px;
    padding: 14px;
  }

  .recommendation-card {
    grid-template-columns: 1fr;
    align-items: start;
    gap: 20px;
  }

  .recommendations-section .recommendations-grid,
  .recommendation-shelf-item {
    grid-template-columns: 1fr;
  }

  .recommendation-shelf-item {
    padding: 18px;
    gap: 16px;
  }

  .recommendation-shelf-copy h3 {
    font-size: 1.7rem;
  }

  .recommendation-product {
    align-items: stretch;
  }

  .recommendation-product iframe {
    width: 100%;
    height: 320px;
  }

  .recommendation-order-link {
    width: 100%;
  }

  .section-block,
  .form-section {
    padding: 86px 0;
  }

  .page-hero {
    padding-top: 118px;
    padding-bottom: 18px;
  }

  .shop-hero {
    padding-top: 104px;
    padding-bottom: 20px;
  }

  .shop-search-row {
    width: 100%;
  }

  .shop-toolbar {
    align-items: stretch;
    flex-direction: column;
  }

  .bridal-hero {
    padding-top: 104px;
    padding-bottom: 20px;
  }

  .bridal-hero-actions {
    width: 100%;
  }

  .bridal-hero-actions .btn {
    flex: 1 1 180px;
  }

  .bridal-search {
    width: 100%;
  }

  .bridal-filter-row {
    width: 100%;
    max-width: 100%;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin-right: 0;
    padding-right: 0;
  }

  .bridal-filter-row::-webkit-scrollbar {
    height: 4px;
  }

  .category-tabs {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 6px;
  }

  .category-tabs button {
    min-height: 42px;
    padding: 10px 8px;
    font-size: 0.82rem;
  }

  .region-switch {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .catalog-grid {
    grid-template-columns: 1fr;
    gap: 16px;
    margin-top: 26px;
  }

  .catalog-card {
    grid-template-columns: minmax(112px, 0.38fr) minmax(0, 0.62fr);
  }

  .catalog-card-image {
    aspect-ratio: auto;
    min-height: 100%;
  }

  .catalog-card-body {
    padding: 14px;
  }

  .catalog-card-region {
    margin-bottom: 6px;
    font-size: 0.62rem;
    letter-spacing: 0.12em;
  }

  .catalog-card-body h3 {
    margin-bottom: 6px;
    font-size: 1.36rem;
  }

  .catalog-card-price,
  .catalog-card-note {
    margin-bottom: 10px;
    font-size: 0.86rem;
  }

  .shop-shell {
    padding-bottom: 116px;
  }

  .bridal-shell {
    padding-bottom: 116px;
  }

  .bridal-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 24px;
  }

  .bridal-card {
    padding: 10px;
    gap: 10px;
  }

  .bridal-card-media {
    aspect-ratio: 1 / 1;
    margin: -2px -2px 0;
  }

  .bridal-card-preview {
    left: 6px;
    right: 6px;
    bottom: 6px;
    padding: 4px;
  }

  .bridal-card-preview-thumb {
    width: 26px;
    height: 26px;
    flex-basis: 26px;
  }

  .bridal-card-preview-label {
    font-size: 0.54rem;
  }

  .bridal-card-summary {
    gap: 9px;
  }

  .bridal-card-panel {
    gap: 10px;
    margin-top: 10px;
  }

  .bridal-card-open {
    min-height: 34px;
    width: 100%;
    padding: 8px;
    font-size: 0.56rem;
    letter-spacing: 0.08em;
  }

  .bridal-card-group,
  .bridal-card-range,
  .bridal-card-count {
    max-width: 100%;
    padding: 5px 7px;
    font-size: 0.54rem;
    letter-spacing: 0.08em;
  }

  .bridal-card-short {
    margin-bottom: 8px;
    line-height: 1.35;
  }

  .bridal-vendor {
    grid-template-columns: minmax(96px, 0.34fr) minmax(0, 0.66fr);
    gap: 10px;
    padding: 10px;
  }

  .bridal-vendor-media,
  .bridal-vendor-empty {
    min-height: 132px;
  }

  .bridal-vendor-main-image {
    aspect-ratio: 1 / 1.15;
  }

  .bridal-vendor-strip {
    grid-template-columns: repeat(3, 1fr);
    gap: 4px;
  }

  .bridal-vendor-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .bridal-vendor-link {
    width: 100%;
  }

  .media-lightbox {
    padding: 12px;
  }

  .media-lightbox-dialog {
    width: 100%;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .media-lightbox figure {
    grid-column: 1 / -1;
    grid-row: 1;
  }

  .media-lightbox picture {
    height: min(72vh, 620px);
  }

  .media-lightbox-prev,
  .media-lightbox-next {
    grid-row: 2;
  }

  .media-lightbox-close {
    top: 10px;
    right: 10px;
    z-index: 2;
    color: var(--text);
    background: rgba(255, 255, 255, 0.9);
    border-color: var(--line);
  }

  .vendor-photo-lightbox-dialog {
    grid-template-columns: 1fr;
    place-items: center;
    max-height: calc(100dvh - 24px);
  }

  .vendor-photo-lightbox-figure {
    width: 100%;
    grid-column: 1;
    grid-row: 1;
  }

  .vendor-photo-lightbox-figure picture {
    height: min(74dvh, 620px);
  }

  .vendor-photo-lightbox .media-lightbox-prev,
  .vendor-photo-lightbox .media-lightbox-next {
    position: absolute;
    top: 50%;
    z-index: 3;
    grid-row: auto;
    width: 44px;
    height: 44px;
    min-height: 44px;
    transform: translateY(-50%);
    background: rgba(17, 24, 39, 0.64);
  }

  .vendor-photo-lightbox .media-lightbox-prev {
    left: 8px;
  }

  .vendor-photo-lightbox .media-lightbox-next {
    right: 8px;
  }

  .service-detail-page {
    padding-top: 104px;
    padding-bottom: 24px;
  }

  .service-breadcrumbs {
    margin-bottom: 12px;
    overflow-x: auto;
    flex-wrap: nowrap;
    white-space: nowrap;
    scrollbar-width: none;
  }

  .service-breadcrumbs::-webkit-scrollbar {
    display: none;
  }

  .vendor-instagram-profile,
  .vendor-ig-tabs-shell {
    max-width: 100%;
  }

  .vendor-instagram-profile {
    padding: 12px 0;
  }

  .vendor-ig-header {
    grid-template-columns: 96px minmax(0, 1fr);
    gap: 12px;
  }

  .vendor-ig-avatar {
    width: 84px;
    height: 84px;
    font-size: 1.8rem;
  }

  .vendor-ig-title-row h1 {
    font-size: 1.32rem;
  }

  .vendor-ig-stats {
    gap: 4px;
  }

  .vendor-ig-stats strong {
    font-size: 0.92rem;
  }

  .vendor-ig-stats em {
    font-size: 0.66rem;
  }

  .vendor-ig-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .is-owner-profile .vendor-ig-actions {
    grid-template-columns: 1fr;
  }

  .vendor-ig-actions .btn {
    min-height: 44px;
    padding: 8px;
    font-size: 0.72rem;
  }

  .vendor-ig-profile .bridal-vendor-actions .btn {
    min-height: 44px;
    padding: 0 14px;
    font-size: 0.72rem;
  }

  .vendor-ig-bio {
    margin-top: 10px;
  }

  .vendor-ig-bio strong,
  .vendor-ig-bio p,
  .vendor-ig-bio a {
    font-size: 0.84rem;
  }

  .vendor-ig-highlight-row {
    gap: 8px;
    margin-top: 10px;
  }

  .vendor-ig-highlight-row span {
    min-width: 72px;
    min-height: 64px;
    padding: 8px;
    box-shadow: inset 0 0 0 5px #f3f4f6;
    font-size: 0.62rem;
  }

  .vendor-ig-meta-line {
    gap: 5px 10px;
    margin-top: 9px;
    font-size: 0.76rem;
  }

  .vendor-ig-meta-line > span:not(:last-child)::after {
    margin-left: 10px;
  }

  .vendor-related-list {
    gap: 8px;
  }

  .vendor-related-card {
    grid-template-columns: 56px minmax(0, 1fr);
    gap: 7px;
    padding: 7px;
  }

  .vendor-related-image {
    width: 56px;
  }

  .sc-selected-photo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .vendor-ig-tabbar {
    top: 0;
  }

  .vendor-ig-tab-button {
    min-height: 44px;
    font-size: 0.68rem;
  }

  .vendor-ig-shop-intro {
    grid-template-columns: 1fr;
    gap: 10px;
    padding: 12px;
  }

  .vendor-ig-shop-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .vendor-profile-panel {
    grid-template-columns: minmax(112px, 0.38fr) minmax(0, 0.62fr);
    gap: 10px;
    padding: 10px;
  }

  .vendor-profile-media {
    min-height: 220px;
  }

  .vendor-profile-photo {
    min-height: 220px;
  }

  .vendor-profile-summary {
    gap: 8px;
  }

  .vendor-profile-summary h1 {
    font-size: 2.45rem;
  }

  .vendor-profile-intro {
    font-size: 0.88rem;
    line-height: 1.45;
  }

  .vendor-profile-facts {
    gap: 6px;
  }

  .vendor-profile-facts span {
    padding: 6px 8px;
    font-size: 0.68rem;
  }

  .vendor-profile-strip {
    grid-template-columns: repeat(4, minmax(44px, 1fr));
    gap: 6px;
  }

  .vendor-profile-actions {
    grid-column: 1 / -1;
    padding: 10px;
  }

  .vendor-profile-actions p {
    font-size: 0.82rem;
  }

  .service-detail-info,
  .service-detail-gallery {
    grid-template-columns: 1fr;
  }

  .service-team-grid,
  .car-rental-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 24px;
  }

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

  .product-catalog-card {
    padding: 8px;
  }

  .product-catalog-card .car-rental-body h3 {
    font-size: 0.95rem;
  }

  .product-catalog-card .bridal-vendor-rate,
  .product-catalog-card .bridal-vendor-note {
    font-size: 0.76rem;
    line-height: 1.28;
  }

  .mehendi-pricing-panel,
  .mehendi-hand-selector,
  .mehendi-coverage-grid,
  .bridal-package-grid {
    grid-template-columns: 1fr;
  }

  .mehendi-pricing-panel,
  .bridal-package-panel {
    padding: 12px;
  }

  .mehendi-diagram {
    min-height: 260px;
  }

  .mehendi-selection-summary,
  .bridal-package-summary {
    align-items: stretch;
    flex-direction: column;
  }

  .mehendi-selection-summary p {
    margin: 0;
  }

  .service-team-card,
  .car-rental-card {
    grid-template-columns: 1fr;
    gap: 9px;
    padding: 10px;
  }

  .service-team-media {
    min-height: auto;
    aspect-ratio: 1 / 1.08;
  }

  .service-team-body h3,
  .car-rental-body h3 {
    font-size: 1rem;
    line-height: 1.18;
  }

  .service-preview,
  .service-brand-row,
  .bridal-vendor-coverage {
    display: none;
  }

  .bridal-vendor-area,
  .bridal-vendor-note {
    font-size: 0.76rem;
    line-height: 1.35;
  }

  .bridal-vendor-rate {
    font-size: 0.78rem;
  }

  .service-team-card .bridal-vendor-actions,
  .car-rental-card .bridal-vendor-actions {
    display: grid;
    grid-template-columns: 1fr;
    width: 100%;
    gap: 6px;
  }

  .service-team-card .bridal-vendor-link,
  .car-rental-card .bridal-vendor-link {
    min-height: 36px;
    width: 100%;
    padding: 8px;
    font-size: 0.58rem;
    letter-spacing: 0.08em;
  }

  .car-rental-image {
    min-height: auto;
  }

  .artist-profile {
    grid-template-columns: 1fr;
    gap: 24px;
    padding-top: 48px;
  }

  .artist-gallery {
    grid-template-columns: repeat(3, minmax(120px, 1fr));
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: none;
  }

  .artist-gallery::-webkit-scrollbar {
    display: none;
  }

  .artist-video-grid {
    grid-template-columns: 1fr;
  }

  .gallery-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    grid-auto-rows: 230px;
  }

  .gallery-card,
  .gallery-card-featured,
  .gallery-card-wide {
    grid-column: span 6;
    grid-row: span 1;
  }

  .quote-section {
    padding: 96px 20px;
  }

  .quote-section p {
    font-size: 2.8rem;
  }

  .form-copy {
    position: static;
  }

  .lead-module {
    padding: 30px 24px;
  }

  .lead-form {
    grid-template-columns: 1fr;
  }

  .testimonials-grid {
    grid-template-columns: 1fr;
  }

  .testimonial-card {
    display: grid;
    gap: 10px;
    padding: 16px;
  }

  .testimonial-card h3 {
    margin-top: 6px;
  }

  .testimonial-description {
    margin-bottom: 8px;
  }

  .site-footer {
    flex-direction: column;
    padding-bottom: 32px;
    text-align: center;
  }

  body.home-page .hero {
    display: none;
  }

  .mobile-sticky-cta {
    display: none;
  }

  .mobile-bottom-nav {
    position: fixed;
    inset: auto 0 0;
    z-index: 2200;
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 0;
    padding: 6px 5px calc(6px + env(safe-area-inset-bottom));
    background: rgba(255, 255, 255, 0.98);
    border-top: 1px solid var(--line);
    box-shadow: 0 -12px 28px rgba(36, 24, 21, 0.08);
  }

  .mobile-bottom-nav a {
    position: relative;
    min-height: 46px;
    display: grid;
    gap: 2px;
    place-items: center;
    color: #111;
    font-size: 0.62rem;
    font-weight: 800;
    letter-spacing: 0;
    text-align: center;
    text-decoration: none;
  }

  .mobile-bottom-nav svg {
    width: 21px;
    height: 21px;
    fill: none;
    stroke: currentColor;
    stroke-width: 2;
    stroke-linecap: round;
    stroke-linejoin: round;
  }

  .mobile-bottom-nav span {
    display: block;
    max-width: 100%;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-nav-count {
    min-width: 17px;
    height: 17px;
    position: absolute;
    top: 2px;
    right: max(14px, 24%);
    display: grid;
    place-items: center;
    padding: 0 5px;
    color: #fff;
    background: var(--accent);
    border-radius: 999px;
    font-size: 0.58rem;
    font-style: normal;
    font-weight: 900;
    line-height: 1;
  }

  .mobile-nav-unread-dot {
    min-width: 16px;
    height: 16px;
    position: absolute;
    top: 2px;
    right: max(16px, 28%);
    margin: 0;
    padding: 0 4px;
    border: 2px solid #fff;
  }

  .message-layout {
    grid-template-columns: minmax(0, 1fr);
  }

  .message-thread-list {
    gap: 8px;
  }

  .message-thread-card {
    padding: 10px;
  }

  .message-panel-card {
    padding: 12px;
  }

  .message-stream {
    max-height: none;
  }

  @media (max-width: 430px) {
    .mobile-bottom-nav a {
      min-height: 42px;
    }

    .mobile-bottom-nav span {
      display: block;
      font-size: 0.58rem;
    }
  }

  .mobile-bottom-nav a[aria-current="page"] {
    color: #111;
  }

}

@media (max-width: 560px) {
  .my-tools-shell {
    grid-template-columns: minmax(0, 1fr);
  }

  .my-event-list {
    position: static;
  }

  .my-event-type-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .my-event-type-grid button {
    min-height: 92px;
    padding: 10px;
  }

  .important-day-preset-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .important-day-preset-grid button {
    min-height: 78px;
    padding: 10px;
  }

  .my-event-tabs {
    grid-auto-flow: column;
    grid-auto-columns: minmax(180px, 78%);
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: none;
  }

  .my-event-tabs::-webkit-scrollbar {
    display: none;
  }

  .my-event-fields,
  .my-important-day-fields,
  .important-day-actions,
  .my-recommendation-grid,
  .my-tools-card-grid {
    grid-template-columns: minmax(0, 1fr);
  }

  .my-checklist-list label {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .my-checklist-list a {
    grid-column: 2;
    width: fit-content;
  }

  .vendor-owner-profile-tools,
  .vendor-owner-shop-tools {
    align-items: flex-start;
    flex-direction: column;
  }

  .vendor-owner-inline-buttons {
    width: 100%;
    justify-content: flex-start;
  }

  .vendor-owner-chip-link {
    flex: 1 1 auto;
  }

  h1,
  h2,
  h3,
  .vendor-profile-summary h1,
  .bridal-package-intro h2,
  .mehendi-pricing-intro h2,
  .service-detail-hero h1 {
    font-family: "Inter", Arial, sans-serif;
    letter-spacing: 0;
  }

  .section-block,
  .booking-widget-section,
  .service-gallery-section,
  .reviews-section {
    width: min(100% - 20px, var(--content-max));
  }

  .service-detail-page {
    padding-top: 92px;
    padding-bottom: 14px;
  }

  .booking-widget-section,
  .service-gallery-section,
  .reviews-section {
    padding-top: 10px;
    padding-bottom: 24px;
  }

  .service-breadcrumbs {
    gap: 6px;
    margin-bottom: 10px;
    padding: 0 2px 4px;
    font-size: 0.7rem;
  }

  .service-breadcrumbs strong,
  .service-breadcrumbs a {
    min-width: 44px;
    min-height: 40px;
    display: inline-flex;
    align-items: center;
    max-width: 132px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .vendor-profile-panel {
    grid-template-columns: 1fr;
    gap: 12px;
    padding: 10px;
    background: #fff;
  }

  .vendor-profile-media {
    min-height: auto;
  }

  .vendor-profile-photo {
    aspect-ratio: 4 / 5;
    min-height: 0;
    max-height: 380px;
  }

  .vendor-profile-summary {
    min-width: 0;
    gap: 10px;
  }

  .vendor-profile-summary .eyebrow,
  .bridal-package-intro .eyebrow,
  .mehendi-pricing-intro .eyebrow {
    font-size: 0.66rem;
    letter-spacing: 0.18em;
  }

  .vendor-profile-summary h1 {
    font-size: clamp(1.45rem, 7vw, 2rem);
    line-height: 1.05;
    overflow-wrap: anywhere;
  }

  .vendor-profile-intro,
  .vendor-profile-actions p {
    font-size: 0.86rem;
    line-height: 1.5;
  }

  .vendor-profile-facts {
    display: grid;
    grid-template-columns: 1fr;
    gap: 6px;
  }

  .vendor-profile-facts span {
    width: 100%;
    padding: 8px 9px;
    font-size: 0.72rem;
    line-height: 1.25;
  }

  .vendor-cost-list,
  .booking-cost-list {
    padding: 9px;
  }

  .vendor-cost-list p,
  .booking-cost-list p {
    font-size: 0.78rem;
  }

  .vendor-profile-strip {
    grid-template-columns: repeat(4, minmax(54px, 1fr));
    overflow-x: auto;
  }

  .vendor-profile-actions {
    padding: 10px;
  }

  .vendor-profile-actions .service-hero-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }

  .bridal-package-panel,
  .mehendi-pricing-panel {
    gap: 10px;
    margin-top: 18px;
    padding: 8px;
    background: #fff;
  }

  .bridal-package-intro h2,
  .mehendi-pricing-intro h2 {
    font-size: 1.35rem;
    line-height: 1.15;
  }

  .bridal-package-intro p:not(.eyebrow),
  .mehendi-pricing-intro p:not(.eyebrow),
  .bridal-addon-panel p {
    font-size: 0.78rem;
    line-height: 1.4;
  }

  .mehendi-hand-selector {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .mehendi-visual-rate-row {
    grid-template-columns: minmax(112px, 0.42fr) minmax(0, 0.58fr);
    gap: 8px;
  }

  .mehendi-diagram {
    height: 100%;
    min-height: 0;
    aspect-ratio: auto;
    position: sticky;
    top: 82px;
    align-self: start;
  }

  .mehendi-side-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px;
  }

  .mehendi-hand-selector > .mehendi-side-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

  .mehendi-leg-panel {
    grid-template-columns: minmax(0, 1fr);
    gap: 8px;
    padding: 8px;
  }

  .mehendi-leg-toggle,
  .mehendi-leg-panel .btn {
    width: 100%;
  }

  .mehendi-side-button {
    padding: 8px;
    font-size: 0.7rem;
    line-height: 1.18;
  }

  .mehendi-coverage-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 7px;
  }

  .mehendi-coverage-card {
    gap: 3px;
    padding: 9px;
  }

  .mehendi-coverage-card strong {
    font-size: 0.78rem;
    line-height: 1.15;
  }

  .mehendi-coverage-card span,
  .mehendi-coverage-card em,
  .mehendi-selection-summary p {
    font-size: 0.72rem;
    line-height: 1.25;
  }

  .bridal-package-card {
    gap: 6px;
    padding: 9px;
  }

  .bridal-package-card ul {
    font-size: 0.72rem;
    line-height: 1.35;
  }

  .bridal-common-inclusions,
  .bridal-addon-panel {
    padding: 8px;
  }

  .bridal-chip-list,
  .bridal-addon-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .bridal-chip-list span {
    padding: 6px 8px;
    font-size: 0.72rem;
  }

  .bridal-addon-option {
    width: 100%;
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr) auto;
    gap: 10px;
    align-items: center;
    padding: 8px;
    font-size: 0.74rem;
  }

  .bridal-addon-option input {
    width: 18px;
    height: 18px;
    margin: 0;
  }

  .bridal-addon-option span {
    min-width: 0;
    line-height: 1.2;
  }

  .bridal-addon-option strong {
    white-space: nowrap;
    font-size: 0.74rem;
  }

  .bridal-package-summary,
  .mehendi-selection-summary {
    position: sticky;
    bottom: calc(62px + env(safe-area-inset-bottom));
    z-index: 15;
    gap: 8px;
    padding: 10px;
    background: #f1e4d8;
    box-shadow: 0 -8px 24px rgba(36, 24, 21, 0.12);
  }

  .bridal-package-summary strong,
  .mehendi-selection-summary strong {
    font-size: 1rem;
  }

  .bridal-package-summary p,
  .mehendi-selection-summary p {
    font-size: 0.8rem;
    line-height: 1.35;
  }

  .bridal-package-summary .btn,
  .mehendi-selection-summary .btn {
    min-height: 42px;
    padding: 10px 12px;
    font-size: 0.72rem;
  }

  .booking-panel .reviews-heading h2,
  .account-help-head h2,
  .account-panel .reviews-heading h2 {
    font-family: "Inter", Arial, sans-serif;
    font-size: 1.25rem;
    line-height: 1.15;
  }

  .booking-form input,
  .booking-form select,
  .booking-form textarea {
    font-size: 0.92rem;
  }

  .account-help-panel,
  .account-panel {
    padding: 12px;
  }

  .account-help-list summary {
    min-height: 48px;
    padding: 0 12px;
    font-size: 0.88rem;
  }

  .account-help-list p {
    margin: -2px 12px 12px;
    font-size: 0.8rem;
  }

  .account-dashboard {
    gap: 10px;
  }

  .account-profile-card {
    grid-template-columns: 50px minmax(0, 1fr) auto;
    gap: 10px;
    padding: 12px;
  }

  .account-profile-avatar {
    width: 50px;
    height: 50px;
    font-size: 1.15rem;
  }

  .account-profile-copy h1 {
    font-size: 1.12rem;
  }

  .account-profile-edit {
    min-height: 34px;
    padding: 0 10px;
    font-size: 0.68rem;
  }

  .account-menu-row {
    min-height: 66px;
    grid-template-columns: 38px minmax(0, 1fr) auto 14px;
    gap: 9px;
    padding: 10px 12px;
  }

  .account-row-icon {
    width: 36px;
    height: 36px;
    font-size: 0.58rem;
  }

  .account-row-copy strong {
    font-size: 0.9rem;
  }

  .account-row-copy small {
    font-size: 0.74rem;
  }

  .account-row-meta {
    max-width: 25vw;
    font-size: 0.68rem;
  }

  .account-menu-body {
    padding: 0 12px 12px;
  }

  .account-menu-body .booking-form {
    grid-template-columns: 1fr;
  }

  .service-card-dashboard-grid,
  .business-status-grid,
  .user-service-card,
  .service-card-edit-grid,
  .service-card-edit-row,
  .sc-package-core-fields,
  .service-card-addon-row,
  .sc-two-grid,
  .sc-mehendi-row,
  .sc-side-preview,
  .sc-amount-box,
  .sc-money-summary {
    grid-template-columns: 1fr;
  }

  .account-service-card-panel {
    gap: 12px;
  }

  .account-collapsible summary {
    grid-template-columns: minmax(0, 1fr) auto auto;
    min-height: 54px;
    padding: 9px 10px;
  }

  .account-collapsible summary em {
    max-width: 34vw;
    font-size: 0.72rem;
  }

  .account-collapsible-body {
    padding: 0 10px 10px;
  }

  .account-quick-action-list {
    grid-template-columns: 1fr;
  }

  .service-card-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .partner-orders-summary {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-card-stat {
    padding: 10px;
  }

  .service-card-activity p,
  .service-card-title-row,
  .service-card-editor-head,
  .service-card-section-head {
    display: grid;
    align-items: stretch;
  }

  .user-service-card {
    padding: 10px;
    gap: 10px;
  }

  .user-service-card-media {
    min-height: 180px;
  }

  .user-service-card h3,
  .service-card-editor h3 {
    font-size: 1.08rem;
  }

  .service-card-meta-list,
  .service-card-item-preview {
    display: grid;
  }

  .service-card-location-grid,
  .service-card-photo-grid {
    grid-template-columns: 1fr;
  }

  .service-card-upload-button {
    width: 100%;
  }

  .service-card-edit-page {
    width: 100%;
    padding-inline: 10px;
  }

  .service-card-app-header {
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 8px;
  }

  .service-card-app-header .btn {
    min-width: 0;
    padding-inline: 10px;
    font-size: 0.78rem;
  }

  .sc-edit-tabs {
    top: 64px;
    margin-inline: -10px;
    padding-inline: 10px;
  }

  .service-card-page-card {
    padding: 10px;
  }

  .sc-booking-topline {
    display: grid;
    justify-content: stretch;
  }

  .sc-booking-topline span {
    width: fit-content;
  }

  .booking-form {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .booking-form label {
    gap: 5px;
    font-size: 0.68rem;
    letter-spacing: 0.06em;
  }

  .booking-form label span {
    font-size: 0.62rem;
  }

  .booking-form > label,
  .booking-address-panel,
  .booking-cost-list,
  .booking-estimate,
  .booking-save-profile,
  .booking-location-confirmation {
    grid-column: 1 / -1 !important;
  }

  .booking-address-panel {
    padding: 9px;
  }

  .booking-address-grid,
  .booking-address-grid label:first-child,
  .booking-address-grid label:nth-child(3) {
    grid-template-columns: 1fr;
    grid-column: 1 / -1;
  }

  .booking-address-panel summary {
    font-size: 0.72rem;
    letter-spacing: 0.04em;
    line-height: 1.25;
  }

  .booking-form textarea {
    min-height: 96px;
  }

  .booking-cost-list {
    max-height: 180px;
    overflow: auto;
  }

  .booking-cost-list span {
    min-width: 0;
    display: block;
    margin-bottom: 2px;
  }

  .booking-estimate {
    font-size: 0.82rem;
  }

  .cart-item-card {
    grid-template-columns: none;
  }

  .cart-item-media {
    min-height: 58px;
  }

  .cart-item-summary {
    grid-template-columns: 58px minmax(0, 1fr) auto;
    gap: 8px;
    padding: 8px;
  }

  .cart-item-summary-meta strong {
    font-size: 0.84rem;
  }

  .cart-item-summary-meta span {
    font-size: 0.72rem;
  }

  .cart-item-summary > .cart-item-price {
    font-size: 0.82rem;
    white-space: nowrap;
  }

  .cart-item-body {
    padding: 0 10px 10px 76px;
    gap: 6px;
  }

  .cart-item-body p {
    margin: 0;
    font-size: 0.78rem;
    line-height: 1.35;
  }

  .booking-address-grid {
    grid-template-columns: 1fr;
  }

  .phone-field {
    grid-template-columns: 1fr;
  }

  .service-hero-actions {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-hero-action {
    min-height: 58px;
    padding: 10px;
  }

  .booking-page-actions,
  .booking-card .bridal-vendor-actions {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .booking-page-actions[data-cart-actions] {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .booking-page-actions[data-cart-actions] .btn {
    width: 100%;
  }

  h1 {
    margin-bottom: 14px;
    font-size: 2.05rem;
    line-height: 1.08;
  }

  h2 {
    margin-bottom: 12px;
    font-size: 1.55rem;
    line-height: 1.12;
  }

  h3 {
    margin-bottom: 8px;
    font-size: 1.18rem;
    line-height: 1.16;
  }

  .reviews-admin-page {
    padding-top: 80px;
  }

  .portal-tabs {
    top: 62px;
    padding: 8px 10px;
  }

  .reviews-heading {
    gap: 6px;
    margin-bottom: 14px;
  }

  .reviews-heading p {
    font-size: 0.9rem;
    line-height: 1.5;
  }

  .cart-summary {
    margin-top: 10px;
    padding: 12px;
  }

  .cart-summary h2 {
    font-size: 1.55rem;
    line-height: 1.1;
  }

  .booking-history-heading {
    margin-top: 26px;
  }

  .portal-follow-section {
    padding-top: 10px;
  }

  .storefront-card-head {
    display: grid;
  }

  .storefront-card-head .btn {
    width: 100%;
  }

  .storefront-mini-grid,
  .storefront-rate-row,
  .storefront-addon-row,
  .storefront-location-grid,
  .storefront-module-grid,
  .photo-package-row,
  .photo-custom-event,
  .photo-deliverable-row {
    grid-template-columns: 1fr;
  }

  .storefront-rate-row {
    gap: 6px;
  }

  .hero-image,
  .split-image {
    min-height: 390px;
  }

  .button-row,
  .contact-cta-grid {
    grid-template-columns: 1fr;
  }

  .button-row {
    display: grid;
  }

  .btn {
    width: 100%;
  }

  .contact-cta-grid {
    display: grid;
  }

  .contact-form {
    padding: 22px;
  }

  .campaign-tile {
    padding: 12px 14px;
  }

  .campaign-tile h2 {
    font-size: 1.34rem;
    line-height: 1.05;
  }

  .campaign-tile h3 {
    font-size: 1.38rem;
  }

  .campaign-kicker {
    margin-bottom: 6px;
    font-size: 0.64rem;
  }

  .campaign-tile p:not(.campaign-kicker) {
    display: none;
  }

  .campaign-tile a {
    font-size: 0.7rem;
  }

  .recommendation-card {
    padding: 22px;
  }

  .home-shop-grid,
  .home-bridal-grid {
    grid-template-columns: 1fr;
  }

  .home-shop-card,
  .home-shop-card-text {
    min-height: 154px;
  }

  .home-bridal-grid a {
    min-height: auto;
    gap: 10px;
  }

  .recommendations-grid {
    gap: 18px;
    margin-top: 30px;
  }

  .recommendation-shelf-item {
    padding: 14px;
  }

  .recommendation-product iframe {
    height: 286px;
  }

  .recommendation-copy h3,
  .recommendation-video h3,
  .recommendation-shelf-copy h3 {
    font-size: 1.65rem;
  }

  .recommendation-label,
  .testimonial-location {
    letter-spacing: 0.12em;
  }

  .shop-hero .section-heading p:last-child,
  .shop-note {
    font-size: 0.92rem;
  }

  .catalog-card {
    min-height: 190px;
  }

  .bridal-card-top h3 {
    font-size: 1rem;
    line-height: 1.12;
  }

  .bridal-card-short,
  .bridal-detail span {
    font-size: 0.76rem;
  }

  .bridal-vendor {
    grid-template-columns: 1fr;
  }

  .service-team-card {
    grid-template-columns: 1fr;
  }

  .service-team-media {
    min-height: auto;
    aspect-ratio: 1 / 1.08;
  }

  .bridal-vendor-media {
    grid-template-columns: 1fr;
    align-items: stretch;
  }

  .bridal-vendor-strip {
    grid-template-columns: repeat(3, 1fr);
  }

  .bridal-vendor-empty {
    min-height: 132px;
  }

  .shorts-frame {
    width: min(100%, 290px);
  }

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

  .quote-section p {
    font-size: 2.25rem;
  }
}

.tools-hub-page {
  min-height: 100vh;
  padding: 96px 18px 110px;
  background: var(--bg);
}

.tools-hub-hero,
.tools-hub-grid {
  width: min(100%, 980px);
  margin: 0 auto;
}

.tools-hub-hero {
  display: grid;
  gap: 10px;
  margin-bottom: 18px;
}

.tools-hub-hero h1,
.tools-hub-hero p {
  margin: 0;
}

.tools-hub-hero h1 {
  font-size: clamp(2.2rem, 6vw, 4rem);
  line-height: 0.96;
}

.tools-hub-hero p {
  max-width: 620px;
  color: var(--muted);
  line-height: 1.6;
}

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

.tools-hub-card {
  min-height: 178px;
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 16px;
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  text-decoration: none;
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.05);
}

.tools-hub-card span {
  width: fit-content;
  padding: 5px 8px;
  color: var(--muted);
  background: var(--bg-warm);
  border-radius: 999px;
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.tools-hub-card strong {
  font-size: 1.2rem;
}

.tools-hub-card p {
  margin: 0;
  color: var(--muted);
  font-size: 0.9rem;
  line-height: 1.5;
}

.tools-hub-card[aria-disabled="true"] {
  cursor: default;
  opacity: 0.72;
}

.my-tools-page {
  color: var(--text);
}

.my-tools-hero h1 {
  max-width: 760px;
}

.my-tools-shell {
  width: min(100%, 1180px);
  margin: 0 auto 14px;
  display: grid;
  grid-template-columns: minmax(240px, 0.32fr) minmax(0, 0.68fr);
  gap: 12px;
  align-items: start;
}

.my-event-list,
.my-event-form,
.my-checklist-panel,
.my-recommendation-panel {
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.05);
}

.my-event-list {
  position: sticky;
  top: 96px;
  display: grid;
  gap: 12px;
}

.my-tools-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.my-tools-section-head h2,
.my-tools-section-head p {
  margin: 0;
}

.my-tools-section-head h2 {
  font-family: Inter, system-ui, sans-serif;
  font-size: 1.15rem;
  font-weight: 900;
}

.my-event-tabs {
  display: grid;
  gap: 8px;
}

.my-event-tabs button {
  min-height: 62px;
  display: grid;
  gap: 4px;
  padding: 10px;
  color: var(--text);
  background: #f8fafc;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
  text-align: left;
}

.my-event-tabs button.is-active {
  background: #111;
  border-color: #111;
  color: #fff;
}

.my-important-days-shell {
  grid-template-columns: minmax(260px, 0.4fr) minmax(0, 0.6fr);
}

.my-important-days-list {
  position: static;
}

.my-important-days-simple {
  width: min(100%, 760px);
  margin: 0 auto 14px;
  display: grid;
  gap: 14px;
}

.my-important-days-panel {
  display: grid;
  gap: 12px;
  padding: 14px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(17, 24, 39, 0.05);
}

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

.important-day-date-grid,
.important-day-saved-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.important-day-preset-grid button {
  min-height: 82px;
  display: grid;
  align-content: start;
  gap: 5px;
  padding: 11px;
  color: var(--text);
  background: #f8fafc;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
  font: inherit;
  text-align: left;
  cursor: pointer;
}

.important-day-date-card,
.important-day-saved-card {
  min-height: 156px;
  display: grid;
  align-content: start;
  gap: 8px;
  padding: 11px;
  color: var(--text);
  background: #f8fafc;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
}

.important-day-preset-grid strong,
.important-day-preset-grid span,
.important-day-saved-card strong {
  min-width: 0;
}

.important-day-preset-grid strong,
.important-day-saved-card strong {
  font-size: 0.88rem;
  font-weight: 900;
  line-height: 1.15;
}

.important-day-preset-grid span {
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 700;
  line-height: 1.3;
}

.important-day-date-card input,
.important-day-saved-card input {
  width: 100%;
  min-height: 44px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #ffffff;
  padding: 0 10px;
  color: var(--text);
  font: inherit;
  font-size: 0.86rem;
  font-weight: 800;
}

.important-day-date-card .btn,
.important-day-saved-card .btn {
  min-height: 44px;
  border-radius: 8px;
  font-size: 0.72rem;
}

.important-day-saved-card label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.important-day-saved-head {
  padding-top: 6px;
  border-top: 1px solid var(--line);
}

.important-day-tabs button {
  min-height: 56px;
}

.my-event-type-grid {
  display: grid;
  gap: 8px;
}

.my-event-type-grid button {
  min-height: 76px;
  display: grid;
  gap: 5px;
  padding: 11px;
  color: var(--text);
  background: #f8fafc;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
  text-align: left;
}

.my-event-type-grid button.is-active {
  color: #fff;
  background: #111;
  border-color: #111;
}

.my-event-type-grid strong,
.my-event-type-grid span {
  min-width: 0;
}

.my-event-type-grid span {
  font-size: 0.76rem;
  font-weight: 700;
  line-height: 1.3;
  opacity: 0.72;
}

.my-event-tabs strong,
.my-event-tabs span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.my-event-tabs span,
.my-tools-sync {
  color: inherit;
  font-size: 0.8rem;
  font-weight: 700;
  opacity: 0.72;
}

.my-tools-sync {
  margin: 0;
  color: var(--text);
}

.my-important-day-insight {
  margin: 0;
  padding: 11px 12px;
  color: #111;
  background: #f8fafc;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
  font-size: 0.9rem;
  font-weight: 760;
  line-height: 1.45;
}

.my-event-workspace {
  display: grid;
  gap: 12px;
}

.my-event-form {
  display: grid;
  gap: 14px;
}

.my-event-fields {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.my-important-day-form {
  align-content: start;
}

.my-important-day-fields {
  grid-template-columns: minmax(0, 1.2fr) minmax(0, 0.8fr);
}

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

.my-event-fields label,
.my-event-notes {
  display: grid;
  gap: 6px;
  color: var(--text);
  font-size: 0.72rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.my-event-fields input,
.my-event-fields select,
.my-event-notes select,
.my-event-notes textarea {
  width: 100%;
  min-height: 44px;
  padding: 10px 11px;
  color: var(--text);
  background: #fff;
  border: 1px solid rgba(17, 24, 39, 0.14);
  border-radius: 8px;
  font: inherit;
  letter-spacing: 0;
  text-transform: none;
}

.my-event-notes textarea {
  resize: vertical;
}

.my-service-picker {
  display: grid;
  gap: 8px;
}

.my-service-picker strong {
  font-size: 0.86rem;
  font-weight: 900;
}

.my-service-picker > div {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.my-service-picker button {
  min-height: 42px;
  padding: 0 12px;
  color: #111;
  background: #f3f4f6;
  border: 1px solid rgba(17, 24, 39, 0.12);
  border-radius: 999px;
  font-size: 0.78rem;
  font-weight: 900;
}

.my-service-picker button.is-selected {
  color: #fff;
  background: #111;
  border-color: #111;
}

.my-progress-number {
  min-width: 54px;
  text-align: right;
  font-size: 1rem;
}

.my-progress-track {
  height: 8px;
  overflow: hidden;
  margin: 10px 0 12px;
  background: #e5e7eb;
  border-radius: 999px;
}

.my-progress-track span {
  height: 100%;
  display: block;
  background: #168447;
  border-radius: inherit;
  transition: width 180ms ease;
}

.my-checklist-list {
  display: grid;
  gap: 8px;
}

.my-checklist-list label {
  min-height: 48px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 9px 10px;
  background: #f8fafc;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
}

.my-checklist-list label.is-done span {
  text-decoration: line-through;
  opacity: 0.62;
}

.my-checklist-list input {
  width: 20px;
  height: 20px;
  accent-color: #168447;
}

.my-checklist-list span {
  color: var(--text);
  font-size: 0.9rem;
  font-weight: 780;
  line-height: 1.35;
}

.my-checklist-list a {
  color: var(--text);
  font-size: 0.72rem;
  font-weight: 900;
  text-decoration: none;
  text-transform: uppercase;
}

.my-recommendation-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.my-recommendation-grid a {
  min-height: 76px;
  display: grid;
  align-content: center;
  gap: 5px;
  padding: 12px;
  color: var(--text);
  background: #f8fafc;
  border: 1px solid rgba(17, 24, 39, 0.1);
  border-radius: 8px;
  text-decoration: none;
}

.my-recommendation-grid strong {
  font-size: 0.95rem;
}

.my-recommendation-grid span {
  color: var(--text);
  font-size: 0.78rem;
  font-weight: 650;
  line-height: 1.35;
  opacity: 0.72;
}

.my-tools-card-grid {
  margin-top: 12px;
}

.save-date-page {
  min-height: 100vh;
  padding: 96px 18px 110px;
  background: var(--bg);
}

.save-date-builder,
.save-date-invite-shell {
  width: min(100%, 1360px);
  margin: 0 auto;
  display: grid;
  grid-template-columns: minmax(300px, 380px) minmax(320px, 1fr) minmax(300px, 360px);
  gap: 18px;
  align-items: start;
}

.save-date-invite-shell {
  grid-template-columns: minmax(320px, 520px) minmax(300px, 420px);
  justify-content: center;
}

.save-date-panel {
  display: grid;
  gap: 14px;
  padding: 18px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 12px 30px rgba(17, 24, 39, 0.04);
}

.save-date-panel h1,
.save-date-panel h2,
.save-date-panel h3,
.save-date-panel p {
  margin: 0;
}

.save-date-panel h1 {
  font-size: clamp(2rem, 4vw, 3.2rem);
  line-height: 0.98;
}

.save-date-panel h2 {
  font-size: 1.4rem;
}

.save-date-form,
.save-date-rsvp-form {
  display: grid;
  gap: 10px;
}

.save-date-form label,
.save-date-rsvp-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.save-date-form input,
.save-date-form textarea,
.save-date-form select,
.save-date-rsvp-form input {
  width: 100%;
  min-height: 46px;
  padding: 11px 12px;
  color: var(--text);
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 6px;
  font-size: 16px;
  letter-spacing: 0;
  text-transform: none;
}

.save-date-form textarea {
  min-height: 84px;
  resize: vertical;
  line-height: 1.45;
}

.save-date-template-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.save-date-template-grid button {
  min-height: 58px;
  display: grid;
  align-content: center;
  gap: 2px;
  padding: 8px;
  color: var(--text);
  text-align: left;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 7px;
  font: inherit;
  box-shadow: inset 0 0 0 999px rgba(255, 255, 255, 0.28);
}

.save-date-template-grid button.is-active {
  border-color: var(--accent-deep);
  box-shadow: 0 0 0 2px rgba(124, 50, 70, 0.12);
}

.save-date-template-grid span {
  font-size: 0.76rem;
  font-weight: 900;
  line-height: 1.12;
}

.save-date-template-grid em {
  color: var(--muted);
  font-size: 0.62rem;
  font-style: normal;
  line-height: 1.15;
}

.save-date-template-classic {
  background:
    linear-gradient(135deg, rgba(251, 247, 239, 0.9), rgba(239, 227, 206, 0.92));
}

.save-date-template-malabar {
  background:
    linear-gradient(135deg, rgba(255, 250, 240, 0.95), rgba(240, 217, 153, 0.7));
}

.save-date-template-minimal {
  background:
    linear-gradient(135deg, #fff, #f4f4f5);
}

.save-date-template-garden {
  background:
    linear-gradient(135deg, rgba(251, 255, 249, 0.95), rgba(223, 238, 221, 0.88));
}

.save-date-two,
.save-date-actions,
.save-date-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.save-date-card-stage {
  position: sticky;
  top: 86px;
  display: grid;
  place-items: center;
  min-width: 0;
  padding: 14px;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.save-date-canvas {
  width: min(100%, 430px);
  height: auto;
  border-radius: 6px;
  box-shadow: 0 24px 54px rgba(17, 24, 39, 0.16);
}

.save-date-login-line,
.save-date-link-box {
  font-size: 0.86rem;
  color: var(--muted);
}

.save-date-link-box {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 10px;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 6px;
}

.save-date-link-box span {
  font-size: 0.68rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.save-date-link-box a {
  min-width: 0;
  overflow-wrap: anywhere;
  color: var(--text);
  font-weight: 800;
  text-decoration: none;
}

.save-date-profile-builder,
.save-date-profile-group,
.save-date-profile-card,
.save-date-profile-report,
.save-date-invite-notes {
  display: grid;
  gap: 10px;
}

.save-date-profile-head,
.save-date-profile-group-head,
.save-date-profile-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.save-date-profile-head strong,
.save-date-profile-group-head strong,
.save-date-profile-title strong,
.save-date-invite-notes strong {
  color: var(--text);
}

.save-date-profile-head span,
.save-date-profile-pending {
  color: var(--muted);
  font-size: 0.78rem;
  line-height: 1.35;
}

.save-date-profile-group {
  padding: 10px;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.save-date-profile-head .btn,
.save-date-profile-group-head .btn {
  width: auto;
  min-height: 36px;
  padding: 0 10px;
  font-size: 0.72rem;
}

.save-date-profile-card {
  padding: 10px;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.save-date-profile-title button {
  color: #b42318;
  background: transparent;
  border: 0;
  font-size: 0.74rem;
  font-weight: 900;
}

.save-date-profile-title button:disabled {
  color: var(--muted);
  cursor: not-allowed;
  opacity: 0.45;
}

.save-date-profile-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.save-date-profile-actions button {
  min-height: 36px;
  padding: 0 8px;
  color: var(--text);
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 999px;
  font-size: 0.7rem;
  font-weight: 900;
}

.save-date-invite-notes {
  padding: 12px;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.save-date-invite-notes span,
.save-date-invite-notes p {
  color: var(--text);
  font-size: 0.86rem;
  line-height: 1.45;
}

.save-date-invite-notes p {
  margin: 0;
}

.save-date-report-head {
  display: flex;
  gap: 12px;
  align-items: start;
  justify-content: space-between;
}

.save-date-report-head span,
.save-date-stats strong {
  padding: 10px;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 6px;
  font-weight: 900;
}

.save-date-stats strong {
  display: grid;
  gap: 2px;
  font-size: 1.4rem;
}

.save-date-stats span {
  color: var(--muted);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.save-date-guest-list,
.save-date-saved-list {
  display: grid;
  gap: 8px;
}

.save-date-guest-list div,
.save-date-saved-list button,
.save-date-profile-report div {
  display: grid;
  gap: 2px;
  width: 100%;
  padding: 10px;
  color: var(--text);
  text-align: left;
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: 6px;
}

.save-date-guest-list span,
.save-date-guest-list small,
.save-date-saved-list em,
.save-date-profile-report span {
  color: var(--muted);
  font-size: 0.8rem;
}

.save-date-saved-list h3 {
  margin-top: 8px;
  font-size: 1rem;
}

.save-date-segmented {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  padding: 4px;
  background: var(--bg-warm);
  border: 1px solid var(--line);
  border-radius: 999px;
}

.save-date-segmented button {
  min-height: 42px;
  color: var(--muted);
  background: transparent;
  border: 0;
  border-radius: 999px;
  font-weight: 900;
}

.save-date-segmented button.is-active {
  color: #fff;
  background: var(--accent-deep);
}

html[data-theme="dark"] :is(
  .site-header,
  .mobile-bottom-nav,
  .shop-category-panel,
  .tools-hub-card,
  .save-date-panel,
  .save-date-card-stage,
  .save-date-profile-card,
  .vendor-owner-fab-menu,
  .vendor-forward-panel,
  .my-important-days-panel,
  .important-day-date-card,
  .important-day-saved-card,
  .account-panel,
  .account-help-panel,
  .booking-card,
  .booking-panel,
  .cart-summary,
  .cart-item-card,
  .order-card,
  .message-thread-card,
  .service-card-page-card,
  .user-service-card,
  .service-team-card,
  .bridal-vendor,
  .catalog-card,
  .recommendation-card
) {
  color: var(--text);
  background: var(--bg-soft);
  border-color: var(--line);
}

html[data-theme="dark"] :is(input, textarea, select) {
  color: var(--text);
  background: #090a0c;
  border-color: var(--line);
}

html[data-theme="dark"] :is(.btn-outline, .save-date-profile-actions button, .vendor-owner-fab-menu a, .shop-category-grid a) {
  color: var(--text);
  background: var(--bg-warm);
  border-color: var(--line);
}

html[data-theme="dark"] :is(.mobile-bottom-nav svg, .shop-category-grid svg) {
  stroke: currentColor;
}

html[data-theme="dark"] .save-date-segmented button.is-active {
  color: #111827;
  background: #ffffff;
}

@media (max-width: 1080px) {
  .save-date-builder {
    grid-template-columns: minmax(0, 1fr) minmax(300px, 380px);
  }

  .save-date-card-stage {
    position: static;
    order: -1;
  }

  .save-date-report {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .tools-hub-page {
    padding: 80px 10px 94px;
  }

  .my-tools-shell,
  .my-important-days-shell {
    grid-template-columns: 1fr;
  }

  .my-event-list {
    position: static;
  }

  .important-day-preset-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .my-important-day-fields,
  .important-day-actions {
    grid-template-columns: 1fr;
  }

  .tools-hub-grid {
    grid-template-columns: 1fr;
  }

  .tools-hub-card {
    min-height: 132px;
  }

  .save-date-page {
    padding: 76px 10px 94px;
  }

  .save-date-builder,
  .save-date-invite-shell,
  .save-date-two,
  .save-date-actions,
  .save-date-profile-actions {
    grid-template-columns: 1fr;
  }

  .save-date-template-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .save-date-panel,
  .save-date-card-stage {
    padding: 12px;
  }

  .save-date-panel h1 {
    font-size: 2.15rem;
  }

  .save-date-canvas {
    width: min(100%, 340px);
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    scroll-behavior: auto !important;
    transition-duration: 0.01ms !important;
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
  }
}
