:root {
  --bg: #f4f6f8;
  --panel: #ffffff;
  --text: #111827;
  --muted: #6b7280;
  --line: #e5e7eb;
  --soft: #f9fafb;
  --primary: #ff6500;
  --primary-dark: #d94e00;
  --danger: #dc2626;
  --nav: #111827;
  --nav-soft: #1f2937;
  --green: #16a34a;
}

* {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

body {
  margin: 0;
  font-family: Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  font-size: 14px;
}

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

* {
  scrollbar-width: thin;
  scrollbar-color: #ffb37a #eef0f3;
}

::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}

::-webkit-scrollbar-track {
  background: #eef0f3;
  border-radius: 999px;
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, #ffb37a, #ff6500);
  border: 2px solid #eef0f3;
  border-radius: 999px;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, #ff9b4d, #d94e00);
}

a {
  color: inherit;
  text-decoration: none;
}

button,
.button {
  min-height: 36px;
  border: 0;
  border-radius: 8px;
  padding: 0 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--primary);
  color: #fff;
  font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}

button:hover,
.button:hover {
  background: var(--primary-dark);
}

button.light,
.button.light {
  color: var(--text);
  background: #fff;
  border: 1px solid var(--line);
}

button.light:hover,
.button.light:hover {
  background: var(--soft);
}

.button.small,
button.small {
  min-height: 30px;
  border-radius: 6px;
  padding: 0 10px;
  font-size: 12px;
}

button.danger {
  background: var(--danger);
}

.small-btn {
  min-height: 30px;
  padding: 0 10px;
  font-size: 12px;
}

.icon-btn {
  width: 34px;
  min-height: 34px;
  padding: 0;
  border-radius: 50%;
  color: var(--muted);
  background: var(--soft);
  border: 1px solid var(--line);
  font-size: 22px;
  font-weight: 400;
}

.sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 260px;
  padding: 18px;
  background: var(--nav);
  color: white;
  display: flex;
  flex-direction: column;
}

.brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 6px 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.brand-mark {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #ff6500, #ffb000);
  font-weight: 800;
}

.brand strong {
  display: block;
  font-size: 18px;
}

.brand span,
small,
.panel p,
.page-actions p,
.topbar p {
  color: var(--muted);
}

.side-nav {
  display: grid;
  gap: 8px;
  padding: 16px 0;
  overflow-y: auto;
}

.side-nav details {
  border-radius: 10px;
}

.side-nav summary,
.side-nav a,
.ghost {
  width: 100%;
  min-height: 36px;
  padding: 9px 12px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  color: #d1d5db;
  background: transparent;
  font-size: 13px;
  cursor: pointer;
}

.side-nav summary {
  justify-content: space-between;
  color: #fff;
  font-weight: 700;
  list-style: none;
}

.side-nav summary::-webkit-details-marker {
  display: none;
}

.side-nav summary::after {
  content: "+";
  color: #9ca3af;
}

.side-nav details[open] summary::after {
  content: "-";
}

.side-nav details a {
  margin-left: 10px;
  width: calc(100% - 10px);
}

.side-nav a:hover,
.side-nav summary:hover,
.ghost:hover {
  background: var(--nav-soft);
  color: #fff;
}

.side-nav .admin-back {
  background: rgba(255, 101, 0, 0.16);
  color: #fff;
  border: 1px solid rgba(255, 101, 0, 0.32);
}

.sidebar-footer {
  margin-top: auto;
}

.main {
  margin-left: 260px;
  padding: 18px;
}

.topbar,
.page-actions,
.toolbar,
.detail-head,
.category-head,
.field-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}

.topbar {
  position: sticky;
  top: 0;
  z-index: 10;
  margin: -18px -18px 18px;
  padding: 14px 18px;
  background: rgba(244, 246, 248, 0.92);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--line);
}

.topbar p,
.topbar h1,
.page-actions h2,
.page-actions p {
  margin: 0;
}

.topbar h1 {
  font-size: 22px;
}

.admin-pill {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 10px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #fff;
}

.admin-pill > span {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: #fff3e8;
  color: var(--primary);
  font-weight: 800;
}

.admin-pill strong,
.admin-pill small {
  display: block;
  line-height: 1.2;
}

.page-actions {
  margin-bottom: 14px;
}

.role-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 14px;
  padding: 22px;
  border: 1px solid #ffd4b2;
  border-radius: 12px;
  background:
    radial-gradient(circle at right, rgba(255, 101, 0, 0.18), transparent 34%),
    linear-gradient(135deg, #fff7ed, #ffffff);
}

.role-hero h2,
.role-hero p {
  margin: 8px 0 0;
}

.role-hero h2 {
  font-size: 28px;
}

.quick-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

