.directory-vue-shell {
  --directory-shell-max-width: 1200px;
  --directory-shell-gap: 24px;
  --directory-shell-surface: rgba(255, 255, 255, 0.92);
  --directory-shell-border: rgba(15, 23, 42, 0.08);
  --directory-shell-muted: #667085;
  --directory-shell-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}

.directory-vue-container {
  width: min(calc(100% - 32px), var(--directory-shell-max-width));
  margin: -18px auto 32px;
  position: relative;
  z-index: 2;
}

.directory-vue-grid {
  display: grid;
  grid-template-columns: minmax(0, 280px) minmax(0, 1fr);
  gap: var(--directory-shell-gap);
  align-items: start;
}

.directory-vue-shell--full .directory-vue-grid {
  grid-template-columns: minmax(0, 1fr);
}

.directory-vue-shell--full .directory-vue-main {
  grid-column: 1 / -1;
}

.directory-vue-main {
  min-width: 0;
  width: 100%;
}

.directory-vue-filters,
.directory-vue-content {
  display: block;
  width: 100%;
}

.directory-vue-mobile-sidebar {
  margin-bottom: 20px;
}

.directory-vue-panel {
  display: block;
  width: 100%;
  background: var(--directory-shell-surface);
  border: 1px solid var(--directory-shell-border);
  border-radius: 24px;
  box-shadow: var(--directory-shell-shadow);
  backdrop-filter: blur(18px);
  position: relative;
}

.directory-vue-panel--filters {
  padding: 24px;
  margin-bottom: 24px;
  z-index: 8;
}

.directory-vue-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  align-items: center;
  width: 100%;
}

.directory-vue-control {
  flex: 0 0 auto;
}

.directory-vue-control--search {
  flex: 1 1 260px;
  min-width: min(100%, 280px);
}

.directory-vue-search {
  width: 100%;
}

.directory-vue-searchbar {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px 10px 16px;
  border-radius: 16px;
  background: rgba(248, 250, 252, 0.96);
  border: 1px solid rgba(148, 163, 184, 0.22);
}

.directory-vue-searchbar input {
  flex: 1 1 auto;
  min-width: 0;
  border: 0;
  background: transparent;
  outline: 0;
  color: inherit;
}

.directory-vue-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: 14px;
  text-decoration: none;
  font-weight: 600;
}

.directory-vue-button--compact {
  min-height: 40px;
  padding: 0 16px;
}

.directory-vue-button--primary {
  background: linear-gradient(135deg, #0f172a, #2563eb);
  color: #fff;
}

.directory-vue-button--ghost {
  background: rgba(226, 232, 240, 0.72);
  color: inherit;
}

.directory-vue-button--danger {
  background: linear-gradient(135deg, #7f1d1d, #dc2626);
  color: #fff;
}

.directory-vue-button--success {
  background: linear-gradient(135deg, #166534, #16a34a);
  color: #fff;
}

.directory-vue-button--warning {
  background: linear-gradient(135deg, #a16207, #f59e0b);
  color: #fff;
}

.directory-vue-menu {
  padding: 10px;
  border-radius: 18px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 22px 40px rgba(15, 23, 42, 0.14);
  z-index: 1080;
}

.directory-vue-menu__item {
  display: flex;
  align-items: center;
  min-height: 40px;
  padding: 0 12px;
  border-radius: 12px;
}

.directory-vue-menu__item:hover {
  background: rgba(37, 99, 235, 0.08);
}

.directory-vue-menu--form {
  width: min(100vw - 32px, 320px);
  padding: 18px;
}

.directory-vue-city-form {
  display: grid;
  gap: 14px;
}

.directory-vue-city-field {
  margin: 0;
  position: relative;
  z-index: 2;
}

.directory-vue-city-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.directory-vue-toolbar-create {
  margin-left: auto;
  background: linear-gradient(135deg, #0f766e, #2563eb) !important;
  color: #fff !important;
  border-color: transparent !important;
}

.directory-vue-toolbar-create:hover,
.directory-vue-toolbar-create:focus {
  color: #fff !important;
  filter: brightness(1.02);
}

.directory-vue-categories-toggle {
  display: none;
}

.directory-vue-categories {
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.directory-vue-categories li {
  margin: 0;
}

.directory-vue-categories li a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 42px;
  padding: 0 16px;
  border-radius: 999px;
  text-decoration: none;
  color: inherit;
  background: rgba(241, 245, 249, 0.95);
  border: 1px solid rgba(148, 163, 184, 0.18);
}

.directory-vue-categories li.active a {
  background: linear-gradient(135deg, #0f172a, #1d4ed8);
  border-color: transparent;
  color: #fff;
}

.directory-vue-content-body {
  width: 100%;
  margin-top: 24px;
}

.directory-vue-create-panel {
  padding: 20px 20px 0;
}

.directory-vue-create-card {
  width: 100%;
  min-height: 160px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 14px;
  text-align: center;
  text-decoration: none;
}

.directory-vue-create-card__icon {
  display: block;
}

.directory-vue-card-grid {
  list-style: none;
  margin: 0;
  padding: 0;
  width: 100%;
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.directory-vue-empty-action {
  text-align: center;
  margin: -16px 0 40px;
}

.directory-vue-page-card {
  display: block;
  width: 100%;
  min-width: 0;
}

.directory-vue-page-card__shell {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  overflow: hidden;
}

.directory-vue-page-card__cover {
  display: block;
  height: 112px;
  background: #e9eef5 center / cover no-repeat;
  border-radius: 18px 18px 0 0;
}

.directory-vue-page-card__body {
  display: flex;
  justify-content: center;
  margin-top: -18px;
}

.directory-vue-page-card__avatar {
  width: 52px;
  height: 52px;
  padding: 3px;
  border-radius: 999px;
  overflow: hidden;
  border: 2px solid #fff;
  background: #fff;
  box-shadow: 0 12px 24px rgba(15, 23, 42, 0.12);
}

.directory-vue-page-card__avatar img {
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  border-radius: 999px;
}

.directory-vue-page-card__meta,
.directory-vue-page-card__price,
.directory-vue-page-card__actions {
  text-align: center;
}

.directory-vue-page-card__meta {
  padding: 14px 18px 0;
}

.directory-vue-page-card__title {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex-wrap: wrap;
}

.directory-vue-page-card__likes {
  margin-top: 4px;
  color: var(--directory-shell-muted);
}

.directory-vue-page-card__price {
  padding: 14px 18px 0;
}

.directory-vue-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.12);
  color: #1d4ed8;
  font-weight: 600;
}

.directory-vue-page-card__actions {
  margin-top: auto;
  padding: 18px;
  display: flex;
  justify-content: center;
}

.directory-vue-see-more {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  min-height: 60px;
  margin-top: 18px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.06);
}

.directory-vue-group-card {
  display: block;
  width: 100%;
  min-width: 0;
}

.directory-vue-group-card__shell {
  display: flex;
  flex-direction: column;
  min-height: 100%;
  overflow: hidden;
}

.directory-vue-group-card__media {
  overflow: hidden;
}

.directory-vue-group-card__media img {
  display: block;
  width: 100%;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.directory-vue-group-card__meta {
  padding: 16px 18px 0;
  text-align: center;
}

.directory-vue-group-card__count {
  margin-top: 4px;
  color: var(--directory-shell-muted);
}

.directory-vue-group-card__actions {
  margin-top: auto;
  padding: 18px;
  display: flex;
  justify-content: center;
}

.city-suggestions {
  z-index: 1200 !important;
  margin-top: 8px;
  padding: 8px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 16px;
  box-shadow: 0 24px 44px rgba(15, 23, 42, 0.14);
}

.city-suggestions .city-suggestion-item {
  width: 100%;
  min-height: 40px;
  padding: 10px 12px;
  border: 0;
  border-radius: 12px;
  background: transparent;
  text-align: left;
}

.city-suggestions .city-suggestion-item:hover,
.city-suggestions .city-suggestion-item:focus {
  background: rgba(37, 99, 235, 0.08);
}

body.night-mode .directory-vue-shell {
  --directory-shell-surface: rgba(17, 24, 39, 0.9);
  --directory-shell-border: rgba(148, 163, 184, 0.18);
  --directory-shell-muted: #cbd5e1;
  --directory-shell-shadow: 0 18px 45px rgba(0, 0, 0, 0.28);
}

body.night-mode .directory-vue-searchbar,
body.night-mode .directory-vue-categories li a {
  background: rgba(15, 23, 42, 0.88);
  border-color: rgba(148, 163, 184, 0.16);
}

body.night-mode .directory-vue-button--ghost {
  background: rgba(30, 41, 59, 0.92);
}

body.night-mode .directory-vue-menu {
  border-color: rgba(148, 163, 184, 0.18);
  box-shadow: 0 22px 40px rgba(0, 0, 0, 0.28);
}

body.night-mode .directory-vue-menu__item:hover {
  background: rgba(59, 130, 246, 0.16);
}

body.night-mode .city-suggestions {
  background: rgba(15, 23, 42, 0.98);
  border-color: rgba(148, 163, 184, 0.18);
  box-shadow: 0 24px 44px rgba(0, 0, 0, 0.32);
}

body.night-mode .city-suggestions .city-suggestion-item:hover,
body.night-mode .city-suggestions .city-suggestion-item:focus {
  background: rgba(59, 130, 246, 0.16);
}

body.night-mode .directory-vue-page-card__avatar {
  border-color: #111827;
  background: #111827;
}

body.night-mode .directory-vue-page-card__cover {
  background-color: #1f2937;
}

body.night-mode .directory-vue-badge {
  background: rgba(59, 130, 246, 0.18);
  color: #bfdbfe;
}

body.night-mode .directory-vue-see-more {
  background: rgba(17, 24, 39, 0.72);
  border-color: rgba(148, 163, 184, 0.18);
}

@media (max-width: 991px) {
  .directory-vue-grid {
    grid-template-columns: 1fr;
  }

  .directory-vue-sidebar {
    display: none;
  }

  .directory-vue-categories-toggle {
    display: inline-flex;
  }

  .directory-vue-categories {
    display: none;
  }

  .directory-vue-categories.is-open {
    display: flex;
  }

  .directory-vue-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 767px) {
  .directory-vue-container {
    width: min(calc(100% - 20px), var(--directory-shell-max-width));
    margin-top: -10px;
  }

  .directory-vue-panel--filters {
    padding: 18px;
  }

  .directory-vue-controls {
    gap: 12px;
  }

  .directory-vue-toolbar-create {
    margin-left: 0;
  }

  .directory-vue-control,
  .directory-vue-control--search {
    flex-basis: 100%;
  }

  .directory-vue-searchbar {
    flex-wrap: wrap;
  }

  .directory-vue-searchbar .btn {
    width: 100%;
  }

  .directory-vue-card-grid {
    grid-template-columns: 1fr;
  }
}