.quick-card {
  min-height: 74px;
  justify-content: flex-start;
  padding: 14px 16px;
  border: 1px solid var(--line);
  background: #fff;
  color: var(--text);
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.quick-card:hover {
  border-color: #ffd4b2;
  background: #fff7ed;
  color: var(--primary);
}

.vendor-console {
  background: #f8fafc;
}

.vendor-sidebar {
  position: fixed;
  inset: 0 auto 0 0;
  width: 236px;
  padding: 16px 14px;
  background: #fff;
  border-right: 1px solid var(--line);
  display: flex;
  flex-direction: column;
}

.vendor-sidebar .brand {
  border-bottom: 0;
  padding-bottom: 20px;
}

.vendor-nav {
  display: grid;
  gap: 4px;
}

.vendor-nav a {
  min-height: 38px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 12px;
  border-radius: 8px;
  color: #475569;
  font-weight: 600;
}

.vendor-nav-logout {
  margin: 0;
}

.vendor-nav-logout button {
  width: 100%;
  min-height: 38px;
  justify-content: flex-start;
  gap: 12px;
  padding: 0 12px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: #dc2626;
  font-weight: 700;
  box-shadow: none;
}

.nav-icon {
  width: 22px;
  height: 22px;
  flex: 0 0 22px;
  position: relative;
  display: grid;
  place-items: center;
  border-radius: 7px;
  background: #f1f5f9;
  color: #64748b;
}

.nav-icon::before,
.nav-icon::after {
  content: "";
  position: absolute;
  box-sizing: border-box;
}

.nav-dashboard::before {
  width: 12px;
  height: 12px;
  background:
    linear-gradient(#64748b 0 0) 0 0 / 5px 5px no-repeat,
    linear-gradient(#64748b 0 0) 7px 0 / 5px 5px no-repeat,
    linear-gradient(#64748b 0 0) 0 7px / 5px 5px no-repeat,
    linear-gradient(#64748b 0 0) 7px 7px / 5px 5px no-repeat;
}

.nav-orders::before,
.nav-products::before,
.nav-reports::before {
  width: 11px;
  height: 13px;
  border: 2px solid currentColor;
  border-radius: 2px;
}

.nav-orders::after,
.nav-reports::after {
  width: 7px;
  height: 2px;
  background: currentColor;
  box-shadow: 0 4px 0 currentColor;
}

.nav-products::after {
  width: 6px;
  height: 6px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-45deg);
  top: 6px;
}

.nav-enquiries::before,
.nav-support::before {
  width: 13px;
  height: 10px;
  border: 2px solid currentColor;
  border-radius: 5px;
}

.nav-enquiries::after,
.nav-support::after {
  width: 5px;
  height: 5px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(-20deg);
  bottom: 4px;
  left: 7px;
}

.nav-wishlist::before {
  width: 12px;
  height: 12px;
  background: currentColor;
  transform: rotate(45deg) scale(0.76);
  border-radius: 2px;
}

.nav-wishlist::after {
  width: 12px;
  height: 8px;
  top: 5px;
  background:
    radial-gradient(circle at 3px 3px, currentColor 4px, transparent 4px),
    radial-gradient(circle at 9px 3px, currentColor 4px, transparent 4px);
}

.nav-profile::before {
  width: 8px;
  height: 8px;
  top: 4px;
  border-radius: 50%;
  border: 2px solid currentColor;
}

.nav-profile::after {
  width: 13px;
  height: 7px;
  bottom: 3px;
  border: 2px solid currentColor;
  border-radius: 10px 10px 3px 3px;
}

.nav-referrals::before {
  width: 7px;
  height: 7px;
  top: 4px;
  left: 4px;
  border: 2px solid currentColor;
  border-radius: 50%;
  box-shadow: 7px 0 0 -1px currentColor;
}

.nav-referrals::after {
  width: 15px;
  height: 7px;
  bottom: 4px;
  border: 2px solid currentColor;
  border-radius: 10px 10px 3px 3px;
}

.nav-logout::before,
.nav-back::before {
  width: 12px;
  height: 9px;
  border: 2px solid currentColor;
  border-left: 0;
  border-radius: 2px;
  right: 4px;
}

.nav-logout::after,
.nav-back::after {
  width: 9px;
  height: 9px;
  border-left: 2px solid currentColor;
  border-bottom: 2px solid currentColor;
  transform: rotate(45deg);
  left: 4px;
}

.nav-settings::before {
  width: 14px;
  height: 14px;
  border: 2px dashed currentColor;
  border-radius: 50%;
}

.nav-settings::after {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: currentColor;
}

.nav-commissions::before,
.nav-payouts::before,
.nav-coupons::before {
  width: 12px;
  height: 12px;
  border: 2px solid currentColor;
  border-radius: 50%;
}

.nav-commissions::after,
.nav-payouts::after,
.nav-coupons::after {
  content: "$";
  position: static;
  font-size: 11px;
  font-weight: 900;
}

.nav-marketing::before {
  width: 13px;
  height: 9px;
  border: 2px solid currentColor;
  border-right-width: 5px;
  transform: skewY(-14deg);
}

.nav-reviews::before {
  width: 13px;
  height: 13px;
  border: 2px solid currentColor;
  clip-path: polygon(50% 0, 62% 35%, 100% 35%, 70% 57%, 82% 100%, 50% 74%, 18% 100%, 30% 57%, 0 35%, 38% 35%);
}

.vendor-nav a:hover .nav-icon,
.vendor-nav a.active .nav-icon {
  background: #ede9fe;
  color: #5b21f6;
}

.vendor-nav-logout .nav-icon {
  background: #fef2f2;
  color: #dc2626;
}

.vendor-nav-logout button:hover .nav-icon {
  color: #b91c1c;
}

.vendor-nav a em {
  margin-left: auto;
  min-width: 30px;
  padding: 3px 7px;
  border-radius: 999px;
  background: #ede9fe;
  color: #5b21b6;
  font-style: normal;
  font-size: 12px;
  text-align: center;
}

.vendor-nav a:hover,
.vendor-nav a.active,
.vendor-nav-logout button:hover {
  background: #f1ecff;
  color: #5b21f6;
}

.vendor-nav-logout button:hover {
  background: #fef2f2;
  color: #b91c1c;
}

.vendor-upgrade {
  margin-top: auto;
  padding: 16px;
  border: 1px solid #ddd6fe;
  border-radius: 10px;
  background: linear-gradient(135deg, #faf5ff, #fff);
  text-align: center;
}

.vendor-upgrade p {
  color: var(--muted);
  font-size: 12px;
}

.vendor-upgrade button {
  width: 100%;
  background: #5b21f6;
}

.vendor-main {
  margin-left: 236px;
  min-height: 100vh;
}

.vendor-topbar {
  height: 76px;
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 0 28px;
  border-bottom: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.9);
  backdrop-filter: blur(14px);
  position: sticky;
  top: 0;
  z-index: 20;
}

.vendor-search {
  max-width: 540px;
  flex: 1;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  border: 1px solid transparent;
  border-radius: 10px;
  background: #f5f3ff;
}

.vendor-search input {
  border: 0;
  background: transparent;
}

.vendor-topbar .admin-pill {
  margin-left: auto;
}

.account-menu-toggle {
  display: none;
  border-radius: 10px;
}

.account-menu-toggle span {
  width: 15px;
  height: 2px;
  display: block;
  border-radius: 999px;
  background: #475569;
}

.account-menu-toggle span + span {
  margin-top: 3px;
}

.account-sidebar-backdrop {
  display: none;
}

.admin-console {
  background:
    radial-gradient(circle at 18% 0%, rgba(255, 101, 0, 0.08), transparent 28%),
    linear-gradient(180deg, #fbfcff 0%, #f7f9fc 100%);
}

.admin-console .sidebar {
  width: 236px;
  padding: 12px;
  background:
    linear-gradient(180deg, rgba(15, 23, 42, 0.96), rgba(2, 12, 27, 0.98)),
    #08111f;
  color: #e5edf7;
  border-right: 1px solid rgba(148, 163, 184, 0.16);
  box-shadow: 14px 0 34px rgba(15, 23, 42, 0.16);
}

.admin-console .brand {
  border-bottom: 0;
  padding: 4px 8px 14px;
}

.admin-console .brand-mark {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  box-shadow: 0 10px 22px rgba(255, 101, 0, 0.24);
}

.admin-console .brand strong {
  color: #0f172a;
  font-size: 18px;
  letter-spacing: -0.02em;
}

.admin-console .brand span {
  color: #64748b;
}

.admin-console .side-nav {
  gap: 3px;
  padding: 2px 0 10px;
}

.admin-console .side-nav details {
  padding: 3px 0;
}

.admin-console .side-nav summary,
.admin-console .side-nav a,
.admin-console .ghost {
  min-height: 34px;
  padding: 0 10px;
  border-radius: 9px;
  color: #475569;
  font-size: 13px;
  font-weight: 650;
}

.admin-console .side-nav summary {
  color: #0f172a;
  font-size: 12px;
  letter-spacing: 0.02em;
}

.admin-console .side-nav summary::after {
  color: #94a3b8;
  font-size: 16px;
}

.admin-console .side-nav a {
  gap: 9px;
  position: relative;
}

.admin-console .side-nav a span {
  width: 22px;
  height: 22px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: #f1f5f9;
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.admin-console .side-nav details a {
  margin-left: 0;
  width: 100%;
}

.admin-console .side-nav a.sub-link {
  min-height: 28px;
  margin-left: 22px;
  width: calc(100% - 22px);
  color: #64748b;
  font-size: 12px;
}

.admin-console .side-nav a.module-root {
  margin-top: 4px;
}

.admin-console .side-nav a.sub-link span {
  width: 20px;
  height: 20px;
  background: #fff;
}

.admin-console .side-nav a:hover,
.admin-console .side-nav summary:hover,
.admin-console .ghost:hover {
  background: #fff7ed;
  color: #ea580c;
}

.admin-console .side-nav a:hover span,
.admin-console .side-nav a.active span {
  background: #ffedd5;
  color: #f97316;
}

.admin-console .side-nav a.active {
  background: linear-gradient(90deg, #fff7ed, #f5f3ff);
  color: #5b21f6;
  box-shadow: inset 3px 0 0 #ff6500;
}

.admin-console .admin-upgrade {
  margin-top: auto;
  padding: 12px;
  border-color: #fed7aa;
  background: linear-gradient(135deg, #fff7ed, #ffffff 52%, #f5f3ff);
  text-align: left;
}

.admin-console .admin-upgrade strong {
  display: block;
  color: #0f172a;
  font-size: 14px;
}

.admin-console .admin-upgrade p {
  margin: 6px 0 10px;
  line-height: 1.42;
}

.admin-console .admin-upgrade .button {
  width: 100%;
  background: linear-gradient(135deg, #ff6500, #5b21f6);
  box-shadow: 0 10px 22px rgba(91, 33, 246, 0.18);
}

.admin-console .sidebar-footer {
  margin-top: 12px;
}

.admin-console .ghost {
  border: 1px solid #e2e8f0;
  background: #fff;
  color: #475569;
  justify-content: center;
}

.admin-console:not(.module-admin-console) .brand strong {
  color: #f8fafc;
}

.admin-console:not(.module-admin-console) .brand span {
  color: #9fb1c7;
}

.admin-console:not(.module-admin-console) .side-nav summary,
.admin-console:not(.module-admin-console) .side-nav a,
.admin-console:not(.module-admin-console) .ghost {
  color: #cbd5e1;
}

.admin-console:not(.module-admin-console) .side-nav summary {
  color: #f8fafc;
}

.admin-console:not(.module-admin-console) .side-nav a span {
  background: rgba(148, 163, 184, 0.13);
  color: #cbd5e1;
}

.admin-console:not(.module-admin-console) .side-nav a.sub-link {
  color: #aebdd0;
}

.admin-console:not(.module-admin-console) .side-nav a:hover,
.admin-console:not(.module-admin-console) .side-nav summary:hover,
.admin-console:not(.module-admin-console) .ghost:hover {
  background: rgba(255, 101, 0, 0.13);
  color: #fff;
}

.admin-console:not(.module-admin-console) .side-nav a.active {
  background: linear-gradient(90deg, rgba(255, 101, 0, 0.24), rgba(59, 130, 246, 0.08));
  color: #fff;
  box-shadow: inset 3px 0 0 #ff6500;
}

.admin-console:not(.module-admin-console) .side-nav a:hover span,
.admin-console:not(.module-admin-console) .side-nav a.active span {
  background: #ffedd5;
  color: #ea580c;
}

.admin-console:not(.module-admin-console) .ghost {
  border-color: rgba(148, 163, 184, 0.2);
  background: rgba(15, 23, 42, 0.62);
  color: #e2e8f0;
}

.admin-console .main {
  margin-left: 236px;
  min-height: 100vh;
  padding: 0 22px 22px;
}

.admin-console .topbar {
  height: 66px;
  margin: 0 -22px 18px;
  padding: 0 22px;
  background: rgba(255, 255, 255, 0.92);
  border-bottom: 1px solid #e8edf5;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.03);
}

.admin-console .topbar .icon-btn {
  border-radius: 10px;
  color: #475569;
  background: #fff;
  font-size: 14px;
  font-weight: 800;
}

.admin-console .menu-toggle {
  display: grid;
  gap: 4px;
  place-content: center;
}

.admin-console .menu-toggle span {
  width: 14px;
  height: 2px;
  border-radius: 999px;
  background: #64748b;
}

.admin-console .admin-search {
  max-width: 500px;
  min-height: 38px;
  background: #f8fafc;
  border-color: #eef2f7;
}

.admin-console .admin-search span {
  width: 24px;
  height: 24px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: #eef2ff;
  color: #5b21f6;
  font-size: 11px;
  font-weight: 800;
}

.admin-console .topbar h1 {
  color: #0f172a;
  font-size: 20px;
  letter-spacing: -0.02em;
}

.admin-console .topbar p {
  color: #64748b;
  font-weight: 650;
}

.admin-console .topbar .button.light {
  min-height: 38px;
  border-color: #e2e8f0;
  border-radius: 10px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.admin-console .admin-pill {
  margin-left: auto;
  padding: 5px 9px 5px 5px;
  border-color: #e2e8f0;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.05);
}

.admin-console .admin-pill > span {
  background: linear-gradient(135deg, #fff7ed, #ffedd5);
  color: #ea580c;
  font-weight: 900;
}

.module-admin-console {
  background: linear-gradient(180deg, #f8fafc 0%, #f3f6fb 100%);
}

.module-admin-console .sidebar {
  width: 232px;
  padding: 14px 12px;
  background:
    radial-gradient(circle at 20% 0%, rgba(249, 115, 22, 0.18), transparent 30%),
    linear-gradient(180deg, #071422 0%, #0b1b2d 58%, #07131f 100%);
  border-right: 1px solid rgba(148, 163, 184, 0.18);
  box-shadow: 8px 0 22px rgba(15, 23, 42, 0.12);
}

.module-admin-console .brand {
  padding: 4px 7px 14px;
  margin-bottom: 6px;
  border-bottom: 1px solid rgba(148, 163, 184, 0.16);
}

.module-admin-console .brand-mark {
  background: linear-gradient(135deg, #ff6500, #0ea5e9);
}

.module-admin-console .brand strong {
  color: #fff;
}

.module-admin-console .brand span {
  color: #93a4bb;
}

.module-side-nav {
  gap: 3px;
  padding-top: 0;
}

.module-nav-label {
  margin: 2px 2px 8px;
  padding: 7px 9px;
  border: 1px solid rgba(148, 163, 184, 0.16);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.07);
  color: #e2e8f0;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0;
  text-transform: uppercase;
}

.module-side-nav details {
  margin-top: 8px;
}

.module-side-nav summary {
  min-height: 24px !important;
  padding: 0 6px !important;
  color: #8ea3bb !important;
  font-size: 10px !important;
  font-weight: 600 !important;
  text-transform: uppercase;
}

.module-side-nav summary::after {
  display: none;
}

.module-side-nav a {
  min-height: 31px !important;
  border-radius: 6px !important;
  color: #dbeafe !important;
  font-size: 12px !important;
  font-weight: 500 !important;
}

.module-side-nav a span {
  width: 21px !important;
  height: 21px !important;
  border-radius: 6px !important;
  background: rgba(219, 234, 254, 0.1) !important;
  color: #bfdbfe !important;
}

.module-side-nav a:hover,
.module-side-nav a.active {
  background: linear-gradient(90deg, #ff6500, #f97316) !important;
  color: #fff !important;
  box-shadow: 0 8px 18px rgba(249, 115, 22, 0.18) !important;
}

.module-side-nav a:hover span,
.module-side-nav a.active span {
  background: rgba(255, 255, 255, 0.16) !important;
  color: #fff !important;
}

.module-side-nav .admin-back-link {
  margin-top: 10px;
  border: 1px solid rgba(148, 163, 184, 0.22);
  background: rgba(255, 255, 255, 0.08) !important;
  color: #e2e8f0 !important;
}

.module-support-card {
  margin-top: auto;
  padding: 10px;
  border: 1px solid rgba(148, 163, 184, 0.18);
  border-radius: 6px;
  background: rgba(255, 255, 255, 0.08);
}

.module-support-card strong,
.module-support-card p {
  margin: 0;
  display: block;
}

.module-support-card p {
  margin-top: 4px;
  color: #94a3b8;
  font-size: 12px;
}

.module-admin-console .main {
  margin-left: 232px;
  padding: 0 22px 24px;
}

.module-admin-console .topbar {
  height: 58px;
  margin: 0 -22px 14px;
  padding: 0 22px;
  border-bottom: 1px solid #e5edf7;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.98), rgba(248, 251, 255, 0.98)),
    radial-gradient(circle at 80% 0%, rgba(249, 115, 22, 0.08), transparent 28%);
  box-shadow: 0 6px 20px rgba(15, 23, 42, 0.04);
}

.module-admin-console .admin-search {
  max-width: 500px;
  height: 34px;
  background: #fff;
  border-color: #dfe7f2;
  border-radius: 5px;
  box-shadow: 0 1px 0 rgba(15, 23, 42, 0.03);
}

.module-admin-console .admin-search span {
  width: 20px;
  height: 20px;
  color: #2563eb;
  background: #eff6ff;
  border-radius: 5px;
  font-size: 0;
  font-weight: 500;
}

.module-admin-console .admin-search span::before {
  content: "Q";
  font-size: 10px;
  font-weight: 500;
}

.module-admin-console .admin-search input {
  color: #334155;
  font-size: 12px;
  font-weight: 400;
}

.module-admin-console .topbar .button.light {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 5px;
  border-color: #dbe5f1;
  background: #fff;
  color: #0f172a;
  font-size: 12px;
  font-weight: 500;
}

.topbar-title-block {
  min-width: 170px;
  padding-left: 2px;
}

.module-admin-console .topbar-title-block p,
.module-admin-console .topbar-title-block h1 {
  margin: 0;
}

.module-admin-console .topbar-title-block p {
  color: #64748b;
  font-size: 10px;
  font-weight: 500;
}

.module-admin-console .topbar-title-block h1 {
  margin-top: 1px;
  color: #0f172a;
  font-size: 18px;
  font-weight: 600;
  letter-spacing: -0.03em;
}

.module-admin-console .admin-pill {
  min-height: 36px;
  padding: 4px 9px 4px 4px;
  border-radius: 999px;
  border-color: #dfe7f2;
  background: #fff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.055);
}

.module-admin-console .admin-pill > span {
  width: 28px;
  height: 28px;
  font-size: 11px;
  font-weight: 600;
}

.module-admin-console .admin-pill strong {
  color: #0f172a;
  font-size: 12px;
  font-weight: 600;
}

.module-admin-console .admin-pill small {
  color: #64748b;
  font-size: 9px;
  font-weight: 400;
}

.admin-listing-hero,
.module-dashboard-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
  padding: 16px;
  border: 1px solid #e5e7eb;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.admin-listing-hero .eyebrow,
.module-dashboard-head .eyebrow {
  display: inline-flex;
  margin-bottom: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  background: #f8fafc;
  color: #475569;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-listing-hero h2,
.admin-listing-hero p,
.module-dashboard-head h2,
.module-dashboard-head p {
  margin: 0;
}

.admin-listing-hero h2,
.module-dashboard-head h2 {
  font-size: 22px;
}

.admin-listing-hero p,
.module-dashboard-head p {
  margin-top: 4px;
  color: #64748b;
  font-size: 13px;
}

.admin-kpi-row {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.admin-kpi-row article {
  min-height: 82px;
  padding: 12px;
  border: 1px solid #e5e7eb;
  border-radius: 11px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.admin-kpi-row small,
.admin-kpi-row span {
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
}

.admin-kpi-row strong {
  display: block;
  margin: 4px 0;
  color: #0f172a;
  font-size: 22px;
}

.admin-listing-panel {
  overflow: hidden;
}

.listing-filter-bar {
  display: grid;
  grid-template-columns: 1.4fr 1fr 0.9fr auto auto;
  gap: 10px;
  align-items: end;
  padding: 12px;
  border-bottom: 1px solid #e5e7eb;
  background: #f9fafb;
}

.listing-filter-bar label {
  margin: 0;
  color: #475569;
  font-size: 11px;
  font-weight: 900;
}

.listing-filter-bar input,
.listing-filter-bar select {
  margin-top: 5px;
  min-height: 36px;
  background: #fff;
}

.listing-admin-table th {
  background: #fff;
  color: #64748b;
  font-size: 11px;
}

.listing-admin-table td {
  padding: 9px 12px;
}

.listing-admin-table tbody tr:hover {
  background: #fafafa;
}

.module-admin-console .admin-listing-hero,
.module-admin-console .module-dashboard-head {
  margin-bottom: 16px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.module-admin-console .admin-listing-hero .eyebrow,
.module-admin-console .module-dashboard-head .eyebrow {
  display: none;
}

.module-admin-console .admin-listing-hero h2,
.module-admin-console .module-dashboard-head h2 {
  font-size: 24px;
}

.module-admin-console .admin-kpi-row {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}

.module-admin-console .admin-kpi-row article {
  min-height: 98px;
  display: grid;
  align-content: center;
  padding: 18px;
  border-radius: 10px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

.module-admin-console .admin-kpi-row article:nth-child(6) {
  display: none;
}

.module-admin-console .admin-kpi-row strong {
  font-size: 24px;
}

.module-admin-console .admin-listing-panel {
  border-radius: 10px;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

.module-admin-console .listing-filter-bar {
  grid-template-columns: 1.5fr 1fr 1fr auto auto;
  padding: 14px 16px;
  background: #fff;
}

.module-admin-console .listing-filter-bar input,
.module-admin-console .listing-filter-bar select {
  min-height: 38px;
  border-radius: 8px;
}

.module-admin-console .listing-admin-table th {
  height: 44px;
  background: #f9fafb;
  color: #475569;
}

.module-admin-console .listing-admin-table td {
  height: 72px;
  padding: 11px 14px;
}

.module-admin-console .listing-admin-table .entity-img,
.module-admin-console .listing-admin-table .entity-icon {
  width: 68px;
  height: 48px;
  border-radius: 8px;
}

.module-admin-console .listing-admin-table .entity {
  gap: 12px;
}

.module-admin-console .listing-admin-table .row-actions .small-btn {
  min-width: 32px;
  min-height: 32px;
  padding: 0 10px;
  border-radius: 8px;
}

.status-approved {
  background: #dcfce7;
  color: #15803d;
}

.status-pending,
.status-draft {
  background: #ffedd5;
  color: #c2410c;
}

.status-rejected,
.status-expired {
  background: #fee2e2;
  color: #b91c1c;
}

.empty-row {
  padding: 22px;
  color: #64748b;
  text-align: center;
}

.module-dashboard-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 14px;
}

.module-report-side {
  display: grid;
  gap: 14px;
  align-content: start;
}

.module-mini-list {
  display: grid;
  gap: 8px;
}

.module-mini-list a {
  display: grid;
  grid-template-columns: 34px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 9px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
}

.module-mini-list a:hover {
  background: #f9fafb;
}

.module-mini-list span {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: #f8fafc;
  color: #0f172a;
  font-weight: 900;
}

.property-dashboard-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 10px;
  padding: 10px 0 4px;
  border-bottom: 1px solid #e8edf5;
}

.property-dashboard-title h2,
.property-dashboard-title p,
.property-card h3 {
  margin: 0;
}

.property-dashboard-title h2 {
  font-size: 22px;
  letter-spacing: -0.03em;
}

.property-dashboard-title p {
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
}

.dashboard-eyebrow {
  display: inline-flex;
  margin-bottom: 4px;
  padding: 3px 7px;
  border: 1px solid #dbe5f1;
  border-radius: 4px;
  background: #f8fafc;
  color: #475569;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.property-dashboard-title select,
.property-card select {
  min-height: 30px;
  padding: 0 9px;
  border: 1px solid #e2e8f0;
  border-radius: 4px;
  background: #fff;
  color: #0f172a;
  font-size: 12px;
  font-weight: 750;
}

.dashboard-seed-actions {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.dashboard-seed-actions form,
.button-row form {
  margin: 0;
}

.admin-inline-notice {
  display: flex;
  align-items: center;
  min-height: 34px;
  margin: -4px 0 10px;
  padding: 8px 12px;
  border: 1px solid #bbf7d0;
  border-radius: 6px;
  background: #f0fdf4;
  color: #166534;
  font-size: 12px;
}

.course-cat-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
  padding: 16px 18px;
  border: 1px solid #dce6f2;
  border-radius: 2px;
  background:
    linear-gradient(135deg, rgba(255, 101, 0, 0.1), rgba(37, 99, 235, 0.06)),
    #fff;
  box-shadow: 0 18px 44px rgba(15, 23, 42, 0.06);
}

.course-cat-hero span {
  display: inline-flex;
  margin-bottom: 5px;
  padding: 3px 8px;
  border: 1px solid #fed7aa;
  background: #fff7ed;
  color: #c2410c;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.course-cat-hero h2,
.course-cat-hero p,
.course-cat-panel h3,
.course-cat-panel p {
  margin: 0;
}

.course-cat-hero h2 {
  font-size: 24px;
  letter-spacing: -0.03em;
}

.course-cat-hero p {
  max-width: 640px;
  margin-top: 4px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.45;
}

.course-cat-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.course-cat-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}

.course-cat-stats article {
  display: grid;
  grid-template-columns: 34px 1fr;
  align-items: center;
  column-gap: 9px;
  min-height: 68px;
  padding: 10px;
  border: 1px solid #dfe7f2;
  border-radius: 2px;
  background: #fff;
}

.course-cat-stats span {
  grid-row: span 2;
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  background: #fff3e8;
  color: var(--primary);
  font-weight: 800;
}

.course-cat-stats small {
  color: #64748b;
  font-size: 11px;
}

.course-cat-stats strong {
  font-size: 22px;
  line-height: 1;
}

.course-cat-shell {
  display: grid;
  grid-template-columns: 0.85fr 1.35fr;
  gap: 10px;
  align-items: start;
}

.course-cat-panel {
  border: 1px solid #dfe7f2;
  border-radius: 2px;
  background: #fff;
  box-shadow: 0 18px 42px rgba(15, 23, 42, 0.05);
}

.course-cat-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px;
  border-bottom: 1px solid #edf2f7;
}

.course-cat-panel-head h3 {
  font-size: 16px;
}

.course-cat-panel-head p {
  margin-top: 2px;
  color: #64748b;
  font-size: 11px;
}

.course-cat-grid {
  display: grid;
  gap: 8px;
  padding: 10px;
  max-height: 620px;
  overflow: auto;
}

.course-main-card {
  display: grid;
  grid-template-columns: 46px 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 9px;
  border: 1px solid #e2e8f0;
  border-radius: 2px;
  background: linear-gradient(135deg, #fff, #f8fafc);
}

.course-media,
.course-mini-media {
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid #e5edf6;
  background: #fff7ed;
  color: var(--primary);
}

.course-media {
  width: 46px;
  height: 46px;
}

.course-mini-media {
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
}

.course-media img,
.course-mini-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.course-media span,
.course-mini-media span {
  font-weight: 800;
}

.course-main-card strong,
.course-table-title strong {
  display: block;
  font-size: 13px;
}

.course-main-card small,
.course-table-title small {
  color: #64748b;
  font-size: 11px;
}

.course-main-card em {
  padding: 4px 7px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
  font-style: normal;
}

.course-card-actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  padding-top: 6px;
  border-top: 1px solid #edf2f7;
}

.course-card-actions form,
.course-cat-table form {
  margin: 0;
}

.course-filter-row {
  display: grid;
  grid-template-columns: minmax(180px, 1fr) 150px 130px auto;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid #edf2f7;
}

.course-filter-row input,
.course-filter-row select {
  min-height: 34px;
  border: 1px solid #dfe7f2;
  border-radius: 2px;
  padding: 0 10px;
  background: #fff;
}

.course-table-wrap {
  overflow: auto;
}

.course-cat-table th,
.course-cat-table td {
  padding: 9px 10px;
}

.course-table-title {
  display: flex;
  align-items: center;
  gap: 9px;
}

.course-icon-chip {
  display: inline-flex;
  padding: 4px 8px;
  border: 1px solid #dbeafe;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
}

.mini-switch {
  gap: 0;
}

.mini-switch span {
  width: 34px;
  height: 18px;
}

.mini-switch span::after {
  width: 14px;
  height: 14px;
}

.mini-switch input:checked + span::after {
  transform: translateX(16px);
}

.course-modal-card {
  width: min(620px, calc(100vw - 28px));
}

.course-manage-hero,
.course-list-card,
.course-manage-kpis article {
  border: 1px solid #dfe7f2;
  border-radius: 2px;
  background: #fff;
}

.course-manage-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 10px;
  padding: 14px 16px;
  background: linear-gradient(135deg, #fff7ed, #fff 55%, #eff6ff);
}

.course-manage-hero span {
  display: inline-flex;
  margin-bottom: 5px;
  padding: 3px 8px;
  border: 1px solid #fed7aa;
  background: #fff;
  color: var(--primary);
  font-size: 10px;
  text-transform: uppercase;
}

.course-manage-hero h2,
.course-manage-hero p,
.course-list-head h3,
.course-list-head p {
  margin: 0;
}

.course-manage-hero h2 {
  font-size: 23px;
  letter-spacing: -0.03em;
}

.course-manage-hero p,
.course-list-head p {
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
}

.course-manage-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}

.course-manage-kpis article {
  min-height: 76px;
  padding: 11px 12px;
}

.course-manage-kpis small,
.course-manage-kpis span {
  display: block;
  color: #64748b;
  font-size: 11px;
}

.course-manage-kpis strong {
  display: block;
  margin: 5px 0 2px;
  font-size: 24px;
  line-height: 1;
}

.course-list-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px;
  border-bottom: 1px solid #edf2f7;
}

.course-list-tools {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 130px;
  gap: 8px;
  min-width: 390px;
}

.course-list-tools input,
.course-list-tools select,
.course-form-grid input,
.course-form-grid select,
.course-form-grid textarea {
  width: 100%;
  min-height: 28px;
  border: 1px solid #dfe7f2;
  border-radius: 3px;
  padding: 0 8px;
  background: #fff;
  color: #111827;
  font-size: 12px;
}

.course-form-grid textarea {
  min-height: 40px;
  padding: 7px 8px;
}

.course-language-select {
  min-height: 62px !important;
  padding: 5px !important;
}

.course-language-select option {
  padding: 5px 7px;
  border-radius: 4px;
}

.course-field-hint {
  display: none;
}

.course-manage-table th,
.course-manage-table td {
  padding: 9px 10px;
}

.course-row-title {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 230px;
}

.course-row-title img,
.course-row-title > span {
  width: 48px;
  height: 38px;
  flex: 0 0 auto;
  border: 1px solid #e5edf6;
  border-radius: 4px;
  object-fit: cover;
  background: #fff7ed;
}

.course-row-title > span {
  display: grid;
  place-items: center;
  color: var(--primary);
  font-weight: 800;
}

.course-row-title strong,
.course-price {
  display: block;
  font-size: 13px;
}

.course-row-title small,
.course-manage-table small {
  color: #64748b;
  font-size: 11px;
}

.course-soft-chip {
  display: inline-flex;
  padding: 4px 8px;
  border: 1px solid #dbeafe;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
}

.course-form-modal {
  align-items: center;
  overflow: hidden;
  padding: 12px;
}

.course-form-card {
  width: 960px;
  max-width: calc(100vw - 32px);
  max-height: calc(100vh - 28px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  padding: 10px;
  border-radius: 8px;
}

.course-form-grid {
  flex: 1 1 auto;
  min-height: 0;
  max-height: calc(100vh - 108px);
  display: grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap: 6px;
  padding: 8px;
  overflow-x: hidden;
  overflow-y: auto;
  scrollbar-width: none;
}

.course-form-grid::-webkit-scrollbar {
  display: none;
}

.course-form-grid label,
.course-toggle-field {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 3px;
  color: #374151;
  font-size: 11px;
}

.course-form-grid .span-2 { grid-column: span 2; }
.course-form-grid .span-3 { grid-column: span 3; }
.course-form-grid .span-4 { grid-column: span 4; }
.course-form-grid .span-6 { grid-column: span 6; }
.course-form-grid .span-full { grid-column: 1 / -1; }

.course-toggle-field {
  justify-items: start;
}

.course-current-thumb {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 6px;
  border: 1px solid #e5edf6;
  border-radius: 3px;
  background: #f8fafc;
}

.course-current-thumb img {
  width: 44px;
  height: 30px;
  object-fit: cover;
  border-radius: 3px;
}

.course-current-thumb span {
  color: #64748b;
  font-size: 11px;
}

.course-editor .html-editor-box {
  min-height: 64px;
}

.course-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}

.course-section-head strong {
  display: block;
  font-size: 12px;
}

.course-section-head small {
  display: block;
  margin-top: 2px;
  color: #64748b;
  font-size: 10px;
}

.course-module-builder {
  padding: 8px;
  border: 1px solid #dfe7f2;
  border-radius: 4px;
  background: linear-gradient(135deg, #fff, #f8fafc);
}

.course-modules-list {
  display: grid;
  gap: 6px;
}

.course-module-row {
  display: grid;
  grid-template-columns: minmax(0, 0.8fr) minmax(0, 1fr) minmax(0, 1fr) auto;
  gap: 6px;
  align-items: end;
  padding: 6px;
  border: 1px solid #e6edf6;
  border-radius: 4px;
  background: #fff;
}

.course-module-row textarea {
  min-height: 36px;
}

.course-form-modal .modal-head {
  position: static;
  margin: -10px -10px 8px;
  padding: 10px 12px;
}

.course-form-modal .modal-head h3 {
  font-size: 17px;
}

.course-form-modal .modal-head small {
  margin-top: 2px;
  font-size: 11px;
  font-weight: 500;
}

.course-form-modal .html-editor-toolbar {
  min-height: 30px;
  padding: 4px 6px;
}

.course-form-modal .html-editor-toolbar button {
  min-height: 24px;
  padding: 0 8px;
  font-size: 11px;
}

.course-form-modal .select2-lite-control {
  min-height: 28px;
  gap: 4px;
  padding: 3px 6px;
  border-radius: 3px;
}

.course-form-modal .select2-lite-chips {
  gap: 4px;
}

.course-form-modal .select2-lite-chips span {
  min-height: 20px;
  padding: 0 5px 0 7px;
  font-size: 10px;
  font-weight: 600;
}

.course-form-modal .select2-lite input {
  min-height: 22px;
  font-size: 12px;
}

.course-form-modal .modal-actions {
  position: sticky;
  bottom: 0;
  z-index: 4;
  padding: 8px 0 0;
  margin-top: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.82), #fff 38%);
}

.course-form-modal .modal-actions button {
  min-height: 32px;
  padding: 0 14px;
  border-radius: 4px;
}

@media (max-width: 920px) {
  .course-manage-hero,
  .course-list-head {
    display: grid;
  }

  .course-list-tools {
    min-width: 0;
    grid-template-columns: 1fr;
  }

  .course-manage-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .course-manage-table {
    min-width: 900px;
  }

  .course-form-grid .span-2,
  .course-form-grid .span-3,
  .course-form-grid .span-4,
  .course-form-grid .span-6 {
    grid-column: span 6;
  }

  .course-module-row {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 620px) {
  .course-form-grid {
    grid-template-columns: 1fr;
  }

  .course-form-grid .span-2,
  .course-form-grid .span-3,
  .course-form-grid .span-4,
  .course-form-grid .span-6,
  .course-form-grid .span-full {
    grid-column: 1 / -1;
  }

  .course-manage-kpis {
    grid-template-columns: 1fr 1fr;
  }

.course-module-row {
  grid-template-columns: 1fr;
  }
}

.store-admin-hero,
.store-category-card {
  margin: 14px 28px;
  border: 1px solid #dbe4ef;
  border-radius: 6px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

.store-admin-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(135deg, #fff, #fff8f1);
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.045);
}

.store-admin-hero.compact {
  margin-bottom: 10px;
}

.store-admin-hero span {
  display: inline-flex;
  padding: 3px 7px;
  border-radius: 999px;
  background: #fff3e8;
  color: var(--primary-dark);
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.store-admin-hero h2 {
  margin: 4px 0 2px;
  font-size: 21px;
}

.store-admin-hero p {
  margin: 0;
  color: #64748b;
  font-size: 12px;
}

.store-admin-hero .button-row form {
  margin: 0;
}

.store-admin-hero .button-row {
  gap: 7px;
}

.store-admin-hero .button-row .button,
.store-admin-hero .button-row button {
  min-height: 34px;
  border-radius: 8px;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 900;
}

.store-category-card {
  overflow: hidden;
}

.store-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid #e5edf6;
}

.store-card-head h3 {
  margin: 0;
  font-size: 18px;
}

.store-card-head small {
  color: #64748b;
}

.store-table-wrap {
  overflow-x: auto;
}

.store-table th,
.store-table td {
  padding: 10px 12px;
  vertical-align: middle;
}

.store-category-title {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 220px;
}

.store-category-title > span,
.store-brand-logo {
  width: 44px;
  height: 40px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid #e5edf6;
  border-radius: 5px;
  background: #fff7ed;
  color: var(--primary-dark);
  font-weight: 800;
}

.store-category-title img,
.store-brand-logo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.store-category-title strong,
.store-table strong {
  display: block;
  font-size: 14px;
}

.store-category-title small,
.store-table small {
  display: block;
  margin-top: 2px;
  color: #64748b;
  font-size: 11px;
}

.store-type-chip {
  display: inline-flex;
  min-height: 24px;
  align-items: center;
  padding: 0 9px;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 800;
}

.store-type-chip.service {
  border-color: #dcfce7;
  background: #f0fdf4;
  color: #15803d;
}

.store-type-chip.neutral {
  border-color: #e5e7eb;
  background: #f8fafc;
  color: #475569;
}

.store-row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.store-row-actions .button,
.store-row-actions button {
  min-height: 30px;
  border-radius: 5px;
  padding: 0 10px;
  font-size: 12px;
}

.store-modal .modal-card {
  width: min(760px, calc(100vw - 32px));
  border-radius: 8px;
}

.store-modal-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.store-modal-form label {
  display: grid;
  gap: 5px;
  color: #374151;
  font-size: 12px;
}

.store-modal-form .check-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: flex-start;
  gap: 9px;
  min-height: 38px;
  padding: 9px 11px;
  border: 1px solid #dfe7f2;
  border-radius: 5px;
  background: #f8fafc;
  color: #111827;
  font-size: 13px;
  font-weight: 700;
}

.store-modal-form .check-row input[type="checkbox"] {
  width: 18px;
  height: 18px;
  min-height: 18px;
  flex: 0 0 auto;
  margin: 0;
  padding: 0;
  accent-color: var(--primary);
}

.store-modal-form input,
.store-modal-form select,
.store-modal-form textarea {
  width: 100%;
  min-height: 34px;
  border: 1px solid #dfe7f2;
  border-radius: 5px;
  padding: 0 10px;
}

.store-modal-form textarea {
  padding: 8px 10px;
}

.store-field-builder {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.store-field-builder > label {
  grid-column: span 2;
}

.store-option-builder {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid #dfe7f2;
  border-radius: 6px;
  background: linear-gradient(135deg, #fff, #f8fafc);
}

.store-option-builder-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

.store-option-builder-head strong {
  font-size: 13px;
}

.store-option-builder-head small {
  color: #64748b;
  font-size: 11px;
}

.store-option-add {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
}

.store-option-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 24px;
}

.store-option-chips span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 0 6px 0 9px;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  background: #fff7ed;
  color: #9a3412;
  font-size: 11px;
  font-weight: 800;
}

.store-option-chips b {
  font: inherit;
}

.store-option-chips button {
  width: 17px;
  min-height: 17px;
  padding: 0;
  border-radius: 50%;
  background: #ffedd5;
  color: #9a3412;
  line-height: 1;
}

.store-full {
  grid-column: 1 / -1;
}

.store-filter-row {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: 8px;
  padding: 12px;
  border-bottom: 1px solid #e5edf6;
}

.store-filter-row input {
  min-height: 36px;
  border: 1px solid #dfe7f2;
  border-radius: 5px;
  padding: 0 12px;
}

.store-kpi-row {
  grid-template-columns: repeat(7, minmax(0, 1fr));
  gap: 8px;
  margin-top: 9px;
  margin-bottom: 10px;
}

.module-admin-console .store-kpi-row article:nth-child(6) {
  display: grid;
}

.store-kpi-row article {
  min-height: 68px;
  align-content: center;
  padding: 10px 11px;
  border: 0;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff, #fbfdff);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.04);
}

.store-kpi-row small,
.store-kpi-row span {
  font-size: 10px;
  font-weight: 850;
}

.store-kpi-row strong {
  margin: 2px 0;
  color: #111827;
  font-size: 20px;
}

.store-listing-shell {
  margin-top: 10px;
  border: 0;
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.045);
}

.store-listing-filter {
  display: grid;
  grid-template-columns: minmax(180px, 1.25fr) repeat(5, minmax(112px, 0.75fr)) auto auto;
  gap: 7px;
  padding: 10px;
  border-bottom: 1px solid #edf2f7;
  background: linear-gradient(180deg, #fff, #fbfdff);
}

.store-listing-filter label {
  display: grid;
  gap: 4px;
  color: #42526b;
  font-size: 10px;
  font-weight: 900;
}

.store-listing-filter input,
.store-listing-filter select {
  min-height: 34px;
  border: 1px solid #d8e2ef;
  border-radius: 8px;
  padding: 0 10px;
  background: linear-gradient(180deg, #fff, #fbfdff);
  color: #0f172a;
  font-size: 12px;
  box-shadow: inset 0 1px 1px rgba(15, 23, 42, 0.025);
}

.store-listing-filter input:focus,
.store-listing-filter select:focus {
  border-color: #ff9b4d;
  box-shadow: 0 0 0 3px rgba(255, 101, 0, 0.1);
  outline: 0;
}

.store-listing-filter button,
.store-listing-filter .button {
  align-self: end;
  min-height: 34px;
  border-radius: 8px;
  padding: 0 12px;
  font-size: 12px;
  font-weight: 900;
}

.store-listing-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
}

.store-listing-table-wrap {
  overflow-x: auto;
  padding: 8px 10px 10px;
  background: #f6f8fb;
}

.store-listing-table {
  width: 100%;
  min-width: 1120px;
  border-collapse: separate;
  border-spacing: 0 5px;
}

.store-listing-table th {
  padding: 3px 9px;
  color: #718096;
  font-size: 10px;
  font-weight: 900;
  text-align: left;
  text-transform: uppercase;
  letter-spacing: 0;
}

.store-listing-table td {
  padding: 7px 9px;
  border-top: 1px solid #e3ebf5;
  border-bottom: 1px solid #e3ebf5;
  background: #fff;
  vertical-align: middle;
}

.store-listing-table td:first-child {
  border-left: 1px solid #e3ebf5;
  border-radius: 9px 0 0 9px;
}

.store-listing-table td:last-child {
  border-right: 1px solid #e3ebf5;
  border-radius: 0 9px 9px 0;
}

.store-listing-table tbody tr:hover td {
  border-color: #cfdbe9;
  background: #fffdfb;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.035);
}

.store-listing-table tr.is-unavailable td {
  background: #fffafa;
}

.store-listing-table strong {
  display: block;
  color: #0f172a;
  font-size: 12px;
  line-height: 1.2;
}

.store-listing-table small {
  display: block;
  margin-top: 2px;
  color: #64748b;
  font-size: 10px;
}

.store-table-product {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 220px;
  color: inherit;
  text-decoration: none;
}

.store-table-product > span {
  width: 48px;
  height: 40px;
  flex: 0 0 48px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border: 1px solid #e2eaf4;
  border-radius: 8px;
  background: #f6f8fb;
  color: #2563eb;
  font-size: 12px;
  font-weight: 900;
}

.store-table-product img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.store-table-product em {
  font-style: normal;
}

.store-table-price strong {
  color: #ff5a00;
  font-size: 13px;
}

.store-spec-chips.compact {
  max-width: 220px;
  gap: 3px;
}

.store-spec-chips.compact span {
  min-height: 18px;
  padding: 2px 6px;
  border: 1px solid #edf2f7;
  border-radius: 999px;
  background: #f8fafc;
  color: #475569;
  font-size: 9px;
  font-weight: 900;
}

.store-status-pill,
.store-availability-pill {
  display: inline-flex;
  width: max-content;
  margin: 0 3px 3px 0;
  padding: 3px 7px;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 10px;
  font-weight: 900;
}

.store-status-pill.approved {
  background: #ecfdf5;
  color: #059669;
}

.store-status-pill.pending,
.store-status-pill.draft {
  background: #fff7ed;
  color: #ea580c;
}

.store-status-pill.rejected,
.store-status-pill.expired {
  background: #fff1f2;
  color: #e11d48;
}

.store-availability-pill.available {
  background: #ecfdf5;
  color: #059669;
}

.store-availability-pill.unavailable {
  background: #fff1f2;
  color: #e11d48;
}

.store-table-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  min-width: 220px;
}

.store-table-actions form {
  margin: 0;
}

.store-table-actions .button.small,
.store-table-actions button.small {
  min-height: 27px;
  padding: 0 8px;
  border-radius: 7px;
  font-size: 10px;
  font-weight: 900;
}

.banner-admin-grid {
  display: grid;
  grid-template-columns: 360px minmax(0, 1fr);
  gap: 14px;
  margin: 14px 28px;
}

.banner-admin-form,
.banner-admin-list {
  overflow: hidden;
  border: 1px solid #dbe4ef;
  border-radius: 6px;
  background: #fff;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.06);
}

.banner-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  padding: 12px;
}

.banner-form-grid label {
  display: grid;
  gap: 5px;
  color: #475569;
  font-size: 11px;
  font-weight: 800;
}

.banner-form-grid input,
.banner-form-grid select {
  min-height: 36px;
  border: 1px solid #dbe4ef;
  border-radius: 5px;
  padding: 0 10px;
}

.banner-form-grid .span-2 {
  grid-column: 1 / -1;
}

.banner-check {
  align-content: center;
  grid-template-columns: auto 1fr;
}

.banner-admin-table-wrap {
  overflow-x: auto;
  padding: 10px 12px 12px;
}

.banner-admin-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.banner-admin-table th,
.banner-admin-table td {
  padding: 10px;
  border-bottom: 1px solid #e5edf6;
  text-align: left;
  vertical-align: middle;
}

.banner-admin-table th {
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.banner-admin-preview {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 280px;
}

.banner-admin-preview img {
  width: 96px;
  height: 54px;
  border-radius: 6px;
  object-fit: cover;
  background: #eef4fb;
}

.banner-admin-preview strong,
.banner-admin-preview small,
.banner-admin-preview em {
  display: block;
}

.banner-admin-preview small {
  margin-top: 2px;
  color: #64748b;
  font-size: 11px;
}

.banner-admin-preview em {
  width: max-content;
  margin-top: 4px;
  padding: 3px 7px;
  border-radius: 999px;
  background: #fff7ed;
  color: #ff5a00;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
}

@media (max-width: 900px) {
  .banner-admin-grid {
    grid-template-columns: 1fr;
    margin: 10px;
  }
}

.store-listing-card {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  min-height: 154px;
  overflow: hidden;
  border: 1px solid #dbe6f3;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
}

.store-listing-photo {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 154px;
  background: #eef4fb;
  color: #1d4ed8;
  font-weight: 900;
  text-decoration: none;
}

.store-listing-photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.store-listing-photo em {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 4px 7px;
  border-radius: 999px;
  background: #ff5a00;
  color: #fff;
  font-size: 10px;
  font-style: normal;
  font-weight: 900;
}

.store-unavailable-badge {
  position: absolute;
  right: 8px;
  bottom: 8px;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.88);
  color: #fff;
  font-size: 10px;
  font-weight: 900;
}

.store-listing-body {
  display: grid;
  gap: 8px;
  padding: 10px;
}

.store-listing-title-row {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}

.store-listing-title-row small {
  color: #64748b;
  font-size: 10px;
  font-weight: 800;
}

.store-listing-title-row h3 {
  margin: 2px 0 0;
  color: #0f172a;
  font-size: 15px;
  line-height: 1.18;
}

.store-listing-title-row strong {
  flex: 0 0 auto;
  color: #ff5a00;
  font-size: 14px;
  text-align: right;
}

.store-listing-body p {
  margin: 0;
  color: #52637a;
  font-size: 12px;
  line-height: 1.35;
}

.store-spec-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.store-spec-chips span {
  min-height: 22px;
  padding: 4px 7px;
  border: 1px solid #dbeafe;
  border-radius: 999px;
  background: #f8fbff;
  color: #0f172a;
  font-size: 10px;
  font-weight: 800;
}

.store-listing-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: auto;
}

.store-listing-foot > span {
  color: #64748b;
  font-size: 11px;
}

.store-listing-foot > div {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
}

.store-listing-foot form {
  margin: 0;
}

.store-empty-card {
  grid-column: 1 / -1;
}

.store-inline-form-card {
  overflow: hidden;
}

.store-form-page-card {
  border: 0;
  box-shadow: none;
  background: transparent;
}

.store-inline-form-card .store-card-head {
  padding: 6px 0 8px;
  border-bottom: 0;
}

.store-inline-form-card .store-card-head span {
  display: inline-flex;
  width: max-content;
  margin-bottom: 3px;
  padding: 3px 7px;
  border-radius: 999px;
  background: #fff4e8;
  color: #ff5a00;
  font-size: 10px;
  font-weight: 900;
}

.store-inline-form-card .store-card-head h3 {
  margin: 0;
}

.store-inline-form-card .store-card-head p {
  margin: 2px 0 0;
  color: #64748b;
  font-size: 11px;
}

.store-inline-listing-form .store-single-actions {
  position: static;
  box-shadow: none;
}

.store-listing-form {
  display: block;
}

.store-single-form {
  display: grid;
  gap: 5px;
  padding: 0;
  background: transparent;
}

.store-single-head,
.store-single-section,
.store-single-actions {
  border: 0;
  border-radius: 8px;
  background: #fff;
}

.store-single-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff, #fbfdff);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.035);
}

.store-single-head span {
  display: inline-flex;
  margin-bottom: 3px;
  padding: 3px 7px;
  border-radius: 999px;
  background: #fff4e8;
  color: #ff5a00;
  font-size: 10px;
  font-weight: 900;
}

.store-single-head h4 {
  margin: 0;
  color: #0f172a;
  font-size: 14px;
}

.store-single-head p {
  margin: 2px 0 0;
  color: #64748b;
  font-size: 11px;
}

.store-active-switch {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-height: 34px;
  color: #475569;
  font-size: 11px;
  font-weight: 900;
}

.store-publish-controls {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 18px;
  flex-wrap: wrap;
}

.store-single-section {
  padding: 4px 0;
}

.store-single-section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 5px;
}

.store-single-section-title strong {
  color: #0f172a;
  font-size: 14px;
}

.store-single-section-title small {
  color: #64748b;
  font-size: 10px;
  font-weight: 800;
}

.store-single-fields .dynamic-title {
  display: none;
}

.store-single-fields .dynamic-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px 10px;
}

.store-single-fields .category-picker,
.store-single-fields .custom-option-wrapper,
.store-single-fields .store-storage-toggle-group,
.store-single-fields .store-checkbox-group,
.store-single-fields .store-contact-toggle-group,
.store-single-fields .html-editor-field,
.store-single-fields .location-extra-field,
.store-single-fields .area-unit-field {
  grid-column: 1 / -1;
}

.store-single-fields label,
.store-single-fields .check-row {
  min-width: 0;
}

.store-single-fields input,
.store-single-fields select,
.store-single-fields textarea {
  min-height: 36px;
  border: 1px solid #d8e2ef;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #fbfdff);
  color: #0f172a;
  font-size: 12px;
  box-shadow: inset 0 1px 1px rgba(15, 23, 42, 0.025);
}

.store-single-fields input:focus,
.store-single-fields select:focus,
.store-single-fields textarea:focus {
  border-color: #ff9b4d;
  box-shadow: 0 0 0 3px rgba(255, 101, 0, 0.11);
  outline: 0;
}

.store-storage-toggle-group,
.store-checkbox-group,
.store-contact-toggle-group {
  display: grid;
  gap: 5px;
}

.store-storage-toggle-group > label,
.store-checkbox-group > label,
.store-contact-toggle-group > label {
  min-height: auto;
}

.store-storage-toggle-grid,
.store-contact-toggle-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 6px 18px;
}

.store-checkbox-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 6px 18px;
}

.store-storage-toggle,
.store-contact-toggle {
  display: grid;
  min-width: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.store-storage-switch {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  min-height: 36px;
  color: #334155;
  font-size: 12px;
  font-weight: 900;
}

.store-storage-switch > span:first-child {
  min-width: 86px;
  line-height: 1.2;
}

.store-toggle-inline-control {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: 8px;
  min-width: 0;
}

.store-row-switch {
  flex: 0 0 auto;
  min-height: auto !important;
  padding: 0 !important;
}

.store-inline-check {
  display: flex !important;
  align-items: center;
  gap: 7px !important;
  min-height: 26px;
  color: #334155;
  font-size: 12px !important;
  font-weight: 850 !important;
}

.store-inline-check input,
.store-single-fields .dynamic-check input {
  width: 15px;
  height: 15px;
  min-height: 0;
  margin: 0;
}

.store-inline-check span {
  line-height: 1.2;
}

.store-single-fields .dynamic-check {
  min-height: 36px;
  display: flex !important;
  align-items: center;
  gap: 7px !important;
  padding: 0;
  border: 0;
  background: transparent;
}

.store-storage-toggle input[data-store-storage-value],
.store-contact-toggle input[data-contact-value] {
  width: min(172px, 100%);
  min-height: 34px;
}

.store-upload-drop {
  min-height: 86px;
  margin-bottom: 8px;
  padding: 14px;
  border-color: #d8e2ef;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff, #fbfdff);
}

.store-single-actions {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 6px 0 0;
  position: sticky;
  bottom: 0;
  z-index: 3;
  box-shadow: none;
}

.store-single-actions > div {
  display: flex;
  gap: 8px;
}

.store-single-form .media-url-field {
  gap: 5px;
  font-size: 12px;
}

.store-single-form .media-url-field textarea {
  min-height: 56px;
  border-radius: 8px;
}

.store-single-form .media-extra-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 8px;
}

.store-single-form .featured-upload-field {
  min-height: auto;
}

.store-single-form .featured-upload-field input[type="file"] {
  min-height: 36px;
  padding: 6px 8px;
  border-radius: 8px;
}

.store-single-form .featured-upload-preview {
  min-height: 36px;
  border-color: #d8e2ef;
  border-radius: 8px;
}

@media (max-width: 760px) {
  .store-admin-hero,
  .store-category-card {
    margin: 10px;
  }

  .store-admin-hero,
  .store-card-head {
    display: grid;
  }

  .store-modal-form,
  .store-field-builder,
  .store-filter-row {
    grid-template-columns: 1fr;
  }

  .store-field-builder > label {
    grid-column: 1 / -1;
  }

  .store-table {
    min-width: 760px;
  }
}

@media (max-width: 1180px) {
  .store-listing-filter,
  .store-listing-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .store-listing-filter,
  .store-listing-grid {
    grid-template-columns: 1fr;
  }

  .store-listing-card {
    grid-template-columns: 118px minmax(0, 1fr);
  }

  .store-single-head,
  .store-single-actions {
    align-items: stretch;
    display: grid;
  }

  .store-single-fields .dynamic-grid {
    grid-template-columns: 1fr;
  }

  .store-storage-toggle-grid,
  .store-checkbox-grid,
  .store-contact-toggle-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 920px) {
  .course-cat-hero,
  .course-cat-shell {
    grid-template-columns: 1fr;
  }

  .course-cat-hero {
    display: grid;
  }

  .course-cat-stats {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .course-filter-row {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 560px) {
  .course-cat-hero {
    padding: 12px;
  }

  .course-cat-hero h2 {
    font-size: 20px;
  }

  .course-cat-actions,
  .course-cat-actions button {
    width: 100%;
  }

  .course-cat-stats {
    grid-template-columns: 1fr 1fr;
  }

  .course-filter-row {
    grid-template-columns: 1fr;
  }

  .course-cat-table {
    min-width: 680px;
  }
}

.property-kpi-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
  margin-bottom: 10px;
}

.property-kpi-grid article,
.property-card {
  border: 1px solid #dfe7f2;
  border-radius: 4px;
  background: #fff;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.035);
}

.property-kpi-grid article {
  min-height: 74px;
  display: grid;
  grid-template-columns: 34px 1fr;
  align-content: center;
  column-gap: 9px;
  padding: 10px;
}

.property-kpi-grid small,
.property-kpi-grid strong,
.property-kpi-grid em {
  display: block;
}

.property-kpi-grid small {
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.property-kpi-grid strong {
  margin-top: 3px;
  color: #0f172a;
  font-size: 18px;
  letter-spacing: -0.03em;
}

.property-kpi-grid em {
  margin-top: 4px;
  color: #64748b;
  font-size: 10px;
  font-style: normal;
  font-weight: 800;
}

.kpi-icon {
  grid-row: span 3;
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 4px;
  color: #fff;
  font-size: 11px;
  font-weight: 900;
}

.kpi-icon.blue { background: linear-gradient(135deg, #60a5fa, #2563eb); }
.kpi-icon.green { background: linear-gradient(135deg, #4ade80, #16a34a); }
.kpi-icon.purple { background: linear-gradient(135deg, #a78bfa, #6d28d9); }
.kpi-icon.orange { background: linear-gradient(135deg, #fdba74, #f97316); }
.kpi-icon.pink { background: linear-gradient(135deg, #fb7185, #e11d48); }
.kpi-icon.teal { background: linear-gradient(135deg, #2dd4bf, #0f766e); }

.property-dashboard-charts,
.property-dashboard-main,
.property-dashboard-bottom {
  display: grid;
  gap: 10px;
  margin-bottom: 10px;
}

.property-dashboard-charts {
  grid-template-columns: 1.1fr 1.1fr 1fr;
}

.property-dashboard-main {
  grid-template-columns: minmax(0, 2fr) 360px;
}

.property-dashboard-bottom {
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 1fr) 360px;
}

.property-card {
  padding: 12px;
  overflow: hidden;
}

.property-card-head {
  min-height: 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}

.property-card-head h3 {
  color: #0f172a;
  font-size: 14px;
  letter-spacing: -0.02em;
}

.property-card-head a {
  color: #2563eb;
  font-size: 12px;
  font-weight: 800;
}

.donut-report {
  display: grid;
  grid-template-columns: 126px 1fr;
  align-items: center;
  gap: 14px;
}

.donut-report.compact {
  grid-template-columns: 112px 1fr;
}

.donut-ring {
  position: relative;
  width: 116px;
  height: 116px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: conic-gradient(#2563eb 0 50%, #22c55e 50% 76%, #f59e0b 76% 92%, #8b5cf6 92% 100%);
}

.donut-report.compact .donut-ring {
  width: 102px;
  height: 102px;
}

.donut-ring::before {
  content: "";
  position: absolute;
  inset: 24px;
  border-radius: 50%;
  background: #fff;
  box-shadow: inset 0 0 0 1px #eef2f7;
}

.donut-ring strong,
.donut-ring small {
  position: relative;
  z-index: 1;
  display: block;
  text-align: center;
}

.donut-ring strong {
  max-width: 76px;
  color: #0f172a;
  font-size: 15px;
  line-height: 1.1;
}

.donut-ring small {
  margin-top: 3px;
  color: #64748b;
  font-size: 11px;
}

.donut-legend {
  display: grid;
  gap: 7px;
}

.donut-legend p {
  display: grid;
  grid-template-columns: 10px 1fr auto;
  align-items: center;
  gap: 8px;
  margin: 0;
  color: #334155;
  font-size: 12px;
}

.donut-legend i {
  width: 9px;
  height: 9px;
  border-radius: 3px;
}

.donut-legend .blue { background: #2563eb; }
.donut-legend .green { background: #22c55e; }
.donut-legend .orange { background: #f59e0b; }
.donut-legend .purple { background: #8b5cf6; }

.chart-report h2 {
  margin: 0 0 10px;
  color: #0f172a;
  font-size: 18px;
}

.chart-report h2 span {
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.line-bars {
  height: 112px;
  display: flex;
  align-items: end;
  gap: 12px;
  padding: 12px 12px 0;
  border-radius: 4px;
  background:
    repeating-linear-gradient(to top, transparent 0 31px, #e8edf5 32px),
    linear-gradient(180deg, #fff, #f8fbff);
}

.line-bars span {
  flex: 1;
  min-width: 12px;
  height: var(--h);
  border-radius: 4px 4px 2px 2px;
}

.blue-line span {
  background: linear-gradient(180deg, #2563eb, rgba(37, 99, 235, 0.18));
}

.orange-line span {
  background: linear-gradient(180deg, #f97316, rgba(249, 115, 22, 0.18));
}

.approvals-card {
  padding: 0;
}

.approvals-card .property-card-head {
  padding: 10px 12px 0;
}

.compact-table {
  width: 100%;
  border-collapse: collapse;
}

.compact-table th,
.compact-table td {
  padding: 9px 11px;
  border-top: 1px solid #eef2f7;
  color: #334155;
  font-size: 11px;
  text-align: left;
  vertical-align: middle;
}

.compact-table th {
  color: #64748b;
  background: #fbfdff;
  font-size: 10px;
  font-weight: 900;
}

.compact-table .entity {
  display: flex;
  align-items: center;
  gap: 10px;
}

.compact-table .entity-img,
.compact-table .entity-icon {
  width: 36px;
  height: 30px;
  border-radius: 4px;
  object-fit: cover;
}

.compact-table .entity-icon {
  display: grid;
  place-items: center;
  background: #e0f2fe;
  color: #0369a1;
  font-weight: 900;
}

.compact-table strong {
  display: block;
  color: #0f172a;
  font-size: 11px;
}

.compact-table small {
  display: block;
  margin-top: 2px;
  color: #64748b;
  font-size: 10px;
}

.agent-rank-list {
  display: grid;
  gap: 6px;
}

.agent-rank-list p {
  display: grid;
  grid-template-columns: 16px 30px 1fr auto;
  align-items: center;
  gap: 7px;
  margin: 0;
  padding: 7px;
  border: 1px solid #eef2f7;
  border-radius: 4px;
  background: #fbfdff;
}

.agent-rank-list b {
  color: #64748b;
  font-size: 12px;
}

.agent-rank-list span {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, #e0f2fe, #dbeafe);
  color: #1d4ed8;
  font-weight: 900;
}

.agent-rank-list strong {
  display: block;
  color: #0f172a;
  font-size: 12px;
}

.agent-rank-list em,
.agent-rank-list i {
  color: #64748b;
  font-size: 11px;
  font-style: normal;
}

.agent-rank-list i {
  grid-column: 4;
  color: #f59e0b;
  font-weight: 900;
}

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

.property-action-grid a {
  min-height: 64px;
  display: grid;
  place-items: center;
  gap: 6px;
  padding: 9px 7px;
  border: 1px solid #e8edf5;
  border-radius: 4px;
  background: linear-gradient(135deg, #f8fbff, #fff);
  color: #334155;
  font-size: 12px;
  font-weight: 850;
  text-align: center;
}

.property-action-grid a:hover {
  border-color: #bfdbfe;
  background: #eff6ff;
  color: #1d4ed8;
}

.property-action-grid span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 4px;
  background: #dbeafe;
  color: #2563eb;
  font-weight: 900;
}

.request-page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 12px;
  padding: 14px 16px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background:
    linear-gradient(135deg, #ffffff, #f8fbff 60%, #fff7ed);
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.request-page-head h2,
.request-page-head p {
  margin: 0;
}

.request-page-head h2 {
  color: #0f172a;
  font-size: 22px;
  letter-spacing: -0.03em;
}

.request-page-head p {
  margin-top: 5px;
  color: #64748b;
  font-size: 13px;
  font-weight: 700;
}

.request-eyebrow {
  display: inline-flex;
  margin-bottom: 6px;
  padding: 4px 8px;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.request-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.request-kpi-grid article {
  min-height: 78px;
  display: grid;
  grid-template-columns: 48px 1fr;
  align-content: center;
  column-gap: 12px;
  padding: 12px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: linear-gradient(180deg, #fff, #fbfdff);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.request-kpi-grid small,
.request-kpi-grid strong,
.request-kpi-grid em {
  display: block;
}

.request-kpi-grid small {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.request-kpi-grid strong {
  margin-top: 3px;
  color: #0f172a;
  font-size: 21px;
  letter-spacing: -0.03em;
}

.request-kpi-grid em {
  margin-top: 6px;
  color: #64748b;
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

.request-table-card {
  padding: 0;
  overflow: hidden;
  border-color: #dfe7f2;
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
}

.request-filter-bar {
  display: grid;
  grid-template-columns: minmax(240px, 1.4fr) repeat(4, minmax(140px, 1fr)) auto auto;
  gap: 9px;
  padding: 12px;
  border-bottom: 1px solid #eef2f7;
  background: #fff;
}

.request-filter-bar label {
  display: grid;
  gap: 5px;
  color: #64748b;
  font-size: 0;
  font-weight: 800;
}

.request-filter-bar input,
.request-filter-bar select {
  min-height: 38px;
  border: 1px solid #e2e8f0;
  border-radius: 9px;
  background: #fff;
  color: #0f172a;
  font-size: 12px;
  font-weight: 700;
}

.request-filter-bar button,
.request-filter-bar .button {
  align-self: end;
  min-height: 38px;
}

.request-tabs {
  display: flex;
  gap: 28px;
  padding: 0 16px;
  border-bottom: 1px solid #eef2f7;
  background: #fff;
  overflow-x: auto;
}

.premium-request-table-wrap {
  padding: 10px;
  background: #f8fafc;
}

.premium-request-table {
  min-width: 1180px;
  border-collapse: separate;
  border-spacing: 0 8px;
}

.premium-request-table th {
  height: 34px;
  padding: 0 12px;
  border: 0;
  background: transparent;
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.premium-request-table td {
  height: 62px;
  padding: 9px 12px;
  border-top: 1px solid #e6edf6;
  border-bottom: 1px solid #e6edf6;
  background: #fff;
  vertical-align: middle;
}

.premium-request-table td:first-child {
  border-left: 1px solid #e6edf6;
  border-radius: 10px 0 0 10px;
}

.premium-request-table td:last-child {
  border-right: 1px solid #e6edf6;
  border-radius: 0 10px 10px 0;
}

.premium-request-table tbody tr:hover td {
  border-color: #bfdbfe;
  background: #fbfdff;
  box-shadow: 0 10px 22px rgba(15, 23, 42, 0.04);
}

.request-property-cell {
  min-width: 260px;
  display: flex;
  align-items: center;
  gap: 10px;
}

.request-property-cell img,
.request-property-cell > span {
  width: 54px;
  height: 42px;
  flex: 0 0 54px;
  border-radius: 8px;
  object-fit: cover;
}

.request-property-cell > span {
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, #eff6ff, #fff7ed);
  color: #1d4ed8;
  font-weight: 900;
}

.request-property-cell strong {
  max-width: 230px;
  display: block;
  overflow: hidden;
  color: #0f172a;
  font-size: 13px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.request-property-cell small,
.premium-request-table td > small {
  display: block;
  margin-top: 3px;
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
}

.premium-request-table td > strong {
  display: block;
  color: #0f172a;
  font-size: 12px;
}

.compact-request-user {
  min-width: 170px;
}

.request-inline-actions {
  min-width: 250px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
}

.request-inline-actions form {
  display: inline-flex;
}

.request-inline-actions .small-btn {
  min-height: 30px;
  padding: 0 9px;
  border-radius: 7px;
}

.request-card-list {
  display: grid;
  gap: 12px;
  padding: 14px;
  background: #f8fafc;
}

.request-review-card {
  display: grid;
  grid-template-columns: 108px minmax(0, 1fr) 112px;
  gap: 14px;
  padding: 12px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
}

.request-review-card:hover {
  border-color: #bfdbfe;
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.07);
}

.request-thumb {
  width: 108px;
  min-height: 92px;
  border-radius: 10px;
  overflow: hidden;
  background: linear-gradient(135deg, #eff6ff, #fff7ed);
  display: grid;
  place-items: center;
}

.request-thumb img {
  width: 100%;
  height: 100%;
  min-height: 92px;
  object-fit: cover;
}

.request-thumb span {
  color: #1d4ed8;
  font-size: 24px;
  font-weight: 900;
}

.request-review-main {
  min-width: 0;
  display: grid;
  gap: 10px;
}

.request-review-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.request-review-title h3 {
  margin: 3px 0 0;
  color: #0f172a;
  font-size: 16px;
  letter-spacing: -0.01em;
}

.request-id {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
}

.request-meta-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.request-meta-grid span {
  min-height: 52px;
  padding: 8px 10px;
  border: 1px solid #eef2f7;
  border-radius: 9px;
  background: #f8fafc;
}

.request-meta-grid small,
.request-meta-grid strong,
.request-date strong,
.request-date small {
  display: block;
}

.request-meta-grid small {
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.request-meta-grid strong {
  margin-top: 4px;
  color: #0f172a;
  font-size: 12px;
}

.request-owner-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.request-date {
  text-align: right;
}

.request-date strong {
  color: #0f172a;
  font-size: 12px;
}

.request-date small {
  margin-top: 2px;
  color: #64748b;
  font-size: 11px;
}

.request-action-stack {
  display: grid;
  align-content: start;
  gap: 7px;
}

.request-action-stack form,
.request-action-stack .button,
.request-action-stack button {
  width: 100%;
}

.request-empty-state {
  padding: 34px 18px;
  border: 1px dashed #cbd5e1;
  border-radius: 12px;
  background: #fff;
  text-align: center;
}

.request-empty-state strong,
.request-empty-state p {
  margin: 0;
}

.request-empty-state strong {
  color: #0f172a;
  font-size: 16px;
}

.request-empty-state p {
  margin-top: 6px;
  color: #64748b;
  font-weight: 700;
}

.request-tabs a {
  position: relative;
  padding: 14px 0;
  color: #475569;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.request-tabs a.active {
  color: #2563eb;
}

.request-tabs a.active::after {
  content: "";
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  height: 3px;
  border-radius: 999px;
  background: #2563eb;
}

.request-table-wrap {
  overflow-x: auto;
}

.request-table {
  min-width: 1180px;
}

.request-table th:first-child,
.request-table td:first-child {
  width: 38px;
  text-align: center;
}

.request-table .entity-img,
.request-table .entity-icon {
  width: 52px;
  height: 42px;
}

.request-user {
  display: flex;
  align-items: center;
  gap: 9px;
}

.request-user > span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, #dbeafe, #fff7ed);
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 900;
}

.request-user strong,
.request-user small,
.request-table td > strong,
.request-table td > small {
  display: block;
}

.request-user small,
.request-table td > small {
  margin-top: 2px;
  color: #64748b;
  font-size: 11px;
}

.request-type {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 7px;
  font-size: 11px;
  font-weight: 900;
}

.request-type.sale {
  background: #dbeafe;
  color: #1d4ed8;
}

.request-type.rent {
  background: #dcfce7;
  color: #15803d;
}

.request-table-footer {
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 12px 16px;
  border-top: 1px solid #eef2f7;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.request-pagination {
  display: flex;
  align-items: center;
  gap: 8px;
}

.request-pagination b,
.request-pagination span,
.request-pagination em {
  min-width: 28px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: #334155;
  font-style: normal;
}

.request-pagination b {
  background: #2563eb;
  color: #fff;
}

.request-table-footer select {
  min-height: 34px;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
}

.listing-detail-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
  padding: 14px 16px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: linear-gradient(135deg, #ffffff, #f8fbff 58%, #fff7ed);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.listing-detail-title a {
  color: #2563eb;
  font-size: 12px;
  font-weight: 900;
}

.listing-detail-title h2,
.listing-detail-title p {
  margin: 0;
}

.listing-detail-title h2 {
  margin-top: 5px;
  color: #0f172a;
  font-size: 23px;
  letter-spacing: -0.03em;
}

.listing-detail-title p {
  margin-top: 4px;
  color: #64748b;
  font-size: 13px;
  font-weight: 750;
}

.listing-detail-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.detail-chip {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
}

.detail-chip.blue {
  background: #dbeafe;
  color: #1d4ed8;
}

.detail-chip.orange {
  background: #ffedd5;
  color: #c2410c;
}

.listing-detail-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 12px;
}

.listing-detail-main,
.listing-detail-side {
  display: grid;
  align-content: start;
  gap: 12px;
}

.listing-detail-card {
  padding: 14px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.listing-summary-card {
  display: grid;
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 14px;
}

.listing-gallery-preview {
  min-height: 170px;
  border-radius: 10px;
  overflow: hidden;
  background: linear-gradient(135deg, #eff6ff, #fff7ed);
  display: grid;
  place-items: center;
}

.listing-gallery-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.listing-gallery-preview span {
  color: #1d4ed8;
  font-size: 34px;
  font-weight: 900;
}

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

.listing-summary-content p {
  margin: 0;
  color: #475569;
  font-size: 13px;
  line-height: 1.55;
}

.listing-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.listing-card-head h3,
.listing-card-head small {
  margin: 0;
}

.listing-card-head h3 {
  color: #0f172a;
  font-size: 15px;
}

.listing-card-head small {
  color: #64748b;
  font-size: 11px;
  font-weight: 850;
}

.listing-detail-stats {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.listing-detail-stats span,
.attribute-grid div {
  min-height: 54px;
  padding: 9px 10px;
  border: 1px solid #eef2f7;
  border-radius: 9px;
  background: #f8fafc;
}

.listing-detail-stats small,
.listing-detail-stats strong,
.attribute-grid small,
.attribute-grid strong {
  display: block;
}

.listing-detail-stats small,
.attribute-grid small {
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.listing-detail-stats strong,
.attribute-grid strong {
  margin-top: 5px;
  color: #0f172a;
  font-size: 12px;
}

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

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

.compact-attribute-grid div {
  min-height: 48px;
}

.attribute-grid strong {
  overflow-wrap: anywhere;
}

.listing-detail-images {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 8px;
}

.listing-detail-images img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: 1px solid #e2e8f0;
  border-radius: 9px;
}

.detail-action-stack {
  display: grid;
  gap: 8px;
}

.detail-action-stack button,
.detail-action-stack form {
  width: 100%;
}

.detail-feature-toggle {
  min-height: 38px;
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 0 10px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: #f8fafc;
  color: #0f172a;
  font-size: 12px;
  font-weight: 900;
  cursor: pointer;
}

.detail-feature-toggle input {
  width: 16px;
  height: 16px;
  margin: 0;
}

.detail-owner-card {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}

.detail-owner-card > span {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: linear-gradient(135deg, #dbeafe, #fff7ed);
  color: #1d4ed8;
  font-weight: 900;
}

.detail-owner-card strong,
.detail-owner-card small,
.detail-lead-list strong,
.detail-lead-list small {
  display: block;
}

.detail-owner-card small,
.detail-lead-list small {
  margin-top: 3px;
  color: #64748b;
  font-size: 11px;
}

.detail-lead-list {
  display: grid;
  gap: 8px;
}

.detail-mini-list {
  display: grid;
  gap: 7px;
}

.detail-mini-list div {
  padding: 8px 9px;
  border: 1px solid #eef2f7;
  border-radius: 8px;
  background: #f8fafc;
}

.detail-mini-list small,
.detail-mini-list strong {
  display: block;
}

.detail-mini-list small {
  color: #64748b;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.detail-mini-list strong {
  margin-top: 3px;
  color: #0f172a;
  font-size: 12px;
  overflow-wrap: anywhere;
}

.detail-lead-list > div:not(.detail-empty) {
  padding: 9px;
  border: 1px solid #eef2f7;
  border-radius: 8px;
  background: #f8fafc;
}

.detail-empty {
  padding: 16px;
  border: 1px dashed #cbd5e1;
  border-radius: 9px;
  color: #64748b;
  background: #f8fafc;
  font-weight: 800;
  text-align: center;
}

.module-manage-kpis {
  margin-bottom: 14px;
}

.user-admin-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 12px;
  padding: 14px 16px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff, #f8fbff 58%, #fff7ed);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.user-admin-hero h2,
.user-admin-hero p {
  margin: 0;
}

.user-admin-hero h2 {
  color: #0f172a;
  font-size: 22px;
  letter-spacing: -0.03em;
}

.user-admin-hero p {
  margin-top: 5px;
  color: #64748b;
  font-size: 13px;
  font-weight: 750;
}

.user-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.user-kpi-grid a {
  min-height: 78px;
  padding: 12px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.user-kpi-grid small,
.user-kpi-grid strong,
.user-kpi-grid span {
  display: block;
}

.user-kpi-grid small {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.user-kpi-grid strong {
  margin-top: 4px;
  color: #0f172a;
  font-size: 22px;
}

.user-kpi-grid span {
  color: #64748b;
  font-size: 11px;
  font-weight: 750;
}

.user-admin-panel {
  overflow: hidden;
}

.user-filter-bar {
  display: grid;
  grid-template-columns: repeat(2, minmax(150px, 1fr)) auto auto;
  gap: 9px;
  padding: 12px;
  border-bottom: 1px solid #eef2f7;
  background: #fff;
}

.user-filter-bar label {
  display: grid;
  gap: 5px;
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
}

.user-filter-bar select {
  min-height: 36px;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #fff;
  color: #0f172a;
  font-weight: 700;
}

.user-filter-bar button,
.user-filter-bar .button {
  align-self: end;
  min-height: 36px;
}

.premium-user-table th {
  height: 38px;
  background: #f8fafc;
  color: #64748b;
  font-size: 10px;
  text-transform: uppercase;
}

.premium-user-table td {
  height: 64px;
}

.module-manage-card {
  margin-bottom: 14px;
}

.module-manage-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 16px;
  border-bottom: 1px solid #eef2f7;
}

.module-manage-head h3,
.module-manage-head p {
  margin: 0;
}

.module-manage-head h3 {
  color: #0f172a;
  font-size: 16px;
  letter-spacing: -0.02em;
}

.module-manage-head p {
  margin-top: 4px;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.module-manage-table {
  min-width: 860px;
}

.module-manage-table td > strong,
.module-manage-table td > small {
  display: block;
}

.module-manage-table td > small {
  margin-top: 3px;
  color: #64748b;
  font-size: 11px;
}

.module-media-cell {
  display: flex;
  align-items: center;
  gap: 8px;
}

.module-media-cell img,
.module-media-cell span {
  width: 34px;
  height: 34px;
  border-radius: 9px;
}

.module-media-cell img {
  object-fit: cover;
}

.module-media-cell span {
  display: grid;
  place-items: center;
  background: #dbeafe;
  color: #2563eb;
  font-weight: 900;
}

.module-media-cell small {
  color: #64748b;
  font-size: 11px;
}

.module-manage-grid {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: 14px;
}

.module-location-hero {
  margin-bottom: 10px;
  padding: 14px 16px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff, #f8fbff 62%, #fff7ed);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.module-location-hero h2 {
  margin-top: 6px;
  font-size: 23px;
  letter-spacing: -0.03em;
}

.module-location-hero .soft-pill {
  width: fit-content;
  padding: 5px 9px;
  color: #1d4ed8;
  background: #eff6ff;
  text-decoration: none;
}

.module-location-kpis {
  gap: 10px;
  margin-bottom: 10px;
}

.module-location-kpis article {
  min-height: 82px;
  padding: 12px;
}

.category-filter-bar {
  display: grid;
  grid-template-columns: minmax(220px, 1.4fr) minmax(130px, 0.7fr) minmax(150px, 0.8fr) minmax(130px, 0.7fr) auto;
  gap: 10px;
  padding: 12px 14px;
  border-bottom: 1px solid #eef2f7;
  background: linear-gradient(180deg, #fff, #fbfdff);
}

.category-filter-bar label {
  display: grid;
  gap: 5px;
  margin: 0;
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
}

.category-filter-bar input,
.category-filter-bar select {
  width: 100%;
  min-height: 36px;
  padding: 0 11px;
  border: 1px solid #dbe5f1;
  border-radius: 9px;
  background: #fff;
  color: #0f172a;
  font-size: 12px;
  font-weight: 750;
  outline: none;
}

.category-filter-bar input:focus,
.category-filter-bar select:focus {
  border-color: #fb923c;
  box-shadow: 0 0 0 3px rgba(249, 115, 22, 0.1);
}

.category-filter-bar button {
  align-self: end;
  min-height: 36px;
}

.category-filter-table {
  min-width: 1040px;
}

.vehicle-category-card .category-filter-table {
  min-width: 860px;
}

.vehicle-category-card .module-media-cell img,
.vehicle-category-card .module-media-cell > span {
  width: 34px;
  height: 34px;
  border-radius: 9px;
}

.vehicle-category-card .request-table th,
.vehicle-category-card .request-table td {
  padding: 9px 10px;
}

.vehicle-manage-head {
  margin-bottom: 10px;
}

.vehicle-manage-head .eyebrow {
  margin-bottom: 6px;
}

.vehicle-manage-kpis {
  gap: 9px;
  margin-bottom: 10px;
}

.vehicle-manage-kpis article {
  min-height: 76px;
  padding: 11px;
}

.vehicle-category-layout {
  display: grid;
  gap: 12px;
  padding: 0 18px 22px;
}

.vehicle-category-card {
  overflow: hidden;
  border-radius: 8px;
}

.vehicle-category-card .module-manage-head {
  padding: 12px 14px;
}

.vehicle-type-table,
.vehicle-child-table {
  min-width: 920px;
}

.vehicle-category-filter {
  grid-template-columns: minmax(220px, 1fr) minmax(140px, 0.6fr) auto;
  padding: 10px 12px;
}

.compact-vehicle-category-modal {
  width: min(640px, calc(100vw - 32px));
}

.compact-vehicle-category-modal .modal-form {
  gap: 9px;
}

@media (max-width: 760px) {
  .admin-home-hero,
  .admin-home-grid {
    grid-template-columns: 1fr;
  }

  .admin-home-hero {
    display: grid;
  }

  .admin-bar-chart {
    grid-auto-columns: minmax(64px, 1fr);
  }

  .vehicle-category-layout {
    padding: 0 10px 18px;
  }

  .vehicle-category-filter {
    grid-template-columns: 1fr;
  }

  .compact-vehicle-category-modal {
    width: 100%;
  }
}

.module-location-card {
  overflow: hidden;
}

.module-location-head {
  padding: 12px 14px;
}

.module-location-table-wrap {
  overflow-x: auto;
}

.module-location-table {
  min-width: 980px;
}

.module-location-table th,
.module-location-table td {
  padding: 10px 12px;
}

.module-location-table .count-chip {
  min-width: 34px;
  min-height: 26px;
  font-size: 12px;
}

.property-count-chip {
  color: #ea580c;
  background: #fff7ed;
  border-color: #fed7aa;
}

.location-actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.location-actions .small-btn {
  min-height: 30px;
  padding: 7px 10px;
  border-radius: 8px;
  line-height: 1;
  text-decoration: none;
}

.disabled-btn {
  cursor: not-allowed;
  opacity: 0.48;
  filter: grayscale(0.25);
}

.compact-location-modal {
  max-width: 560px;
}

.compact-location-modal .modal-head {
  padding: 14px 16px;
}

.compact-location-modal .modal-form {
  padding: 14px 16px;
  gap: 10px;
}

.compact-location-modal .modal-actions {
  padding-top: 4px;
}

.empty-row {
  padding: 26px !important;
  color: #64748b !important;
  font-weight: 800;
  text-align: center !important;
}

.inline-toggle-form {
  margin: 0;
}

.switch-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}

.switch-toggle input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.switch-toggle span {
  position: relative;
  width: 42px;
  height: 22px;
  border-radius: 999px;
  background: #e2e8f0;
  box-shadow: inset 0 0 0 1px #cbd5e1;
  transition: 0.2s ease;
}

.switch-toggle span::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 2px 6px rgba(15, 23, 42, 0.18);
  transition: 0.2s ease;
}

.switch-toggle input:checked + span {
  background: linear-gradient(135deg, #22c55e, #16a34a);
  box-shadow: inset 0 0 0 1px rgba(22, 163, 74, 0.38);
}

.switch-toggle input:checked + span::after {
  transform: translateX(20px);
}

.switch-toggle em {
  min-width: 22px;
  color: #64748b;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.switch-toggle input:checked ~ em {
  color: #15803d;
}

.brand-mark img,
.login-brand-mark img {
  width: 100%;
  height: 100%;
  border-radius: inherit;
  object-fit: contain;
  display: block;
  background: #fff;
}

.brand:has(.brand-mark img) .brand-mark {
  width: 64px;
  border-radius: 12px;
  background: #fff;
}

.admin-login-brand:has(.login-brand-mark img) .login-brand-mark,
.mobile-login-logo:has(.login-brand-mark img) .login-brand-mark {
  width: 92px;
  border-radius: 16px;
  background: #fff;
}

.listing-admin-table .inline-toggle-form {
  display: inline-flex;
  margin-right: 8px;
  vertical-align: middle;
}

.listing-admin-table .switch-toggle {
  gap: 6px;
}

.listing-admin-table .switch-toggle span {
  width: 36px;
  height: 20px;
}

.listing-admin-table .switch-toggle span::after {
  width: 14px;
  height: 14px;
}

.listing-admin-table .switch-toggle input:checked + span::after {
  transform: translateX(16px);
}

.confirm-card {
  max-width: 440px;
}

.confirm-body {
  display: grid;
  gap: 8px;
  padding: 12px;
  border: 1px solid #fee2e2;
  border-radius: 10px;
  background: #fff7f7;
}

.confirm-body strong {
  color: #991b1b;
  font-size: 15px;
}

.confirm-body p {
  margin: 0;
  color: #64748b;
  line-height: 1.45;
}

.module-mini-list strong,
.module-mini-list small {
  display: block;
}

.module-mini-list small {
  color: #64748b;
  font-size: 11px;
}

.vendor-page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 28px 28px 14px;
}

.vendor-page-head h1,
.vendor-page-head p {
  margin: 0;
}

.vendor-page-head h1 {
  font-size: 26px;
}

.vendor-page-head p {
  color: var(--muted);
  margin-top: 6px;
}

.vendor-page-head button {
  min-height: 44px;
  padding: 0 20px;
  background: #5b21f6;
  box-shadow: 0 10px 20px rgba(91, 33, 246, 0.18);
}

.vendor-stat-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(150px, 1fr));
  gap: 12px;
  padding: 0 28px 16px;
}

.vendor-stat-grid article {
  display: flex;
  align-items: center;
  gap: 14px;
  min-height: 104px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.stat-icon {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  font-weight: 800;
}

.stat-icon.purple { background: #ede9fe; color: #6d28d9; }
.stat-icon.green { background: #dcfce7; color: #16a34a; }
.stat-icon.orange { background: #ffedd5; color: #f97316; }
.stat-icon.pink { background: #ffe4e6; color: #e11d48; }
.stat-icon.blue { background: #dbeafe; color: #2563eb; }

.vendor-stat-grid small,
.vendor-stat-grid p {
  color: var(--muted);
}

.vendor-stat-grid strong {
  display: block;
  margin: 3px 0;
  font-size: 24px;
}

.vendor-stat-grid a {
  color: #5b21f6;
  font-weight: 700;
  font-size: 12px;
}

.vendor-stat-grid p {
  margin: 0;
  font-size: 12px;
}

.vendor-table-card {
  margin: 0 28px 28px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  overflow: hidden;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.vendor-filters {
  display: grid;
  grid-template-columns: 1fr 190px 170px auto auto;
  gap: 12px;
  padding: 16px;
  border-bottom: 1px solid var(--line);
}

.vendor-filters label {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 38px;
  padding: 0 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.vendor-filters input {
  border: 0;
  padding: 0;
}

.vendor-product-table th,
.vendor-product-table td {
  padding: 12px 14px;
  border-bottom: 1px solid var(--line);
}

.vendor-product {
  display: flex;
  align-items: center;
  gap: 12px;
}

.vendor-product img,
.product-thumb {
  width: 46px;
  height: 46px;
  border-radius: 8px;
  background: #f1f5f9;
}

.vendor-product img {
  object-fit: cover;
}

.product-thumb {
  display: grid;
  place-items: center;
  color: #5b21f6;
  font-weight: 800;
}

.vendor-product strong,
.vendor-product small,
.vendor-product-table td small {
  display: block;
}

.vendor-product small,
.vendor-product-table td small {
  color: var(--muted);
  margin-top: 3px;
}

.property-account-console {
  background: #f8fafc;
}

.property-account-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin: 0 24px 14px;
  padding: 20px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: linear-gradient(135deg, #fff, #f8fbff 58%, #fff7ed);
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.property-account-hero span {
  display: inline-flex;
  margin-bottom: 7px;
  padding: 4px 8px;
  border-radius: 999px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.property-account-hero h1,
.property-account-hero p {
  margin: 0;
}

.property-account-hero h1 {
  color: #0f172a;
  font-size: 26px;
  letter-spacing: -0.03em;
}

.property-account-hero p {
  margin-top: 5px;
  color: #64748b;
  font-weight: 700;
}

.property-account-kpis {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 10px;
  padding: 0 24px 14px;
}

.property-account-kpis article {
  min-height: 86px;
  padding: 13px;
  border: 1px solid #dfe7f2;
  border-radius: 11px;
  background: #fff;
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.04);
}

.property-account-kpis small,
.property-account-kpis strong,
.property-account-kpis span {
  display: block;
}

.property-account-kpis small {
  color: #64748b;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.property-account-kpis strong {
  margin-top: 5px;
  color: #0f172a;
  font-size: 24px;
}

.property-account-kpis span {
  color: #64748b;
  font-size: 11px;
  font-weight: 750;
}

.property-account-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 330px;
  gap: 14px;
  padding: 0 24px 24px;
}

.property-account-main,
.property-account-side {
  display: grid;
  align-content: start;
  gap: 14px;
}

.property-account-card {
  overflow: hidden;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.property-account-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px;
  border-bottom: 1px solid #eef2f7;
}

.property-account-card-head h3,
.property-account-card-head p {
  margin: 0;
}

.property-account-card-head h3 {
  color: #0f172a;
  font-size: 16px;
}

.property-account-card-head p {
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
  font-weight: 750;
}

.property-account-table-wrap {
  overflow-x: auto;
}

.property-account-table {
  width: 100%;
  min-width: 900px;
  border-collapse: collapse;
}

.property-account-table th {
  height: 38px;
  padding: 0 12px;
  background: #f8fafc;
  color: #64748b;
  font-size: 10px;
  text-align: left;
  text-transform: uppercase;
}

.property-account-table td {
  height: 66px;
  padding: 10px 12px;
  border-top: 1px solid #eef2f7;
  vertical-align: middle;
}

.property-account-listing {
  display: flex;
  align-items: center;
  gap: 10px;
}

.property-account-listing img,
.property-account-listing > span {
  width: 58px;
  height: 44px;
  flex: 0 0 58px;
  border-radius: 8px;
  object-fit: cover;
}

.property-account-listing > span {
  display: grid;
  place-items: center;
  background: #eff6ff;
  color: #1d4ed8;
  font-weight: 900;
}

.property-account-listing strong,
.property-account-table td > strong {
  display: block;
  color: #0f172a;
  font-size: 13px;
}

.property-account-listing small,
.property-account-table td > small {
  display: block;
  margin-top: 3px;
  color: #64748b;
  font-size: 11px;
}

.property-account-actions,
.property-lead-list {
  display: grid;
  gap: 9px;
  padding: 14px;
}

.property-account-actions .button,
.property-account-actions button {
  width: 100%;
}

.property-lead-list div:not(.empty-row) {
  padding: 10px;
  border: 1px solid #eef2f7;
  border-radius: 9px;
  background: #f8fafc;
}

.property-lead-list strong,
.property-lead-list small {
  display: block;
}

.property-lead-list small {
  margin-top: 4px;
  color: #64748b;
  font-size: 11px;
}

.property-account-hero {
  gap: 14px;
  margin-bottom: 10px;
  padding: 14px 16px;
}

.property-account-hero span {
  margin-bottom: 5px;
  padding: 3px 8px;
}

.property-account-hero h1 {
  font-size: 22px;
}

.property-account-hero p {
  margin-top: 3px;
}

.property-account-kpis {
  gap: 8px;
  padding-bottom: 10px;
}

.property-account-kpis article {
  min-height: 70px;
  padding: 10px 12px;
}

.property-account-kpis strong {
  margin-top: 3px;
  font-size: 21px;
}

.property-account-layout {
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 10px;
  padding-bottom: 18px;
}

.property-account-console .property-account-layout {
  grid-template-columns: minmax(0, 1fr);
}

.property-account-main,
.property-account-side {
  gap: 10px;
}

.property-account-card-head {
  padding: 10px 12px;
}

.property-account-table th {
  height: 32px;
  padding: 0 10px;
}

.property-account-table td {
  height: 54px;
  padding: 7px 10px;
}

.property-account-listing img,
.property-account-listing > span {
  width: 46px;
  height: 36px;
  flex-basis: 46px;
}

.property-lead-list {
  gap: 7px;
  padding: 10px;
}

.property-account-console .vendor-main {
  background: #f8fafc;
}

.property-account-console .vendor-sidebar {
  box-shadow: 8px 0 22px rgba(15, 23, 42, 0.04);
}

.property-account-console .vendor-nav a,
.property-account-console .vendor-nav-logout button {
  min-height: 38px;
}

.vendor-chip,
.vendor-status {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
}

.vendor-chip {
  background: #f1ecff;
  color: #5b21f6;
}

.vendor-status.approved {
  background: #dcfce7;
  color: #15803d;
}

.vendor-status.pending {
  background: #ffedd5;
  color: #c2410c;
}

.vendor-status.processing,
.vendor-status.confirmed,
.vendor-status.unpaid {
  background: #dbeafe;
  color: #1d4ed8;
}

.vendor-status.completed,
.vendor-status.paid {
  background: #dcfce7;
  color: #15803d;
}

.vendor-status.cancelled,
.vendor-status.refunded {
  background: #ffe4e6;
  color: #be123c;
}

.vendor-status.draft {
  background: #f1f5f9;
  color: #475569;
}

.vendor-status.rejected {
  background: #ffe4e6;
  color: #be123c;
}

.vendor-status.active {
  background: #dcfce7;
  color: #15803d;
}

.vendor-status.scheduled {
  background: #dbeafe;
  color: #1d4ed8;
}

.vendor-status.expired,
.vendor-status.disabled {
  background: #f1f5f9;
  color: #64748b;
}

.coupon-code {
  display: inline-flex;
  min-height: 26px;
  align-items: center;
  padding: 0 10px;
  border: 1px dashed #8b5cf6;
  border-radius: 7px;
  color: #5b21f6;
  background: #faf5ff;
}

.coupon-filters {
  grid-template-columns: 1fr 170px 170px auto;
}

.empty-state {
  display: grid;
  justify-items: center;
  gap: 8px;
  padding: 34px;
  text-align: center;
}

.empty-state p {
  margin: 0;
  color: var(--muted);
}

.module-stats {
  grid-template-columns: repeat(4, minmax(160px, 1fr));
}

.module-card {
  min-height: 420px;
}

.module-empty {
  min-height: 420px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 10px;
  padding: 40px;
  text-align: center;
}

.module-empty h2,
.module-empty p {
  margin: 0;
}

.module-empty p {
  max-width: 560px;
  color: var(--muted);
}

.category-hero {
  position: relative;
  align-items: stretch;
  padding: 14px;
  border: 1px solid rgba(255, 101, 0, 0.14);
  border-radius: 12px;
  background:
    linear-gradient(120deg, rgba(255, 101, 0, 0.1), rgba(255, 255, 255, 0) 42%),
    linear-gradient(135deg, #ffffff, #f8fbff);
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.05);
}

.category-hero::after {
  content: "";
  position: absolute;
  inset: auto 18px 0;
  height: 3px;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(90deg, #ff6500, #2563eb, #16a34a, #f59e0b);
}

.category-hero .eyebrow {
  display: inline-flex;
  margin-bottom: 5px;
  padding: 4px 8px;
  border: 1px solid rgba(255, 101, 0, 0.24);
  border-radius: 999px;
  background: #fff7ed;
  color: var(--primary-dark);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
}

.category-hero h2 {
  font-size: 22px;
  letter-spacing: 0;
}

.category-hero-stats {
  min-width: 270px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  align-self: center;
}

.category-hero-stats span {
  min-height: 50px;
  display: grid;
  align-content: center;
  gap: 3px;
  padding: 10px 12px;
  border: 1px solid rgba(226, 232, 240, 0.9);
  border-radius: 11px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--muted);
  font-size: 12px;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

.category-hero-stats strong {
  color: var(--text);
  font-size: 18px;
}

.module-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr));
  gap: 10px;
  margin-bottom: 14px;
}

.module-grid .module-card {
  min-height: auto;
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: 40px 1fr auto;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(226, 232, 240, 0.92);
  border-radius: 13px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
  transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.module-grid .module-card:hover {
  transform: translateY(-2px);
  border-color: #cbd5e1;
  box-shadow: 0 12px 26px rgba(15, 23, 42, 0.08);
}

.module-grid .module-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: #0f172a;
}

.module-tone-2::before {
  background: #2563eb !important;
}

.module-tone-3::before {
  background: #16a34a !important;
}

.module-tone-4::before {
  background: #7c3aed !important;
}

.module-tone-5::before {
  background: #f59e0b !important;
}

.module-icon {
  width: 40px;
  height: 40px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: #f8fafc;
  color: #0f172a;
  border: 1px solid #e2e8f0;
  font-weight: 800;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.86);
}

.svg-icon {
  width: 19px;
  height: 19px;
  display: block;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.module-grid .module-card h3,
.module-grid .module-card p {
  margin: 0;
}

.module-grid .module-card p {
  color: var(--muted);
  font-size: 11px;
  line-height: 1.3;
  margin-top: 2px;
}

.module-grid .module-card small {
  display: inline-flex;
  margin-top: 6px;
  padding: 3px 7px;
  border-radius: 999px;
  background: #f8fafc;
  color: #475569;
  font-weight: 700;
}

.module-card-actions {
  display: grid;
  gap: 5px;
}

.ghost-icon-btn {
  min-height: 28px;
  padding: 0 9px;
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 8px;
  background: #fff;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.ghost-icon-btn:hover {
  background: #0f172a;
  color: #fff;
}

.entity-img {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  object-fit: cover;
  border: 1px solid var(--line);
}

.category-table-panel {
  border: 1px solid rgba(226, 232, 240, 0.96);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 14px 38px rgba(15, 23, 42, 0.06);
}

.category-filter-bar {
  display: flex;
  align-items: end;
  gap: 10px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--line);
  background: #ffffff;
}

.category-filter-bar label {
  min-width: min(320px, 100%);
  margin: 0;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.category-filter-bar select {
  margin-top: 6px;
}

.panel-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: linear-gradient(180deg, #fff, #fbfdff);
}

.panel-title-row h3,
.panel-title-row p {
  margin: 0;
}

.panel-title-row p {
  margin-top: 4px;
  color: var(--muted);
  font-size: 12px;
}

.soft-pill,
.module-pill,
.count-chip,
.state-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.soft-pill {
  padding: 7px 10px;
  background: #f1f5f9;
  color: #334155;
}

.module-pill {
  padding: 5px 9px;
  background: #eff6ff;
  color: #1d4ed8;
}

.count-chip {
  min-width: 28px;
  min-height: 28px;
  background: #f8fafc;
  color: #334155;
  border: 1px solid var(--line);
}

.field-badge {
  background: #f5f3ff;
  color: #6d28d9;
}

.field-builder-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 12px;
  border: 1px dashed #fed7aa;
  border-radius: 10px;
  background: #fff7ed;
  color: #9a3412;
  font-size: 12px;
  font-weight: 700;
}

.builder-tabs {
  position: sticky;
  top: 0;
  z-index: 4;
  display: flex;
  gap: 8px;
  margin: -2px 0 12px;
  padding: 8px;
  border: 1px solid #eef2f7;
  border-radius: 12px;
  background: rgba(248, 250, 252, 0.92);
  backdrop-filter: blur(10px);
}

.builder-tabs a {
  min-height: 32px;
  padding: 0 12px;
  display: inline-flex;
  align-items: center;
  border-radius: 9px;
  color: #475569;
  font-size: 12px;
  font-weight: 900;
}

.builder-tabs a:hover {
  background: #fff7ed;
  color: #ea580c;
}

.builder-tabs a:first-child {
  background: #0f172a;
  color: #fff;
}

.builder-section {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid #e8edf5;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.builder-section-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.builder-section-head strong,
.builder-section-head small {
  display: block;
}

.builder-section-head strong {
  color: #0f172a;
  font-size: 14px;
}

.builder-section-head small {
  margin-top: 3px;
  color: #64748b;
  font-size: 11px;
}

.builder-add-field .grid-form {
  margin-top: 0;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.field-table-wrap {
  margin-top: 0;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  overflow: auto;
}

.wizard-builder-note {
  margin-top: 4px;
}

.inline-builder {
  margin: 10px 0 0;
  padding: 10px 12px;
  border: 1px solid var(--line);
  border-radius: 11px;
  background: #fbfdff;
}

.inline-builder summary {
  cursor: pointer;
  color: var(--primary);
  font-weight: 900;
}

.inline-builder form {
  margin-top: 10px;
}

.wizard-step-table {
  min-width: 820px;
}

.field-order-table {
  min-width: 900px;
  font-size: 12px;
}

.field-order-table th {
  position: sticky;
  top: 0;
  z-index: 1;
  padding: 10px 12px;
  background: #f9fafb;
  color: #64748b;
  font-size: 11px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

.field-order-table td {
  height: 54px;
  padding: 9px 12px;
  border-bottom: 1px solid #eef2f7;
}

.field-order-table tbody tr:hover {
  background: #fafafa;
}

.field-order-table td {
  vertical-align: middle;
}

.field-order-table td strong,
.field-order-table td small {
  display: block;
}

.field-order-table td strong {
  color: #0f172a;
  font-size: 13px;
}

.field-order-table td small {
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
}

.field-order-table code {
  padding: 4px 6px;
  border-radius: 7px;
  background: #f8fafc;
  color: #475569;
  font-size: 11px;
}

.field-step-table-select {
  min-width: 132px;
  min-height: 32px;
  border: 1px solid var(--line);
  border-radius: 9px;
  background: #fff;
  font-size: 12px;
}

.compact-tags {
  max-width: 180px;
  gap: 4px;
}

.sortable-fields {
  align-items: stretch;
}

.draggable-field {
  cursor: grab;
}

.draggable-field.dragging {
  opacity: 0.55;
  border-color: #ff6500;
  box-shadow: 0 12px 30px rgba(255, 101, 0, 0.16);
}

.field-drag-handle {
  width: fit-content;
  min-height: 26px;
  padding: 0 8px;
  border: 0;
  border-radius: 999px;
  background: #eef2ff;
  color: #475569;
  font-size: 10px;
  font-weight: 800;
}

[id^="module-form-"] .row-actions,
[id^="module-wizard-"] .row-actions {
  gap: 5px;
  flex-wrap: nowrap;
}

[id^="module-form-"] .row-actions form,
[id^="module-wizard-"] .row-actions form {
  margin: 0;
}

[id^="module-form-"] .small-btn,
[id^="module-wizard-"] .small-btn {
  min-height: 28px;
  padding: 0 9px;
  border-radius: 8px;
  font-size: 11px;
}

[id^="module-form-"] .danger.small-btn,
[id^="module-wizard-"] .danger.small-btn {
  background: #fee2e2;
  color: #b91c1c;
}

[id^="module-form-"] .danger.small-btn:hover,
[id^="module-wizard-"] .danger.small-btn:hover {
  background: #dc2626;
  color: #fff;
}

.field-step-select {
  margin: 0;
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.field-step-select select {
  margin-top: 4px;
  min-height: 34px;
}

.state-pill {
  padding: 5px 9px;
}

.state-pill.active {
  background: #dcfce7;
  color: #15803d;
}

.state-pill.inactive {
  background: #fee2e2;
  color: #b91c1c;
}

.category-table-panel .compact-table th {
  background: #f8fafc;
  color: #64748b;
  padding: 9px 11px;
  font-size: 11px;
}

.category-table-panel .compact-table td {
  padding: 9px 11px;
}

.category-table-panel .compact-table tbody tr {
  transition: background 0.15s ease;
}

.category-table-panel .compact-table tbody tr:hover {
  background: #fffaf6;
}

.category-table-panel .entity-icon,
.category-table-panel .entity-img {
  width: 38px;
  height: 38px;
  border-radius: 11px;
}

.category-table-panel .row-actions .small-btn {
  border-color: #fed7aa;
  color: #c2410c;
  background: #fff7ed;
}

.category-table-panel .row-actions .small-btn:hover {
  background: #ff6500;
  color: #fff;
}

.category-table-panel .entity-icon .svg-icon {
  width: 18px;
  height: 18px;
}

#add-module-modal input[type="file"],
#add-category-modal input[type="file"],
[id^="edit-module-"] input[type="file"],
[id^="edit-category-"] input[type="file"] {
  padding: 10px;
  border-style: dashed;
  background: #f8fafc;
  cursor: pointer;
}

#add-module-modal .modal-card,
#add-category-modal .modal-card,
[id^="edit-module-"] .modal-card,
[id^="edit-category-"] .modal-card,
[id^="fields-"] .modal-card {
  border: 1px solid rgba(226, 232, 240, 0.96);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 247, 237, 0.62), rgba(255, 255, 255, 0) 120px),
    #fff;
}

[id^="module-form-"] .modal-card,
[id^="module-wizard-"] .modal-card {
  width: min(1180px, calc(100vw - 28px));
  padding: 14px;
  border: 1px solid rgba(226, 232, 240, 0.96);
  border-radius: 14px;
  background: #fff;
}

#add-module-modal .modal-head,
#add-category-modal .modal-head,
[id^="edit-module-"] .modal-head,
[id^="edit-category-"] .modal-head,
[id^="fields-"] .modal-head {
  margin: -18px -18px 16px;
  padding: 16px 18px;
  border-bottom: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.7);
}

[id^="module-form-"] .modal-head,
[id^="module-wizard-"] .modal-head {
  position: sticky;
  top: -14px;
  z-index: 6;
  margin: -14px -14px 12px;
  padding: 13px 14px;
  border-bottom: 1px solid #e8edf5;
  background: rgba(255, 255, 255, 0.94);
  backdrop-filter: blur(12px);
}

[id^="module-form-"] .modal-head h3,
[id^="module-wizard-"] .modal-head h3 {
  font-size: 20px;
}

[id^="module-form-"] .modal-form label,
[id^="module-wizard-"] .modal-form label {
  font-size: 11px;
}

[id^="module-form-"] input,
[id^="module-form-"] select,
[id^="module-form-"] textarea,
[id^="module-wizard-"] input,
[id^="module-wizard-"] select,
[id^="module-wizard-"] textarea {
  min-height: 34px;
  font-size: 13px;
}

#add-module-modal .modal-form,
#add-category-modal .modal-form,
[id^="edit-module-"] .modal-form,
[id^="edit-category-"] .modal-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

#add-module-modal .modal-form label:has(textarea),
[id^="edit-module-"] .modal-form label:has(textarea),
#add-module-modal .modal-actions,
#add-category-modal .modal-actions,
[id^="edit-module-"] .modal-actions,
[id^="edit-category-"] .modal-actions {
  grid-column: 1 / -1;
}

.settings-layout {
  display: grid;
  grid-template-columns: 240px 1fr 300px;
  gap: 16px;
  padding: 0 28px 28px;
}

.settings-toast {
  position: fixed;
  top: 18px;
  right: 24px;
  z-index: 1400;
  width: min(360px, calc(100vw - 32px));
  display: grid;
  gap: 3px;
  padding: 13px 16px;
  border: 1px solid #dbeafe;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.16);
  backdrop-filter: blur(14px);
  animation: settingsToastIn 0.22s ease-out both, settingsToastFade 0.28s ease-in 5.2s forwards;
}

.settings-toast::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 4px;
  border-radius: inherit;
  background: #2563eb;
}

.settings-toast strong {
  color: #0f172a;
  font-size: 13px;
}

.settings-toast span {
  color: #52627a;
  font-size: 12px;
  line-height: 1.4;
}

.settings-toast-success {
  border-color: #bbf7d0;
}

.settings-toast-success::before {
  background: #16a34a;
}

.settings-toast-error {
  border-color: #fed7aa;
}

.settings-toast-error::before {
  background: #ff6500;
}

@keyframes settingsToastIn {
  from {
    opacity: 0;
    transform: translateY(-10px) scale(0.98);
  }
  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@keyframes settingsToastFade {
  to {
    opacity: 0;
    transform: translateY(-8px);
    pointer-events: none;
  }
}

@media (max-width: 720px) {
  .settings-toast {
    top: 12px;
    right: 12px;
    left: 12px;
    width: auto;
    padding: 12px 14px;
  }
}

.settings-tabs,
.settings-form,
.settings-side article {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
}

.settings-tabs {
  overflow: hidden;
}

.settings-tabs a {
  display: grid;
  gap: 4px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--line);
}

.settings-tabs a.active {
  background: #f1ecff;
  color: #5b21f6;
  border-left: 3px solid #5b21f6;
}

.settings-tabs small,
.settings-form p,
.settings-side p {
  color: var(--muted);
}

.settings-form label small,
.settings-url {
  display: block;
  margin-top: 6px;
  color: #64748b;
  font-size: 11px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.settings-form {
  padding: 22px;
}

.settings-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
}

.settings-head h2,
.settings-head p {
  margin: 0;
}

.toggle-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}

.toggle-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
}

.toggle-row input {
  width: auto;
  min-height: auto;
}

.settings-side {
  display: grid;
  gap: 16px;
  align-content: start;
}

.settings-side article {
  padding: 18px;
}

.settings-brand-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  margin-bottom: 14px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: linear-gradient(135deg, #fff7ed, #f8fbff);
}

.settings-brand-preview span {
  width: 52px;
  height: 52px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 14px;
  background: linear-gradient(135deg, #ff6500, #ffb000);
  color: #071326;
  font-weight: 900;
}

.settings-brand-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  border-radius: inherit;
  background: #fff;
}

.settings-favicon-preview {
  width: 28px;
  height: 28px;
  display: inline-block;
  margin-top: 5px;
  border-radius: 8px;
  object-fit: contain;
  box-shadow: inset 0 0 0 1px #e2e8f0;
}

.settings-brand-preview strong,
.settings-brand-preview small {
  display: block;
}

.settings-side h3 {
  margin-top: 0;
}

.settings-side a {
  display: block;
  padding: 10px 0;
  border-top: 1px solid var(--line);
  color: #5b21f6;
  font-weight: 700;
}

.report-hero {
  margin: 24px 28px 16px;
  padding: 26px;
  border-radius: 18px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  color: #fff;
  background:
    radial-gradient(circle at 85% 10%, rgba(255, 255, 255, 0.28), transparent 24%),
    linear-gradient(135deg, #4c1d95, #6d28d9 52%, #f97316);
  box-shadow: 0 20px 50px rgba(76, 29, 149, 0.22);
}

.report-hero span {
  display: inline-block;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.16);
  font-size: 12px;
  font-weight: 800;
}

.report-hero h1,
.report-hero p {
  margin: 8px 0 0;
}

.report-hero h1 {
  font-size: 30px;
}

.report-range {
  display: flex;
  gap: 10px;
}

.report-kpis,
.report-ribbon {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  margin: 0 28px 16px;
}

.report-kpis article,
.report-ribbon article,
.report-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 10px 30px rgba(15, 23, 42, 0.05);
}

.report-kpis article,
.report-ribbon article {
  padding: 16px;
}

.report-kpis small,
.report-ribbon small,
.muted-text {
  color: var(--muted);
}

.report-kpis strong,
.report-ribbon strong {
  display: block;
  margin: 6px 0;
  font-size: 24px;
}

.report-kpis span {
  font-size: 12px;
  color: var(--muted);
}

.report-kpis .up {
  color: #16a34a;
}

.report-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 16px;
  margin: 0 28px 16px;
}

.report-card {
  padding: 18px;
}

.report-card h2,
.report-card p {
  margin: 0;
}

.report-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 18px;
}

.chart-card {
  min-height: 310px;
}

.line-chart {
  height: 220px;
  display: flex;
  align-items: end;
  gap: 16px;
  padding: 18px;
  border-radius: 14px;
  background:
    linear-gradient(to top, rgba(109, 40, 217, 0.09), transparent),
    repeating-linear-gradient(to top, transparent, transparent 43px, rgba(100, 116, 139, 0.12) 44px);
}

.line-chart span {
  flex: 1;
  height: var(--h);
  display: flex;
  align-items: end;
  border-radius: 999px 999px 0 0;
  background: linear-gradient(180deg, #8b5cf6, #5b21f6);
  min-height: 18px;
}

.line-chart i {
  width: 100%;
  height: 8px;
  border-radius: 999px;
  background: #fff;
  opacity: 0.45;
}

.bar-chart {
  display: grid;
  gap: 16px;
}

.bar-chart div {
  display: grid;
  grid-template-columns: 110px 1fr 36px;
  gap: 10px;
  align-items: center;
}

.bar-chart strong {
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, #f97316, #6d28d9);
}

.bar-chart span,
.bar-chart em {
  color: var(--muted);
  font-style: normal;
  font-size: 12px;
}

.donut-wrap {
  display: grid;
  grid-template-columns: 150px 1fr;
  gap: 18px;
  align-items: center;
}

.donut {
  width: 150px;
  height: 150px;
  border-radius: 50%;
  background: conic-gradient(#6d28d9 0 35%, #22c55e 35% 58%, #f97316 58% 78%, #e11d48 78% 100%);
  position: relative;
}

.donut::after {
  content: "";
  position: absolute;
  inset: 34px;
  border-radius: 50%;
  background: #fff;
}

.dot {
  width: 9px;
  height: 9px;
  display: inline-block;
  margin-right: 8px;
  border-radius: 50%;
  background: #6d28d9;
}

.rank-list {
  display: grid;
  gap: 10px;
}

.rank-list div {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border-radius: 10px;
  background: #f8fafc;
}

.rank-list span {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: #ede9fe;
  color: #5b21f6;
  font-weight: 800;
}

.rank-list small {
  grid-column: 2;
  color: var(--muted);
}

.report-ribbon {
  grid-template-columns: repeat(4, 1fr);
  padding: 14px;
  border-radius: 16px;
  background: linear-gradient(135deg, #f5f3ff, #fff7ed);
}

.reports-page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 28px 28px 16px;
}

.reports-page-head h1,
.reports-page-head p {
  margin: 0;
}

.reports-page-head h1 {
  font-size: 26px;
}

.reports-page-head p {
  color: var(--muted);
  margin-top: 6px;
}

.reports-actions {
  display: flex;
  gap: 12px;
}

.reports-stat-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 12px;
  padding: 0 28px 16px;
}

.reports-stat-row article,
.report-white-card,
.reports-bottom-strip {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.05);
}

.reports-stat-row article {
  display: flex;
  gap: 14px;
  align-items: center;
  min-height: 104px;
  padding: 16px;
}

.reports-stat-row small,
.reports-stat-row p {
  color: var(--muted);
}

.reports-stat-row strong {
  display: block;
  margin: 4px 0;
  font-size: 22px;
}

.up {
  color: #16a34a !important;
}

.down {
  color: #e11d48 !important;
}

.reports-tabs {
  display: flex;
  gap: 28px;
  margin: 0 28px 16px;
  padding: 0 18px;
  border-bottom: 1px solid var(--line);
  background: #fff;
  border-radius: 10px 10px 0 0;
}

.reports-tabs a {
  padding: 14px 0;
  color: #475569;
  font-weight: 700;
  position: relative;
}

.reports-tabs a.active {
  color: #5b21f6;
}

.reports-tabs a.active::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -1px;
  height: 3px;
  border-radius: 999px;
  background: #5b21f6;
}

.reports-shell {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 16px;
  margin: 0 28px 16px;
}

.reports-main-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

.report-white-card {
  padding: 18px;
}

.report-white-card h2,
.report-white-card p {
  margin: 0;
}

.big-chart {
  min-height: 310px;
}

.small-report {
  min-height: 220px;
}

.reports-side {
  display: grid;
  gap: 16px;
  align-content: start;
}

.legend {
  width: 20px;
  height: 4px;
  display: inline-block;
  margin: 0 7px 2px 0;
  border-radius: 999px;
}

.legend.purple {
  background: #5b21f6;
}

.legend.gray {
  background: #cbd5e1;
  margin-left: 16px;
}

.smooth-chart {
  position: relative;
  height: 220px;
  margin-top: 14px;
  border-radius: 12px;
  overflow: hidden;
  background:
    linear-gradient(to top, rgba(91, 33, 246, 0.12), transparent 58%),
    repeating-linear-gradient(to top, transparent, transparent 43px, rgba(100, 116, 139, 0.14) 44px);
}

.smooth-chart::before {
  content: "";
  position: absolute;
  inset: 18px 24px 34px;
  border-bottom: 3px solid #5b21f6;
  border-radius: 55% 45% 20% 35%;
  transform: skewY(-6deg);
}

.smooth-chart::after {
  content: "20 May        21 May        22 May        23 May        24 May        25 May        26 May";
  position: absolute;
  left: 24px;
  right: 24px;
  bottom: 8px;
  color: var(--muted);
  font-size: 11px;
  word-spacing: 12px;
}

.smooth-chart span {
  position: absolute;
  left: var(--x);
  top: var(--y);
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #5b21f6;
  box-shadow: 0 0 0 4px rgba(91, 33, 246, 0.12);
}

.smooth-chart .tooltip {
  position: absolute;
  left: calc(var(--x) - 34px);
  top: calc(var(--y) - 52px);
  padding: 8px 10px;
  border-radius: 8px;
  background: #fff;
  box-shadow: 0 8px 24px rgba(15, 23, 42, 0.14);
  font-style: normal;
  font-size: 12px;
  color: var(--text);
}

.donut-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 18px;
  align-items: center;
  margin-top: 16px;
}

.donut-row.compact {
  grid-template-columns: 112px 1fr;
}

.clean-donut {
  width: 128px;
  height: 128px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: conic-gradient(#5b21f6 0 58%, #3b82f6 58% 86%, #f59e0b 86% 95%, #22c55e 95% 100%);
  position: relative;
}

.donut-row.compact .clean-donut {
  width: 112px;
  height: 112px;
}

.clean-donut::after {
  content: "";
  position: absolute;
  inset: 28px;
  border-radius: 50%;
  background: #fff;
}

.clean-donut b {
  z-index: 1;
  text-align: center;
}

.clean-donut small {
  display: block;
  color: var(--muted);
  font-weight: 400;
}

.report-list {
  display: grid;
  gap: 10px;
}

.report-list p,
.top-list p {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: #475569;
}

.dot.purple { background: #5b21f6; }
.dot.blue { background: #3b82f6; }
.dot.orange { background: #f59e0b; }
.dot.green { background: #22c55e; }

.refund-bars {
  height: 160px;
  display: flex;
  align-items: end;
  gap: 18px;
  margin-top: 16px;
  padding: 12px;
  background: repeating-linear-gradient(to top, transparent, transparent 38px, rgba(100, 116, 139, 0.12) 39px);
}

.refund-bars span {
  flex: 1;
  border-radius: 7px 7px 0 0;
  background: linear-gradient(180deg, #fb7185, #fecdd3);
}

.mini-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.mini-head a {
  color: #5b21f6;
  font-size: 12px;
  font-weight: 800;
}

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

.top-list p {
  align-items: center;
  margin: 0;
}

.top-list span {
  width: 28px;
  height: 28px;
  display: inline-grid;
  place-items: center;
  margin-right: 8px;
  border-radius: 8px;
  background: #e0f2fe;
  color: #0284c7;
  font-weight: 800;
}

.top-list strong {
  margin-left: auto;
}

.reports-bottom-strip {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 0;
  margin: 0 28px 28px;
  padding: 14px;
  background: #faf5ff;
}

.reports-bottom-strip article {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 10px 16px;
  border-right: 1px solid #ddd6fe;
}

.reports-bottom-strip article:last-child {
  border-right: 0;
}

.reports-bottom-strip small,
.reports-bottom-strip p {
  color: var(--muted);
}

.reports-bottom-strip strong {
  display: block;
  margin: 3px 0;
  font-size: 22px;
}

.cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

.cards article,
.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
}

.cards article {
  padding: 16px;
}

.cards span {
  color: var(--muted);
  font-size: 12px;
}

.cards strong {
  display: block;
  margin-top: 6px;
  font-size: 26px;
}

.panel {
  padding: 16px;
  margin-bottom: 14px;
}

.compact-panel {
  padding: 0;
  overflow: hidden;
}

.panel h2,
.panel h3 {
  margin-top: 0;
}

.admin-home-hero {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
  padding: 16px 18px;
  border: 1px solid #e2e8f0;
  border-radius: 10px;
  background: linear-gradient(135deg, #fff, #f8fbff 62%, #fff7ed);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.05);
}

.admin-home-hero .eyebrow {
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.admin-home-hero h2 {
  margin: 5px 0 4px;
  font-size: 26px;
  letter-spacing: -0.03em;
}

.admin-home-hero p,
.admin-home-cards em {
  margin: 0;
  color: #64748b;
  font-style: normal;
}

.admin-home-cards article {
  padding: 14px 16px;
  border-radius: 9px;
  background: linear-gradient(180deg, #fff, #fbfdff);
}

.admin-home-cards strong {
  font-size: 28px;
  letter-spacing: -0.03em;
}

.admin-home-cards em {
  display: block;
  margin-top: 4px;
  font-size: 11px;
  font-weight: 700;
}

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

.admin-chart-panel {
  min-height: 250px;
}

.admin-bar-chart {
  height: 168px;
  display: grid;
  grid-auto-flow: column;
  grid-auto-columns: minmax(74px, 1fr);
  align-items: end;
  gap: 10px;
  padding-top: 14px;
  overflow-x: auto;
}

.admin-bar-chart a {
  height: 100%;
  min-width: 74px;
  display: grid;
  grid-template-rows: 1fr auto auto;
  align-items: end;
  gap: 5px;
  color: #0f172a;
  text-align: center;
  text-decoration: none;
}

.admin-bar-chart a > span {
  width: 100%;
  min-height: 8px;
  align-self: end;
  border-radius: 8px 8px 3px 3px;
  background: linear-gradient(180deg, #2563eb, #93c5fd);
  box-shadow: inset 0 -20px 28px rgba(255, 255, 255, 0.26);
}

.admin-bar-chart.lead-chart a > span {
  background: linear-gradient(180deg, #ff6500, #fdba74);
}

.admin-bar-chart strong {
  font-size: 11px;
}

.admin-bar-chart small {
  color: #64748b;
  font-weight: 800;
}

.admin-module-table-card {
  margin-top: 14px;
}

.admin-module-table td strong,
.admin-module-table td small {
  display: block;
}

.admin-module-table td small {
  color: #64748b;
  font-size: 11px;
}

.status-dot {
  width: 8px;
  height: 8px;
  display: inline-block;
  margin-right: 6px;
  border-radius: 50%;
  background: #94a3b8;
}

.status-dot.good {
  background: #16a34a;
}

.status-dot.warn {
  background: #f97316;
}

.table-wrap {
  width: 100%;
  overflow-x: auto;
}

table {
  width: 100%;
  border-collapse: collapse;
}

.compact-table th,
.compact-table td,
th,
td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

th {
  color: var(--muted);
  background: var(--soft);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 0;
}

td small {
  display: block;
  margin-top: 3px;
}

.entity {
  display: flex;
  align-items: center;
  gap: 10px;
}

.entity-icon {
  width: 34px;
  height: 34px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: #fff3e8;
  color: var(--primary);
  font-weight: 800;
  flex: 0 0 auto;
}

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

.spread {
  justify-content: flex-end;
}

.badge,
.mini {
  display: inline-block;
  border-radius: 999px;
  font-size: 12px;
}

.badge {
  padding: 4px 8px;
  background: #eef2ff;
  color: #1e3a8a;
}

.mini {
  padding: 3px 7px;
  background: #ecfdf5;
  color: #047857;
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
  margin-right: 6px;
  background: var(--muted);
}

.status-dot.ok {
  background: var(--green);
}

.status-dot.off {
  background: var(--danger);
}

.segmented {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
}

.segmented a {
  padding: 7px 10px;
  border-radius: 7px;
  color: var(--muted);
  font-size: 13px;
}

.segmented a:hover {
  color: var(--text);
  background: var(--soft);
}

input,
select,
textarea {
  width: 100%;
  min-height: 36px;
  border-radius: 8px;
  border: 1px solid var(--line);
  padding: 8px 10px;
  background: #fff;
  color: var(--text);
  resize: vertical;
}

input:focus,
select:focus,
textarea:focus {
  border-color: #94a3b8;
  box-shadow: 0 0 0 3px rgba(148, 163, 184, 0.16);
  outline: 0;
}

input[type="file"] {
  padding: 8px;
}

label {
  display: grid;
  gap: 5px;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.check-row {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text);
}

.check-row input {
  width: auto;
  min-height: auto;
}

.native-hidden-select {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.select2-lite {
  position: relative;
  width: 100%;
}

.select2-lite-control {
  min-height: 42px;
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 8px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
  cursor: text;
}

.select2-lite-control:focus-within {
  border-color: #ffb37a;
  box-shadow: 0 0 0 3px rgba(255, 101, 0, 0.12);
}

.select2-lite-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.select2-lite-chips span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 26px;
  padding: 0 7px 0 9px;
  border-radius: 999px;
  background: #fff3e8;
  color: var(--primary-dark);
  font-size: 12px;
  font-weight: 700;
}

.select2-lite-chips button {
  width: 18px;
  min-height: 18px;
  padding: 0;
  border-radius: 50%;
  background: rgba(255, 101, 0, 0.14);
  color: var(--primary-dark);
  line-height: 1;
}

.select2-lite input {
  flex: 1 1 130px;
  min-width: 120px;
  min-height: 28px;
  padding: 0;
  border: 0;
  outline: 0;
}

.select2-lite-menu {
  position: absolute;
  z-index: 80;
  left: 0;
  right: 0;
  top: calc(100% + 6px);
  display: none;
  max-height: 220px;
  overflow-y: auto;
  padding: 6px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.14);
}

.select2-lite.open .select2-lite-menu {
  display: grid;
  gap: 4px;
}

.select2-lite-menu button {
  min-height: 34px;
  justify-content: space-between;
  padding: 0 10px;
  background: #fff;
  color: var(--text);
  border: 0;
  font-weight: 600;
}

.select2-lite-menu button:hover,
.select2-lite-menu button.selected {
  background: #fff7ed;
  color: var(--primary-dark);
}

.select2-lite-menu small {
  color: var(--muted);
}

.modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 18px;
  background: rgba(15, 23, 42, 0.58);
  backdrop-filter: blur(8px);
}

.modal.is-open {
  display: flex;
}

.modal-card {
  width: min(620px, calc(100vw - 32px));
  max-height: calc(100vh - 40px);
  overflow-y: auto;
  padding: 16px;
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 14px;
  background: #fff;
  box-shadow: 0 24px 70px rgba(15, 23, 42, 0.22);
  scrollbar-gutter: stable;
}

.wide-modal .modal-card {
  width: min(1100px, calc(100vw - 32px));
}

.modal-head {
  position: sticky;
  top: -16px;
  z-index: 8;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin: -16px -16px 14px;
  padding: 14px 16px;
  border-bottom: 1px solid #e5e7eb;
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
}

.modal-head h3,
.modal-head h4 {
  margin: 0;
  color: #0f172a;
  font-size: 19px;
  letter-spacing: -0.01em;
}

.modal-head small {
  display: block;
  margin-top: 4px;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.modal-form {
  display: grid;
  gap: 10px;
}

.wizard-form {
  gap: 10px;
}

.wizard-steps {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 4px;
  padding: 5px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #f9fafb;
}

.wizard-steps button {
  min-height: 46px;
  padding: 7px 8px;
  border: 1px solid transparent;
  border-radius: 8px;
  background: transparent;
  color: var(--muted);
  display: grid;
  grid-template-columns: auto 1fr;
  grid-template-rows: 1fr 1fr;
  column-gap: 8px;
  align-items: center;
  justify-content: start;
  text-align: left;
  position: relative;
  overflow: hidden;
}

.wizard-steps button.active {
  background: #fff;
  color: #0f172a;
  border-color: #cbd5e1;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.05);
}

.wizard-steps button.done {
  background: #f0fdf4;
  border-color: #bbf7d0;
  color: #15803d;
}

.wizard-steps button span {
  grid-row: 1 / span 2;
  width: 24px;
  height: 24px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: #fff;
  border: 1px solid var(--line);
  font-size: 12px;
  font-weight: 800;
}

.wizard-steps button strong,
.wizard-steps button small {
  display: block;
  line-height: 1.15;
}

.wizard-steps button strong {
  color: var(--text);
  font-size: 12px;
}

.wizard-steps button small {
  color: var(--muted);
  font-size: 10px;
}

.wizard-panel {
  display: none;
  min-height: 240px;
  padding: 0;
}

.wizard-panel.active {
  display: block;
}

.wizard-section-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 10px;
  padding: 10px 12px;
  border: 1px solid #e5e7eb;
  border-radius: 9px;
  background: #fafafa;
}

.wizard-section-head h4,
.wizard-section-head p {
  margin: 0;
}

.wizard-section-head h4 {
  color: #111827;
  font-size: 14px;
}

.wizard-section-head p {
  max-width: 460px;
  color: var(--muted);
  font-size: 12px;
}

.wizard-actions {
  position: sticky;
  bottom: -16px;
  z-index: 7;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin: 2px -16px -16px;
  padding: 12px 16px;
  border-top: 1px solid var(--line);
  background: rgba(255, 255, 255, 0.96);
  backdrop-filter: blur(12px);
}

.wizard-actions button {
  min-height: 36px;
  border-radius: 8px;
}

.wizard-actions button[disabled] {
  opacity: 0.5;
  cursor: not-allowed;
}

.property-builder-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 14px;
}

.property-builder-head h2,
.property-builder-head p {
  margin: 0;
}

.property-builder-head h2 {
  color: #0f172a;
  font-size: 24px;
  letter-spacing: -0.03em;
}

.property-builder-head p {
  margin-top: 6px;
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.property-builder-head p span {
  margin: 0 6px;
  color: #94a3b8;
}

.property-builder-page {
  min-height: calc(100vh - 150px);
  padding: 16px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #f8fafc;
  box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.module-admin-console #add-listing-modal.wide-modal .modal-card,
.module-admin-console [id^="edit-listing-"].wide-modal .modal-card {
  width: min(96vw, 1440px);
  max-height: 94vh;
  padding: 0;
  border-radius: 12px;
  background: #f8fafc;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

.module-admin-console #add-listing-modal .modal-head,
.module-admin-console [id^="edit-listing-"] .modal-head {
  position: sticky;
  top: 0;
  z-index: 10;
  margin: 0;
  padding: 16px 18px;
  border-bottom: 1px solid #e8edf5;
  background: rgba(255, 255, 255, 0.96);
}

.module-admin-console #add-listing-modal .modal-head h3,
.module-admin-console [id^="edit-listing-"] .modal-head h3 {
  color: #0f172a;
  font-size: 22px;
  letter-spacing: -0.03em;
}

.property-account-console [id^="edit-listing-"] .modal-head h3,
.property-account-console #post-property-modal .modal-head h3 {
  font-size: 21px;
  letter-spacing: -0.02em;
}

.property-account-console [id^="edit-listing-"] .modal-head small,
.property-account-console #post-property-modal .modal-head small {
  margin-top: 3px;
  color: #475569;
  font-size: 12px;
}

.property-account-console [id^="edit-listing-"] .modal-head,
.property-account-console #post-property-modal .modal-head {
  background:
    linear-gradient(90deg, rgba(255, 101, 0, 0.06), rgba(37, 99, 235, 0.04)),
    rgba(255, 255, 255, 0.98);
}

.module-admin-console .property-builder-page,
.module-admin-console #add-listing-modal .listing-form,
.module-admin-console [id^="edit-listing-"] .listing-form {
  padding: 14px;
}

.module-admin-console #add-listing-modal .listing-form,
.module-admin-console [id^="edit-listing-"] .listing-form {
  min-height: 0;
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  scrollbar-gutter: stable;
}

.module-admin-console #add-listing-modal .wizard-panel,
.module-admin-console [id^="edit-listing-"] .wizard-panel {
  min-height: 0;
}

.module-admin-console #add-listing-modal .wizard-panel.active,
.module-admin-console [id^="edit-listing-"] .wizard-panel.active {
  flex: 1 1 auto;
  overflow-y: auto;
  padding-right: 6px;
  padding-bottom: 12px;
  scrollbar-gutter: stable;
}

.module-admin-console .property-builder-page .wizard-steps,
.module-admin-console #add-listing-modal .wizard-steps,
.module-admin-console [id^="edit-listing-"] .wizard-steps {
  position: relative;
  top: auto;
  z-index: 8;
  flex: 0 0 auto;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
  margin: 0 0 12px;
  padding: 9px;
  border: 1px solid #e3eaf3;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff, #f8fafc);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
  overflow: visible;
}

.module-admin-console .property-builder-page .wizard-steps button,
.module-admin-console #add-listing-modal .wizard-steps button,
.module-admin-console [id^="edit-listing-"] .wizard-steps button {
  position: relative;
  min-width: 0;
  min-height: 48px;
  display: grid;
  grid-template-columns: 34px 1fr;
  align-content: center;
  column-gap: 9px;
  padding: 6px 7px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: #475569;
  text-align: left;
}

.module-admin-console .property-builder-page .wizard-steps button::after,
.module-admin-console #add-listing-modal .wizard-steps button::after,
.module-admin-console [id^="edit-listing-"] .wizard-steps button::after {
  content: "";
  position: absolute;
  top: 24px;
  right: -12px;
  left: calc(100% - 8px);
  height: 1px;
  background: #cbd5e1;
}

.module-admin-console .property-builder-page .wizard-steps button:last-child::after,
.module-admin-console #add-listing-modal .wizard-steps button:last-child::after,
.module-admin-console [id^="edit-listing-"] .wizard-steps button:last-child::after {
  display: none;
}

.module-admin-console .property-builder-page .wizard-steps button span,
.module-admin-console #add-listing-modal .wizard-steps button span,
.module-admin-console [id^="edit-listing-"] .wizard-steps button span {
  grid-row: span 2;
  width: 28px;
  height: 28px;
  border: 1px solid #cbd5e1;
  border-radius: 50%;
  background: #fff;
  color: #64748b;
  font-size: 12px;
}

.module-admin-console .property-builder-page .wizard-steps button strong,
.module-admin-console #add-listing-modal .wizard-steps button strong,
.module-admin-console [id^="edit-listing-"] .wizard-steps button strong {
  color: #1e293b;
  font-size: 12px;
}

.module-admin-console .property-builder-page .wizard-steps button small,
.module-admin-console #add-listing-modal .wizard-steps button small,
.module-admin-console [id^="edit-listing-"] .wizard-steps button small {
  color: #64748b;
  font-size: 10px;
}

.module-admin-console .property-builder-page .wizard-steps button.active span,
.module-admin-console #add-listing-modal .wizard-steps button.active span,
.module-admin-console [id^="edit-listing-"] .wizard-steps button.active span,
.module-admin-console .property-builder-page .wizard-steps button.done span,
.module-admin-console #add-listing-modal .wizard-steps button.done span,
.module-admin-console [id^="edit-listing-"] .wizard-steps button.done span {
  border-color: #2563eb;
  background: #2563eb;
  color: #fff;
}

.module-admin-console .property-builder-page .wizard-steps button.active,
.module-admin-console #add-listing-modal .wizard-steps button.active,
.module-admin-console [id^="edit-listing-"] .wizard-steps button.active {
  background: #fff;
  box-shadow: 0 10px 20px rgba(15, 23, 42, 0.06);
}

.property-step-panel .wizard-section-head {
  display: none;
}

.property-admin-form-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(360px, 0.9fr);
  gap: 14px;
}

.property-admin-main,
.property-admin-side {
  display: grid;
  align-content: start;
  gap: 14px;
}

.property-form-card {
  position: relative;
  overflow: hidden;
  padding: 14px 16px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
}

.property-form-card::before {
  content: "";
  position: absolute;
  inset: 0 0 auto;
  height: 3px;
  background: linear-gradient(90deg, #ff6500, #2563eb, #16a34a);
}

.property-form-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.property-form-title h4,
.property-form-title small {
  margin: 0;
}

.property-form-title h4 {
  color: #0f172a;
  font-size: 16px;
  letter-spacing: -0.02em;
}

.property-form-title small {
  color: #64748b;
  font-size: 11px;
  font-weight: 700;
}

.property-core-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 12px;
}

.account-property-core-strip {
  grid-template-columns: 1fr;
  margin-bottom: 0;
}

.account-property-core-strip + .property-dynamic-fields .dynamic-grid {
  grid-template-columns: minmax(260px, 0.72fr) minmax(320px, 1fr);
  align-items: end;
}

.account-property-core-strip + .property-dynamic-fields .category-picker {
  grid-column: 1 / -1;
}

.account-snapshot-side {
  display: grid;
}

.account-listing-snapshot {
  min-height: 100%;
  display: grid;
  align-content: center;
  gap: 12px;
  padding: 20px;
  border: 1px solid #dbeafe;
  border-radius: 12px;
  background:
    radial-gradient(circle at 82% 20%, rgba(255, 101, 0, 0.18), transparent 24%),
    linear-gradient(135deg, #eff6ff, #fff 48%, #fff7ed);
  box-shadow: 0 14px 30px rgba(15, 23, 42, 0.05);
}

.account-listing-snapshot span {
  width: max-content;
  padding: 4px 9px;
  border-radius: 999px;
  background: #dbeafe;
  color: #1d4ed8;
  font-size: 10px;
  font-weight: 900;
  text-transform: uppercase;
}

.account-listing-snapshot h4,
.account-listing-snapshot p {
  margin: 0;
}

.account-listing-snapshot h4 {
  max-width: 260px;
  color: #0f172a;
  font-size: 20px;
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.account-listing-snapshot p {
  max-width: 280px;
  color: #475569;
  font-size: 12px;
  line-height: 1.55;
  font-weight: 750;
}

.account-listing-snapshot div {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.account-listing-snapshot small {
  padding: 6px 8px;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.82);
  color: #334155;
  font-size: 10px;
  font-weight: 900;
}

.property-core-strip label,
.property-dynamic-fields label,
.media-url-field {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.property-core-strip input:not([type="checkbox"]),
.property-core-strip select,
.property-dynamic-fields input:not([type="checkbox"]),
.property-dynamic-fields select,
.property-dynamic-fields textarea,
.media-url-field textarea,
.category-picker select {
  min-height: 38px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #fbfdff);
  color: #0f172a;
  font-size: 12px;
  box-shadow: inset 0 1px 1px rgba(15, 23, 42, 0.03);
}

.property-core-strip input:focus,
.property-core-strip select:focus,
.property-dynamic-fields input:focus,
.property-dynamic-fields select:focus,
.property-dynamic-fields textarea:focus,
.media-url-field textarea:focus,
.category-picker select:focus {
  border-color: #ff9b4d;
  box-shadow: 0 0 0 3px rgba(255, 101, 0, 0.12);
  outline: 0;
}

.category-picker {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  padding: 12px;
  border: 1px solid #e4eaf3;
  border-radius: 10px;
  background: #f8fbff;
}

.category-picker label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.category-picker select:disabled {
  color: #94a3b8;
  background: #f8fafc;
  cursor: not-allowed;
}

.property-feature-check {
  min-height: 46px;
  align-self: end;
  display: flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: 10px !important;
  padding: 8px 12px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #f8fafc);
  color: #0f172a;
  cursor: pointer;
}

.property-feature-check input {
  position: relative;
  width: 18px;
  height: 18px;
  flex: 0 0 18px;
  margin: 0;
  appearance: none;
  border: 1px solid #cbd5e1;
  border-radius: 5px;
  background: #fff;
  box-shadow: inset 0 1px 1px rgba(15, 23, 42, 0.04);
}

.property-feature-check input:checked {
  border-color: #2563eb;
  background: #2563eb;
}

.property-feature-check input:checked::after {
  content: "";
  position: absolute;
  left: 5px;
  top: 2px;
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.property-feature-check span {
  display: grid;
  gap: 2px;
  line-height: 1.1;
}

.property-feature-check strong {
  color: #0f172a;
  font-size: 12px;
}

.property-feature-check small {
  color: #64748b;
  font-size: 10px;
  font-weight: 700;
}

.property-feature-check:has(input:checked) {
  border-color: #bfdbfe;
  background: linear-gradient(180deg, #eff6ff, #fff);
}

.property-dynamic-fields {
  margin-top: 0;
}

.property-dynamic-fields .dynamic-title {
  display: none;
}

.property-dynamic-fields .dynamic-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.property-admin-side .property-dynamic-fields .dynamic-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.property-dynamic-fields textarea {
  min-height: 88px;
}

.html-editor-field {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid #dbe4ef;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff, #f8fafc);
}

.html-editor-label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

.html-editor-label span {
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.html-editor-label small {
  color: #64748b;
  font-size: 10px;
  font-weight: 800;
}

.html-editor-toolbar {
  display: flex;
  gap: 6px;
}

.html-editor-toolbar button {
  min-width: 34px;
  min-height: 28px;
  padding: 0 10px;
  border: 1px solid #dbe4ef;
  border-radius: 7px;
  background: #fff;
  color: #0f172a;
  font-size: 11px;
  font-weight: 850;
}

.html-editor-toolbar button:hover {
  border-color: #ff9b4d;
  background: #fff7ed;
}

.html-editor-box {
  min-height: 92px;
  padding: 10px 11px;
  border: 1px solid #dbe4ef;
  border-radius: 9px;
  background: #fff;
  color: #0f172a;
  font-size: 13px;
  line-height: 1.5;
  outline: 0;
}

.html-editor-box:focus {
  border-color: #ff9b4d;
  box-shadow: 0 0 0 3px rgba(255, 101, 0, 0.12);
}

.html-editor-box:empty::before {
  content: attr(data-placeholder);
  color: #94a3b8;
}

.property-dynamic-fields .dynamic-check {
  min-height: 40px;
  display: flex !important;
  align-items: center;
  justify-content: flex-start;
  gap: 9px !important;
  padding: 9px 11px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: #fff;
  color: #334155;
  cursor: pointer;
}

.property-dynamic-fields .dynamic-check input {
  position: relative;
  width: 16px;
  height: 16px;
  flex: 0 0 16px;
  min-height: 0;
  margin: 0;
  appearance: none;
  border: 1px solid #cbd5e1;
  border-radius: 4px;
  background: #fff;
}

.property-dynamic-fields .dynamic-check input:checked {
  border-color: #2563eb;
  background: #2563eb;
}

.property-dynamic-fields .dynamic-check input:checked::after {
  content: "";
  position: absolute;
  left: 4px;
  top: 1px;
  width: 5px;
  height: 9px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.property-dynamic-fields .dynamic-check span {
  color: #334155;
  font-size: 12px;
  font-weight: 850;
}

.property-dynamic-fields .dynamic-check:has(input:checked) {
  border-color: #bfdbfe;
  background: #eff6ff;
}

.property-dynamic-fields .compact-option-grid {
  grid-template-columns: repeat(auto-fit, minmax(145px, 1fr));
  gap: 8px;
}

.property-dynamic-fields .compact-option-pill {
  min-height: 36px;
  place-items: stretch;
  align-items: center;
  justify-content: start;
  padding: 0 10px;
  text-align: left;
}

.property-dynamic-fields .compact-option-pill span {
  display: flex;
  align-items: center;
  color: #334155;
  font-size: 12px;
  line-height: 1.2;
}

.property-dynamic-fields .compact-option-pill:has(input:checked) {
  border-color: #2563eb;
  background: #eff6ff;
}

.property-dynamic-fields .compact-option-pill:has(input:checked) span {
  color: #1d4ed8;
}

.property-dynamic-fields .distance-input-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.property-dynamic-fields .distance-field {
  display: grid;
  gap: 5px;
  padding: 9px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: #fff;
}

.property-dynamic-fields .distance-field span {
  color: #475569;
  font-size: 11px;
  font-weight: 850;
}

.property-dynamic-fields .distance-field input {
  min-height: 34px;
  border: 1px solid #dbe4ef;
  border-radius: 7px;
  padding: 0 10px;
  background: #f8fafc;
  color: #0f172a;
  font-size: 12px;
}

.custom-option-wrapper {
  display: grid;
  gap: 8px;
}

.custom-option-wrapper > label {
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.custom-option-add {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 8px;
  padding: 8px;
  border: 1px solid #e3eaf3;
  border-radius: 9px;
  background: #f8fafc;
}

.custom-option-add.has-distance {
  grid-template-columns: minmax(180px, 1fr) 130px 130px auto;
}

.custom-option-add input,
.custom-option-add select {
  min-height: 34px !important;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: #fff;
  color: #0f172a;
  font-size: 12px;
}

.custom-option-add button {
  min-height: 34px;
  padding: 0 14px;
  border-radius: 8px;
  font-size: 12px;
}

.distance-control-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 116px;
  gap: 6px;
}

.property-dynamic-fields .distance-control-row input,
.property-dynamic-fields .distance-control-row select {
  min-height: 34px;
  border: 1px solid #dbe4ef;
  border-radius: 7px;
  padding: 0 10px;
  background: #f8fafc;
  color: #0f172a;
  font-size: 12px;
}

.count-toggle-field {
  min-height: 42px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  align-items: center;
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #fbfdff);
}

.count-toggle-field .toggle-line {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 9px;
  color: #334155;
  font-size: 12px;
  font-weight: 850;
  cursor: pointer;
}

.count-toggle-field .toggle-line input {
  position: relative;
  width: 34px;
  height: 18px;
  min-height: 0;
  flex: 0 0 34px;
  margin: 0;
  appearance: none;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  background: #e2e8f0;
  transition: 0.18s ease;
}

.count-toggle-field .toggle-line input::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(15, 23, 42, 0.18);
  transition: 0.18s ease;
}

.count-toggle-field .toggle-line input:checked {
  border-color: #2563eb;
  background: #2563eb;
}

.count-toggle-field .toggle-line input:checked::after {
  transform: translateX(16px);
}

.count-stepper {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 42px;
  gap: 5px;
  align-items: center;
}

.count-stepper button {
  min-height: 32px;
  padding: 0;
  border-radius: 7px;
  font-size: 12px;
  font-weight: 900;
}

.count-stepper input {
  min-height: 32px !important;
  border-radius: 7px !important;
  text-align: center;
}

.count-stepper input:disabled {
  color: #94a3b8;
  background: #f1f5f9;
}

.property-contact-toggle-group {
  padding: 8px;
  border: 1px solid #e3eaf3;
  border-radius: 10px;
  background: #f8fafc;
}

.property-contact-toggle-group .store-contact-toggle-grid {
  grid-template-columns: 1fr;
}

.property-contact-toggle-group .store-storage-switch {
  min-height: 34px;
}

.property-contact-toggle-group input[data-contact-value] {
  min-height: 34px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: #fff;
}

.property-upload-drop {
  min-height: 150px;
  display: grid;
  place-items: center;
  gap: 7px;
  margin-bottom: 10px;
  padding: 18px;
  border: 1px dashed #94a3b8;
  border-radius: 10px;
  background: linear-gradient(135deg, #f8fafc, #fff7ed);
  color: #0f172a;
  text-align: center;
  cursor: pointer;
}

.property-upload-drop input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.property-upload-drop strong {
  color: #0f172a;
  font-size: 13px;
}

.property-upload-drop small {
  color: #64748b;
  font-size: 11px;
}

.media-card .current-images {
  margin-bottom: 10px;
}

.upload-preview-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 8px;
  margin: -2px 0 10px;
}

.current-image-item {
  position: relative;
  min-width: 0;
}

.upload-preview-item img,
.current-image-item img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border: 1px solid #e5e7eb;
  border-radius: 7px;
  background: #fff;
}

.current-image-item button {
  position: absolute;
  top: -6px;
  right: -6px;
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border: 1px solid #fecaca;
  border-radius: 50%;
  background: #fff;
  color: #dc2626;
  font-size: 17px;
  line-height: 1;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.media-extra-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.media-extra-grid label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.media-extra-grid input {
  min-height: 38px;
  border: 1px solid #dbe4ef;
  border-radius: 8px;
  background: linear-gradient(180deg, #fff, #fbfdff);
  color: #0f172a;
  font-size: 12px;
}

.featured-upload-field {
  min-height: 100%;
}

.featured-upload-field input[type="file"] {
  padding: 8px;
}

.featured-upload-preview {
  display: block;
  min-height: 46px;
  border: 1px dashed #cbd5e1;
  border-radius: 8px;
  background: #f8fafc;
  overflow: hidden;
}

.featured-upload-preview:empty {
  display: none;
}

.featured-upload-preview img {
  width: 100%;
  height: 76px;
  display: block;
  object-fit: cover;
}

.contact-toggle-group {
  display: grid;
  gap: 9px;
}

.contact-toggle-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
}

.contact-toggle-field {
  display: grid;
  gap: 8px;
  padding: 9px;
  border: 1px solid #dbe4ef;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff, #f8fafc);
}

.contact-toggle-field .toggle-line {
  display: flex;
  align-items: center;
  gap: 9px;
  color: #0f172a;
  font-size: 12px;
  font-weight: 850;
}

.contact-toggle-field .toggle-line input {
  position: relative;
  width: 34px;
  height: 18px;
  min-height: 0;
  margin: 0;
  appearance: none;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  background: #e2e8f0;
}

.contact-toggle-field .toggle-line input::after {
  content: "";
  position: absolute;
  top: 2px;
  left: 2px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #fff;
  transition: 0.18s ease;
}

.contact-toggle-field .toggle-line input:checked {
  border-color: #2563eb;
  background: #2563eb;
}

.contact-toggle-field .toggle-line input:checked::after {
  transform: translateX(16px);
}

.contact-toggle-field > input {
  min-height: 34px !important;
}

.contact-toggle-field > input[hidden] {
  display: none;
}

.area-unit-field {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 180px;
  gap: 12px;
  align-items: end;
  padding: 10px;
  border: 1px solid #e3eaf3;
  border-radius: 10px;
  background: #f8fafc;
}

.area-unit-field label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.location-extra-field {
  display: grid;
  gap: 10px;
  padding: 10px;
  border: 1px solid #e3eaf3;
  border-radius: 10px;
  background: #f8fafc;
}

.location-extra-field label {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 11px;
  font-weight: 900;
}

.location-extra-field textarea {
  min-height: 76px !important;
  resize: vertical;
}

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

.property-map-preview {
  position: relative;
  min-height: 116px;
  margin-bottom: 12px;
  border: 1px solid #e8edf5;
  border-radius: 10px;
  background:
    linear-gradient(25deg, transparent 48%, rgba(37, 99, 235, 0.12) 49%, transparent 51%),
    linear-gradient(145deg, #eef8f2, #f8fbff);
  overflow: hidden;
}

.property-map-preview::before,
.property-map-preview::after {
  content: "";
  position: absolute;
  background: rgba(148, 163, 184, 0.28);
}

.property-map-preview::before {
  width: 140%;
  height: 2px;
  top: 45%;
  left: -20%;
  transform: rotate(-12deg);
}

.property-map-preview::after {
  width: 2px;
  height: 140%;
  top: -20%;
  left: 38%;
  transform: rotate(12deg);
}

.property-map-preview b {
  position: absolute;
  inset: 44px auto auto 55%;
  width: 18px;
  height: 18px;
  border-radius: 50% 50% 50% 0;
  background: #ef4444;
  transform: rotate(-45deg);
}

.property-map-preview span,
.property-map-preview em {
  position: absolute;
  color: #64748b;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.property-map-preview span {
  top: 28px;
  left: 22px;
  color: #ef4444;
}

.property-map-preview em {
  right: 34px;
  bottom: 26px;
  color: #16a34a;
}

.property-map-preview.has-live-map {
  display: grid;
  place-items: stretch;
  background: #f8fafc;
}

.property-map-preview iframe {
  width: 100%;
  height: 100%;
  min-height: 116px;
  border: 0;
}

.map-link-preview {
  display: grid;
  place-content: center;
  justify-items: center;
  gap: 7px;
  padding: 14px;
  text-align: center;
}

.map-link-preview strong {
  color: #0f172a;
  font-size: 13px;
}

.map-link-preview small {
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.map-link-preview a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 32px;
  padding: 0 14px;
  border-radius: 8px;
  background: #ff6500;
  color: #fff;
  font-size: 12px;
  font-weight: 900;
}

.property-step-note {
  padding: 18px;
  border: 1px solid #e8edf5;
  border-radius: 12px;
  background: #fff;
  color: #64748b;
  font-weight: 800;
}

.property-side-note {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid #dbeafe;
  border-radius: 10px;
  background: linear-gradient(135deg, #eff6ff, #fff);
}

.property-side-note strong {
  color: #1e3a8a;
  font-size: 13px;
}

.property-side-note p {
  margin: 0;
  color: #64748b;
  font-size: 12px;
  line-height: 1.45;
}

.module-admin-console .property-builder-page .wizard-actions,
.module-admin-console #add-listing-modal .wizard-actions,
.module-admin-console [id^="edit-listing-"] .wizard-actions {
  position: relative;
  z-index: 9;
  flex: 0 0 auto;
  bottom: auto;
  margin: 12px 0 0;
  padding: 10px;
  border: 1px solid #e3eaf3;
  border-radius: 10px;
  background: linear-gradient(180deg, #fff, #f8fafc);
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.04);
  backdrop-filter: none;
}

.review-box {
  padding: 14px;
  border: 1px solid #e4eaf3;
  border-radius: 12px;
  background: linear-gradient(135deg, #ffffff, #f8fafc);
  box-shadow: 0 16px 34px rgba(15, 23, 42, 0.06);
  display: grid;
  gap: 12px;
}

.compact-review-box {
  max-width: 760px;
  margin: 0 auto;
}

.review-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.review-title-row span {
  padding: 6px 10px;
  border: 1px solid #fed7aa;
  border-radius: 999px;
  background: #fff7ed;
  color: #c2410c;
  font-size: 11px;
  font-weight: 900;
}

.review-box h4 {
  margin: 0 0 4px;
  font-size: 17px;
}

.review-box p {
  margin: 0;
}

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

.review-stats span {
  padding: 10px;
  border: 1px solid #e4eaf3;
  border-radius: 9px;
  background: #fff;
}

.review-stats small,
.review-stats strong {
  display: block;
}

.review-stats small {
  color: var(--muted);
  font-size: 11px;
}

.review-stats strong {
  margin-top: 3px;
  font-size: 13px;
}

.grid-form {
  grid-template-columns: repeat(3, 1fr);
}

.span-full {
  grid-column: 1 / -1;
}

.modal-actions {
  justify-content: flex-end;
  padding-top: 4px;
}

.field-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
}

.field-card {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
}

.dynamic-fields {
  margin-top: 12px;
  padding: 0;
  border: 0;
  border-radius: 12px;
  background: transparent;
}

.dynamic-fields:empty {
  display: none;
}

.dynamic-title {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
  padding: 9px 10px;
  border: 1px solid #e5e7eb;
  border-radius: 9px;
  background: #fafafa;
}

.dynamic-title strong,
.dynamic-title small {
  display: block;
}

.dynamic-title strong {
  width: fit-content;
  padding: 0;
  border-radius: 999px;
  background: transparent;
  color: #0f172a;
  font-size: 12px;
  letter-spacing: 0;
  text-transform: none;
}

.dynamic-title small {
  align-self: center;
  color: var(--muted);
  font-weight: 700;
  font-size: 11px;
}

.dynamic-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px 12px;
  padding: 0 0 4px;
}

.dynamic-grid label {
  gap: 5px;
  color: #475569;
  font-size: 11px;
  font-weight: 800;
}

.dynamic-grid input,
.dynamic-grid select,
.dynamic-grid textarea {
  min-height: 36px;
  border-color: #e1e8f0;
  border-radius: 9px;
  background: #fff;
}

.dynamic-grid textarea {
  min-height: 84px;
  padding-top: 9px;
  resize: vertical;
}

.dynamic-grid select[multiple] {
  min-height: 108px;
  padding: 8px;
}

.locked-module-card {
  min-height: 58px;
  padding: 10px 12px;
  display: grid;
  align-content: center;
  gap: 3px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #f8fafc;
}

.locked-module-card span,
.locked-module-card small {
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
}

.locked-module-card strong {
  color: #0f172a;
  font-size: 15px;
}

.vehicle-single-form {
  display: grid;
  gap: 14px;
  padding: 2px 0 0;
}

.vehicle-form-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 10px 8px;
}

.vehicle-form-grid label {
  grid-column: span 3;
  display: grid;
  gap: 6px;
  color: #3f3f46;
  font-size: 12px;
  font-weight: 700;
}

.vehicle-form-grid input,
.vehicle-form-grid select,
.vehicle-form-grid textarea {
  min-height: 30px;
  padding: 6px 9px;
  border: 1px solid #dde5ef;
  border-radius: 5px;
  background: #fff;
  color: #111827;
  font-size: 13px;
  outline: none;
}

.vehicle-form-grid textarea {
  min-height: 48px;
  resize: vertical;
}

.vehicle-form-grid input:focus,
.vehicle-form-grid select:focus,
.vehicle-form-grid textarea:focus {
  border-color: #ff6500;
  box-shadow: 0 0 0 2px rgba(255, 101, 0, 0.08);
}

.vehicle-span-4 {
  grid-column: span 4 !important;
}

.vehicle-span-full {
  grid-column: 1 / -1 !important;
}

.vehicle-toggle-label {
  align-content: center;
}

.vehicle-switch {
  width: fit-content;
}

.vehicle-current-images {
  display: flex;
  gap: 8px;
  padding: 8px;
  border: 1px solid #e5edf5;
  border-radius: 7px;
  background: #f8fafc;
  overflow-x: auto;
}

.vehicle-current-images img {
  width: 68px;
  height: 48px;
  border-radius: 5px;
  object-fit: cover;
  border: 1px solid #dbe3ee;
}

.vehicle-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding-top: 8px;
  border-top: 1px solid #edf1f6;
}

.vehicle-form-actions button {
  min-height: 32px;
  border-radius: 5px;
}

.vehicle-brand-select-label {
  position: relative;
}

.vehicle-brand-form-preview {
  position: absolute;
  right: 7px;
  bottom: 4px;
  width: 34px;
  height: 24px;
  padding: 3px;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  background: #fff;
}

.vehicle-brand-form-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}

.vehicle-brand-shell {
  display: grid;
  grid-template-columns: 340px 1fr;
  gap: 14px;
  padding: 0 18px 22px;
}

.vehicle-brand-card {
  border-radius: 6px;
}

.vehicle-brand-table-shell {
  padding: 0 18px 22px;
}

.vehicle-brand-table-head {
  align-items: center;
  margin-bottom: 10px;
}

.vehicle-brand-table-head h3 {
  margin: 0;
  font-size: 18px;
}

.vehicle-brand-filter-bar {
  display: grid;
  grid-template-columns: minmax(220px, 1.5fr) minmax(180px, 0.9fr) auto auto;
  gap: 8px;
  align-items: end;
  margin: 0 0 10px;
  padding: 10px;
  border: 1px solid #e5edf5;
  border-radius: 8px;
  background: #f8fafc;
}

.vehicle-brand-filter-bar label,
.vehicle-brand-modal-form label {
  display: grid;
  gap: 5px;
  color: #475569;
  font-size: 12px;
  font-weight: 700;
}

.vehicle-brand-filter-bar input,
.vehicle-brand-filter-bar select,
.vehicle-brand-modal-form input,
.vehicle-brand-modal-form select {
  min-height: 34px;
  border-radius: 7px;
  border-color: #dbe5f0;
  color: #0f172a;
  font-size: 13px;
  font-weight: 600;
}

.vehicle-brand-filter-bar button,
.vehicle-brand-filter-bar .button,
.vehicle-brand-row-actions .button,
.vehicle-brand-table-head .button {
  min-height: 34px;
  padding: 8px 13px;
  border-radius: 7px;
  font-size: 12px;
}

.vehicle-brand-table-wrap {
  border: 1px solid #e5edf5;
  border-radius: 8px;
  overflow: auto;
}

.vehicle-brand-table {
  min-width: 860px;
}

.vehicle-brand-table th {
  font-size: 11px;
  letter-spacing: 0.02em;
}

.vehicle-brand-table td {
  vertical-align: middle;
  font-size: 13px;
}

.vehicle-brand-table td small {
  display: block;
  margin-top: 2px;
  color: #64748b;
  font-size: 11px;
}

.vehicle-brand-name {
  display: block;
  color: #0f172a;
  font-size: 14px;
}

.vehicle-brand-scope {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 4px 8px;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #fff;
  color: #475569;
  font-size: 11px;
  font-weight: 800;
}

.vehicle-brand-row-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.vehicle-brand-row-actions form {
  margin: 0;
}

.vehicle-brand-modal .modal-card {
  width: min(680px, calc(100vw - 32px));
  border-radius: 10px;
}

.vehicle-brand-modal-form {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.vehicle-brand-full {
  grid-column: 1 / -1;
}

.vehicle-brand-current-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px;
  border: 1px solid #e5edf5;
  border-radius: 8px;
  background: #f8fafc;
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.vehicle-brand-current-logo img {
  width: 48px;
  height: 48px;
  object-fit: contain;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #fff;
}

@media (max-width: 860px) {
  .vehicle-brand-table-shell {
    padding: 0 10px 18px;
  }

  .vehicle-brand-filter-bar {
    grid-template-columns: 1fr 1fr;
  }

  .vehicle-brand-filter-bar label:first-child {
    grid-column: 1 / -1;
  }

  .vehicle-brand-modal-form {
    grid-template-columns: 1fr;
  }

  .vehicle-brand-table-head {
    gap: 8px;
  }
}

@media (max-width: 560px) {
  .vehicle-brand-filter-bar {
    grid-template-columns: 1fr;
  }

  .vehicle-brand-table-head {
    align-items: flex-start;
  }

  .vehicle-brand-table-head .button {
    width: 100%;
  }
}

.vehicle-brand-card .listing-card-head {
  margin-bottom: 10px;
}

.vehicle-brand-form {
  display: grid;
  gap: 10px;
}

.vehicle-brand-form label {
  display: grid;
  gap: 6px;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.vehicle-brand-category-box {
  display: grid;
  gap: 6px;
  padding: 8px;
  border: 1px solid #e5edf5;
  border-radius: 6px;
  background: #f8fafc;
}

.vehicle-brand-category-box strong,
.vehicle-brand-category-box small {
  display: block;
}

.vehicle-brand-category-box strong {
  color: #0f172a;
  font-size: 12px;
}

.vehicle-brand-category-box small {
  color: #64748b;
  font-size: 11px;
}

.vehicle-brand-category-box div {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.vehicle-brand-category-box label {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 5px 7px;
  border: 1px solid #e2e8f0;
  border-radius: 999px;
  background: #fff;
  color: #334155;
  font-size: 11px;
  font-weight: 700;
}

.vehicle-brand-category-box.compact {
  padding: 6px;
}

.vehicle-brand-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 8px;
}

.vehicle-brand-edit-grid {
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
}

.vehicle-brand-pill {
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 7px 8px;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  background: #fff;
}

.vehicle-brand-edit-card {
  align-items: flex-start;
  padding: 9px;
}

.vehicle-brand-logo {
  width: 44px;
  height: 44px;
  flex: 0 0 44px;
  display: grid;
  place-items: center;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #fff7ed;
  overflow: hidden;
}

.vehicle-brand-logo.table-logo {
  width: 42px;
  height: 42px;
  flex-basis: 42px;
  border-radius: 9px;
}

.vehicle-brand-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #fff;
}

.vehicle-brand-pill span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 6px;
  background: #fff7ed;
  color: #ff6500;
  font-size: 12px;
  font-weight: 900;
}

.vehicle-brand-edit-body {
  flex: 1;
  display: grid;
  gap: 7px;
}

.vehicle-brand-edit-row {
  display: grid;
  grid-template-columns: 110px 1fr;
  gap: 6px;
}

.vehicle-brand-edit-body input,
.vehicle-brand-edit-body select,
.vehicle-brand-form input,
.vehicle-brand-form select {
  min-height: 32px;
  border-radius: 6px;
  border-color: #e2e8f0;
  font-size: 12px;
}

.vehicle-brand-card-actions {
  display: flex;
  justify-content: flex-end;
}

.vehicle-brand-delete-form {
  align-self: end;
}

.vehicle-brand-pill strong {
  flex: 1;
  color: #0f172a;
  font-size: 13px;
}

.vehicle-brand-pill form {
  margin: 0;
}

.vehicle-brand-pill .icon-btn {
  width: 28px;
  height: 28px;
  color: #dc2626;
}

.option-pill-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(110px, 1fr));
  gap: 8px;
}

.option-pill {
  position: relative;
  min-height: 40px;
  display: grid !important;
  place-items: center;
  border: 1px solid #e1e8f0;
  border-radius: 9px;
  background: #fff;
  color: #334155;
  cursor: pointer;
}

.option-pill input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.option-pill span {
  font-weight: 900;
}

.option-pill:has(input:checked) {
  border-color: #0f172a;
  background: #f8fafc;
  color: #0f172a;
  box-shadow: none;
}

.property-option-builder {
  margin: 8px 0 0;
  padding: 12px;
  border: 1px solid #e4eaf3;
  border-radius: 10px;
  background: linear-gradient(135deg, #ffffff, #f8fafc);
  box-shadow: 0 8px 22px rgba(15, 23, 42, 0.04);
}

.property-option-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}

.property-option-head strong,
.property-option-head small {
  display: block;
}

.property-option-head strong {
  color: #0f172a;
  font-size: 13px;
}

.property-option-head small {
  color: #64748b;
  font-weight: 700;
  font-size: 11px;
}

.property-option-builder h4 {
  margin: 10px 0 7px;
  color: #334155;
  font-size: 12px;
}

.property-option-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.property-option-grid label {
  min-height: 34px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 10px;
  border: 1px solid #e8e2ff;
  border-radius: 8px;
  background: #fff;
  color: #334155;
  font-size: 12px;
  font-weight: 700;
}

.property-option-grid input {
  width: 15px;
  height: 15px;
  accent-color: #0f7bd8;
}

.dynamic-check {
  align-self: end;
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #fff;
}

.field-tags {
  min-height: 22px;
}

.summary-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 14px;
}

.summary-list div {
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: var(--soft);
}

.summary-list span,
.summary-list strong {
  display: block;
}

.summary-list span {
  color: var(--muted);
  font-size: 12px;
}

.note-box {
  padding: 12px;
  margin-bottom: 14px;
  border: 1px solid #fde6d1;
  border-radius: 8px;
  background: #fffaf5;
  color: var(--text);
}

.login-page {
  min-height: 100vh;
  display: grid;
  place-items: center;
  background: radial-gradient(circle at top, #fff3e8, var(--bg) 48%);
}

.admin-login-page {
  background:
    radial-gradient(circle at 12% 12%, rgba(255, 101, 0, 0.16), transparent 28%),
    radial-gradient(circle at 88% 16%, rgba(37, 99, 235, 0.14), transparent 30%),
    linear-gradient(135deg, #f8fafc, #eef4fb);
}

.admin-login-shell {
  width: min(980px, calc(100vw - 32px));
  min-height: 560px;
  display: grid;
  grid-template-columns: 1fr 430px;
  overflow: hidden;
  border: 1px solid #dfe7f2;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 28px 70px rgba(15, 23, 42, 0.16);
}

.admin-login-brand {
  display: grid;
  align-content: center;
  gap: 16px;
  padding: 44px;
  background:
    linear-gradient(135deg, rgba(6, 20, 36, 0.96), rgba(10, 28, 48, 0.96)),
    linear-gradient(135deg, #ff6500, #2563eb);
  color: #fff;
}

.login-brand-mark {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: linear-gradient(135deg, #ff6500, #0ea5e9);
  color: #061424;
  font-size: 18px;
  font-weight: 950;
}

.admin-login-brand h1,
.admin-login-brand p {
  margin: 0;
}

.admin-login-brand h1 {
  font-size: 34px;
  letter-spacing: -0.04em;
}

.admin-login-brand p {
  max-width: 420px;
  color: #cbd5e1;
  font-size: 14px;
  line-height: 1.6;
}

.login-feature-list {
  display: grid;
  gap: 9px;
  margin-top: 10px;
}

.login-feature-list span {
  min-height: 38px;
  display: flex;
  align-items: center;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.08);
  color: #e2e8f0;
  font-weight: 800;
}

.login-card {
  width: min(420px, calc(100vw - 32px));
  padding: 28px;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 10px;
  display: grid;
  gap: 12px;
  box-shadow: 0 16px 50px rgba(15, 23, 42, 0.1);
}

.admin-login-card {
  width: auto;
  padding: 42px;
  border: 0;
  border-radius: 0;
  align-content: center;
  box-shadow: none;
}

.account-login-shell {
  grid-template-columns: 0.95fr 430px;
}

.register-login-shell {
  width: min(1080px, calc(100vw - 32px));
  grid-template-columns: 0.8fr 1fr;
}

.register-card {
  max-height: 90vh;
  overflow-y: auto;
}

.admin-login-card h2,
.admin-login-card p {
  margin: 0;
}

.admin-login-card h2 {
  margin-top: 8px;
  color: #0f172a;
  font-size: 28px;
  letter-spacing: -0.03em;
}

.admin-login-card label {
  display: grid;
  gap: 7px;
  color: #334155;
  font-size: 12px;
  font-weight: 900;
}

.admin-login-card input {
  min-height: 42px;
  border: 1px solid #dbe4ef;
  border-radius: 9px;
  background: #fff;
}

.login-card-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.login-card-row a {
  color: #2563eb;
  font-size: 12px;
  font-weight: 900;
}

.login-remember {
  display: flex !important;
  align-items: center;
  gap: 8px !important;
}

.login-remember input {
  min-height: 0;
  width: 15px;
  height: 15px;
}

.mobile-login-top,
.mobile-login-logo,
.mobile-auth-tabs,
.mobile-social-divider,
.mobile-social-row,
.mobile-secure-card,
.mobile-login-terms {
  display: none;
}

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

.alert {
  padding: 12px;
  border-radius: 8px;
  background: #fee2e2;
  color: #991b1b;
}

.success-alert {
  padding: 12px;
  border-radius: 8px;
  border: 1px solid #bbf7d0;
  background: #f0fdf4;
  color: #166534;
  font-weight: 700;
}

.customer-dashboard-hero {
  margin: 0 28px 16px;
  padding: 24px;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 18px;
  border: 1px solid #dfe7f2;
  border-radius: 14px;
  background:
    radial-gradient(circle at 90% 12%, rgba(255, 101, 0, 0.12), transparent 30%),
    linear-gradient(135deg, #ffffff, #f8fbff);
  box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06);
}

.customer-dashboard-hero span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 9px;
  border-radius: 999px;
  background: #eff6ff;
  color: #2563eb;
  font-size: 11px;
  font-weight: 900;
}

.customer-dashboard-hero h1,
.customer-dashboard-hero p {
  margin: 0;
}

.customer-dashboard-hero h1 {
  font-size: 30px;
  letter-spacing: -0.03em;
}

.customer-dashboard-hero p {
  margin-top: 6px;
  color: #64748b;
  line-height: 1.5;
}

.customer-referral-card {
  min-width: 260px;
  padding: 16px;
  display: grid;
  align-content: center;
  gap: 8px;
  border: 1px solid #fed7aa;
  border-radius: 12px;
  background: #fff7ed;
}

.customer-referral-card small,
.customer-referral-large small,
.customer-kpi-grid small,
.customer-panel-head a,
.customer-list small,
.customer-wishlist-card small {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.customer-referral-card strong,
.customer-referral-large strong {
  color: #0f172a;
  font-size: 22px;
  letter-spacing: 0.04em;
}

.customer-referral-card a,
.customer-panel-head a {
  color: #2563eb;
  font-weight: 900;
}

.customer-kpi-grid {
  margin: 0 28px 16px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.customer-kpi-grid article,
.customer-panel {
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
}

.customer-kpi-grid article {
  min-height: 92px;
  padding: 16px;
}

.customer-kpi-grid strong {
  display: block;
  margin: 6px 0 3px;
  color: #0f172a;
  font-size: 26px;
}

.customer-kpi-grid span {
  color: #64748b;
  font-size: 12px;
}

.customer-dashboard-grid {
  margin: 0 28px 28px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.wide-customer-panel {
  grid-column: 1 / -1;
}

.customer-panel {
  padding: 16px;
}

.customer-panel-head {
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.customer-panel-head h3 {
  margin: 0;
  font-size: 17px;
}

.customer-list {
  display: grid;
  gap: 8px;
}

.customer-list a,
.customer-list > div {
  min-height: 52px;
  padding: 11px 12px;
  display: grid;
  gap: 3px;
  border: 1px solid #eef2f7;
  border-radius: 9px;
  background: #f8fafc;
}

.customer-list a:hover {
  border-color: #bfdbfe;
  background: #eff6ff;
}

.customer-list strong {
  color: #0f172a;
}

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

.customer-wishlist-card {
  min-height: 78px;
  padding: 10px;
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr) auto;
  align-items: center;
  gap: 12px;
  border: 1px solid #eef2f7;
  border-radius: 10px;
  background: #f8fafc;
}

.customer-wishlist-card img,
.customer-wishlist-card > span {
  width: 76px;
  height: 56px;
  border-radius: 9px;
  object-fit: cover;
  background: #e0f2fe;
}

.customer-wishlist-card > span {
  display: grid;
  place-items: center;
  color: #0284c7;
  font-weight: 950;
}

.customer-wishlist-card strong,
.customer-wishlist-card small {
  display: block;
}

.customer-referral-large {
  margin-bottom: 10px;
  padding: 14px;
  border: 1px dashed #fed7aa;
  border-radius: 10px;
  background: #fff7ed;
}

.customer-referral-large p {
  margin: 8px 0 0;
  color: #64748b;
}

.admin-pill img {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
}

.customer-profile-hero {
  margin: 0 28px 16px;
  padding: 22px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) 220px;
  align-items: center;
  gap: 18px;
  border: 1px solid #dfe7f2;
  border-radius: 14px;
  background: linear-gradient(135deg, #ffffff, #f8fbff);
  box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06);
}

.profile-avatar-large,
.profile-avatar-preview {
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 16px;
  background: #fff7ed;
  color: #ea580c;
  font-weight: 950;
}

.profile-avatar-large {
  width: 86px;
  height: 86px;
  font-size: 28px;
}

.profile-avatar-preview {
  width: 76px;
  height: 76px;
  border: 1px solid #fed7aa;
  font-size: 24px;
}

.profile-avatar-large img,
.profile-avatar-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.customer-profile-hero span {
  display: inline-flex;
  margin-bottom: 7px;
  padding: 5px 9px;
  border-radius: 999px;
  background: #eff6ff;
  color: #2563eb;
  font-size: 11px;
  font-weight: 900;
}

.customer-profile-hero h1,
.customer-profile-hero p {
  margin: 0;
}

.customer-profile-hero h1 {
  font-size: 28px;
  letter-spacing: -0.03em;
}

.customer-profile-hero p {
  margin-top: 5px;
  color: #64748b;
}

.profile-completion-card {
  padding: 14px;
  border: 1px solid #dbeafe;
  border-radius: 12px;
  background: #eff6ff;
}

.profile-completion-card small,
.profile-completion-card strong {
  display: block;
}

.profile-completion-card strong {
  margin: 5px 0;
  font-size: 24px;
}

.profile-completion-card div {
  height: 8px;
  overflow: hidden;
  border-radius: 999px;
  background: #dbeafe;
}

.profile-completion-card i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2563eb, #ff6500);
}

.profile-saved {
  margin: 0 28px 16px;
}

.customer-profile-layout {
  margin: 0 28px 28px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 14px;
}

.customer-profile-form,
.customer-profile-side article {
  padding: 16px;
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
}

.profile-upload-row {
  margin-bottom: 14px;
  padding: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
  border: 1px solid #eef2f7;
  border-radius: 11px;
  background: #f8fafc;
}

.profile-upload-box {
  flex: 1;
  min-height: 76px;
  padding: 13px;
  display: grid;
  align-content: center;
  gap: 4px;
  border: 1px dashed #bfdbfe;
  border-radius: 10px;
  background: #fff;
  cursor: pointer;
}

.profile-upload-box input {
  margin-top: 7px;
}

.profile-grid-form input,
.profile-grid-form select,
.profile-grid-form textarea {
  min-height: 42px;
  border-color: #dbe4ef;
  border-radius: 9px;
}

.customer-profile-side {
  display: grid;
  gap: 14px;
  align-content: start;
}

.customer-profile-side h3,
.customer-profile-side p {
  margin: 0;
}

.customer-profile-side p {
  margin-top: 12px;
  color: #64748b;
}

.customer-profile-side strong {
  color: #0f172a;
}

.customer-profile-side ul {
  display: grid;
  gap: 9px;
  margin: 12px 0 0;
  padding: 0;
  list-style: none;
}

.customer-profile-side li {
  padding: 10px 11px;
  border: 1px solid #eef2f7;
  border-radius: 9px;
  background: #f8fafc;
  color: #64748b;
  font-weight: 800;
}

.customer-profile-side li.done {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #15803d;
}

.referral-hero {
  margin: 0 28px 16px;
  padding: 24px;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  gap: 18px;
  border: 1px solid #dfe7f2;
  border-radius: 14px;
  background:
    radial-gradient(circle at 88% 10%, rgba(37, 99, 235, 0.12), transparent 30%),
    linear-gradient(135deg, #ffffff, #fff7ed);
  box-shadow: 0 16px 38px rgba(15, 23, 42, 0.06);
}

.referral-hero span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 9px;
  border-radius: 999px;
  background: #eff6ff;
  color: #2563eb;
  font-size: 11px;
  font-weight: 900;
}

.referral-hero h1,
.referral-hero p {
  margin: 0;
}

.referral-hero h1 {
  font-size: 30px;
  letter-spacing: -0.03em;
}

.referral-hero p {
  margin-top: 6px;
  color: #64748b;
}

.referral-code-card {
  min-width: 260px;
  padding: 16px;
  display: grid;
  align-content: center;
  gap: 8px;
  border: 1px solid #bfdbfe;
  border-radius: 12px;
  background: #eff6ff;
}

.referral-code-card small,
.referral-stat-grid small,
.referral-stat-grid span,
.referral-list-panel small,
.referral-list-panel time {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.referral-code-card strong {
  color: #0f172a;
  font-size: 24px;
  letter-spacing: 0.04em;
}

.referral-code-card a {
  color: #2563eb;
  font-weight: 900;
}

.referral-stat-grid {
  margin: 0 28px 16px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.referral-stat-grid article,
.referral-share-panel,
.referral-list-panel {
  border: 1px solid #dfe7f2;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 10px 26px rgba(15, 23, 42, 0.04);
}

.referral-stat-grid article {
  min-height: 92px;
  padding: 16px;
}

.referral-stat-grid strong {
  display: block;
  margin: 6px 0 3px;
  font-size: 24px;
}

.referral-layout {
  margin: 0 28px 28px;
  display: grid;
  grid-template-columns: 0.9fr 1.4fr;
  gap: 14px;
}

.referral-share-panel,
.referral-list-panel {
  padding: 16px;
}

.referral-share-panel label {
  display: grid;
  gap: 7px;
  color: #334155;
  font-size: 12px;
  font-weight: 900;
}

.referral-share-panel input {
  min-height: 42px;
  border: 1px solid #dbe4ef;
  border-radius: 9px;
  background: #f8fafc;
}

.referral-share-actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 12px;
}

.referral-list {
  display: grid;
  gap: 8px;
}

.referral-row {
  min-height: 62px;
  padding: 10px;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 10px;
  border: 1px solid #eef2f7;
  border-radius: 10px;
  background: #f8fafc;
}

.referral-row > span {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  overflow: hidden;
  border-radius: 50%;
  background: #fff7ed;
  color: #ea580c;
  font-weight: 950;
}

.referral-row img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.referral-row strong,
.referral-row small {
  display: block;
}

.referral-row em {
  padding: 5px 8px;
  border-radius: 999px;
  background: #dcfce7;
  color: #15803d;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
}

.referral-row .status-blocked,
.referral-row .status-pending {
  background: #ffedd5;
  color: #c2410c;
}

.account-footer {
  margin: 10px 0 0;
  padding: 10px 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  border-top: 1px solid #dfe7f2;
  background: #fff;
  color: #64748b;
  font-size: 12px;
}

.account-footer small {
  color: #64748b;
}

.account-footer a {
  color: #2563eb;
  font-weight: 800;
}

.detail-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 12px;
}

.detail-grid article {
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 14px;
}

dl {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 8px;
  margin: 0;
}

dt {
  color: var(--muted);
}

dd {
  margin: 0;
}

.image-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 10px;
}

.image-grid img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid var(--line);
}

.current-images {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
  gap: 8px;
  padding: 8px;
  border: 1px solid #e5e7eb;
  border-radius: 9px;
  background: #f9fafb;
}

.current-images img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 7px;
  border: 1px solid #e5e7eb;
  background: #fff;
}

hr {
  border: 0;
  border-top: 1px solid var(--line);
  margin: 16px 0;
}

@media (max-width: 980px) {
  .vehicle-form-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .vehicle-form-grid label,
  .vehicle-span-4 {
    grid-column: span 1 !important;
  }

  .vehicle-span-full,
  .vehicle-form-grid label:has(textarea) {
    grid-column: 1 / -1 !important;
  }

  .vehicle-brand-shell {
    grid-template-columns: 1fr;
    padding: 0 12px 18px;
  }
}

@media (max-width: 560px) {
  .vehicle-form-grid {
    grid-template-columns: 1fr;
  }

  .vehicle-form-grid label,
  .vehicle-span-4 {
    grid-column: 1 / -1 !important;
  }

  .vehicle-form-actions {
    position: sticky;
    bottom: 0;
    padding: 10px 0 0;
    background: #fff;
  }
}

@media (max-width: 980px) {
  body {
    overflow-x: hidden;
  }

  .sidebar {
    position: static;
    width: auto;
    min-height: auto;
  }

  .main {
    margin-left: 0;
    padding-left: 12px;
    padding-right: 12px;
  }

  .topbar {
    position: static;
    margin: -18px -18px 18px;
  }

  .admin-console .sidebar {
    position: static;
    width: auto;
    min-height: auto;
    border-right: 0;
    border-bottom: 1px solid #e8edf5;
  }

  .admin-console .main {
    margin-left: 0;
    padding: 0 12px 18px;
  }

  .admin-console .topbar {
    height: auto;
    min-height: 76px;
    margin: 0 -12px 18px;
    padding: 14px 12px;
  }

  .admin-console .admin-search {
    width: 100%;
    max-width: none;
  }

  .module-admin-console .main {
    margin-left: 0;
    padding: 0 12px 18px;
  }

  .module-admin-console .topbar {
    height: auto;
    margin: 0 -12px 18px;
    padding: 14px 12px;
  }

  .module-admin-console .admin-kpi-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .module-admin-console .admin-kpi-row article:nth-child(6) {
    display: grid;
  }

  .admin-listing-hero,
  .module-dashboard-head {
    align-items: flex-start;
    flex-direction: column;
  }

  .admin-kpi-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .listing-filter-bar,
  .module-dashboard-grid {
    grid-template-columns: 1fr;
  }

  .property-dashboard-title,
  .property-card-head {
    align-items: flex-start;
    flex-direction: column;
  }

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

  .property-dashboard-charts,
  .property-dashboard-main,
  .property-dashboard-bottom {
    grid-template-columns: 1fr;
  }

  .donut-report,
  .donut-report.compact {
    grid-template-columns: 1fr;
    justify-items: center;
  }

  .approvals-card {
    overflow-x: auto;
  }

  .compact-table {
    min-width: 720px;
  }

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

  .request-page-head,
  .request-table-footer {
    align-items: flex-start;
    flex-direction: column;
  }

  .request-page-head .button-row {
    width: 100%;
  }

  .user-admin-hero {
    align-items: flex-start;
    flex-direction: column;
  }

  .user-admin-hero .button-row {
    width: 100%;
  }

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

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

  .request-filter-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .request-filter-bar .request-search {
    grid-column: 1 / -1;
  }

  .request-review-card {
    grid-template-columns: 92px minmax(0, 1fr);
  }

  .request-thumb {
    width: 92px;
  }

  .request-action-stack {
    grid-column: 1 / -1;
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }

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

  .premium-request-table-wrap {
    overflow-x: auto;
  }

  .user-filter-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .listing-detail-shell,
  .listing-summary-card {
    grid-template-columns: 1fr;
  }

  .listing-detail-stats,
  .attribute-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

  .module-manage-grid {
    grid-template-columns: 1fr;
  }

  .module-location-hero {
    padding: 12px;
  }

  .module-location-hero h2 {
    font-size: 20px;
  }

  .module-location-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-filter-bar {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .category-filter-bar .request-search,
  .category-filter-bar button {
    grid-column: 1 / -1;
  }

  .category-filter-table {
    min-width: 920px;
  }

  .module-location-table {
    min-width: 820px;
  }

  .module-location-table th,
  .module-location-table td {
    padding: 9px 10px;
  }

  .location-actions .small-btn {
    min-height: 28px;
    padding: 6px 8px;
    font-size: 11px;
  }

  .module-admin-console .property-builder-page .wizard-steps,
  .module-admin-console #add-listing-modal .wizard-steps,
  .module-admin-console [id^="edit-listing-"] .wizard-steps {
    grid-template-columns: repeat(5, 160px);
    overflow-x: auto;
  }

  .custom-option-add.has-distance {
    grid-template-columns: 1fr 1fr;
  }

  .custom-option-add.has-distance button {
    grid-column: 1 / -1;
  }

  .property-admin-form-grid {
    grid-template-columns: 1fr;
  }

  .property-core-strip,
  .category-picker,
  .property-dynamic-fields .dynamic-grid,
  .account-property-core-strip + .property-dynamic-fields .dynamic-grid,
  .property-admin-side .property-dynamic-fields .dynamic-grid,
  .media-extra-grid,
  .contact-toggle-grid,
  .property-option-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .account-listing-snapshot {
    min-height: 170px;
  }

  .module-report-side {
    grid-template-columns: 1fr;
  }

  [id^="module-form-"] .modal-card,
  [id^="module-wizard-"] .modal-card {
    width: 100%;
    padding: 12px;
  }

  [id^="module-form-"] .modal-head,
  [id^="module-wizard-"] .modal-head {
    top: -12px;
    margin: -12px -12px 10px;
    padding: 12px;
  }

  .builder-tabs {
    overflow-x: auto;
  }

  .builder-add-field .grid-form {
    grid-template-columns: 1fr;
  }

  .page-actions,
  .role-hero,
  .topbar {
    align-items: flex-start;
    flex-direction: column;
  }

  .category-hero,
  .category-hero .button-row {
    width: 100%;
  }

  .category-hero-stats {
    width: 100%;
    min-width: 0;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .category-filter-bar {
    align-items: stretch;
    flex-direction: column;
  }

  #add-module-modal .modal-form,
  #add-category-modal .modal-form,
  [id^="edit-module-"] .modal-form,
  [id^="edit-category-"] .modal-form {
    grid-template-columns: 1fr;
  }

  .grid-form,
  .dynamic-grid,
  .detail-grid,
  .summary-list {
    grid-template-columns: 1fr;
  }

  .wizard-steps {
    display: flex;
    grid-template-columns: none;
    overflow-x: auto;
    padding: 7px;
    scrollbar-width: thin;
  }

  .wizard-steps button {
    min-width: 154px;
    min-height: 58px;
    flex: 0 0 auto;
  }

  .modal {
    align-items: flex-end;
    padding: 0;
  }

  .modal-card,
  .wide-modal .modal-card {
    width: 100%;
    max-height: 92vh;
    padding: 14px;
    border-radius: 18px 18px 0 0;
  }

  .modal-head {
    position: sticky;
    top: -14px;
    z-index: 3;
    margin: -14px -14px 14px;
    padding: 14px;
    border-bottom: 1px solid var(--line);
    background: rgba(255, 255, 255, 0.96);
    backdrop-filter: blur(14px);
  }

  .wizard-section-head,
  .dynamic-title {
    display: block;
  }

  .wizard-section-head p,
  .dynamic-title small {
    margin-top: 6px;
  }

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

  .module-grid .module-card {
    grid-template-columns: 42px 1fr;
  }

  .module-card-actions {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
  }

  .table-wrap {
    overflow-x: auto;
    scrollbar-width: thin;
  }

  .data-table,
  .compact-table {
    min-width: 720px;
  }

  .listing-essential-card {
    padding: 14px;
  }

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

  .vendor-sidebar {
    position: fixed;
    inset: 0 auto 0 0;
    z-index: 80;
    width: min(300px, 86vw);
    padding: 14px 12px;
    border-right: 1px solid var(--line);
    border-bottom: 0;
    box-shadow: 18px 0 42px rgba(15, 23, 42, 0.18);
    transform: translateX(-104%);
    transition: transform 0.22s ease;
  }

  .vendor-sidebar .brand {
    padding: 4px 6px 12px;
  }

  .vendor-nav {
    grid-auto-flow: row;
    grid-auto-columns: auto;
    overflow-x: visible;
    overflow-y: auto;
    padding-bottom: 8px;
  }

  .vendor-nav a,
  .vendor-nav-logout button {
    min-width: 0;
    min-height: 40px;
    padding: 0 12px;
  }

  .account-sidebar-open .vendor-sidebar {
    transform: translateX(0);
  }

  .account-sidebar-backdrop {
    position: fixed;
    inset: 0;
    z-index: 70;
    display: none;
    border: 0;
    background: rgba(15, 23, 42, 0.42);
  }

  .account-sidebar-open .account-sidebar-backdrop {
    display: block;
  }

  .account-sidebar-open {
    overflow: hidden;
  }

  .vendor-upgrade {
    margin-top: 12px;
  }

  .vendor-main {
    margin-left: 0;
    min-width: 0;
  }

  .vendor-topbar,
  .vendor-page-head {
    flex-direction: column;
    align-items: stretch;
    height: auto;
    padding: 16px;
  }

  .account-menu-toggle {
    display: grid;
    place-content: center;
    flex: 0 0 38px;
  }

  .vendor-search {
    width: 100%;
    max-width: none;
  }

  .vendor-topbar .button.light,
  .vendor-topbar .admin-pill {
    width: 100%;
    justify-content: center;
  }

  .admin-pill {
    min-width: 0;
  }

  .vendor-stat-grid,
  .vendor-filters {
    grid-template-columns: 1fr;
    padding-left: 16px;
    padding-right: 16px;
  }

  .property-account-hero {
    align-items: flex-start;
    flex-direction: column;
    margin-left: 16px;
    margin-right: 16px;
  }

  .property-account-kpis,
  .property-account-layout {
    grid-template-columns: 1fr;
    padding-left: 16px;
    padding-right: 16px;
  }

  .property-account-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .property-account-table {
    min-width: 720px;
  }

  .vendor-table-card {
    margin: 0 16px 16px;
  }

  .customer-dashboard-hero {
    align-items: flex-start;
    flex-direction: column;
    margin-left: 16px;
    margin-right: 16px;
  }

  .customer-profile-hero {
    grid-template-columns: auto minmax(0, 1fr);
    margin-left: 16px;
    margin-right: 16px;
  }

  .referral-hero {
    align-items: flex-start;
    flex-direction: column;
    margin-left: 16px;
    margin-right: 16px;
  }

  .referral-code-card {
    width: 100%;
    min-width: 0;
  }

  .profile-completion-card {
    grid-column: 1 / -1;
  }

  .customer-referral-card {
    width: 100%;
    min-width: 0;
  }

  .customer-kpi-grid,
  .customer-dashboard-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-left: 16px;
    margin-right: 16px;
  }

  .customer-profile-layout {
    grid-template-columns: 1fr;
    margin-left: 16px;
    margin-right: 16px;
  }

  .referral-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    margin-left: 16px;
    margin-right: 16px;
  }

  .referral-layout {
    grid-template-columns: 1fr;
    margin-left: 16px;
    margin-right: 16px;
  }

  .account-footer {
    flex-direction: row;
    margin-left: 0;
    margin-right: 0;
  }

  .customer-profile-form,
  .customer-profile-side article,
  .customer-panel,
  .customer-kpi-grid article {
    min-width: 0;
  }

  .wide-customer-panel,
  .customer-wishlist-grid {
    grid-column: 1 / -1;
  }

  .settings-layout,
  .toggle-grid,
  .report-kpis,
  .report-grid,
  .report-ribbon {
    grid-template-columns: 1fr;
    padding: 0 16px 16px;
  }

  .report-hero,
  .report-kpis,
  .report-grid,
  .report-ribbon {
    margin-left: 16px;
    margin-right: 16px;
  }

  .report-hero,
  .donut-wrap {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: flex-start;
  }

  .reports-page-head,
  .reports-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .reports-stat-row,
  .reports-shell,
  .reports-main-grid,
  .reports-bottom-strip {
    grid-template-columns: 1fr;
  }

  .reports-tabs {
    overflow-x: auto;
    gap: 18px;
  }

  .reports-shell,
  .reports-tabs,
  .reports-bottom-strip {
    margin-left: 16px;
    margin-right: 16px;
  }

  .reports-stat-row {
    padding-left: 16px;
    padding-right: 16px;
  }

  .reports-bottom-strip article {
    border-right: 0;
    border-bottom: 1px solid #ddd6fe;
  }
}

@media (max-width: 560px) {
  .vendor-sidebar {
    padding: 10px;
  }

  .vendor-sidebar .brand {
    gap: 9px;
  }

  .vendor-sidebar .brand-mark {
    width: 36px;
    height: 36px;
    border-radius: 10px;
  }

  .vendor-sidebar .brand strong {
    font-size: 16px;
  }

  .vendor-sidebar .brand span {
    font-size: 12px;
  }

  .vendor-nav {
    margin: 0;
  }

  .vendor-topbar {
    height: 64px;
    flex-direction: row;
    align-items: center;
    gap: 10px;
    padding: 12px;
  }

  .vendor-search,
  .vendor-topbar .button.light {
    display: none;
  }

  .vendor-topbar .admin-pill {
    width: auto;
    min-height: 40px;
    margin-left: auto;
    justify-content: flex-end;
    gap: 8px;
    padding: 4px 8px 4px 4px;
    border-radius: 999px;
  }

  .vendor-topbar .admin-pill > span,
  .vendor-topbar .admin-pill img {
    width: 32px;
    height: 32px;
  }

  .vendor-topbar .admin-pill strong {
    max-width: 78px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 13px;
  }

  .vendor-topbar .admin-pill small {
    font-size: 10px;
  }

  .account-menu-toggle {
    width: 42px;
    min-height: 42px;
    flex-basis: 42px;
  }

  .vendor-page-head {
    padding: 12px;
  }

  .vendor-page-head h1 {
    font-size: 24px;
  }

  .property-account-hero {
    margin: 10px;
    padding: 12px;
    border-radius: 10px;
  }

  .property-account-hero h1 {
    font-size: 20px;
  }

  .property-account-hero p {
    font-size: 12px;
    line-height: 1.35;
  }

  .property-account-hero button {
    width: 100%;
    min-height: 40px;
  }

  .property-account-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding: 0 10px 10px;
  }

  .property-account-kpis article {
    min-height: 64px;
    padding: 9px;
  }

  .property-account-kpis small {
    font-size: 9px;
  }

  .property-account-kpis strong {
    font-size: 19px;
  }

  .property-account-kpis span {
    font-size: 10px;
  }

  .property-account-layout {
    padding: 0 10px 12px;
  }

  .property-account-card-head {
    align-items: flex-start;
    gap: 8px;
  }

  .property-account-table-wrap {
    overflow: visible;
  }

  .property-account-table {
    min-width: 0;
    border-collapse: separate;
    border-spacing: 0 10px;
  }

  .property-account-table thead {
    display: none;
  }

  .property-account-table,
  .property-account-table tbody,
  .property-account-table tr,
  .property-account-table td {
    display: block;
    width: 100%;
  }

  .property-account-table tr {
    padding: 10px;
    border: 1px solid #dfe7f2;
    border-radius: 12px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.05);
  }

  .property-account-table td {
    height: auto;
    padding: 6px 0;
    border: 0;
  }

  .property-account-table td:first-child {
    padding-top: 0;
    padding-bottom: 10px;
    border-bottom: 1px solid #eef2f7;
  }

  .property-account-table td[data-label] {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    color: #0f172a;
    font-size: 12px;
  }

  .property-account-table td[data-label]::before {
    content: attr(data-label);
    color: #64748b;
    font-size: 10px;
    font-weight: 900;
    text-transform: uppercase;
  }

  .property-account-table .row-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
    padding-top: 10px;
  }

  .property-account-table .row-actions button,
  .property-account-table .row-actions form {
    width: 100%;
  }

  .property-account-table .row-actions button {
    min-height: 36px;
  }

  .property-account-listing img,
  .property-account-listing > span {
    width: 54px;
    height: 44px;
    flex-basis: 54px;
  }

  .vendor-stat-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    padding-left: 10px;
    padding-right: 10px;
  }

  .vendor-stat-grid article {
    min-height: 82px;
    gap: 9px;
    padding: 10px;
    border-radius: 9px;
  }

  .stat-icon {
    width: 32px;
    height: 32px;
    font-size: 11px;
  }

  .vendor-stat-grid strong {
    font-size: 20px;
  }

  .vendor-stat-grid small,
  .vendor-stat-grid p,
  .vendor-stat-grid a {
    font-size: 11px;
    line-height: 1.25;
  }

  .main {
    padding-left: 10px;
    padding-right: 10px;
  }

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

  .property-kpi-grid article {
    min-height: 76px;
  }

  .property-card {
    padding: 12px;
    border-radius: 4px;
  }

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

  .line-bars {
    height: 120px;
    gap: 10px;
  }

  .request-kpi-grid,
  .request-filter-bar,
  .user-kpi-grid,
  .user-filter-bar {
    grid-template-columns: 1fr;
  }

  .request-filter-bar .request-search {
    grid-column: auto;
  }

  .request-review-card {
    grid-template-columns: 1fr;
  }

  .request-thumb {
    width: 100%;
    min-height: 150px;
  }

  .request-owner-row {
    align-items: flex-start;
    flex-direction: column;
  }

  .request-date {
    text-align: left;
  }

  .request-action-stack,
  .request-meta-grid {
    grid-template-columns: 1fr;
  }

  .premium-request-table-wrap {
    margin: 0 -2px;
    padding: 8px;
  }

  .premium-request-table {
    min-width: 1040px;
  }

  .admin-login-shell {
    grid-template-columns: 1fr;
  }

  .login-page.admin-login-page.customer-login-page {
    display: block;
    min-height: 100vh;
    background:
      radial-gradient(circle at -10% -8%, rgba(255, 101, 0, 0.18), transparent 36%),
      linear-gradient(135deg, #fff7ed 0 14%, #ffffff 38%, #fbfdff 100%);
  }

  .account-login-shell,
  .register-login-shell {
    grid-template-columns: 1fr;
  }

  .customer-login-shell {
    width: 100%;
    min-height: 100vh;
    display: block;
    overflow: visible;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
  }

  .admin-login-brand {
    padding: 28px;
  }

  .customer-login-shell .admin-login-brand {
    display: none;
  }

  .admin-login-brand h1 {
    font-size: 28px;
  }

  .customer-login-shell .admin-login-card {
    width: 100%;
    min-height: 100vh;
    padding: 88px 22px 30px;
    display: grid;
    align-content: start;
    gap: 14px;
    border: 0;
    background: transparent;
  }

  .mobile-login-top {
    position: absolute;
    inset: 18px 18px auto;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }

  .mobile-login-top a,
  .mobile-login-top button {
    min-height: 38px;
    border: 1px solid #e5e7eb;
    border-radius: 14px;
    background: rgba(255, 255, 255, 0.78);
    color: #111827;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
  }

  .mobile-login-top a {
    width: 38px;
    display: grid;
    place-items: center;
  }

  .mobile-login-top a span {
    width: 11px;
    height: 11px;
    border-left: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    transform: rotate(45deg);
  }

  .mobile-login-top button {
    padding: 0 12px;
    gap: 7px;
    font-weight: 800;
  }

  .mobile-login-top button span {
    width: 15px;
    height: 15px;
    display: inline-block;
    border: 2px solid currentColor;
    border-radius: 50%;
    position: relative;
  }

  .mobile-login-top button span::before,
  .mobile-login-top button span::after {
    content: "";
    position: absolute;
    inset: 2px 5px;
    border-left: 1px solid currentColor;
    border-right: 1px solid currentColor;
  }

  .mobile-login-logo {
    display: grid;
    justify-items: center;
    gap: 4px;
    padding-top: 20px;
    text-align: center;
  }

  .mobile-login-logo .login-brand-mark {
    width: 74px;
    height: 74px;
    border-radius: 22px;
    color: #061424;
    box-shadow: 0 18px 34px rgba(255, 101, 0, 0.2);
  }

  .mobile-login-logo h1 {
    margin: 6px 0 0;
    font-size: 36px;
    line-height: 1;
    letter-spacing: 0;
    color: #1677ff;
  }

  .mobile-login-logo h1 span {
    color: #ff6500;
  }

  .mobile-login-logo strong {
    color: #ff6500;
    font-size: 15px;
  }

  .mobile-login-logo small {
    margin-top: 8px;
    color: #8b93a3;
    font-weight: 800;
  }

  .customer-login-shell .login-title-block {
    margin-top: 18px;
    text-align: center;
  }

  .customer-login-shell .request-eyebrow {
    display: none;
  }

  .customer-login-shell .admin-login-card h2 {
    font-size: 28px;
    letter-spacing: 0;
  }

  .customer-login-shell .admin-login-card p {
    color: #6b7280;
    font-size: 14px;
  }

  .mobile-auth-tabs {
    height: 58px;
    margin-top: 18px;
    padding: 4px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    border: 1px solid #e5e7eb;
    border-radius: 24px;
    background: rgba(255, 255, 255, 0.82);
  }

  .mobile-auth-tabs a {
    display: grid;
    place-items: center;
    border-radius: 20px;
    color: #111827;
    font-size: 16px;
    font-weight: 800;
  }

  .mobile-auth-tabs a.active {
    color: #ff6500;
    box-shadow: inset 0 -2px 0 #ff6500;
  }

  .customer-login-shell .admin-login-card label:not(.login-remember) {
    min-height: 58px;
    display: grid;
    grid-template-columns: 50px minmax(0, 1fr);
    align-items: center;
    gap: 8px;
    padding: 7px 12px;
    border: 1px solid #e5e7eb;
    border-radius: 17px;
    background: rgba(255, 255, 255, 0.94);
    color: transparent;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.035);
    width: 100%;
  }

  .customer-login-shell .admin-login-card label:not(.login-remember)::before {
    content: "";
    width: 38px;
    height: 38px;
    grid-row: 1;
    border-radius: 13px;
    background:
      linear-gradient(135deg, rgba(255, 101, 0, 0.14), rgba(255, 237, 213, 0.66)),
      radial-gradient(circle at 50% 50%, #ff6500 0 4px, transparent 5px);
  }

  .customer-login-shell .admin-login-card input {
    min-width: 0;
    width: 100%;
    min-height: 42px;
    padding: 0 4px;
    border: 0;
    background: transparent;
    font-size: 15px;
    font-weight: 400;
    color: #111827;
  }

  .customer-login-shell .admin-login-card input::placeholder {
    color: #9ca3af;
    font-weight: 400;
  }

  .customer-login-shell .login-card-row {
    margin-top: 2px;
  }

  .customer-login-shell .login-remember {
    display: flex !important;
    color: #111827;
    font-size: 13px;
    font-weight: 800;
  }

  .customer-login-shell .login-remember input {
    accent-color: #ff6500;
  }

  .customer-login-shell .login-card-row a {
    color: #ff6500;
    font-size: 13px;
  }

  .customer-login-shell .admin-login-card > button[type="submit"] {
    min-height: 58px;
    margin-top: 6px;
    border-radius: 16px;
    background: linear-gradient(135deg, #ff6500, #ff4d00);
    font-size: 18px;
    box-shadow: 0 14px 30px rgba(255, 101, 0, 0.26);
  }

  .customer-login-shell .admin-login-card > .button.light {
    display: none;
  }

  .mobile-social-divider {
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 12px;
    margin-top: 14px;
  }

  .mobile-social-divider span {
    height: 1px;
    background: #e5e7eb;
  }

  .mobile-social-divider small {
    color: #8b93a3;
    font-weight: 800;
  }

  .mobile-social-row {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
  }

  .mobile-social-row button {
    min-height: 48px;
    border: 1px solid #e5e7eb;
    border-radius: 15px;
    background: #fff;
    color: #111827;
    font-size: 13px;
    box-shadow: none;
  }

  .mobile-secure-card {
    margin-top: 18px;
    padding: 16px;
    display: grid;
    grid-template-columns: 48px 1fr;
    gap: 14px;
    align-items: center;
    border-radius: 18px;
    background: linear-gradient(135deg, #fff7ed, #ffffff);
    box-shadow: 0 12px 28px rgba(255, 101, 0, 0.08);
  }

  .mobile-secure-card > span {
    width: 44px;
    height: 44px;
    border: 3px solid #ff6500;
    border-radius: 16px;
    position: relative;
  }

  .mobile-secure-card > span::before {
    content: "";
    position: absolute;
    left: 13px;
    top: 11px;
    width: 12px;
    height: 7px;
    border-left: 3px solid #ff6500;
    border-bottom: 3px solid #ff6500;
    transform: rotate(-45deg);
  }

  .mobile-secure-card strong,
  .mobile-secure-card small {
    display: block;
  }

  .mobile-secure-card strong {
    color: #111827;
    font-size: 16px;
  }

  .mobile-secure-card small {
    margin-top: 3px;
    color: #4b5563;
    line-height: 1.4;
  }

  .mobile-login-terms {
    display: block;
    margin-top: 14px !important;
    color: #6b7280;
    text-align: center;
    line-height: 1.5;
  }

  .mobile-login-terms a {
    color: #ff6500;
    font-weight: 900;
  }

  .customer-login-page {
    height: 100svh;
    overflow: hidden;
  }

  .customer-login-shell {
    height: 100svh;
    min-height: 0;
  }

  .customer-login-shell .admin-login-card {
    height: 100svh;
    min-height: 0;
    overflow: hidden;
    padding: 56px 18px 10px;
    gap: 8px;
  }

  .mobile-login-top {
    inset: 10px 18px auto;
  }

  .mobile-login-top a,
  .mobile-login-top button {
    min-height: 34px;
    border-radius: 12px;
    font-size: 13px;
  }

  .mobile-login-top a {
    width: 34px;
  }

  .mobile-login-logo {
    gap: 2px;
    padding-top: 2px;
  }

  .mobile-login-logo .login-brand-mark {
    width: 58px;
    height: 58px;
    border-radius: 18px;
  }

  .mobile-login-logo h1 {
    margin-top: 3px;
    font-size: 30px;
  }

  .mobile-login-logo strong {
    font-size: 13px;
  }

  .mobile-login-logo small {
    margin-top: 4px;
    font-size: 11px;
  }

  .customer-login-shell .login-title-block {
    margin-top: 8px;
  }

  .customer-login-shell .admin-login-card h2 {
    font-size: 24px;
  }

  .customer-login-shell .admin-login-card p {
    font-size: 12px;
  }

  .mobile-auth-tabs {
    height: 44px;
    margin-top: 6px;
    border-radius: 18px;
  }

  .mobile-auth-tabs a {
    border-radius: 15px;
    font-size: 14px;
  }

  .customer-login-shell .admin-login-card label:not(.login-remember) {
    min-height: 46px;
    grid-template-columns: 40px minmax(0, 1fr);
    padding: 5px 12px;
    border-radius: 14px;
  }

  .customer-login-shell .admin-login-card label:not(.login-remember)::before {
    width: 32px;
    height: 32px;
    border-radius: 11px;
  }

  .customer-login-shell .admin-login-card input {
    min-height: 34px;
    font-size: 14px;
  }

  .customer-login-shell .login-card-row {
    min-height: 22px;
  }

  .customer-login-shell .login-remember,
  .customer-login-shell .login-card-row a {
    font-size: 12px;
  }

  .customer-login-shell .admin-login-card > button[type="submit"] {
    min-height: 48px;
    margin-top: 2px;
    border-radius: 14px;
    font-size: 16px;
  }

  .mobile-social-divider {
    gap: 9px;
    margin-top: 6px;
  }

  .mobile-social-divider small {
    font-size: 11px;
  }

  .mobile-social-row {
    gap: 8px;
  }

  .mobile-social-row button {
    min-height: 38px;
    border-radius: 12px;
    font-size: 12px;
  }

  .mobile-secure-card {
    min-height: 58px;
    margin-top: 8px;
    padding: 10px 12px;
    grid-template-columns: 38px 1fr;
    gap: 10px;
    border-radius: 14px;
  }

  .mobile-secure-card > span {
    width: 34px;
    height: 34px;
    border-width: 2px;
    border-radius: 12px;
  }

  .mobile-secure-card > span::before {
    left: 10px;
    top: 9px;
    width: 10px;
    height: 6px;
    border-left-width: 2px;
    border-bottom-width: 2px;
  }

  .mobile-secure-card strong {
    font-size: 14px;
  }

  .mobile-secure-card small {
    font-size: 11px;
    line-height: 1.25;
  }

  .mobile-login-terms {
    margin-top: 6px !important;
    font-size: 11px !important;
    line-height: 1.35;
  }

  @media (max-height: 700px) {
    .customer-login-shell .admin-login-card {
      padding-top: 48px;
      gap: 6px;
    }

    .mobile-login-logo .login-brand-mark {
      width: 48px;
      height: 48px;
    }

    .mobile-login-logo h1 {
      font-size: 26px;
    }

    .mobile-login-logo small {
      display: none;
    }

    .customer-login-shell .login-title-block {
      margin-top: 4px;
    }

    .mobile-secure-card {
      min-height: 50px;
      margin-top: 4px;
    }
  }

  .listing-detail-hero {
    align-items: flex-start;
    flex-direction: column;
  }

  .listing-detail-actions {
    justify-content: flex-start;
  }

  .listing-detail-stats,
  .attribute-grid {
    grid-template-columns: 1fr;
  }

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

  .property-core-strip,
  .category-picker,
  .property-dynamic-fields .dynamic-grid,
  .account-property-core-strip + .property-dynamic-fields .dynamic-grid,
  .property-admin-side .property-dynamic-fields .dynamic-grid,
  .media-extra-grid,
  .contact-toggle-grid,
  .property-option-grid {
    grid-template-columns: 1fr;
  }

  .account-listing-snapshot {
    min-height: auto;
    padding: 14px;
  }

  .account-listing-snapshot h4 {
    font-size: 17px;
  }

  .module-admin-console .property-builder-page,
  .module-admin-console #add-listing-modal .listing-form,
  .module-admin-console [id^="edit-listing-"] .listing-form {
    padding: 10px;
  }

  .category-hero-stats,
  .option-pill-grid,
  .summary-list {
    grid-template-columns: 1fr;
  }

  .wizard-steps button {
    min-width: 132px;
  }

  .custom-option-add,
  .custom-option-add.has-distance,
  .distance-control-row,
  .area-unit-field,
  .location-extra-grid {
    grid-template-columns: 1fr;
  }

  .modal-card,
  .wide-modal .modal-card {
    max-height: 94vh;
  }

  .wizard-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }

  .wizard-actions button[type="submit"] {
    grid-column: 1 / -1;
  }

  .customer-kpi-grid,
  .customer-wishlist-grid,
  .customer-wishlist-card,
  .profile-grid-form {
    grid-template-columns: 1fr;
  }

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

  .customer-dashboard-grid {
    grid-template-columns: 1fr;
    gap: 10px;
  }

  .customer-dashboard-hero,
  .customer-kpi-grid,
  .customer-dashboard-grid,
  .customer-profile-hero,
  .customer-profile-layout,
  .referral-hero,
  .referral-stat-grid,
  .referral-layout,
  .account-footer,
  .profile-saved {
    margin-left: 10px;
    margin-right: 10px;
  }

  .account-footer {
    margin-left: 0;
    margin-right: 0;
  }

  .customer-dashboard-hero,
  .customer-profile-hero,
  .customer-profile-form,
  .customer-profile-side article,
  .customer-panel,
  .referral-hero,
  .referral-share-panel,
  .referral-list-panel,
  .account-footer {
    padding: 14px;
    border-radius: 11px;
  }

  .customer-dashboard-hero h1,
  .customer-profile-hero h1,
  .referral-hero h1 {
    font-size: 24px;
  }

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

  .referral-stat-grid article {
    min-height: 76px;
    padding: 11px;
  }

  .referral-stat-grid strong {
    margin: 4px 0 2px;
    font-size: 21px;
  }

  .referral-share-actions {
    grid-template-columns: 1fr;
  }

  .referral-row {
    grid-template-columns: 38px minmax(0, 1fr) auto;
    gap: 8px;
  }

  .referral-row > span {
    width: 38px;
    height: 38px;
  }

  .referral-row time {
    grid-column: 2 / -1;
    justify-self: start;
  }

  .customer-panel-head {
    align-items: stretch;
    flex-direction: column;
  }

  .customer-panel-head button {
    width: 100%;
  }

  .customer-kpi-grid article {
    min-height: 76px;
    padding: 11px;
  }

  .customer-kpi-grid strong {
    margin: 4px 0 2px;
    font-size: 22px;
  }

  .customer-kpi-grid small,
  .customer-kpi-grid span {
    font-size: 11px;
  }

  .customer-list {
    gap: 7px;
  }

  .customer-list a,
  .customer-list > div {
    min-height: 46px;
    padding: 9px 10px;
    border-radius: 8px;
  }

  .customer-wishlist-card {
    min-height: 66px;
    padding: 8px;
    grid-template-columns: 58px minmax(0, 1fr) auto;
    gap: 9px;
  }

  .customer-wishlist-card img,
  .customer-wishlist-card > span {
    width: 58px;
    height: 46px;
  }

  .profile-completion-card {
    padding: 11px;
  }

  .profile-upload-box {
    width: 100%;
  }

  .customer-wishlist-card {
    justify-items: start;
  }

  .customer-profile-hero,
  .profile-upload-row {
    grid-template-columns: 1fr;
    flex-direction: column;
    align-items: flex-start;
  }
}
@media (max-width: 760px) {
  .property-account-console #post-property-modal,
  .property-account-console [id^="edit-listing-"] {
    align-items: stretch;
    padding: 0;
    background: #f6f7fb;
  }

  .property-account-console #post-property-modal .modal-card,
  .property-account-console [id^="edit-listing-"] .modal-card {
    width: 100vw;
    height: 100dvh;
    max-height: none;
    margin: 0;
    border: 0;
    border-radius: 0;
    background: #f6f7fb;
    display: flex;
    flex-direction: column;
    overflow: hidden;
  }

  .property-account-console #post-property-modal .modal-head,
  .property-account-console [id^="edit-listing-"] .modal-head {
    flex: 0 0 auto;
    min-height: 70px;
    padding: 14px 16px 10px;
    border-bottom: 1px solid #e5edf5;
    background: rgba(255, 255, 255, .96);
    backdrop-filter: blur(14px);
  }

  .property-account-console #post-property-modal .modal-head h3,
  .property-account-console [id^="edit-listing-"] .modal-head h3 {
    font-size: 20px;
    line-height: 1.05;
  }

  .property-account-console #post-property-modal .modal-head small,
  .property-account-console [id^="edit-listing-"] .modal-head small {
    display: block;
    max-width: 260px;
    margin-top: 5px;
    color: #64748b;
    font-size: 11px;
    font-weight: 600;
  }

  .property-account-console #post-property-modal .listing-form,
  .property-account-console [id^="edit-listing-"] .listing-form {
    flex: 1 1 auto;
    min-height: 0;
    display: flex;
    flex-direction: column;
    padding: 10px 10px 0;
    overflow: hidden;
  }

  .property-account-console #post-property-modal .wizard-steps,
  .property-account-console [id^="edit-listing-"] .wizard-steps {
    flex: 0 0 auto;
    display: flex;
    gap: 8px;
    margin: 0 -10px 10px;
    padding: 0 10px 8px;
    border: 0;
    border-radius: 0;
    background: transparent;
    box-shadow: none;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .property-account-console #post-property-modal .wizard-steps button,
  .property-account-console [id^="edit-listing-"] .wizard-steps button {
    flex: 0 0 128px;
    min-height: 52px;
    grid-template-columns: 30px 1fr;
    padding: 8px;
    border: 1px solid #e2e8f0;
    border-radius: 15px;
    background: #fff;
    box-shadow: 0 8px 18px rgba(15, 23, 42, .05);
  }

  .property-account-console #post-property-modal .wizard-steps button::after,
  .property-account-console [id^="edit-listing-"] .wizard-steps button::after {
    display: none;
  }

  .property-account-console #post-property-modal .wizard-steps button span,
  .property-account-console [id^="edit-listing-"] .wizard-steps button span {
    width: 27px;
    height: 27px;
    border-radius: 10px;
    font-size: 11px;
  }

  .property-account-console #post-property-modal .wizard-steps button.active,
  .property-account-console [id^="edit-listing-"] .wizard-steps button.active {
    border-color: #fed7aa;
    background: #fff7ed;
    box-shadow: 0 10px 22px rgba(255, 101, 0, .12);
  }

  .property-account-console #post-property-modal .wizard-panel.active,
  .property-account-console [id^="edit-listing-"] .wizard-panel.active {
    flex: 1 1 auto;
    overflow-y: auto;
    padding: 0 0 88px;
    scrollbar-width: thin;
  }

  .property-account-console #post-property-modal .property-admin-form-grid,
  .property-account-console [id^="edit-listing-"] .property-admin-form-grid,
  .property-account-console #post-property-modal .dynamic-grid,
  .property-account-console [id^="edit-listing-"] .dynamic-grid,
  .property-account-console #post-property-modal .property-core-strip,
  .property-account-console [id^="edit-listing-"] .property-core-strip,
  .property-account-console #post-property-modal .category-picker,
  .property-account-console [id^="edit-listing-"] .category-picker,
  .property-account-console #post-property-modal .area-unit-field,
  .property-account-console [id^="edit-listing-"] .area-unit-field,
  .property-account-console #post-property-modal .location-extra-grid,
  .property-account-console [id^="edit-listing-"] .location-extra-grid {
    grid-template-columns: 1fr;
    gap: 9px;
  }

  .property-account-console #post-property-modal .property-admin-side,
  .property-account-console [id^="edit-listing-"] .property-admin-side {
    display: none;
  }

  .property-account-console #post-property-modal .property-form-card,
  .property-account-console [id^="edit-listing-"] .property-form-card {
    padding: 12px;
    border: 1px solid #dfe8f3;
    border-radius: 16px;
    background: #fff;
    box-shadow: 0 10px 24px rgba(15, 23, 42, .06);
  }

  .property-account-console #post-property-modal input,
  .property-account-console #post-property-modal select,
  .property-account-console #post-property-modal textarea,
  .property-account-console [id^="edit-listing-"] input,
  .property-account-console [id^="edit-listing-"] select,
  .property-account-console [id^="edit-listing-"] textarea {
    min-height: 42px;
    border-radius: 12px;
    background: #fbfdff;
    font-size: 13px;
  }

  .property-account-console #post-property-modal .wizard-actions,
  .property-account-console [id^="edit-listing-"] .wizard-actions {
    position: sticky;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 20;
    flex: 0 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 9px;
    margin: 0 -10px;
    padding: 10px 12px calc(10px + env(safe-area-inset-bottom));
    border-top: 1px solid #e5edf5;
    background: rgba(255,255,255,.96);
    backdrop-filter: blur(14px);
    box-shadow: 0 -10px 28px rgba(15, 23, 42, .10);
  }

  .property-account-console #post-property-modal .wizard-actions button,
  .property-account-console [id^="edit-listing-"] .wizard-actions button {
    min-height: 46px;
    border-radius: 14px;
    font-size: 14px;
    font-weight: 800;
  }

  .property-account-console #post-property-modal .wizard-actions button[type="submit"],
  .property-account-console [id^="edit-listing-"] .wizard-actions button[type="submit"] {
    grid-column: 1 / -1;
  }
}

.mobile-title-block,
.mobile-trust-strip {
  display: none;
}

@media (max-width: 760px) {
  .auth-app-page {
    display: block !important;
    min-height: 100svh !important;
    background: radial-gradient(circle at -18% -8%, rgba(255,101,0,.18), transparent 34%), linear-gradient(135deg, rgba(255,237,213,.72), transparent 20%), #fff !important;
  }

  .auth-login-page {
    overflow: hidden !important;
  }

  .auth-register-page {
    overflow-y: auto !important;
  }

  .auth-app-page .customer-login-shell {
    width: 100% !important;
    min-height: 100svh !important;
    display: block !important;
    border: 0 !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .auth-login-page .customer-login-shell,
  .auth-login-page .admin-login-card {
    height: 100svh !important;
    overflow: hidden !important;
  }

  .auth-app-page .admin-login-brand,
  .auth-app-page .request-eyebrow,
  .auth-app-page .desktop-title-block,
  .auth-app-page .admin-login-card > .button.light {
    display: none !important;
  }

  .auth-app-page .admin-login-card {
    width: 100% !important;
    min-height: 100svh !important;
    display: grid !important;
    align-content: start !important;
    gap: 10px !important;
    padding: 62px 22px 18px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .auth-register-page .admin-login-card {
    gap: 8px !important;
    padding-top: 58px !important;
    padding-bottom: 28px !important;
  }

  .auth-app-page .mobile-login-top {
    position: fixed !important;
    inset: 16px 24px auto !important;
    z-index: 5 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
  }

  .auth-app-page .mobile-login-logo,
  .auth-app-page .mobile-title-block,
  .auth-app-page .mobile-auth-tabs,
  .auth-app-page .mobile-social-divider,
  .auth-app-page .mobile-social-row,
  .auth-app-page .mobile-secure-card,
  .auth-app-page .mobile-login-terms {
    display: grid !important;
  }

  .auth-app-page .mobile-login-logo {
    justify-items: center !important;
    gap: 2px !important;
    padding-top: 16px !important;
    text-align: center !important;
  }

  .auth-register-page .mobile-login-logo {
    padding-top: 6px !important;
  }

  .auth-app-page .mobile-login-logo .login-brand-mark {
    width: 118px !important;
    height: 66px !important;
    border-radius: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
  }

  .auth-register-page .mobile-login-logo .login-brand-mark {
    width: 112px !important;
    height: 56px !important;
  }

  .auth-app-page .mobile-login-logo h1 {
    margin: 0 !important;
    color: #1687f3 !important;
    font-size: 32px !important;
    line-height: .96 !important;
    letter-spacing: 0 !important;
  }

  .auth-app-page .mobile-login-logo strong {
    color: #ff6500 !important;
    font-size: 14px !important;
    font-weight: 800 !important;
  }

  .auth-app-page .mobile-login-logo small {
    margin-top: 5px !important;
    color: #8a93a3 !important;
    font-size: 10.5px !important;
    font-weight: 600 !important;
  }

  .auth-app-page .mobile-title-block {
    margin: 11px 0 2px !important;
    text-align: center !important;
  }

  .auth-app-page .mobile-title-block h2 {
    margin: 0 !important;
    color: #111827 !important;
    font-size: 27px !important;
    line-height: 1.12 !important;
    letter-spacing: 0 !important;
  }

  .auth-register-page .mobile-title-block h2 {
    font-size: 25px !important;
  }

  .auth-app-page .mobile-title-block p {
    margin: 5px 0 0 !important;
    color: #7b8190 !important;
    font-size: 13px !important;
    line-height: 1.3 !important;
  }

  .auth-app-page .mobile-auth-tabs {
    height: 48px !important;
    margin-top: 7px !important;
    padding: 0 !important;
    grid-template-columns: 1fr 1fr !important;
    overflow: hidden !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 22px !important;
    background: rgba(255,255,255,.92) !important;
  }

  .auth-app-page .mobile-auth-tabs a {
    position: relative !important;
    display: grid !important;
    place-items: center !important;
    color: #1f2937 !important;
    font-size: 14px !important;
    font-weight: 600 !important;
  }

  .auth-app-page .mobile-auth-tabs a.active {
    color: #ff6500 !important;
    box-shadow: none !important;
  }

  .auth-app-page .mobile-auth-tabs a.active::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2px;
    background: #ff6500;
  }

  .auth-app-page .auth-field,
  .auth-app-page .auth-referral-card {
    min-height: 50px !important;
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 44px minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 8px !important;
    padding: 6px 11px !important;
    border: 1px solid #e7eaf0 !important;
    border-radius: 16px !important;
    background: rgba(255,255,255,.94) !important;
    color: transparent !important;
    box-shadow: 0 7px 18px rgba(15,23,42,.035) !important;
  }

  .auth-register-page .auth-field {
    min-height: 47px !important;
  }

  .auth-user { --auth-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23ff6500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='12' cy='8' r='4'/%3E%3Cpath d='M4 21c1.8-4 14.2-4 16 0'/%3E%3C/svg%3E"); }
  .auth-phone { --auth-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23ff6500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M22 16.9v3a2 2 0 0 1-2.2 2A19.8 19.8 0 0 1 3 5.2 2 2 0 0 1 5 3h3a2 2 0 0 1 2 1.7c.1.9.3 1.7.6 2.5a2 2 0 0 1-.5 2.1L8.8 10.6a16 16 0 0 0 4.6 4.6l1.3-1.3a2 2 0 0 1 2.1-.5c.8.3 1.6.5 2.5.6A2 2 0 0 1 22 16.9Z'/%3E%3C/svg%3E"); }
  .auth-lock { --auth-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23ff6500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Crect x='5' y='10' width='14' height='11' rx='2'/%3E%3Cpath d='M8 10V7a4 4 0 0 1 8 0v3'/%3E%3C/svg%3E"); }
  .auth-email { --auth-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23ff6500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 6h16v12H4z'/%3E%3Cpath d='m4 7 8 6 8-6'/%3E%3C/svg%3E"); }
  .auth-ticket { --auth-icon: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23ff6500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M4 8a2 2 0 0 0 0 4 2 2 0 0 1 0 4v2h16v-2a2 2 0 0 1 0-4 2 2 0 0 0 0-4V6H4z'/%3E%3Cpath d='M9 8v8M15 8v8'/%3E%3C/svg%3E"); }

  .auth-app-page .auth-field::before,
  .auth-app-page .auth-referral-card::before {
    content: "" !important;
    width: 34px !important;
    height: 34px !important;
    display: block !important;
    border-radius: 12px !important;
    background: linear-gradient(135deg, rgba(255,101,0,.13), rgba(255,247,237,.95)), var(--auth-icon) center / 19px 19px no-repeat !important;
  }

  .auth-app-page .auth-field input,
  .auth-app-page .auth-referral-card input {
    min-width: 0 !important;
    width: 100% !important;
    min-height: 36px !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    color: #111827 !important;
    font-size: 14px !important;
    font-weight: 400 !important;
  }

  .auth-app-page .auth-field input::placeholder,
  .auth-app-page .auth-referral-card input::placeholder {
    color: #8f96a3 !important;
    font-weight: 400 !important;
  }

  .auth-app-page .auth-field button {
    width: 24px !important;
    min-width: 24px !important;
    height: 24px !important;
    min-height: 24px !important;
    border: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    color: #ff6500 !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    white-space: nowrap !important;
    box-shadow: none !important;
  }

  .auth-app-page .auth-field i {
    width: 22px !important;
    height: 22px !important;
    display: block !important;
    opacity: .68 !important;
    background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 3l18 18'/%3E%3Cpath d='M10.6 10.6a2 2 0 0 0 2.8 2.8'/%3E%3Cpath d='M9.9 5.1A10.5 10.5 0 0 1 12 5c5 0 8.5 4 10 7a14.8 14.8 0 0 1-2.1 3.2'/%3E%3Cpath d='M6.6 6.6A14.5 14.5 0 0 0 2 12c1.5 3 5 7 10 7 1.5 0 2.9-.4 4.1-1'/%3E%3C/svg%3E") center / 19px 19px no-repeat !important;
  }

  .auth-app-page .login-card-row {
    min-height: 26px !important;
    margin-top: 0 !important;
  }

  .auth-app-page .login-remember {
    gap: 8px !important;
    color: #111827 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
  }

  .auth-app-page .login-remember input {
    width: 16px !important;
    height: 16px !important;
    accent-color: #ff6500 !important;
  }

  .auth-app-page .admin-login-card > button[type="submit"] {
    min-height: 50px !important;
    margin-top: 2px !important;
    border-radius: 15px !important;
    background: linear-gradient(135deg, #ff6500, #ff4d00) !important;
    color: #fff !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    box-shadow: 0 13px 28px rgba(255,101,0,.24) !important;
  }

  .auth-app-page .mobile-social-divider {
    grid-template-columns: 1fr auto 1fr !important;
    gap: 12px !important;
    margin-top: 8px !important;
  }

  .auth-app-page .mobile-social-row {
    grid-template-columns: repeat(3, 1fr) !important;
    gap: 9px !important;
  }

  .auth-app-page .mobile-social-row button {
    min-height: 40px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    border: 1px solid #e5e7eb !important;
    border-radius: 13px !important;
    background: #fff !important;
    color: #111827 !important;
    font-size: 12px !important;
    font-weight: 600 !important;
  }

  .auth-app-page .mobile-secure-card {
    min-height: 66px !important;
    margin-top: 10px !important;
    padding: 12px 14px !important;
    grid-template-columns: 40px 1fr !important;
    border: 0 !important;
    border-radius: 16px !important;
    background: linear-gradient(135deg, rgba(255,247,237,.94), rgba(255,255,255,.94)) !important;
    box-shadow: 0 9px 22px rgba(255,101,0,.08) !important;
  }

  .auth-referral-card {
    min-height: 62px !important;
    grid-template-columns: 44px minmax(0, 1fr) 70px !important;
    background: linear-gradient(135deg, #fff7ed, #fff) !important;
  }

  .auth-referral-card::after {
    content: "";
    width: 54px;
    height: 42px;
    justify-self: end;
    border-radius: 14px;
    background: radial-gradient(circle at 68% 67%, #fbbf24 0 10px, transparent 11px), linear-gradient(135deg, #fb923c, #ef4444);
    opacity: .9;
  }

  .auth-referral-card small {
    grid-column: 2;
    margin-top: -4px !important;
    color: #111827 !important;
    font-size: 10.5px !important;
    font-weight: 600 !important;
  }
}

@media (max-width: 760px) {
  .auth-app-page .auth-field {
    grid-template-columns: 42px minmax(0, 1fr) 24px !important;
    grid-auto-flow: column !important;
    min-height: 50px !important;
    padding: 6px 12px !important;
    font-size: 0 !important;
  }

  .auth-app-page .auth-field::before {
    grid-column: 1 !important;
    grid-row: 1 !important;
    align-self: center !important;
    justify-self: center !important;
  }

  .auth-app-page .auth-field input {
    grid-column: 2 / 4 !important;
    grid-row: 1 !important;
    align-self: center !important;
    justify-self: stretch !important;
    text-align: left !important;
    font-size: 14px !important;
  }

  .auth-app-page .auth-field i {
    grid-column: 3 !important;
    grid-row: 1 !important;
    align-self: center !important;
    justify-self: center !important;
  }

  .auth-app-page .auth-field:has(i) input {
    grid-column: 2 !important;
  }

  .auth-app-page .auth-field button {
    display: none !important;
  }

  .auth-app-page .auth-referral-card {
    grid-template-columns: 42px minmax(0, 1fr) 62px !important;
    font-size: 0 !important;
  }

  .auth-app-page .auth-referral-card::before {
    grid-column: 1 !important;
    grid-row: 1 / span 2 !important;
    align-self: center !important;
  }

  .auth-app-page .auth-referral-card input {
    grid-column: 2 !important;
    grid-row: 1 !important;
    text-align: left !important;
    font-size: 14px !important;
  }

  .auth-app-page .auth-referral-card small {
    grid-column: 2 !important;
    grid-row: 2 !important;
    align-self: start !important;
  }

  .auth-app-page .auth-referral-card::after {
    grid-column: 3 !important;
    grid-row: 1 / span 2 !important;
    align-self: center !important;
  }
}

@media (max-width: 760px) {
  .customer-register-page,
  .auth-register-page {
    height: auto !important;
    min-height: 100dvh !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .auth-register-page .customer-login-shell,
  .auth-register-page .admin-login-card,
  .customer-register-page .customer-login-shell,
  .customer-register-page .admin-login-card {
    height: auto !important;
    min-height: 100dvh !important;
    overflow: visible !important;
  }

  .auth-register-page .admin-login-card {
    padding-bottom: calc(28px + env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width: 760px) {
  .auth-app-page .auth-field,
  .auth-app-page .auth-referral-card {
    border-color: #eef1f6 !important;
    transition: border-color .18s ease, box-shadow .18s ease, background .18s ease !important;
  }

  .auth-app-page .auth-field:focus-within,
  .auth-app-page .auth-referral-card:focus-within {
    border-color: transparent !important;
    border-bottom-color: #ff6500 !important;
    border-bottom-width: 2px !important;
    border-radius: 16px 16px 7px 7px !important;
    background: #fff !important;
    box-shadow: 0 10px 24px rgba(255,101,0,.08) !important;
  }

  .auth-app-page .auth-field .password-toggle {
    grid-column: 3 !important;
    grid-row: 1 !important;
    align-self: center !important;
    justify-self: center !important;
    width: 24px !important;
    height: 24px !important;
    display: block !important;
    padding: 0 !important;
    border: 0 !important;
    border-radius: 50% !important;
    background: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 3l18 18'/%3E%3Cpath d='M10.6 10.6a2 2 0 0 0 2.8 2.8'/%3E%3Cpath d='M9.9 5.1A10.5 10.5 0 0 1 12 5c5 0 8.5 4 10 7a14.8 14.8 0 0 1-2.1 3.2'/%3E%3Cpath d='M6.6 6.6A14.5 14.5 0 0 0 2 12c1.5 3 5 7 10 7 1.5 0 2.9-.4 4.1-1'/%3E%3C/svg%3E") center / 20px 20px no-repeat !important;
    box-shadow: none !important;
    opacity: .72 !important;
  }

  .auth-app-page .auth-field .password-toggle.is-visible {
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 24 24' fill='none' stroke='%23ff6500' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M2 12s3.5-7 10-7 10 7 10 7-3.5 7-10 7S2 12 2 12Z'/%3E%3Ccircle cx='12' cy='12' r='3'/%3E%3C/svg%3E") !important;
    opacity: 1 !important;
  }

  .auth-app-page .auth-field:has(.password-toggle) input {
    grid-column: 2 !important;
    padding-right: 4px !important;
  }

  .auth-app-page .auth-field i {
    display: none !important;
  }

  .auth-app-page .mobile-secure-card {
    margin-top: 12px !important;
  }

  .auth-register-page .mobile-trust-strip {
    margin-top: 10px !important;
  }
}

.customer-chat-page {
  display: grid;
  gap: 16px;
  padding: 24px 28px;
}

.customer-chat-head {
  min-height: 128px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 22px;
  border: 1px solid #dfe8f3;
  border-radius: 18px;
  background: linear-gradient(135deg, #fff7ed, #ffffff);
  box-shadow: 0 14px 34px rgba(15, 23, 42, .07);
}

.customer-chat-head span {
  display: inline-flex;
  margin-bottom: 8px;
  padding: 5px 10px;
  border-radius: 999px;
  background: #fff0e6;
  color: #ff6500;
  font-size: 11px;
  font-weight: 900;
  text-transform: uppercase;
}

.customer-chat-head h1,
.customer-chat-head p {
  margin: 0;
}

.customer-chat-head h1 {
  color: #111827;
  font-size: 28px;
  letter-spacing: -0.02em;
}

.customer-chat-head p {
  margin-top: 5px;
  color: #64748b;
}

.customer-chat-head a,
.customer-chat-empty a {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 16px;
  border-radius: 12px;
  background: #ff6500;
  color: #fff;
  font-weight: 900;
}

.customer-chat-card {
  min-height: 420px;
  display: grid;
  border: 1px solid #dfe8f3;
  border-radius: 18px;
  background: #fff;
  box-shadow: 0 16px 38px rgba(15, 23, 42, .06);
}

.customer-chat-empty {
  place-self: center;
  max-width: 360px;
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 26px;
  text-align: center;
}

.customer-chat-empty > span {
  width: 72px;
  height: 72px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  background: #fff7ed;
  color: #ff6500;
  box-shadow: inset 0 0 0 1px #fed7aa;
}

.customer-chat-empty > span::before {
  content: "";
  width: 34px;
  height: 24px;
  border: 3px solid currentColor;
  border-radius: 16px;
}

.customer-chat-empty h2,
.customer-chat-empty p {
  margin: 0;
}

.customer-chat-empty h2 {
  color: #111827;
  font-size: 22px;
}

.customer-chat-empty p {
  color: #64748b;
  line-height: 1.5;
}

@media (max-width: 760px) {
  .customer-chat-page {
    padding: 14px;
  }

  .customer-chat-head {
    min-height: 106px;
    align-items: flex-start;
    padding: 16px;
    border-radius: 16px;
  }

  .customer-chat-head h1 {
    font-size: 22px;
  }

  .customer-chat-head p {
    font-size: 13px;
  }

  .customer-chat-head a {
    min-height: 36px;
    padding: 0 12px;
    font-size: 12px;
    white-space: nowrap;
  }

  .customer-chat-card {
    min-height: calc(100dvh - 230px);
    border-radius: 16px;
  }
}
