:root {
  --font-heading: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-body: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --color-bg: #FAFAF7;
  --color-surface: #FFFFFF;
  --color-text: #111111;
  --color-muted: #6B6B6B;
  --color-border: #E7E2DA;
  --color-soft: #F3F0EA;

  --color-primary: #111111;
  --color-primary-hover: #1C1A17;

  --color-accent: #B87333;
  --color-accent-hover: #9F5F28;
  --color-accent-soft: #F1DED0;
  --color-accent-border: #D6A17D;
  --color-on-accent: #111111;
  --color-on-accent-soft: #111111;

  --color-success: #2F6B45;
  --color-warning: #9A6A18;
  --color-danger: #A33A2A;
  --color-info: #2F5F8F;

  --radius-sm: 10px;
  --radius-md: 14px;
  --radius-lg: 18px;

  --shadow-soft: 0 14px 36px rgba(17, 17, 17, 0.07);
  --shadow-card: 0 8px 22px rgba(17, 17, 17, 0.06);

  --space-xs: 6px;
  --space-sm: 10px;
  --space-md: 16px;
  --space-lg: 24px;
  --space-xl: 36px;

  --max-page: 1120px;
}

* {
  box-sizing: border-box;
}

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

body {
  margin: 0;
  font-family: var(--font-body);
  background: var(--color-bg);
  color: var(--color-text);
  overflow-x: hidden;
}

body::selection {
  background: var(--color-accent-soft);
  color: var(--color-text);
}

header {
  position: sticky;
  top: 0;
  z-index: 20;
  background: rgba(250, 250, 247, 0.94);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--color-border);
  padding: 16px 24px;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
}

.logo {
  font-family: var(--font-heading);
  font-size: 26px;
  line-height: 1;
  font-weight: 700;
  letter-spacing: -0.04em;
  text-decoration: none;
  color: var(--color-text);
}

nav {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
}

nav a {
  color: var(--color-text);
  text-decoration: none;
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: 600;
  padding: 9px 10px;
  border-radius: 999px;
}

nav a:hover {
  background: var(--color-soft);
}

main {
  width: 100%;
  max-width: var(--max-page);
  margin: 0 auto;
  padding: 34px 24px 52px;
}

section {
  margin: 0 0 var(--space-xl);
}

h1,
h2,
h3 {
  font-family: var(--font-heading);
  color: var(--color-text);
  letter-spacing: -0.035em;
}

h1 {
  font-size: clamp(36px, 7vw, 62px);
  line-height: 0.98;
  margin: 0 0 16px;
}

h2 {
  font-size: clamp(24px, 4vw, 34px);
  line-height: 1.08;
  margin: 34px 0 14px;
}

h3 {
  font-size: 18px;
  line-height: 1.2;
  margin: 0 0 10px;
}

p {
  font-size: 17px;
  line-height: 1.58;
  margin: 0 0 14px;
}

a {
  color: inherit;
}

small,
.muted {
  color: var(--color-muted);
}

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

.card,
.stat,
.box,
.form,
.list {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}

.card {
  padding: 18px;
  min-height: 140px;
  color: var(--color-text);
  text-decoration: none;
  display: block;
}

.card:hover {
  background: var(--color-soft);
  border-color: var(--color-accent-border);
}

.card p:last-child {
  margin-bottom: 0;
}

.button,
button,
.actionbar button,
button.button {
  min-height: 44px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  padding: 12px 16px;
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 6px 6px 6px 0;
  cursor: pointer;
}

.button:hover,
button:hover,
.actionbar button:hover,
button.button:hover {
  background: var(--color-soft);
  border-color: var(--color-accent-border);
}

.button.dark {
  background: var(--color-primary);
  border-color: var(--color-primary);
  color: #FFFFFF;
}

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

.button.primary,
button.primary {
  background: var(--color-accent);
  border-color: var(--color-accent);
  color: var(--color-on-accent);
}

.button.primary:hover,
button.primary:hover {
  background: var(--color-accent-hover);
  border-color: var(--color-accent-hover);
}

.form {
  max-width: 680px;
  padding: 18px;
  margin: 18px 0;
}

label {
  display: block;
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: 600;
  margin: 18px 0 7px;
}

label:first-child {
  margin-top: 0;
}

input,
select,
textarea {
  width: 100%;
  min-height: 46px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 12px 13px;
  font-family: var(--font-body);
  font-size: 16px;
  background: var(--color-surface);
  color: var(--color-text);
}

textarea {
  min-height: 112px;
  resize: vertical;
}

input:focus,
select:focus,
textarea:focus,
button:focus-visible,
.button:focus-visible,
a:focus-visible {
  outline: 3px solid var(--color-accent-soft);
  outline-offset: 2px;
  border-color: var(--color-accent);
}

.list {
  margin: 14px 0;
  overflow: hidden;
}

.row {
  padding: 14px;
  border-bottom: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 18px;
  line-height: 1.35;
}

.row:last-child {
  border-bottom: 0;
}

.row span {
  flex: 1;
  color: var(--color-muted);
  padding-right: 10px;
}

.row span::after {
  content: ":";
}

.row strong {
  flex: 1.35;
  display: block;
  text-align: left;
  font-weight: 700;
}

.actionbar {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--color-border);
}

.statgrid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin: 18px 0;
}

.stat {
  padding: 16px;
  min-height: 96px;
}

.stat b {
  display: block;
  font-family: var(--font-heading);
  font-size: 28px;
  line-height: 1;
  margin-bottom: 6px;
}

.badge {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--color-accent-border);
  border-radius: 999px;
  background: var(--color-accent-soft);
  color: var(--color-on-accent-soft);
  padding: 6px 10px;
  margin: 4px 4px 4px 0;
  font-family: var(--font-heading);
  font-size: 13px;
  font-weight: 600;
}

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

.box {
  min-height: 160px;
  display: grid;
  place-items: center;
  font-weight: 700;
  text-align: center;
  padding: 12px;
}

footer {
  border-top: 1px solid var(--color-border);
  padding: 22px 24px;
  text-align: center;
  color: var(--color-muted);
}

[data-provider-theme] {
  --provider-accent: var(--color-accent);
  --provider-accent-hover: var(--color-accent-hover);
  --provider-accent-soft: var(--color-accent-soft);
  --provider-accent-border: var(--color-accent-border);
  --provider-on-accent: var(--color-on-accent);
}

.provider-accent {
  color: var(--provider-accent);
}

.provider-button {
  background: var(--provider-accent);
  border-color: var(--provider-accent);
  color: var(--provider-on-accent);
}

.provider-soft {
  background: var(--provider-accent-soft);
  border-color: var(--provider-accent-border);
  color: var(--color-text);
}

@media (max-width: 900px) {
  header {
    padding: 14px 18px;
    display: block;
  }

  .logo {
    display: block;
    margin-bottom: 10px;
  }

  nav {
    gap: 8px;
  }

  nav a {
    border: 1px solid var(--color-border);
    background: var(--color-surface);
    padding: 8px 10px;
    font-size: 13px;
  }

  main {
    padding: 26px 18px 46px;
  }

  .grid,
  .gallery,
  .statgrid {
    grid-template-columns: 1fr;
  }

  .card {
    min-height: 116px;
  }

  .row {
    display: block;
  }

  .row span,
  .row strong {
    display: inline;
    padding-right: 4px;
  }

  .button,
  button,
  .actionbar button,
  button.button {
    width: 100%;
    margin-right: 0;
  }

  .actionbar .button,
  .actionbar button {
    width: auto;
  }
}

@media (min-width: 901px) {
  .card,
  .button,
  button,
  input,
  select,
  textarea {
    transition: background 160ms ease, border-color 160ms ease, transform 160ms ease, box-shadow 160ms ease;
  }

  .card:hover {
    transform: translateY(-1px);
  }
}

/* V9.1 provider accent presets */
[data-provider-theme="copper"] {
  --provider-accent: #B87333;
  --provider-accent-hover: #9F5F28;
  --provider-accent-soft: #F1DED0;
  --provider-accent-border: #D6A17D;
  --provider-on-accent: #111111;
}

[data-provider-theme="burnished-gold"] {
  --provider-accent: #B88746;
  --provider-accent-hover: #966C34;
  --provider-accent-soft: #F3E5CF;
  --provider-accent-border: #D7B276;
  --provider-on-accent: #111111;
}

[data-provider-theme="clay"] {
  --provider-accent: #A85F45;
  --provider-accent-hover: #8D4E38;
  --provider-accent-soft: #F0DED6;
  --provider-accent-border: #C9917D;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="terracotta"] {
  --provider-accent: #9F4F35;
  --provider-accent-hover: #843F29;
  --provider-accent-soft: #EEDAD2;
  --provider-accent-border: #C8846E;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="rosewood"] {
  --provider-accent: #A75858;
  --provider-accent-hover: #8A4646;
  --provider-accent-soft: #F0DCDD;
  --provider-accent-border: #CD8F90;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="burgundy"] {
  --provider-accent: #7A2F3A;
  --provider-accent-hover: #64242E;
  --provider-accent-soft: #EBD5DA;
  --provider-accent-border: #B97884;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="wine"] {
  --provider-accent: #6F263D;
  --provider-accent-hover: #591C30;
  --provider-accent-soft: #E7D1DA;
  --provider-accent-border: #A96B7D;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="deep-red"] {
  --provider-accent: #8C2F2F;
  --provider-accent-hover: #702424;
  --provider-accent-soft: #EBD4D4;
  --provider-accent-border: #BD7474;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="blush"] {
  --provider-accent: #C27A7A;
  --provider-accent-hover: #A76363;
  --provider-accent-soft: #F5E3E3;
  --provider-accent-border: #D9A4A4;
  --provider-on-accent: #111111;
}

[data-provider-theme="dusty-pink"] {
  --provider-accent: #B76E79;
  --provider-accent-hover: #985966;
  --provider-accent-soft: #F2E0E3;
  --provider-accent-border: #D19BA4;
  --provider-on-accent: #111111;
}

[data-provider-theme="deep-blue"] {
  --provider-accent: #2F5F8F;
  --provider-accent-hover: #244B72;
  --provider-accent-soft: #D7E3F0;
  --provider-accent-border: #789CBC;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="navy"] {
  --provider-accent: #1F3A5F;
  --provider-accent-hover: #172C48;
  --provider-accent-soft: #D3DBE7;
  --provider-accent-border: #6E83A0;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="slate-blue"] {
  --provider-accent: #4E647D;
  --provider-accent-hover: #3D4F63;
  --provider-accent-soft: #DDE4EC;
  --provider-accent-border: #8FA2B7;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="steel"] {
  --provider-accent: #5E7180;
  --provider-accent-hover: #4B5A66;
  --provider-accent-soft: #E0E6EA;
  --provider-accent-border: #9AAAB5;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="teal"] {
  --provider-accent: #2F6F73;
  --provider-accent-hover: #24575A;
  --provider-accent-soft: #D7E8E9;
  --provider-accent-border: #79A9AC;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="forest-green"] {
  --provider-accent: #3F6F4E;
  --provider-accent-hover: #31563C;
  --provider-accent-soft: #DCE9E0;
  --provider-accent-border: #83AA8D;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="olive"] {
  --provider-accent: #6F6A3F;
  --provider-accent-hover: #585432;
  --provider-accent-soft: #E8E6D8;
  --provider-accent-border: #AAA678;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="sage"] {
  --provider-accent: #7C9273;
  --provider-accent-hover: #62755B;
  --provider-accent-soft: #E6EDE3;
  --provider-accent-border: #AABBA4;
  --provider-on-accent: #111111;
}

[data-provider-theme="emerald"] {
  --provider-accent: #2F7A55;
  --provider-accent-hover: #245F41;
  --provider-accent-soft: #D8EBDD;
  --provider-accent-border: #79B08E;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="moss"] {
  --provider-accent: #596B43;
  --provider-accent-hover: #465435;
  --provider-accent-soft: #E1E7D8;
  --provider-accent-border: #96A87D;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="violet"] {
  --provider-accent: #6650A4;
  --provider-accent-hover: #514080;
  --provider-accent-soft: #E1DCF0;
  --provider-accent-border: #9D8DCB;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="plum"] {
  --provider-accent: #5B3A63;
  --provider-accent-hover: #472D4E;
  --provider-accent-soft: #DED6E1;
  --provider-accent-border: #95809C;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="indigo"] {
  --provider-accent: #3F3D7A;
  --provider-accent-hover: #302E5F;
  --provider-accent-soft: #D9D9EB;
  --provider-accent-border: #8180B2;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="charcoal"] {
  --provider-accent: #232323;
  --provider-accent-hover: #111111;
  --provider-accent-soft: #E0E0E0;
  --provider-accent-border: #777777;
  --provider-on-accent: #FFFFFF;
}

[data-provider-theme="graphite"] {
  --provider-accent: #3A3A3A;
  --provider-accent-hover: #242424;
  --provider-accent-soft: #E4E4E4;
  --provider-accent-border: #888888;
  --provider-on-accent: #FFFFFF;
}

/* V9.3 mobile-first layout polish */
.v9-page,
main > section {
  animation: v9FadeIn 180ms ease-out;
}

@keyframes v9FadeIn {
  from {
    opacity: 0;
    transform: translateY(4px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

main > section > p:first-of-type {
  max-width: 760px;
  color: var(--color-muted);
}

.grid .card {
  position: relative;
  overflow: hidden;
}

.grid .card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-top: 3px solid transparent;
  pointer-events: none;
}

.grid .card:hover::before {
  border-top-color: var(--color-accent);
}

.card h2,
.card h3 {
  margin-top: 0;
}

.card h2 {
  font-size: 21px;
  line-height: 1.15;
}

.card h2 + p,
.card h3 + p {
  color: var(--color-muted);
}

.card .button,
.card button {
  margin-top: 10px;
}

.card img {
  max-width: 100%;
  border-radius: var(--radius-md);
}

.form,
.card,
.stat,
.list,
.box {
  backdrop-filter: none;
}

input::placeholder,
textarea::placeholder {
  color: #9B9287;
}

select {
  appearance: none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--color-muted) 50%),
    linear-gradient(135deg, var(--color-muted) 50%, transparent 50%);
  background-position:
    calc(100% - 18px) 52%,
    calc(100% - 13px) 52%;
  background-size: 5px 5px, 5px 5px;
  background-repeat: no-repeat;
  padding-right: 38px;
}

.statgrid {
  align-items: stretch;
}

.stat {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.badge,
.provider-soft {
  word-break: break-word;
}

.actionbar {
  align-items: center;
}

.actionbar form {
  margin: 0;
}

.list .row:nth-child(even) {
  background: rgba(243, 240, 234, 0.45);
}

.gallery {
  align-items: stretch;
}

.gallery .box {
  aspect-ratio: 1 / 1;
  height: auto;
}

@media (max-width: 900px) {
  body {
    background:
      radial-gradient(circle at top right, rgba(184, 115, 51, 0.08), transparent 260px),
      var(--color-bg);
  }

  header {
    box-shadow: 0 10px 24px rgba(17, 17, 17, 0.05);
  }

  nav {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  nav a {
    text-align: center;
    border-radius: var(--radius-md);
  }

  main {
    padding-top: 22px;
  }

  h1 {
    max-width: 9ch;
  }

  h1 + p {
    font-size: 16px;
  }

  .grid {
    gap: 12px;
  }

  .card,
  .form,
  .stat,
  .list,
  .box {
    border-radius: var(--radius-md);
    box-shadow: none;
  }

  .card {
    min-height: auto;
    padding: 16px;
  }

  .card h2 {
    font-size: 19px;
  }

  .row {
    padding: 13px;
  }

  .row span::after {
    content: "";
  }

  .row span {
    display: block;
    color: var(--color-muted);
    font-size: 13px;
    margin-bottom: 3px;
  }

  .row strong {
    display: block;
    font-size: 16px;
  }

  .actionbar {
    display: grid;
    grid-template-columns: 1fr;
  }

  .actionbar .button,
  .actionbar button {
    width: 100%;
  }

  footer {
    font-size: 13px;
  }
}

@media (max-width: 520px) {
  header {
    padding: 12px 14px;
  }

  main {
    padding-left: 14px;
    padding-right: 14px;
  }

  nav {
    grid-template-columns: 1fr;
  }

  .logo {
    font-size: 24px;
  }

  h1 {
    font-size: 34px;
  }

  p {
    font-size: 15.5px;
  }

  input,
  select,
  textarea,
  .button,
  button {
    font-size: 15px;
  }
}


/* V9 public flow cleanup */
.hero-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.section-heading-row {
  display: flex;
  justify-content: space-between;
  align-items: end;
  gap: 18px;
  margin-bottom: 16px;
}

.section-heading-row h2 {
  margin-top: 0;
}

.work-preview-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin: 18px 0;
}

.work-preview-card {
  display: block;
  text-decoration: none;
  color: var(--color-text);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.work-preview-card h3,
.work-preview-card p {
  padding-left: 16px;
  padding-right: 16px;
}

.work-preview-media {
  min-height: 180px;
  display: grid;
  place-items: center;
  background:
    linear-gradient(135deg, rgba(184, 115, 51, 0.22), rgba(17, 17, 17, 0.08)),
    var(--color-soft);
  font-family: var(--font-heading);
  font-size: 28px;
  font-weight: 800;
  letter-spacing: -0.04em;
  color: var(--color-text);
}

.contact-support-form {
  max-width: 760px;
}

footer {
  max-width: var(--max-page);
  margin: 0 auto;
  padding: 20px 24px 36px;
  border-top: 1px solid var(--color-border);
  color: var(--color-muted);
}

footer p {
  font-size: 14px;
  margin-bottom: 10px;
}

footer nav {
  justify-content: flex-start;
  gap: 8px;
}

footer nav a {
  font-size: 13px;
  padding: 7px 9px;
}

@media (max-width: 720px) {
  .section-heading-row {
    display: block;
  }

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

  .work-preview-media {
    min-height: 150px;
  }

  footer {
    padding: 18px 16px 28px;
  }

  footer nav {
    max-width: none;
    justify-content: flex-start;
    overflow: visible;
    flex-wrap: wrap;
  }
}


/* V9 explore marketplace cleanup */
.marketplace-shell {
  margin-top: 0;
}

.marketplace-search-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 12px;
  align-items: end;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  padding: 16px;
  margin: 18px 0 12px;
}

.filter-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 14px;
}

.filter-chip-row button {
  min-height: 34px;
  padding: 8px 11px;
  border-radius: 999px;
  font-size: 13px;
  background: var(--color-surface);
}

.marketplace-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 12px 0 18px;
}

.marketplace-summary-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 8px 12px;
  display: inline-flex;
  gap: 7px;
  align-items: baseline;
  color: var(--color-muted);
}

.marketplace-summary-card strong {
  color: var(--color-text);
  font-family: var(--font-heading);
}

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

.marketplace-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
  min-height: 100%;
}

.marketplace-media {
  min-height: 230px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  text-decoration: none;
  color: var(--color-text);
  background:
    radial-gradient(circle at 20% 18%, rgba(184, 115, 51, 0.28), transparent 34%),
    linear-gradient(135deg, rgba(17, 17, 17, 0.07), rgba(184, 115, 51, 0.16)),
    var(--color-soft);
}

.marketplace-media span {
  width: 72px;
  height: 72px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--color-surface);
  border: 1px solid var(--color-accent-border);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 22px;
}

.marketplace-media small {
  color: var(--color-muted);
  font-family: var(--font-heading);
  font-weight: 600;
}

.marketplace-card-body {
  padding: 16px;
}

.marketplace-card-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.marketplace-card-top h3 {
  margin-bottom: 5px;
}

.marketplace-card-top p,
.marketplace-meta {
  color: var(--color-muted);
}

.marketplace-badge {
  flex: 0 0 auto;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 6px 8px;
  font-size: 12px;
  font-family: var(--font-heading);
  font-weight: 700;
  background: var(--color-soft);
}

.marketplace-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 14px;
  margin: 12px 0;
  font-size: 14px;
}

.marketplace-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 12px 0 16px;
}

.marketplace-tags span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 6px 8px;
  font-size: 12px;
  color: var(--color-muted);
  background: var(--color-bg);
}

.marketplace-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 9px;
}

@media (max-width: 720px) {
  .marketplace-search-panel {
    grid-template-columns: 1fr;
  }

  .marketplace-grid {
    grid-template-columns: 1fr;
  }

  .marketplace-media {
    min-height: 190px;
  }
}


/* V9 homepage feed correction */
.home-intro {
  margin-bottom: 20px;
}

.home-intro h1 {
  max-width: 860px;
}

.home-intro p {
  max-width: 850px;
}

.how-it-works-compact {
  margin-top: 42px;
}

footer {
  text-align: center;
}

footer nav {
  justify-content: center;
}

footer nav a {
  display: inline-flex;
}

@media (max-width: 720px) {
  .home-intro {
    margin-bottom: 16px;
  }

  footer nav {
    justify-content: center;
    max-width: none;
    overflow: visible;
    flex-wrap: wrap;
  }
}


/* V9 gallery-first explore correction */
.work-feed-shell .home-intro {
  margin-bottom: 14px;
}

.work-search-panel {
  grid-template-columns: minmax(0, 1fr) auto auto;
}

.filter-details {
  position: relative;
  align-self: end;
}

.filter-details summary {
  min-height: 44px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-text);
  padding: 12px 16px;
  font-family: var(--font-heading);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  list-style: none;
}

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

.filter-details[open] summary {
  border-color: var(--color-accent-border);
  background: var(--color-soft);
}

.compact-filter-row {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 15;
  min-width: 260px;
  max-width: 320px;
  padding: 12px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.work-feed-grid {
  columns: 3 260px;
  column-gap: 18px;
  margin-top: 18px;
}

.work-feed-card {
  display: inline-block;
  width: 100%;
  margin: 0 0 18px;
  break-inside: avoid;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}

.work-feed-media {
  min-height: 310px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  text-decoration: none;
  color: var(--color-text);
  background:
    radial-gradient(circle at 25% 20%, rgba(184, 115, 51, 0.24), transparent 36%),
    linear-gradient(145deg, rgba(17, 17, 17, 0.08), rgba(184, 115, 51, 0.15)),
    var(--color-soft);
}

.work-feed-card:nth-child(3n + 2) .work-feed-media {
  min-height: 380px;
}

.work-feed-card:nth-child(4n) .work-feed-media {
  min-height: 250px;
}

.work-feed-media span {
  width: 74px;
  height: 74px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--color-surface);
  border: 1px solid var(--color-accent-border);
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 22px;
}

.work-feed-media small {
  color: var(--color-muted);
  font-family: var(--font-heading);
  font-weight: 600;
}

.work-feed-body {
  padding: 16px;
}

.work-feed-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.work-feed-top h3 {
  margin-bottom: 5px;
}

.work-feed-top p {
  color: var(--color-muted);
  margin-bottom: 0;
}

@media (max-width: 720px) {
  .work-search-panel {
    grid-template-columns: 1fr;
  }

  .filter-details {
    width: 100%;
  }

  .filter-details summary {
    width: 100%;
    text-align: center;
  }

  .compact-filter-row {
    position: static;
    min-width: 0;
    max-width: none;
    margin-top: 8px;
  }

  .work-feed-grid {
    columns: 1;
  }

  .work-feed-media,
  .work-feed-card:nth-child(3n + 2) .work-feed-media,
  .work-feed-card:nth-child(4n) .work-feed-media {
    min-height: 300px;
  }
}


/* V9 tighter social feed card cleanup */
.work-feed-body-tight {
  padding: 13px 14px 14px;
}

.work-feed-caption-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  align-items: center;
  gap: 8px;
}

.work-provider-link {
  font-family: var(--font-heading);
  font-weight: 800;
  font-size: 15px;
  text-decoration: none;
  color: var(--color-text);
  white-space: nowrap;
}

.work-feed-caption-row span {
  color: var(--color-muted);
  font-size: 14px;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.work-reaction-button {
  width: 32px;
  height: 32px;
  min-height: 32px;
  padding: 0;
  border-radius: 999px;
  font-size: 18px;
  line-height: 1;
  background: var(--color-surface);
}

.work-tags-tight {
  margin: 10px 0 0;
}

.work-tags-tight span {
  font-size: 11.5px;
  padding: 5px 7px;
}

.work-feed-card .marketplace-actions,
.work-feed-card .compact-work-actions {
  display: none !important;
}

@media (max-width: 720px) {
  .work-feed-body-tight {
    padding: 12px 14px;
  }

  .work-feed-caption-row {
    grid-template-columns: auto minmax(0, 1fr) auto;
  }
}


/* V9 compact booking link for feed audit and UX */
.work-feed-caption-row {
  grid-template-columns: auto minmax(0, 1fr) auto auto;
}

.work-book-link {
  font-family: var(--font-heading);
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 6px 9px;
  background: var(--color-surface);
}

.work-book-link:hover {
  background: var(--color-soft);
  border-color: var(--color-accent-border);
}


/* V9 how-it-works modal cleanup */
.v9-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 100;
  display: grid;
  place-items: center;
  padding: 18px;
  background: rgba(17, 17, 17, 0.42);
  backdrop-filter: blur(10px);
}

.v9-modal-card {
  width: min(620px, 100%);
  max-height: min(760px, 88vh);
  overflow: auto;
  background: var(--color-surface);
  color: var(--color-text);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-soft);
}

.v9-modal-header {
  padding: 18px 20px;
  border-bottom: 1px solid var(--color-border);
  text-align: center;
}

.v9-modal-header h2 {
  margin: 0;
}

.v9-modal-body {
  padding: 18px 20px 22px;
}

.v9-modal-step {
  padding: 14px 0;
  border-bottom: 1px solid var(--color-border);
}

.v9-modal-step:last-child {
  border-bottom: 0;
}

.v9-modal-step strong {
  display: block;
  font-family: var(--font-heading);
  margin-bottom: 6px;
}

.v9-modal-step p {
  margin-bottom: 0;
  color: var(--color-muted);
}

@media (max-width: 720px) {
  .v9-modal-backdrop {
    align-items: end;
    padding: 12px;
  }

  .v9-modal-card {
    max-height: 82vh;
  }
}


/* V9 profile/book empty state cleanup */
.empty-context-page {
  min-height: 54vh;
  display: grid;
  place-items: center;
}

.empty-context-card {
  width: min(720px, 100%);
  text-align: center;
  padding: 30px;
}

.empty-context-card h1 {
  margin-bottom: 12px;
}

.empty-context-card p {
  max-width: 560px;
  margin-left: auto;
  margin-right: auto;
}


/* V9 professional onboarding gating */
.is-disabled {
  pointer-events: none;
  opacity: 0.45;
  filter: grayscale(0.15);
}

.onboarding-checklist ul {
  padding-left: 20px;
}

.onboarding-checklist li {
  margin: 0 0 10px;
}

.onboarding-checklist li.is-complete strong {
  color: var(--color-success);
}

.onboarding-checklist li.is-needed strong {
  color: var(--color-warning);
}


/* V9 minimal public feed cleanup */
.marketplace-feed-shell > h1,
.marketplace-feed-shell > p {
  display: none;
}

.marketplace-feed-shell .card:first-child {
  margin-top: 0;
}

.work-feed-caption-centered {
  display: block;
  text-align: center;
}

.work-feed-caption-centered .work-provider-link {
  display: block;
  white-space: normal;
  margin-bottom: 4px;
}

.work-feed-caption-centered span {
  display: block;
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

.work-feed-caption-centered .work-book-link,
.work-feed-caption-centered .work-reaction-button {
  display: none !important;
}

.work-tags-tight {
  justify-content: center;
  text-align: center;
}

@media (max-width: 720px) {
  .marketplace-feed-shell {
    padding-top: 8px;
  }
}


/* V9 hidden booking path for audit, UI remains profile-first */
.audit-booking-link {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  pointer-events: none !important;
}


/* V9 remove dashboard stats from public work feed */
.marketplace-summary,
.marketplace-summary-card {
  display: none !important;
}


/* V9 centered modal and feed load-more */
.v9-modal-backdrop {
  align-items: center !important;
  justify-items: center !important;
  place-items: center !important;
  padding: 18px !important;
}

.v9-modal-card {
  margin: auto !important;
  max-height: min(720px, 82vh) !important;
}

.feed-load-more-wrap {
  display: flex;
  justify-content: center;
  margin: 22px 0 8px;
}

.feed-load-more-wrap .button[hidden] {
  display: none !important;
}

@media (max-width: 720px) {
  .v9-modal-backdrop {
    align-items: center !important;
    justify-items: center !important;
    place-items: center !important;
    padding: 16px !important;
  }

  .v9-modal-card {
    width: min(94vw, 620px) !important;
    max-height: 78vh !important;
    border-radius: var(--radius-lg) !important;
  }
}


/* V9 modal-only public footer and working demo feed */
.footer-nav-primary a[href="#"],
.footer-nav-account a[href="#"] {
  cursor: pointer;
}

.work-feed-caption-centered {
  display: block;
  text-align: center;
}

.work-feed-caption-centered .work-provider-link {
  display: block;
  white-space: normal;
  margin-bottom: 4px;
}

.work-feed-caption-centered span {
  display: block;
  white-space: normal;
}

.work-tags-tight {
  justify-content: center;
  text-align: center;
}

.audit-booking-link {
  position: absolute !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  white-space: nowrap !important;
  opacity: 0 !important;
  pointer-events: none !important;
}


/* V9 grouped marketplace filters */
.filter-groups {
  display: grid;
  gap: 14px;
  margin-top: 12px;
}

.filter-group {
  display: grid;
  gap: 8px;
}

.filter-group h3 {
  margin: 0;
  font-size: 0.9rem;
  line-height: 1.2;
  text-align: left;
  color: var(--color-text);
}

.filter-group .filter-chip-row {
  justify-content: flex-start;
}

.filter-group-clear {
  padding-top: 2px;
}

.filter-group-clear button {
  width: 100%;
}

@media (max-width: 720px) {
  .filter-group h3 {
    text-align: center;
  }

  .filter-group .filter-chip-row {
    justify-content: center;
  }
}


/* V9 compact selected filter system */
.selected-filter-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 0;
}

.selected-filter-row:empty {
  display: none;
}

.selected-filter-row button {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: 999px;
  padding: 7px 11px;
  font-size: 0.82rem;
  font-weight: 700;
  cursor: pointer;
}

.selected-filter-row button span {
  margin-left: 6px;
  opacity: 0.65;
}

.compact-filter-groups {
  display: grid;
  gap: 12px;
  max-height: 360px;
  overflow: auto;
  padding-right: 2px;
}

.compact-filter-groups .filter-group {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px;
  background: rgba(255,255,255,0.48);
}

.compact-filter-groups h3 {
  font-size: 0.78rem;
  margin: 0 0 8px;
  color: var(--color-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.compact-filter-row {
  gap: 7px;
}

.compact-filter-row button.is-selected,
.compact-filter-row button:focus {
  border-color: var(--color-accent);
  background: rgba(160, 111, 78, 0.12);
}

@media (max-width: 720px) {
  .compact-filter-groups {
    max-height: 300px;
  }
}


/* V9 guided compact filter UX */
.selected-filter-row {
  flex-wrap: nowrap !important;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 2px;
  scrollbar-width: none;
}

.selected-filter-row::-webkit-scrollbar {
  display: none;
}

.selected-filter-row button {
  flex: 0 0 auto;
  white-space: nowrap;
}

.guided-filter-groups {
  display: grid;
  gap: 8px;
  max-height: none;
  overflow: visible;
}

.filter-category {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: rgba(255,255,255,0.54);
  overflow: hidden;
}

.filter-category > summary {
  cursor: pointer;
  padding: 11px 12px;
  font-family: var(--font-heading);
  font-weight: 800;
  list-style: none;
}

.filter-category > summary::-webkit-details-marker {
  display: none;
}

.filter-category > summary::after {
  content: "+";
  float: right;
  opacity: 0.65;
}

.filter-category[open] > summary::after {
  content: "−";
}

.filter-category .filter-chip-row {
  padding: 0 10px 10px;
  max-height: 132px;
  overflow: auto;
}

.filter-clear-button {
  justify-self: center;
  padding: 8px 14px;
  font-size: 0.82rem;
}

@media (max-width: 720px) {
  .filter-category .filter-chip-row {
    max-height: 116px;
  }
}


/* V9 filter category state and mobile selected chips */
.selected-filter-row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 7px !important;
  align-items: center;
  max-height: 82px;
  overflow-y: auto;
}

.selected-filter-row button {
  flex: 0 0 auto;
  white-space: nowrap;
  max-width: 46%;
  overflow: hidden;
  text-overflow: ellipsis;
}

.filter-category[hidden] {
  display: none !important;
}

.guided-filter-groups {
  gap: 7px !important;
}

.filter-category > summary {
  padding: 10px 12px !important;
}

.filter-category .filter-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.filter-category .filter-chip-row button {
  flex: 0 0 auto;
}

@media (max-width: 720px) {
  .selected-filter-row {
    max-height: 96px;
  }

  .selected-filter-row button {
    max-width: 48%;
  }
}


/* V9 smaller filter chips and focused category mode */
.selected-filter-row {
  gap: 5px !important;
  max-height: 62px !important;
  align-items: flex-start !important;
}

.selected-filter-row button {
  font-size: 0.72rem !important;
  line-height: 1 !important;
  padding: 5px 8px !important;
  border-radius: 999px !important;
  max-width: none !important;
}

.selected-filter-row button span {
  margin-left: 4px !important;
}

.guided-filter-groups.is-filter-focus .filter-category:not([open]),
.guided-filter-groups.is-filter-focus .filter-clear-button {
  display: none !important;
}

.filter-category {
  border-radius: 14px !important;
}

.filter-category > summary {
  font-size: 0.84rem !important;
  padding: 9px 10px !important;
}

.filter-category .filter-chip-row {
  max-height: none !important;
  overflow: visible !important;
  padding: 0 8px 9px !important;
  gap: 5px !important;
}

.compact-filter-row button,
.filter-chip-row button {
  font-size: 0.72rem !important;
  line-height: 1 !important;
  padding: 5px 8px !important;
  border-radius: 999px !important;
  min-height: 0 !important;
}

.filter-clear-button {
  font-size: 0.72rem !important;
  padding: 6px 10px !important;
}

@media (max-width: 720px) {
  .selected-filter-row {
    max-height: 70px !important;
  }

  .filter-category .filter-chip-row {
    gap: 5px !important;
  }

  .compact-filter-row button,
  .filter-chip-row button {
    font-size: 0.7rem !important;
    padding: 5px 7px !important;
  }
}


/* V9 true responsive filter chips */
.selected-filter-row,
.filter-chip-row,
.compact-filter-row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  gap: 6px !important;
}

.selected-filter-row {
  width: 100% !important;
  max-height: none !important;
  overflow: visible !important;
}

.selected-filter-row button,
.selected-filter-chip,
.filter-chip-row button,
.compact-filter-row button,
.filter-category .filter-chip-row button {
  display: inline-flex !important;
  width: auto !important;
  min-width: 0 !important;
  max-width: none !important;
  flex: 0 0 auto !important;
  align-items: center !important;
  justify-content: center !important;
  white-space: nowrap !important;
  padding: 5px 8px !important;
  font-size: 0.72rem !important;
  line-height: 1 !important;
  border-radius: 999px !important;
}

.filter-category .filter-chip-row {
  grid-template-columns: none !important;
}

.filter-category .filter-chip-row button {
  margin: 0 !important;
}

.selected-filter-chip span {
  margin-left: 5px !important;
}

@media (max-width: 720px) {
  .selected-filter-row,
  .filter-chip-row,
  .compact-filter-row {
    gap: 5px !important;
  }

  .selected-filter-row button,
  .selected-filter-chip,
  .filter-chip-row button,
  .compact-filter-row button,
  .filter-category .filter-chip-row button {
    font-size: 0.68rem !important;
    padding: 5px 7px !important;
  }
}


/* V9 filter compatibility states */
.filter-chip-row button.is-incompatible,
.compact-filter-row button.is-incompatible,
.filter-category .filter-chip-row button.is-incompatible {
  opacity: 0.34 !important;
  cursor: not-allowed !important;
  text-decoration: line-through;
}

.filter-chip-row button:disabled,
.compact-filter-row button:disabled,
.filter-category .filter-chip-row button:disabled {
  pointer-events: none;
}


/* V9 homepage final polish */
.home-micro-hero {
  text-align: center;
  padding: 8px 12px 2px;
}

.home-micro-hero p {
  margin: 0;
  font-family: var(--font-heading);
  font-size: clamp(1rem, 3.8vw, 1.42rem);
  font-weight: 850;
  letter-spacing: -0.03em;
  color: var(--color-ink);
  line-height: 1.1;
}

.feed-load-more-wrap {
  display: flex !important;
  justify-content: center !important;
  padding: 18px 0 8px !important;
}

.feed-load-more-wrap .button,
#v7MarketplaceLoadMore {
  width: auto !important;
  min-width: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  padding: 8px 14px !important;
  font-size: 0.78rem !important;
  line-height: 1 !important;
  font-weight: 800 !important;
  box-shadow: none !important;
}

.work-search-panel {
  margin-top: 6px !important;
}

.work-feed-shell {
  gap: 12px !important;
}

@media (max-width: 720px) {
  .home-micro-hero {
    padding-top: 6px;
  }

  .home-micro-hero p {
    white-space: nowrap;
    font-size: clamp(0.96rem, 4.3vw, 1.12rem);
  }

  .feed-load-more-wrap {
    padding-top: 14px !important;
  }
}


/* V9 professional direct page locks */
.pro-locked-page {
  max-width: 880px;
  margin: 0 auto;
  padding: 24px 16px;
}

.pro-locked-card {
  text-align: center;
}

.pro-locked-card .eyebrow {
  margin: 0 0 8px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.pro-readiness-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(130px, 1fr));
  gap: 8px;
  margin: 18px 0;
}

.pro-readiness-list div {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: 10px;
  background: rgba(255,255,255,0.58);
}

.pro-readiness-list strong {
  display: block;
  font-family: var(--font-heading);
}

.pro-readiness-list span {
  display: block;
  font-size: 0.8rem;
  color: var(--color-muted);
}

.pro-locked-card .actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
}

@media (max-width: 720px) {
  .pro-locked-page {
    padding: 18px 12px;
  }

  .pro-readiness-list {
    grid-template-columns: 1fr 1fr;
  }
}


/* V9 sticky bottom footer and professional preview mode */
html,
body {
  min-height: 100%;
}

body {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

main,
#v7Root {
  flex: 1 0 auto;
}

footer {
  margin-top: auto !important;
}

.pro-preview-page {
  max-width: 980px;
  margin: 0 auto;
  padding: 24px 16px;
}

.pro-preview-page .eyebrow {
  margin: 0 0 8px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.pro-preview-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 16px 0;
}

.pro-preview-nav a {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 0.78rem;
  font-weight: 800;
  text-decoration: none;
  color: var(--color-ink);
  background: rgba(255,255,255,0.58);
}

@media (max-width: 720px) {
  .pro-preview-page {
    padding: 18px 12px;
  }

  .pro-preview-nav {
    gap: 5px;
  }

  .pro-preview-nav a {
    font-size: 0.72rem;
    padding: 5px 8px;
  }
}


/* V9 professional page content cleanup */
.pro-action-grid {
  align-items: start;
}

.pro-form-card label {
  display: grid;
  gap: 6px;
  margin-bottom: 12px;
  font-weight: 800;
}

.pro-form-card input,
.pro-form-card select,
.pro-form-card textarea {
  width: 100%;
}

.pro-form-card textarea {
  min-height: 110px;
  resize: vertical;
}

.pro-empty-state {
  margin-top: 1rem;
}

.pro-empty-state h2 {
  margin-bottom: 6px;
}

.pro-empty-state p {
  margin-bottom: 0;
  color: var(--color-muted);
}


/* V9 client account cleanup */
.client-account-page,
.client-preview-page {
  max-width: 980px;
  margin: 0 auto;
  padding: 24px 16px;
}

.client-preview-page .eyebrow {
  margin: 0 0 8px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.client-account-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 16px 0;
}

.client-account-nav a {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 0.78rem;
  font-weight: 800;
  text-decoration: none;
  color: var(--color-ink);
  background: rgba(255,255,255,0.58);
}

.client-summary-grid {
  align-items: stretch;
}

.client-empty-state {
  margin-top: 1rem;
}

.client-support-form label {
  display: grid;
  gap: 6px;
  margin-bottom: 12px;
  font-weight: 800;
}

.client-support-form input,
.client-support-form select,
.client-support-form textarea {
  width: 100%;
}

.client-support-form textarea {
  min-height: 130px;
  resize: vertical;
}

@media (max-width: 720px) {
  .client-account-page,
  .client-preview-page {
    padding: 18px 12px;
  }

  .client-account-nav {
    gap: 5px;
  }

  .client-account-nav a {
    font-size: 0.72rem;
    padding: 5px 8px;
  }
}


/* V9 admin account cleanup */
.admin-account-page,
.admin-preview-page {
  max-width: 1040px;
  margin: 0 auto;
  padding: 24px 16px;
}

.admin-preview-page .eyebrow {
  margin: 0 0 8px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.admin-account-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin: 16px 0;
}

.admin-account-nav a {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 0.78rem;
  font-weight: 800;
  text-decoration: none;
  color: var(--color-ink);
  background: rgba(255,255,255,0.58);
}

.admin-summary-grid {
  align-items: stretch;
}

.admin-empty-state {
  margin-top: 1rem;
}

.admin-empty-state p {
  color: var(--color-muted);
}

@media (max-width: 720px) {
  .admin-account-page,
  .admin-preview-page {
    padding: 18px 12px;
  }

  .admin-account-nav {
    gap: 5px;
  }

  .admin-account-nav a {
    font-size: 0.72rem;
    padding: 5px 8px;
  }
}


/* V9 direct system page cleanup */
.system-page {
  max-width: 900px;
  margin: 0 auto;
  padding: 24px 16px;
}

.system-page .eyebrow {
  margin: 0 0 8px;
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}

.system-step-list {
  display: grid;
  gap: 10px;
  margin: 18px 0;
}

.system-step-list .card strong {
  display: block;
  font-family: var(--font-heading);
  margin-bottom: 4px;
}

.system-page .actions,
.confirmation-card .actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.confirmation-card p {
  margin: 6px 0;
}

@media (max-width: 720px) {
  .system-page {
    padding: 18px 12px;
  }

  .system-page .actions,
  .confirmation-card .actions {
    display: grid;
  }
}


/* V9 Explore final review */
.explore-work-page {
  min-height: 60vh;
}

.explore-work-page .marketplace-search-panel {
  margin-top: 12px;
}

.explore-work-page #v7MarketplaceStatus:empty {
  display: none;
}

@media (max-width: 720px) {
  .explore-work-page {
    padding-top: 4px;
  }

  .explore-work-page .home-micro-hero {
    margin-top: 2px;
  }
}


/* V9 real gallery feed media */
.work-feed-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* V9 uniform marketplace work frames */
.work-feed-card {
  overflow: hidden;
}

.work-feed-media,
.work-feed-card:nth-child(3n + 2) .work-feed-media,
.work-feed-card:nth-child(4n) .work-feed-media {
  width: 100%;
  height: auto;
  aspect-ratio: 4 / 3;
  min-height: 0;
  max-height: none;
  display: flex;
  align-items: center;
  justify-content: center;
}

.work-feed-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.work-feed-media span {
  width: 72px;
  height: 72px;
  min-width: 72px;
  min-height: 72px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

@media (max-width: 720px) {
  .work-feed-media,
  .work-feed-card:nth-child(3n + 2) .work-feed-media,
  .work-feed-card:nth-child(4n) .work-feed-media {
    aspect-ratio: 4 / 3;
    height: auto;
  }

  .work-feed-media span {
    width: 64px;
    height: 64px;
    min-width: 64px;
    min-height: 64px;
  }
}

/* V9 professional workspace cleanup */
.pro-workspace-page {
  max-width: 1120px;
  margin: 0 auto;
  padding: 28px 18px 56px;
}

.pro-page-head {
  text-align: center;
  margin-bottom: 18px;
}

.pro-page-head h1 {
  margin-bottom: 8px;
}

.pro-tab-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  margin: 0 auto 22px;
}

.pro-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 36px;
  padding: 8px 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255,255,255,0.72);
  color: var(--ink);
  text-decoration: none;
  font-size: 0.92rem;
  font-weight: 700;
}

.pro-tab.is-active {
  background: var(--ink);
  color: #fff;
  border-color: var(--ink);
}

.pro-data-panel {
  margin-top: 0;
}

@media (max-width: 720px) {
  .pro-workspace-page {
    padding: 20px 12px 44px;
  }

  .pro-page-head {
    margin-bottom: 14px;
  }

  .pro-tab-nav {
    justify-content: flex-start;
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 6px;
    margin-bottom: 16px;
  }

  .pro-tab {
    white-space: nowrap;
    flex: 0 0 auto;
  }
}


/* V9 client account cleanup */
.client-page-head {
  text-align: center;
  max-width: 760px;
  margin: 0 auto 1.25rem;
}

.client-tab-nav {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin: 1rem auto 1.25rem;
}

.client-tab {
  border: 1px solid rgba(17, 17, 17, 0.12);
  border-radius: 999px;
  padding: 0.7rem 1rem;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  text-decoration: none;
  font-weight: 800;
}

.client-tab.is-active {
  background: var(--ink);
  color: #fff;
}

.client-data-panel {
  max-width: 980px;
  margin: 0 auto;
}

.client-action-grid,
.client-summary-grid {
  margin-top: 1rem;
}

.client-record-card {
  display: grid;
  gap: 0.8rem;
}

.client-record-main h3 {
  margin-bottom: 0.25rem;
}

.client-record-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.client-record-meta span,
.client-style-chip-grid span {
  border: 1px solid rgba(17, 17, 17, 0.1);
  border-radius: 999px;
  padding: 0.45rem 0.7rem;
  background: rgba(255, 255, 255, 0.7);
  font-weight: 700;
  font-size: 0.88rem;
}

.client-record-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
}

.client-booking-section {
  margin-top: 1.25rem;
}

.client-style-profile,
.client-tagged-work {
  margin-top: 1rem;
}

.client-style-chip-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 1rem 0;
}

@media (max-width: 720px) {
  .client-tab-nav {
    justify-content: flex-start;
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 0.3rem;
  }

  .client-tab {
    white-space: nowrap;
    flex: 0 0 auto;
  }

  .client-record-actions .button {
    width: 100%;
  }
}

/* V9 admin workspace cleanup */
.admin-workspace-page {
  max-width: 1120px;
  margin: 0 auto;
}

.admin-page-head {
  text-align: left;
  margin-bottom: 18px;
}

.admin-tab-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 18px 0 22px;
}

.admin-tab {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 40px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(20, 20, 20, 0.12);
  background: rgba(255, 255, 255, 0.72);
  color: #171717;
  font-weight: 800;
  text-decoration: none;
}

.admin-tab.is-active {
  background: #111;
  color: #fff;
  border-color: #111;
}

.admin-data-panel,
.admin-record-card,
.admin-empty-state {
  overflow: hidden;
}

.admin-action-grid,
.admin-summary-grid {
  align-items: stretch;
}

.admin-record-card {
  margin: 0.75rem 0;
}

@media (max-width: 720px) {
  .admin-page-head {
    text-align: center;
  }

  .admin-tab-nav {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 8px;
  }

  .admin-tab {
    white-space: nowrap;
    flex: 0 0 auto;
  }
}

/* V9 shared modal close polish */
.v9-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}

.v9-modal-close {
  border: 0;
  background: transparent;
  color: inherit;
  font-size: 1.7rem;
  line-height: 1;
  cursor: pointer;
  padding: 0.2rem 0.35rem;
}


/* V9 Page 01 marketplace empty state */
.marketplace-empty-state {
  grid-column: 1 / -1;
  width: min(760px, 100%);
  margin: 18px auto 28px;
  padding: 34px 24px;
  border: 1px solid rgba(30, 24, 18, 0.12);
  border-radius: 28px;
  background:
    radial-gradient(circle at top left, rgba(180, 124, 69, 0.16), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.96), rgba(250,247,242,0.94));
  box-shadow: 0 22px 60px rgba(38, 28, 18, 0.10);
  text-align: center;
}

.marketplace-empty-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border-radius: 999px;
  background: rgba(30, 24, 18, 0.06);
  color: #7b4c25;
  font-family: Inter, system-ui, sans-serif;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 16px;
}

.marketplace-empty-state h2 {
  margin: 0 0 10px;
  font-family: Inter, system-ui, sans-serif;
  font-size: clamp(1.65rem, 4vw, 2.4rem);
  line-height: 1.05;
  letter-spacing: -0.05em;
  color: #1f1a16;
}

.marketplace-empty-state p {
  max-width: 600px;
  margin: 0 auto 20px;
  color: rgba(31, 26, 22, 0.68);
  line-height: 1.65;
}

.marketplace-empty-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: center;
}

@media (max-width: 640px) {
  .marketplace-empty-state {
    padding: 26px 18px;
    border-radius: 22px;
  }

  .marketplace-empty-actions {
    flex-direction: column;
  }

  .marketplace-empty-actions .button {
    width: 100%;
  }
}

/* V9 footer modal cleanup final */
body.v9-modal-open {
  overflow: hidden !important;
}

.v9-modal-backdrop {
  position: fixed !important;
  inset: 0 !important;
  z-index: 1000 !important;
  display: grid !important;
  place-items: center !important;
  padding: 18px !important;
  overflow: auto !important;
  background: rgba(17, 17, 17, 0.42) !important;
  backdrop-filter: blur(10px) !important;
}

.v9-modal-card {
  width: min(620px, 100%) !important;
  max-height: min(760px, calc(100vh - 36px)) !important;
  margin: auto !important;
  overflow: auto !important;
  background: var(--color-surface) !important;
  color: var(--color-text) !important;
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--shadow-soft) !important;
}

.v9-modal-header {
  display: block !important;
  padding: 20px 22px 16px !important;
  border-bottom: 1px solid var(--color-border) !important;
  text-align: center !important;
}

.v9-modal-header h2 {
  margin: 0 !important;
  text-align: center !important;
  white-space: normal !important;
  line-height: 1.05 !important;
}

.v9-modal-close {
  display: none !important;
}

.v9-modal-body {
  padding: 20px 22px 24px !important;
}

.v9-modal-body p {
  font-size: 1rem;
  line-height: 1.58;
}

.v9-modal-note {
  text-align: center;
  color: var(--color-muted);
}

.v9-modal-small {
  margin: 0;
  font-size: 0.9rem !important;
  color: var(--color-muted);
  text-align: center;
}

.v9-modal-form {
  display: grid;
  gap: 0.9rem;
}

.v9-modal-form label {
  display: grid;
  gap: 0.35rem;
  font-weight: 700;
}

.v9-modal-form input,
.v9-modal-form textarea,
.v9-modal-form select {
  width: 100%;
}

.v9-modal-form .button,
.v9-modal-body .button {
  width: 100%;
  justify-content: center;
  text-align: center;
}

@media (max-width: 720px) {
  .v9-modal-backdrop {
    place-items: center !important;
    padding: 12px !important;
  }

  .v9-modal-card {
    width: min(94vw, 620px) !important;
    max-height: calc(100vh - 24px) !important;
    border-radius: 24px !important;
  }

  .v9-modal-header {
    padding: 18px 18px 14px !important;
  }

  .v9-modal-body {
    padding: 18px !important;
  }
}

/* V9 castle footer rules */
.footer-nav-primary,
.footer-nav-account {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 0.55rem 0.7rem;
}

.footer-nav-account[hidden] {
  display: none !important;
}

.v9-modal-header {
  justify-content: center !important;
  text-align: center !important;
}

.v9-modal-close {
  display: none !important;
}

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

/* V9 footer modal binding repair */
.v9-modal-open {
  overflow: hidden !important;
}

.v9-modal-backdrop {
  position: fixed !important;
  inset: 0 !important;
  z-index: 9999 !important;
  display: grid !important;
  place-items: center !important;
  padding: 18px !important;
  background: rgba(17, 17, 17, 0.42) !important;
  backdrop-filter: blur(10px) !important;
}

.v9-modal-card {
  width: min(620px, 100%) !important;
  max-height: min(720px, calc(100vh - 36px)) !important;
  overflow: auto !important;
  background: var(--color-surface, #fff) !important;
  color: var(--color-text, #111) !important;
  border: 1px solid var(--color-border, rgba(0,0,0,.12)) !important;
  border-radius: var(--radius-lg, 24px) !important;
  box-shadow: var(--shadow-soft, 0 24px 80px rgba(0,0,0,.18)) !important;
}

.v9-modal-header {
  display: block !important;
  padding: 18px 20px !important;
  border-bottom: 1px solid var(--color-border, rgba(0,0,0,.12)) !important;
  text-align: center !important;
}

.v9-modal-header h2 {
  margin: 0 !important;
  text-align: center !important;
}

.v9-modal-close {
  display: none !important;
}

.v9-modal-body {
  padding: 18px 20px 22px !important;
}

.v9-modal-body p {
  margin: 0 0 14px !important;
}

.v9-modal-body p:last-child {
  margin-bottom: 0 !important;
}

.v9-modal-step {
  padding: 14px 0 !important;
  border-bottom: 1px solid var(--color-border, rgba(0,0,0,.12)) !important;
}

.v9-modal-step:last-child {
  border-bottom: 0 !important;
}

.v9-modal-step strong {
  display: block !important;
  margin-bottom: 6px !important;
}

.v9-modal-form {
  display: grid !important;
  gap: 0.9rem !important;
}

.v9-modal-form label {
  display: grid !important;
  gap: 0.4rem !important;
  font-weight: 700 !important;
}

.v9-modal-form input,
.v9-modal-form textarea {
  width: 100% !important;
}

.v9-modal-note,
.v9-modal-small {
  color: var(--color-muted, #555) !important;
}

@media (max-width: 720px) {
  .v9-modal-backdrop {
    padding: 14px !important;
  }

  .v9-modal-card {
    width: min(94vw, 620px) !important;
    max-height: calc(100vh - 28px) !important;
  }
}

/* V9 modal verification flow */
body.v9-modal-open {
  overflow: hidden !important;
}

.v9-modal-header {
  justify-content: center !important;
  text-align: center !important;
}

.v9-modal-header h2 {
  width: 100%;
  text-align: center;
}

.v9-modal-close {
  display: none !important;
}

.v9-modal-note,
.v9-modal-small {
  text-align: center;
  color: var(--color-muted);
}

.v9-code-row {
  display: grid;
  grid-template-columns: minmax(120px, 0.55fr) minmax(140px, 1fr);
  gap: 0.7rem;
  align-items: center;
}

.v9-code-status {
  min-height: 1.2rem;
  text-align: center;
  font-size: 0.9rem;
  color: var(--color-muted);
}

.v9-code-status[data-tone="success"] {
  color: #166534;
}

.v9-code-status[data-tone="error"] {
  color: #991b1b;
}

.v9-slide-send {
  display: grid;
  gap: 0.45rem;
  padding: 0.85rem;
  border: 1px solid var(--color-border);
  border-radius: 999px;
  background: var(--color-soft);
  text-align: center;
}

.v9-slide-send input[type="range"] {
  accent-color: var(--color-text);
}

.v9-support-form.is-slide-ready .v9-slide-send {
  border-color: var(--color-accent-border);
  background: var(--color-accent-soft);
}

@media (max-width: 520px) {
  .v9-code-row {
    grid-template-columns: 1fr;
  }
}

/* V9 modal phone verification cleanup */
.v9-compact-form {
  gap: 0.72rem !important;
}

.v9-compact-form label {
  gap: 0.32rem !important;
}

.v9-compact-form input,
.v9-compact-form textarea {
  min-height: 46px !important;
}

.v9-compact-form textarea {
  resize: vertical !important;
}

.v9-two-col {
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0.75rem !important;
}

.v9-choice-row {
  display: flex !important;
  justify-content: center !important;
  gap: 0.75rem !important;
  flex-wrap: wrap !important;
}

.v9-choice-row label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
  padding: 0.55rem 0.8rem !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 999px !important;
  background: var(--color-soft) !important;
}

.v9-choice-row input {
  width: auto !important;
  min-height: auto !important;
}

@media (max-width: 640px) {
  .v9-two-col {
    grid-template-columns: 1fr !important;
  }
}

/* V9 compact support/auth modal cleanup */
.v9-modal-card {
  max-height: calc(100vh - 72px) !important;
}

.v9-tight-modal {
  gap: 0.52rem !important;
}

.v9-tight-modal .v9-modal-note,
.v9-tight-modal .v9-modal-small {
  margin-bottom: 0.2rem !important;
}

.v9-tight-modal label {
  gap: 0.24rem !important;
}

.v9-tight-modal input,
.v9-tight-modal textarea {
  min-height: 42px !important;
  padding-top: 0.65rem !important;
  padding-bottom: 0.65rem !important;
}

.v9-topic-grid {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md, 18px) !important;
  padding: 0.7rem !important;
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0.45rem 0.6rem !important;
}

.v9-topic-grid legend {
  padding: 0 0.35rem !important;
  font-weight: 800 !important;
}

.v9-topic-grid label {
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
  font-weight: 650 !important;
}

.v9-topic-grid input {
  width: auto !important;
  min-height: auto !important;
}

@media (max-width: 640px) {
  .v9-topic-grid {
    grid-template-columns: 1fr !important;
  }
}

/* V9 support modal chip cleanup */
#v9SupportForm {
  gap: 0.58rem !important;
}

#v9SupportForm input,
#v9SupportForm textarea {
  min-height: 44px !important;
}

.v9-topic-chips {
  border: 1px solid var(--color-border) !important;
  border-radius: var(--radius-md, 18px) !important;
  padding: 0.65rem !important;
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 0.45rem !important;
}

.v9-topic-chips legend {
  padding: 0 0.35rem !important;
  font-weight: 800 !important;
}

.v9-topic-chips label {
  display: inline-flex !important;
  align-items: center !important;
  margin: 0 !important;
  cursor: pointer !important;
}

.v9-topic-chips input {
  position: absolute !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.v9-topic-chips span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-height: 36px !important;
  padding: 0.42rem 0.72rem !important;
  border: 1px solid var(--color-border) !important;
  border-radius: 999px !important;
  background: var(--color-surface, #fff) !important;
  font-weight: 800 !important;
  font-size: 0.88rem !important;
  line-height: 1 !important;
}

.v9-topic-chips input:checked + span {
  border-color: var(--color-text, #111) !important;
  background: var(--color-soft, #f3f0ea) !important;
  box-shadow: inset 0 0 0 1px var(--color-text, #111) !important;
}

#v9SupportForm [data-v9-message-wrap] textarea {
  width: 100% !important;
  resize: vertical !important;
}

#v9SupportForm .v9-code-row {
  margin-top: 0.1rem !important;
}

/* V9 support no-scroll compression */
#v9SupportForm {
  gap: 0.42rem !important;
}

#v9SupportForm .v9-two-col {
  gap: 0.5rem !important;
}

#v9SupportForm input,
#v9SupportForm textarea {
  min-height: 38px !important;
  padding: 0.52rem 0.78rem !important;
}

#v9SupportForm .v9-topic-chips {
  padding: 0.5rem !important;
  gap: 0.34rem !important;
  border-radius: 16px !important;
}

#v9SupportForm .v9-topic-chips legend {
  font-size: 0.92rem !important;
  line-height: 1 !important;
}

#v9SupportForm .v9-topic-chips span {
  min-height: 30px !important;
  padding: 0.32rem 0.58rem !important;
  font-size: 0.78rem !important;
  letter-spacing: -0.01em !important;
}

#v9SupportForm [data-v9-toggle-message] {
  min-height: 38px !important;
  padding: 0.52rem 0.75rem !important;
}

#v9SupportForm .v9-code-row {
  gap: 0.5rem !important;
  margin-top: 0 !important;
}

#v9SupportForm .v9-code-row button,
#v9SupportForm .v9-code-row input {
  min-height: 40px !important;
}

#v9SupportForm .v9-code-status {
  min-height: 0 !important;
  font-size: 0.82rem !important;
  line-height: 1.1 !important;
}

#v9SupportForm > .button.dark {
  min-height: 42px !important;
  margin-top: 0.1rem !important;
}

#v9SupportForm textarea {
  max-height: 96px !important;
}

@media (max-width: 520px) {
  #v9SupportForm .v9-two-col {
    grid-template-columns: 1fr !important;
  }

  #v9SupportForm .v9-topic-chips span {
    font-size: 0.76rem !important;
    padding: 0.3rem 0.52rem !important;
  }
}

/* V9 create/login modal compression */
.v9-auth-clean {
  gap: 0.52rem !important;
}

.v9-auth-clean input {
  min-height: 42px !important;
  padding: 0.58rem 0.78rem !important;
}

.v9-auth-clean .v9-code-row {
  gap: 0.5rem !important;
  margin-top: 0.08rem !important;
}

.v9-auth-clean .v9-code-row button,
.v9-auth-clean .v9-code-row input {
  min-height: 40px !important;
}

.v9-auth-clean > .button.dark {
  min-height: 42px !important;
  margin-top: 0.08rem !important;
}

.v9-auth-clean .v9-modal-small {
  margin-top: 0.08rem !important;
  margin-bottom: 0 !important;
  font-size: 0.86rem !important;
  line-height: 1.25 !important;
}

.v9-auth-clean .v9-code-status {
  min-height: 0 !important;
  font-size: 0.82rem !important;
  line-height: 1.1 !important;
}

/* V9 footer copyright */
.footer-legal {
  margin: 0.8rem 0 0 !important;
  text-align: center !important;
  font-size: 0.78rem !important;
  line-height: 1.35 !important;
  color: var(--color-muted, #666) !important;
}

/* V9 safe footer uniformity */
footer .footer-nav,
footer .footer-nav-primary,
footer .footer-nav-account {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  flex-wrap: wrap !important;
  gap: 1rem !important;
  margin-top: 0.6rem !important;
}

footer .footer-nav a,
footer .footer-nav-primary a,
footer .footer-nav-account a {
  display: inline-block !important;
  min-height: auto !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--color-text, #111) !important;
  font-weight: 800 !important;
  font-size: 0.9rem !important;
  line-height: 1.35 !important;
  text-decoration: none !important;
}

footer .footer-nav a:hover,
footer .footer-nav-primary a:hover,
footer .footer-nav-account a:hover {
  text-decoration: underline !important;
}

/* V9 safe homepage responsiveness */
body {
  overflow-x: hidden !important;
}

main,
#v7Root {
  max-width: 100% !important;
}

#v7Root [class*="search"],
#v7Root [class*="filter"],
#v7Root form {
  max-width: 100% !important;
}

#v7Root [class*="grid"],
#v7Root [class*="results"],
#v7Root [class*="cards"],
#v7Root [class*="list"] {
  max-width: 100% !important;
}

#v7Root [class*="provider"],
#v7Root [class*="professional"],
#v7Root [class*="card"] {
  max-width: 100% !important;
}

@media (min-width: 760px) {
  #v7Root [class*="results"],
  #v7Root [class*="cards"],
  #v7Root [class*="grid"] {
    justify-content: center !important;
    align-items: start !important;
  }
}

@media (max-width: 760px) {
  #v7Root {
    padding-left: 1rem !important;
    padding-right: 1rem !important;
  }

  #v7Root [class*="grid"],
  #v7Root [class*="results"],
  #v7Root [class*="cards"] {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  #v7Root input,
  #v7Root button,
  #v7Root .button {
    max-width: 100% !important;
  }
}

/* V9 professional onboarding readiness modal, scoped only */
#v7Root[data-page="pro:onboarding"] {
  width: 100%;
  max-width: 1180px;
  margin: 0 auto;
  padding: clamp(1rem, 3vw, 2rem);
  overflow-x: hidden;
}

.v9-pro-onboarding {
  display: grid;
  gap: clamp(1rem, 2vw, 1.4rem);
}

.v9-pro-onboarding-hero {
  text-align: center;
  display: grid;
  gap: 0.45rem;
  padding-top: 0.5rem;
}

.v9-pro-kicker {
  margin: 0;
  font-weight: 800;
  color: var(--color-muted, #666);
}

.v9-pro-onboarding-hero h1 {
  margin: 0;
  font-size: clamp(2rem, 6vw, 3.2rem);
  line-height: 0.95;
  letter-spacing: -0.06em;
}

.v9-pro-onboarding-hero p {
  max-width: 760px;
  margin: 0 auto;
  color: var(--color-muted, #666);
  font-weight: 600;
  line-height: 1.45;
}

.v9-pro-readiness-card {
  border: 1px solid var(--color-border, rgba(0,0,0,.12));
  border-radius: 24px;
  background: var(--color-surface, #fff);
  padding: clamp(1rem, 3vw, 1.4rem);
  box-shadow: var(--shadow-soft, 0 18px 55px rgba(0,0,0,.08));
}

.v9-pro-readiness-card h2 {
  margin: 0 0 1rem;
  text-align: center;
  font-size: clamp(1.25rem, 3vw, 1.7rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

.v9-pro-readiness-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.75rem;
}

.v9-pro-ready-item {
  border: 1px solid var(--color-border, rgba(0,0,0,.12));
  border-radius: 18px;
  background: var(--color-soft, #f7f4ef);
  padding: 0.9rem;
  display: grid;
  gap: 0.35rem;
  min-width: 0;
}

.v9-pro-ready-item strong {
  font-weight: 900;
  line-height: 1.15;
}

.v9-pro-ready-item span {
  color: var(--color-muted, #666);
  font-weight: 600;
  line-height: 1.35;
  font-size: 0.92rem;
}

.v9-pro-readiness-action {
  margin-top: 1rem;
  display: flex;
  justify-content: center;
}

.v9-pro-readiness-action .button {
  width: min(100%, 420px);
}

.v9-pro-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: rgba(0,0,0,.45);
  display: grid;
  place-items: center;
  padding: 1rem;
}

.v9-pro-modal {
  width: min(100%, 620px);
  max-height: min(720px, 88vh);
  overflow: auto;
  border-radius: 24px;
  background: var(--color-surface, #fff);
  box-shadow: 0 24px 80px rgba(0,0,0,.25);
}

.v9-pro-modal-head {
  padding: 1rem 1.2rem;
  border-bottom: 1px solid var(--color-border, rgba(0,0,0,.12));
  text-align: center;
}

.v9-pro-modal-head h2 {
  margin: 0;
  font-size: 1.35rem;
  letter-spacing: -0.04em;
}

.v9-pro-modal-body {
  padding: 1rem;
  display: grid;
  gap: 0.75rem;
}

.v9-pro-modal-step {
  display: grid;
  grid-template-columns: 34px 1fr;
  gap: 0.75rem;
  align-items: start;
  border: 1px solid var(--color-border, rgba(0,0,0,.12));
  border-radius: 18px;
  padding: 0.75rem;
  background: var(--color-soft, #f7f4ef);
}

.v9-pro-modal-step > span {
  width: 34px;
  height: 34px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--color-text, #111);
  color: var(--color-surface, #fff);
  font-weight: 900;
}

.v9-pro-modal-step strong {
  display: block;
  font-weight: 900;
  margin-bottom: 0.2rem;
}

.v9-pro-modal-step p {
  margin: 0;
  color: var(--color-muted, #666);
  font-weight: 600;
  line-height: 1.35;
}

.v9-pro-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
}

@media (max-width: 860px) {
  .v9-pro-readiness-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 560px) {
  #v7Root[data-page="pro:onboarding"] {
    padding: 1rem;
  }

  .v9-pro-readiness-grid {
    grid-template-columns: 1fr;
  }

  .v9-pro-modal-actions {
    grid-template-columns: 1fr;
  }
}

/* V9 FINAL professional onboarding, scoped only */
#v7Root[data-page="pro:onboarding"] {
  width: 100%;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start {
  width: min(100%, 820px);
  margin: 0 auto;
  padding: clamp(1.5rem, 5vw, 4rem) 1rem 2rem;
  text-align: center;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-eyebrow {
  margin: 0 0 0.7rem;
  font-weight: 800;
  letter-spacing: 0.02em;
  color: var(--muted, #666);
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start h1 {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: clamp(2rem, 7vw, 4.2rem);
  line-height: 0.95;
  letter-spacing: -0.06em;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-subtitle {
  max-width: 680px;
  margin: 1rem auto 1.6rem;
  font-size: clamp(1rem, 2.6vw, 1.2rem);
  line-height: 1.45;
  color: var(--muted, #555);
}

#v7Root[data-page="pro:onboarding"] .v9-pro-readiness-card {
  width: 100%;
  border: 1px solid var(--line, #e5e0d8);
  border-radius: 1.4rem;
  background: rgba(255,255,255,0.84);
  box-shadow: 0 18px 46px rgba(0,0,0,0.06);
  padding: clamp(1rem, 3vw, 1.5rem);
  text-align: left;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-readiness-card h2 {
  margin: 0 0 1rem;
  text-align: center;
  font-family: "Inter", system-ui, sans-serif;
  font-size: clamp(1.25rem, 4vw, 1.75rem);
  line-height: 1.05;
  letter-spacing: -0.04em;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-readiness-list {
  display: grid;
  gap: 0.75rem;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-readiness-list article {
  border: 1px solid var(--line, #e8e4dc);
  border-radius: 1rem;
  background: var(--surface-soft, #f6f3ee);
  padding: 1rem;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-readiness-list strong {
  display: block;
  font-weight: 900;
  margin-bottom: 0.25rem;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-readiness-list p {
  margin: 0;
  color: var(--muted, #555);
  line-height: 1.35;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start-button {
  width: 100%;
  margin-top: 1rem;
}

.v9-pro-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0,0,0,0.48);
  backdrop-filter: blur(10px);
}

.v9-pro-modal {
  width: min(100%, 560px);
  max-height: calc(100vh - 2rem);
  overflow: auto;
  border-radius: 1.4rem;
  background: #fff;
  box-shadow: 0 28px 80px rgba(0,0,0,0.28);
}

.v9-pro-modal-head {
  padding: 1.15rem 1.25rem;
  text-align: center;
  border-bottom: 1px solid var(--line, #eee);
}

.v9-pro-modal-head h2 {
  margin: 0;
  font-family: "Inter", system-ui, sans-serif;
  font-size: 1.35rem;
  letter-spacing: -0.04em;
}

.v9-pro-modal-body {
  padding: 1rem;
}

.v9-pro-step-list {
  display: grid;
  gap: 0.7rem;
}

.v9-pro-step {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 0.75rem;
  align-items: start;
  padding: 0.9rem;
  border-radius: 1rem;
  background: var(--surface-soft, #f6f3ee);
  border: 1px solid var(--line, #e8e4dc);
}

.v9-pro-step span {
  display: grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  border-radius: 999px;
  background: #111;
  color: #fff;
  font-weight: 900;
}

.v9-pro-step strong {
  display: block;
  font-weight: 900;
  margin-bottom: 0.2rem;
}

.v9-pro-step p {
  margin: 0;
  color: var(--muted, #555);
  line-height: 1.32;
}

.v9-pro-modal-note {
  margin: 0.9rem 0 0;
  font-size: 0.92rem;
  color: var(--muted, #555);
  line-height: 1.4;
}

.v9-pro-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.65rem;
  margin-top: 1rem;
}

.v9-pro-modal-status {
  min-height: 1.2rem;
  margin: 0.75rem 0 0;
  text-align: center;
  color: var(--muted, #555);
  font-weight: 700;
}

@media (max-width: 640px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-start {
    padding-top: 1.25rem;
  }

  .v9-pro-modal-actions {
    grid-template-columns: 1fr;
  }
}

/* V9 pro onboarding clean final screen */
#v7Root[data-page="pro:onboarding"] .v9-pro-clean-start {
  width: min(100%, 720px);
  margin: 0 auto;
  padding: clamp(1.75rem, 6vw, 4rem) 1rem 2rem;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-clean-card {
  width: 100%;
  border: 1px solid var(--line, #e5e0d8);
  border-radius: 1.5rem;
  background: rgba(255,255,255,0.88);
  box-shadow: 0 18px 48px rgba(0,0,0,0.06);
  padding: clamp(1.15rem, 4vw, 1.75rem);
  text-align: center;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-clean-card h1 {
  margin: 0 0 1rem;
  font-family: "Inter", system-ui, sans-serif;
  font-size: clamp(1.85rem, 7vw, 3.4rem);
  line-height: 0.98;
  letter-spacing: -0.06em;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-clean-steps {
  display: grid;
  gap: 0.7rem;
  margin: 0 0 1rem;
  text-align: left;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-clean-steps div {
  border: 1px solid var(--line, #e8e4dc);
  border-radius: 1rem;
  background: var(--surface-soft, #f6f3ee);
  padding: 0.9rem 1rem;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-clean-steps strong {
  display: block;
  font-weight: 900;
  margin-bottom: 0.2rem;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-clean-steps span {
  display: block;
  color: var(--muted, #555);
  line-height: 1.35;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-clean-button {
  width: 100%;
}

/* V9 pro onboarding title lock */
#v7Root[data-page="pro:onboarding"] .v9-pro-clean-card h1 {
  white-space: nowrap !important;
  font-size: clamp(1.65rem, 6vw, 2.65rem) !important;
  line-height: 1 !important;
  letter-spacing: -0.055em !important;
  text-align: center !important;
  margin-bottom: 1rem !important;
}

@media (max-width: 420px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-clean-card h1 {
    font-size: clamp(1.45rem, 8vw, 1.9rem) !important;
    letter-spacing: -0.06em !important;
  }
}

/* V9 pro onboarding clean single flow */
#v7Root[data-page="pro:onboarding"] {
  width: 100%;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start-page {
  width: min(100%, 980px);
  margin: 0 auto;
  padding: clamp(2rem, 6vw, 4.5rem) clamp(1rem, 4vw, 2rem);
  text-align: center;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-kicker {
  margin: 0 0 0.75rem;
  font-size: clamp(0.95rem, 2.5vw, 1.1rem);
  font-weight: 800;
  color: rgba(0, 0, 0, 0.58);
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start-page h1 {
  margin: 0 auto clamp(1.25rem, 4vw, 2rem);
  font-size: clamp(1.85rem, 7vw, 3rem);
  line-height: 0.95;
  letter-spacing: -0.06em;
  font-weight: 900;
  white-space: nowrap;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start-card {
  width: min(100%, 560px);
  margin: 0 auto;
  padding: clamp(1rem, 4vw, 1.6rem);
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 1.4rem;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08);
  display: grid;
  gap: 0.75rem;
  text-align: left;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start-step {
  padding: 1rem;
  border-radius: 1rem;
  background: rgba(0, 0, 0, 0.035);
  border: 1px solid rgba(0, 0, 0, 0.07);
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start-step strong,
.v9-pro-modal-step strong {
  display: block;
  font-weight: 900;
  line-height: 1.1;
  margin-bottom: 0.25rem;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-start-step span,
.v9-pro-modal-step span {
  display: block;
  font-weight: 600;
  line-height: 1.35;
  color: rgba(0, 0, 0, 0.62);
}

#v7Root[data-page="pro:onboarding"] .v9-pro-button,
.v9-pro-modal-card .v9-pro-button {
  width: 100%;
  min-height: 3.25rem;
  border: 0;
  border-radius: 0.9rem;
  background: #111;
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}

.v9-pro-button-secondary {
  width: 100%;
  min-height: 3.25rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 0.9rem;
  background: #fff;
  color: #111;
  font-weight: 900;
  cursor: pointer;
}

.v9-pro-modal-open {
  overflow: hidden;
}

.v9-pro-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, 0.42);
}

.v9-pro-modal-card {
  width: min(100%, 560px);
  max-height: calc(100vh - 2rem);
  overflow: auto;
  padding: clamp(1rem, 4vw, 1.5rem);
  border-radius: 1.4rem;
  background: #fff;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.22);
}

.v9-pro-modal-card h2 {
  margin: 0 0 1rem;
  text-align: center;
  font-size: clamp(1.35rem, 5vw, 2rem);
  line-height: 1;
  letter-spacing: -0.04em;
  font-weight: 900;
}

.v9-pro-modal-steps {
  display: grid;
  gap: 0.75rem;
}

.v9-pro-modal-step {
  padding: 1rem;
  border-radius: 1rem;
  background: rgba(0, 0, 0, 0.035);
  border: 1px solid rgba(0, 0, 0, 0.07);
}

.v9-pro-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
  margin-top: 1rem;
}

@media (max-width: 560px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-start-page h1 {
    font-size: clamp(1.55rem, 8vw, 2.1rem);
  }

  .v9-pro-modal-actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 380px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-start-page h1 {
    white-space: normal;
  }
}

/* V9 pro onboarding final clean */
#v7Root[data-page="pro:onboarding"] {
  width: 100%;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-final-page {
  width: min(100%, 980px);
  margin: 0 auto;
  padding: clamp(2.25rem, 6vw, 4.5rem) clamp(1rem, 4vw, 2rem);
  text-align: center;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-final-page h1 {
  margin: 0 auto clamp(1.5rem, 4vw, 2rem);
  font-size: clamp(1.85rem, 5.2vw, 2.75rem);
  line-height: 1;
  letter-spacing: -0.055em;
  font-weight: 900;
  white-space: nowrap;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-final-card {
  width: min(100%, 540px);
  margin: 0 auto;
  padding: clamp(1rem, 4vw, 1.5rem);
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 20px 50px rgba(0, 0, 0, 0.08);
  display: grid;
  gap: 0.85rem;
  text-align: left;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-final-step,
.v9-pro-final-modal .v9-pro-final-step {
  padding: 1rem;
  border-radius: 1rem;
  background: rgba(0, 0, 0, 0.035);
  border: 1px solid rgba(0, 0, 0, 0.07);
}

#v7Root[data-page="pro:onboarding"] .v9-pro-final-step strong,
.v9-pro-final-modal .v9-pro-final-step strong {
  display: block;
  margin-bottom: 0.25rem;
  font-weight: 900;
  line-height: 1.1;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-final-step span,
.v9-pro-final-modal .v9-pro-final-step span {
  display: block;
  color: rgba(0, 0, 0, 0.64);
  font-weight: 600;
  line-height: 1.35;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-final-button,
.v9-pro-final-modal .v9-pro-final-button {
  width: 100%;
  min-height: 3.25rem;
  border: 0;
  border-radius: 0.9rem;
  background: #111;
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}

.v9-pro-final-secondary {
  width: 100%;
  min-height: 3.25rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 0.9rem;
  background: #fff;
  color: #111;
  font-weight: 900;
  cursor: pointer;
}

.v9-pro-final-modal-open {
  overflow: hidden;
}

.v9-pro-final-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, 0.42);
}

.v9-pro-final-modal {
  width: min(100%, 540px);
  max-height: calc(100vh - 2rem);
  overflow: auto;
  padding: clamp(1rem, 4vw, 1.5rem);
  border-radius: 1.35rem;
  background: #fff;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.22);
  display: grid;
  gap: 0.85rem;
}

.v9-pro-final-modal h2 {
  margin: 0 0 0.25rem;
  text-align: center;
  font-size: clamp(1.45rem, 5vw, 2rem);
  line-height: 1;
  letter-spacing: -0.045em;
  font-weight: 900;
  white-space: nowrap;
}

.v9-pro-final-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

@media (max-width: 560px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-final-page h1,
  .v9-pro-final-modal h2 {
    font-size: clamp(1.55rem, 7vw, 2rem);
  }

  .v9-pro-final-modal-actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 390px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-final-page h1,
  .v9-pro-final-modal h2 {
    white-space: normal;
  }
}

/* V9 pro onboarding homepage-style final */
#v7Root[data-page="pro:onboarding"] {
  width: 100%;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-homepage-match {
  width: min(100%, 980px);
  margin: 0 auto;
  padding: clamp(2rem, 6vw, 4rem) clamp(1rem, 4vw, 2rem);
  text-align: center;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-homepage-match h1 {
  margin: 0 auto clamp(1.5rem, 4vw, 2rem);
  font-size: clamp(1.85rem, 5vw, 2.5rem);
  line-height: 1;
  letter-spacing: -0.055em;
  font-weight: 900;
  text-align: center;
  white-space: nowrap;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-homepage-card {
  width: min(100%, 540px);
  margin: 0 auto;
  padding: clamp(1rem, 4vw, 1.5rem);
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.92);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08);
  display: grid;
  gap: 0.85rem;
  text-align: left;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-homepage-step,
.v9-pro-membership-modal .v9-pro-modal-step {
  padding: 1rem;
  border-radius: 1rem;
  background: rgba(0, 0, 0, 0.035);
  border: 1px solid rgba(0, 0, 0, 0.07);
}

#v7Root[data-page="pro:onboarding"] .v9-pro-homepage-step strong,
.v9-pro-membership-modal .v9-pro-modal-step strong {
  display: block;
  margin-bottom: 0.25rem;
  font-weight: 900;
  line-height: 1.1;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-homepage-step span,
.v9-pro-membership-modal .v9-pro-modal-step span {
  display: block;
  color: rgba(0, 0, 0, 0.64);
  font-weight: 600;
  line-height: 1.35;
}

#v7Root[data-page="pro:onboarding"] .v9-pro-primary-button,
.v9-pro-membership-modal .v9-pro-primary-button {
  width: 100%;
  min-height: 3.25rem;
  border: 0;
  border-radius: 0.9rem;
  background: #111;
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}

.v9-pro-secondary-button {
  width: 100%;
  min-height: 3.25rem;
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 0.9rem;
  background: #fff;
  color: #111;
  font-weight: 900;
  cursor: pointer;
}

.v9-pro-modal-open {
  overflow: hidden;
}

.v9-pro-membership-modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, 0.42);
}

.v9-pro-membership-modal {
  width: min(100%, 540px);
  max-height: calc(100vh - 2rem);
  overflow: auto;
  padding: clamp(1rem, 4vw, 1.5rem);
  border-radius: 1.35rem;
  background: #fff;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.22);
  display: grid;
  gap: 0.85rem;
}

.v9-pro-membership-modal h2 {
  margin: 0 0 0.25rem;
  text-align: center;
  font-size: clamp(1.55rem, 5vw, 2rem);
  line-height: 1;
  letter-spacing: -0.045em;
  font-weight: 900;
  white-space: nowrap;
}

.v9-pro-modal-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

@media (max-width: 560px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-homepage-match {
    padding-top: 2rem;
  }

  #v7Root[data-page="pro:onboarding"] .v9-pro-homepage-match h1 {
    font-size: clamp(1.45rem, 6.5vw, 2rem);
  }

  .v9-pro-membership-modal h2 {
    font-size: clamp(1.45rem, 6.5vw, 2rem);
  }

  .v9-pro-modal-actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 390px) {
  #v7Root[data-page="pro:onboarding"] .v9-pro-homepage-match h1,
  .v9-pro-membership-modal h2 {
    white-space: normal;
  }
}

/* Fresh standalone professional onboarding page */
#v7Root[data-page="pro:onboarding-fresh"] {
  width: 100%;
}

#v7Root[data-page="pro:onboarding-fresh"] .pro-fresh-hero {
  width: min(100%, 980px);
  margin: 0 auto;
  padding: clamp(2.5rem, 6vw, 4rem) clamp(1rem, 4vw, 2rem);
  text-align: center;
}

#v7Root[data-page="pro:onboarding-fresh"] h1 {
  margin: 0 auto clamp(1.5rem, 4vw, 2rem);
  font-size: clamp(1.75rem, 5vw, 2.65rem);
  line-height: 1;
  letter-spacing: -0.055em;
  font-weight: 900;
  text-align: center;
  white-space: nowrap;
}

#v7Root[data-page="pro:onboarding-fresh"] .pro-fresh-card {
  width: min(100%, 540px);
  margin: 0 auto;
  padding: clamp(1rem, 4vw, 1.5rem);
  border: 1px solid rgba(0, 0, 0, 0.12);
  border-radius: 1.35rem;
  background: rgba(255, 255, 255, 0.94);
  box-shadow: 0 18px 45px rgba(0, 0, 0, 0.08);
  display: grid;
  gap: 0.85rem;
  text-align: left;
}

#v7Root[data-page="pro:onboarding-fresh"] .pro-fresh-step {
  padding: 1rem;
  border-radius: 1rem;
  background: rgba(0, 0, 0, 0.035);
  border: 1px solid rgba(0, 0, 0, 0.07);
}

#v7Root[data-page="pro:onboarding-fresh"] .pro-fresh-step strong {
  display: block;
  margin-bottom: 0.25rem;
  font-weight: 900;
  line-height: 1.1;
}

#v7Root[data-page="pro:onboarding-fresh"] .pro-fresh-step span {
  display: block;
  color: rgba(0, 0, 0, 0.64);
  font-weight: 600;
  line-height: 1.35;
}

#v7Root[data-page="pro:onboarding-fresh"] .pro-fresh-button {
  width: 100%;
  min-height: 3.25rem;
  border: 0;
  border-radius: 0.9rem;
  background: #111;
  color: #fff;
  font-weight: 900;
  cursor: pointer;
}

#v7Root[data-page="pro:onboarding-fresh"] .pro-fresh-button.secondary {
  background: #fff;
  color: #111;
  border: 1px solid rgba(0, 0, 0, 0.12);
}

.pro-fresh-modal-open {
  overflow: hidden;
}

.pro-fresh-modal[hidden] {
  display: none !important;
}

.pro-fresh-modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: grid;
  place-items: center;
  padding: 1rem;
  background: rgba(0, 0, 0, 0.42);
}

.pro-fresh-modal-card {
  width: min(100%, 540px);
  padding: clamp(1rem, 4vw, 1.5rem);
  border-radius: 1.35rem;
  background: #fff;
  box-shadow: 0 24px 70px rgba(0, 0, 0, 0.22);
  display: grid;
  gap: 0.85rem;
}

.pro-fresh-modal-card h2 {
  margin: 0 0 0.25rem;
  text-align: center;
  font-size: clamp(1.55rem, 5vw, 2rem);
  line-height: 1;
  letter-spacing: -0.045em;
  font-weight: 900;
  white-space: nowrap;
}

.pro-fresh-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.75rem;
}

@media (max-width: 560px) {
  #v7Root[data-page="pro:onboarding-fresh"] h1,
  .pro-fresh-modal-card h2 {
    font-size: clamp(1.35rem, 6.5vw, 2rem);
  }

  .pro-fresh-actions {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 390px) {
  #v7Root[data-page="pro:onboarding-fresh"] h1,
  .pro-fresh-modal-card h2 {
    white-space: normal;
  }
}

/* CUT.CREDIT LOCKED HEADER */
.site-header-centered {
  position: sticky !important;
  top: 0 !important;
  z-index: 20 !important;
  width: 100% !important;
  min-height: 72px !important;
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 0 !important;
  padding: 16px 24px !important;
  border-bottom: 1px solid var(--color-border) !important;
  background: rgba(250, 250, 247, 0.94) !important;
  backdrop-filter: blur(16px) !important;
  text-align: center !important;
}

.site-header-centered .logo {
  display: inline-flex !important;
  align-items: baseline !important;
  justify-content: center !important;
  gap: 0 !important;
  margin: 0 auto !important;
  padding: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  color: var(--color-text) !important;
  text-decoration: none !important;
  font-family: var(--font-heading) !important;
  font-size: 26px !important;
  line-height: 1 !important;
  font-weight: 700 !important;
  letter-spacing: -0.04em !important;
  white-space: nowrap !important;
}

.site-header-centered .logo span {
  display: inline !important;
}

.site-header-centered .logo-dot {
  color: var(--color-accent) !important;
}

.site-header-centered .logo::after {
  content: none !important;
}

.site-header-centered nav {
  display: none !important;
}

@media (max-width: 900px) {
  .site-header-centered {
    min-height: 72px !important;
    display: flex !important;
    padding: 16px 24px !important;
  }

  .site-header-centered .logo {
    display: inline-flex !important;
    margin: 0 auto !important;
    font-size: 26px !important;
  }
}

@media (max-width: 520px) {
  .site-header-centered {
    min-height: 64px !important;
    padding: 12px 14px !important;
  }

  .site-header-centered .logo {
    font-size: 24px !important;
  }
}



/* V10 RUN 3: Provider bookings workflow demo */
.pro-bookings-workspace {
  padding-bottom: 4.5rem;
}

.pro-booking-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-booking-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-booking-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-booking-command-card {
  margin-bottom: 0.85rem;
}

.pro-booking-list {
  display: grid;
  gap: 0.75rem;
}

.pro-booking-ticket {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-booking-ticket-main {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.9rem;
}

.pro-booking-ticket small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-booking-ticket h3 {
  margin: 0 0 0.2rem;
}

.pro-booking-ticket p {
  margin: 0;
}

.pro-booking-price {
  text-align: right;
  white-space: nowrap;
}

.pro-booking-price strong {
  display: block;
  font-size: 1.35rem;
  font-family: var(--font-heading);
}

.pro-booking-price span {
  color: var(--color-muted);
  font-size: 0.9rem;
}

.pro-booking-notes {
  margin: 0.7rem 0 !important;
  color: var(--color-muted);
}

.pro-booking-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.75rem 0;
}

.pro-booking-meta span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.45rem 0.65rem;
  background: var(--color-soft);
  font-size: 0.85rem;
}

.pro-booking-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
}

.pro-booking-actions .pro-small-btn {
  min-height: 42px;
  text-align: center;
}

.pro-booking-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-booking-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pro-booking-ticket-main {
    display: block;
  }

  .pro-booking-price {
    text-align: left;
    margin-top: 0.6rem;
  }

  .pro-booking-actions {
    grid-template-columns: 1fr 1fr;
  }
}


/* V10 RUN 4: Provider services workstation demo */
.pro-services-workspace {
  padding-bottom: 4.5rem;
}

.pro-service-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-service-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-service-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-service-command-card {
  margin-bottom: 0.85rem;
}

.pro-service-work-area {
  display: grid;
  gap: 0.75rem;
}

.pro-service-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-service-card-main {
  display: flex;
  justify-content: space-between;
  gap: 0.9rem;
}

.pro-service-card small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-service-card h3 {
  margin: 0 0 0.2rem;
}

.pro-service-card p {
  margin: 0 0 0.45rem;
}

.pro-service-price {
  text-align: right;
  white-space: nowrap;
}

.pro-service-price strong {
  display: block;
  font-size: 1.35rem;
  font-family: var(--font-heading);
}

.pro-service-price span {
  color: var(--color-muted);
  font-size: 0.9rem;
}

.pro-service-meta,
.pro-service-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.75rem 0;
}

.pro-service-meta span,
.pro-service-chip-row span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.45rem 0.65rem;
  background: var(--color-soft);
  font-size: 0.85rem;
}

.pro-service-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
}

.pro-service-pricing-grid,
.pro-public-menu-preview {
  display: grid;
  gap: 0.75rem;
}

.pro-service-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-service-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pro-service-card-main {
    display: block;
  }

  .pro-service-price {
    text-align: left;
    margin-top: 0.6rem;
  }

  .pro-service-actions {
    grid-template-columns: 1fr;
  }
}


/* V10 RUN 5: Provider schedule availability demo */
.pro-schedule-workspace {
  padding-bottom: 4.5rem;
}

.pro-schedule-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-schedule-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-schedule-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-schedule-command-card {
  margin-bottom: 0.85rem;
}

.pro-schedule-work-area,
.pro-schedule-section,
.pro-schedule-day,
.pro-schedule-hours-grid,
.pro-public-schedule-preview {
  display: grid;
  gap: 0.75rem;
}

.pro-schedule-day h3,
.pro-schedule-section h2 {
  margin: 0.35rem 0 0.1rem;
}

.pro-schedule-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-schedule-card-main {
  display: flex;
  justify-content: space-between;
  gap: 0.9rem;
}

.pro-schedule-card small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-schedule-card h3 {
  margin: 0 0 0.2rem;
}

.pro-schedule-card p {
  margin: 0 0 0.45rem;
}

.pro-schedule-state {
  text-align: right;
  white-space: nowrap;
}

.pro-schedule-state strong {
  display: block;
  font-size: 1.05rem;
  font-family: var(--font-heading);
}

.pro-schedule-state span {
  color: var(--color-muted);
  font-size: 0.9rem;
}

.pro-schedule-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
  margin-top: 0.75rem;
}

.pro-schedule-booked-card {
  background: var(--color-soft);
}

.pro-schedule-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-schedule-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pro-schedule-card-main {
    display: block;
  }

  .pro-schedule-state {
    text-align: left;
    margin-top: 0.6rem;
  }

  .pro-schedule-actions {
    grid-template-columns: 1fr;
  }
}


/* V10 RUN 6: Provider profile workstation demo */
.pro-profile-workspace {
  padding-bottom: 4.5rem;
}

.pro-profile-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-profile-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-profile-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-profile-command-card {
  margin-bottom: 0.85rem;
}

.pro-profile-work-area,
.pro-profile-policy-grid,
.pro-public-profile-preview {
  display: grid;
  gap: 0.75rem;
}

.pro-profile-public-card,
.pro-profile-form-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-profile-hero {
  display: flex;
  gap: 0.75rem;
  align-items: center;
  margin-bottom: 0.85rem;
}

.pro-profile-hero small,
.pro-profile-form-card small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-profile-chip-row,
.pro-profile-preview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin-top: 0.75rem;
}

.pro-profile-chip-row span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.45rem 0.65rem;
  background: var(--color-soft);
  font-size: 0.85rem;
}

.pro-profile-readiness {
  margin-top: 0.85rem;
  border-radius: 18px;
  padding: 0.85rem;
  border: 1px solid var(--color-border);
}

.pro-profile-readiness strong {
  display: block;
  font-family: var(--font-heading);
}

.pro-profile-readiness.is-ready {
  background: rgba(34, 197, 94, 0.1);
}

.pro-profile-readiness.is-locked {
  background: var(--color-soft);
}

.pro-profile-checklist {
  display: grid;
  gap: 0.55rem;
}

.pro-profile-check {
  border: 1px solid var(--color-border);
  border-radius: 18px;
  padding: 0.85rem;
  background: var(--color-surface);
}

.pro-profile-check strong,
.pro-profile-check span,
.pro-profile-check small {
  display: block;
}

.pro-profile-check strong {
  font-family: var(--font-heading);
}

.pro-profile-check small {
  color: var(--color-muted);
}

.pro-profile-form-card label {
  display: grid;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
}

.pro-profile-form-card input,
.pro-profile-form-card textarea,
.pro-profile-form-card select {
  width: 100%;
}

.pro-profile-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-profile-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pro-profile-hero {
    align-items: flex-start;
  }
}


/* V10 RUN 7: Provider gallery workstation demo */
.pro-gallery-workspace {
  padding-bottom: 4.5rem;
}

.pro-gallery-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-gallery-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-gallery-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-gallery-command-card {
  margin-bottom: 0.85rem;
}

.pro-gallery-work-area,
.pro-gallery-list {
  display: grid;
  gap: 0.75rem;
}

.pro-gallery-card,
.pro-gallery-upload-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-gallery-card {
  display: grid;
  grid-template-columns: 96px 1fr;
  gap: 0.85rem;
}

.pro-gallery-media {
  width: 96px;
  height: 96px;
  border-radius: 20px;
  background: var(--color-soft);
  border: 1px solid var(--color-border);
  display: grid;
  place-items: center;
  overflow: hidden;
  font-weight: 900;
  font-family: var(--font-heading);
}

.pro-gallery-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.pro-gallery-body small,
.pro-gallery-upload-card small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-gallery-body h3 {
  margin: 0 0 0.2rem;
}

.pro-gallery-body p {
  margin: 0 0 0.45rem;
}

.pro-gallery-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.75rem 0;
}

.pro-gallery-meta span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.45rem 0.65rem;
  background: var(--color-soft);
  font-size: 0.85rem;
}

.pro-gallery-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
}

.pro-gallery-upload-card label {
  display: grid;
  gap: 0.35rem;
  margin-bottom: 0.75rem;
}

.pro-gallery-upload-card input,
.pro-gallery-upload-card textarea,
.pro-gallery-upload-card select {
  width: 100%;
}

.pro-gallery-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-gallery-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pro-gallery-card {
    grid-template-columns: 1fr;
  }

  .pro-gallery-media {
    width: 100%;
    height: 160px;
  }

  .pro-gallery-actions {
    grid-template-columns: 1fr;
  }
}


/* V10 RUN 8: Provider payments workstation demo */
.pro-payments-workspace {
  padding-bottom: 4.5rem;
}

.pro-payment-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-payment-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-payment-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-payment-command-card {
  margin-bottom: 0.85rem;
}

.pro-payment-work-area,
.pro-payment-payout-grid {
  display: grid;
  gap: 0.75rem;
}

.pro-payment-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-payment-card-main {
  display: flex;
  justify-content: space-between;
  gap: 0.9rem;
}

.pro-payment-card small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-payment-card h3 {
  margin: 0 0 0.2rem;
}

.pro-payment-card p {
  margin: 0 0 0.45rem;
}

.pro-payment-amount {
  text-align: right;
  white-space: nowrap;
}

.pro-payment-amount strong {
  display: block;
  font-size: 1.35rem;
  font-family: var(--font-heading);
}

.pro-payment-amount span {
  color: var(--color-muted);
  font-size: 0.9rem;
}

.pro-payment-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.75rem 0;
}

.pro-payment-meta span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.45rem 0.65rem;
  background: var(--color-soft);
  font-size: 0.85rem;
}

.pro-payment-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
}

.pro-payment-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-payment-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pro-payment-card-main {
    display: block;
  }

  .pro-payment-amount {
    text-align: left;
    margin-top: 0.6rem;
  }

  .pro-payment-actions {
    grid-template-columns: 1fr;
  }
}


/* V10 RUN 9: Provider client records workstation demo */
.pro-clients-workspace {
  padding-bottom: 4.5rem;
}

.pro-client-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-client-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-client-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-client-command-card {
  margin-bottom: 0.85rem;
}

.pro-client-work-area {
  display: grid;
  gap: 0.75rem;
}

.pro-client-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-client-card-main {
  display: flex;
  gap: 0.75rem;
  align-items: flex-start;
}

.pro-client-card small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-client-card h3 {
  margin: 0 0 0.2rem;
}

.pro-client-card p {
  margin: 0 0 0.45rem;
}

.pro-client-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0.75rem 0;
}

.pro-client-meta span {
  border: 1px solid var(--color-border);
  border-radius: 999px;
  padding: 0.45rem 0.65rem;
  background: var(--color-soft);
  font-size: 0.85rem;
}

.pro-client-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.45rem;
}

.pro-client-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-client-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .pro-client-actions {
    grid-template-columns: 1fr;
  }
}


/* V10 RUN 10: Provider settings readiness workstation demo */
.pro-settings-workspace {
  padding-bottom: 4.5rem;
}

.pro-settings-status-rail {
  display: flex;
  gap: 0.55rem;
  overflow-x: auto;
  padding: 0.25rem 0 0.85rem;
  margin: 0 0 0.9rem;
}

.pro-settings-status-rail .pro-tab {
  flex: 0 0 auto;
}

.pro-settings-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 0.55rem;
  margin: 0 0 0.8rem;
}

.pro-settings-command-card {
  margin-bottom: 0.85rem;
}

.pro-settings-work-area,
.pro-settings-readiness-list {
  display: grid;
  gap: 0.75rem;
}

.pro-settings-card {
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 22px;
  padding: 1rem;
  box-shadow: var(--shadow-card);
}

.pro-settings-card small {
  display: block;
  margin-bottom: 0.25rem;
  color: var(--color-muted);
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.pro-settings-card h3 {
  margin: 0 0 0.2rem;
}

.pro-settings-card p {
  margin: 0 0 0.75rem;
}

.pro-settings-card.is-complete {
  background: rgba(34, 197, 94, 0.1);
}

.pro-settings-card.is-needed,
.pro-settings-card.danger-zone {
  background: var(--color-soft);
}

.pro-settings-demo-note {
  margin-top: 0.9rem;
}

@media (max-width: 720px) {
  .pro-settings-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}


/* FINAL V10 professional UI normalization */
.pro-page-head {
  margin-bottom: 14px !important;
}

.pro-page-head h1 {
  font-size: clamp(24px, 4vw, 36px) !important;
  margin-bottom: 8px !important;
}

.pro-page-head p {
  font-size: 14px !important;
  line-height: 1.4 !important;
  margin-bottom: 0 !important;
}

.pro-shell nav[aria-label],
.pro-service-status-rail,
.pro-schedule-status-rail,
.pro-payment-status-rail,
.pro-client-status-rail,
.pro-profile-status-rail,
.pro-gallery-status-rail,
.pro-settings-status-rail {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(82px, 1fr)) !important;
  gap: 8px !important;
  overflow: visible !important;
  padding: 0 0 12px !important;
  margin: 0 0 12px !important;
}

.pro-tab,
.pro-action,
.pro-small-btn {
  min-height: 36px !important;
  padding: 8px 10px !important;
  border-radius: 999px !important;
  font-size: 12.5px !important;
  line-height: 1.1 !important;
  font-weight: 800 !important;
  margin: 0 !important;
  width: 100% !important;
  min-width: 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  text-align: center !important;
  text-decoration: none !important;
  white-space: normal !important;
}

.pro-next-actions,
.pro-service-actions,
.pro-schedule-actions,
.pro-gallery-actions,
.pro-payment-actions,
.pro-client-actions {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(86px, 1fr)) !important;
  gap: 8px !important;
  width: 100% !important;
}

.pro-service-card,
.pro-schedule-card,
.pro-payment-card,
.pro-client-card,
.pro-gallery-card,
.pro-settings-card,
.pro-gallery-upload-card {
  padding: 14px !important;
  border-radius: 18px !important;
}

.pro-service-card-main,
.pro-schedule-card-main,
.pro-payment-card-main {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) auto !important;
  gap: 12px !important;
  align-items: start !important;
}

.pro-service-price,
.pro-schedule-state,
.pro-payment-amount {
  text-align: right !important;
  min-width: 72px !important;
}

.pro-service-card h3,
.pro-schedule-card h3,
.pro-payment-card h3,
.pro-client-card h3,
.pro-gallery-card h3,
.pro-settings-card h3 {
  font-size: 16px !important;
  line-height: 1.15 !important;
  margin-bottom: 4px !important;
}

.pro-service-card p,
.pro-schedule-card p,
.pro-payment-card p,
.pro-client-card p,
.pro-gallery-card p,
.pro-settings-card p {
  font-size: 13px !important;
  line-height: 1.35 !important;
}

.pro-payment-meta span,
.pro-client-meta span,
.pro-gallery-meta span,
.pro-service-chip-row span {
  font-size: 12px !important;
  padding: 5px 8px !important;
}

.pro-payment-actions {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.pro-settings-card .actions,
.pro-settings-card div:has(.pro-small-btn),
.pro-settings-card div:has(button) {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr)) !important;
  gap: 10px !important;
  justify-content: center !important;
}

@media (max-width: 720px) {
  .pro-shell nav[aria-label],
  .pro-service-status-rail,
  .pro-schedule-status-rail,
  .pro-payment-status-rail,
  .pro-client-status-rail,
  .pro-profile-status-rail,
  .pro-gallery-status-rail,
  .pro-settings-status-rail {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  }

  .pro-tab {
    font-size: 11px !important;
    padding: 8px 5px !important;
  }

  .pro-service-card-main,
  .pro-schedule-card-main,
  .pro-payment-card-main {
    grid-template-columns: minmax(0, 1fr) auto !important;
  }

  .pro-service-actions,
  .pro-schedule-actions,
  .pro-gallery-actions,
  .pro-payment-actions,
  .pro-client-actions {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .pro-small-btn,
  .pro-action {
    font-size: 11.5px !important;
    padding: 8px 6px !important;
    min-height: 34px !important;
  }
}

@media (max-width: 430px) {
  .pro-shell nav[aria-label],
  .pro-service-status-rail,
  .pro-schedule-status-rail,
  .pro-payment-status-rail,
  .pro-client-status-rail,
  .pro-profile-status-rail,
  .pro-gallery-status-rail,
  .pro-settings-status-rail {
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .pro-tab {
    font-size: 10.5px !important;
  }
}

/* Admin five-page rail: keep Dashboard / People / Payments / Content / Settings on one line */
.pages-admin .admin-rail,
.admin-dashboard .admin-rail{
  display:grid !important;
  grid-template-columns:repeat(5,minmax(0,1fr)) !important;
  gap:.45rem !important;
  width:100% !important;
}

.pages-admin .admin-pill,
.admin-dashboard .admin-pill{
  min-width:0 !important;
  white-space:nowrap !important;
}

@media(max-width:560px){
  .pages-admin .admin-rail,
  .admin-dashboard .admin-rail{
    grid-template-columns:repeat(5,minmax(0,1fr)) !important;
    gap:.28rem !important;
  }

  .pages-admin .admin-pill,
  .admin-dashboard .admin-pill{
    min-height:34px !important;
    padding:0 .18rem !important;
    font-size:.5rem !important;
  }
}

/* ===== V9 CLIENT RAIL ACTIVE STATE FIX ===== */

.client-account-page .client-tab-nav,
.client-account-page .client-role-rail {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin: 0 auto 18px;
  width: min(100%, 760px);
}

.client-account-page .client-tab,
.client-account-page .client-role-rail .client-tab {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.75rem 1rem;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.08);
  background: #fff;
  color: #111;
  font-weight: 800;
  text-decoration: none;
  opacity: 1;
  box-shadow: 0 8px 22px rgba(0,0,0,0.04);
}

.client-account-page .client-tab:hover,
.client-account-page .client-role-rail .client-tab:hover {
  border-color: rgba(0,0,0,0.22);
  background: #f7f4ee;
  color: #111;
  opacity: 1;
}

.client-account-page .client-tab.is-active,
.client-account-page .client-role-rail .client-tab.is-active,
.client-account-page .client-tab[aria-current="page"] {
  background: #050505 !important;
  color: #fff !important;
  border-color: #050505 !important;
  opacity: 1 !important;
  box-shadow: none;
}

.client-account-page .client-tab.is-active:hover,
.client-account-page .client-role-rail .client-tab.is-active:hover {
  background: #050505 !important;
  color: #fff !important;
}

.client-account-page .client-page-body {
  width: min(100%, 760px);
  margin: 0 auto;
}

@media (max-width: 720px) {
  .client-account-page .client-tab-nav,
  .client-account-page .client-role-rail {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* ===== V9 CLIENT SINGLE-LINE ROLE RAIL FIX ===== */

.client-account-page .client-tab-nav,
.client-account-page .client-role-rail {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  gap: 10px !important;
  width: min(100%, 760px) !important;
  max-width: 760px !important;
  margin: 0 auto 18px !important;
  overflow-x: auto !important;
  overflow-y: hidden !important;
  padding: 0 0 4px !important;
  scroll-snap-type: x proximity;
  -webkit-overflow-scrolling: touch;
}

.client-account-page .client-tab-nav::-webkit-scrollbar,
.client-account-page .client-role-rail::-webkit-scrollbar {
  display: none;
}

.client-account-page .client-tab,
.client-account-page .client-role-rail .client-tab {
  flex: 0 0 auto !important;
  min-width: auto !important;
  width: auto !important;
  min-height: 40px !important;
  padding: 0.65rem 1.15rem !important;
  border-radius: 999px !important;
  border: 1px solid rgba(0,0,0,0.08) !important;
  background: #fff !important;
  color: #111 !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  white-space: nowrap !important;
  text-decoration: none !important;
  opacity: 1 !important;
  box-shadow: 0 8px 22px rgba(0,0,0,0.04) !important;
  scroll-snap-align: start;
}

.client-account-page .client-tab:hover,
.client-account-page .client-role-rail .client-tab:hover {
  background: #f7f4ee !important;
  color: #111 !important;
  border-color: rgba(0,0,0,0.18) !important;
}

.client-account-page .client-tab.is-active,
.client-account-page .client-role-rail .client-tab.is-active,
.client-account-page .client-tab[aria-current="page"] {
  background: #050505 !important;
  color: #fff !important;
  border-color: #050505 !important;
  box-shadow: none !important;
  opacity: 1 !important;
}

.client-account-page .client-tab.is-active:hover,
.client-account-page .client-role-rail .client-tab.is-active:hover,
.client-account-page .client-tab[aria-current="page"]:hover {
  background: #050505 !important;
  color: #fff !important;
  border-color: #050505 !important;
}

.client-account-page .client-page-body {
  width: min(100%, 760px) !important;
  margin: 0 auto !important;
}

@media (max-width: 720px) {
  .client-account-page .client-tab-nav,
  .client-account-page .client-role-rail {
    width: 100% !important;
    max-width: 100% !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .client-account-page .client-tab,
  .client-account-page .client-role-rail .client-tab {
    min-height: 38px !important;
    padding: 0.6rem 1rem !important;
    font-size: 0.88rem !important;
  }
}


/* ===== V9 CLIENT UTILITY RAIL FINAL ===== */

.client-account-page.client-workspace,
.client-account-page {
  width: min(100%, 780px);
  margin: 0 auto;
}

.client-account-page .client-tab-nav,
.client-account-page .client-role-rail {
  display: flex !important;
  flex-wrap: nowrap !important;
  align-items: center;
  justify-content: flex-start;
  gap: 10px;
  width: min(100%, 760px);
  max-width: 760px;
  margin: 0 auto 18px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 0 2px 8px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.client-account-page .client-tab-nav::-webkit-scrollbar,
.client-account-page .client-role-rail::-webkit-scrollbar {
  display: none;
}

.client-account-page .client-tab,
.client-account-page .client-role-rail .client-tab {
  flex: 0 0 auto !important;
  min-width: auto !important;
  width: auto !important;
  min-height: 40px;
  padding: 0.68rem 1.15rem;
  border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.08);
  background: #fff;
  color: #111;
  font-weight: 800;
  line-height: 1;
  text-decoration: none;
  white-space: nowrap;
  opacity: 1 !important;
  box-shadow: 0 8px 22px rgba(0,0,0,0.04);
}

.client-account-page .client-tab:hover,
.client-account-page .client-role-rail .client-tab:hover {
  background: #f7f4ee;
  color: #111;
  border-color: rgba(0,0,0,0.18);
}

.client-account-page .client-tab.is-active,
.client-account-page .client-role-rail .client-tab.is-active,
.client-account-page .client-tab[aria-current="page"] {
  background: #050505 !important;
  color: #fff !important;
  border-color: #050505 !important;
  opacity: 1 !important;
  box-shadow: none !important;
}

.client-account-page .client-page-body {
  width: min(100%, 760px);
  margin: 0 auto;
}

/* =========================================================
   CUT.CREDIT UI NORMALIZATION
   Keeps client/pro buttons, inputs, cards, chips, and rows uniform.
   ========================================================= */

:root {
  --cc-black: #111;
  --cc-white: #fff;
  --cc-border: rgba(0,0,0,.10);
  --cc-border-soft: rgba(0,0,0,.08);
  --cc-bg-soft: #faf8f3;
  --cc-chip-bg: #f7f3ea;
  --cc-chip-text: #5f4a27;
  --cc-radius-pill: 999px;
  --cc-radius-card: 22px;
  --cc-shadow-card: 0 12px 34px rgba(0,0,0,.05);
  --cc-shadow-soft: 0 8px 24px rgba(0,0,0,.04);
}

/* Main page spacing */
.client-page,
.pro-page,
.pro-shell {
  width: min(1120px, calc(100% - 32px));
  margin-left: auto;
  margin-right: auto;
}

/* Pill navigation */
.client-rail,
.pro-rail,
.pro-nav,
.pro-pill-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin: 0 0 22px;
}

.client-rail-link,
.pro-pill,
.pro-nav a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 20px;
  border: 1px solid var(--cc-border-soft);
  border-radius: var(--cc-radius-pill);
  background: var(--cc-white);
  color: var(--cc-black);
  text-decoration: none;
  font-weight: 800;
  line-height: 1;
  box-shadow: var(--cc-shadow-soft);
  white-space: nowrap;
}

.client-rail-link.active,
.pro-pill.active,
.pro-nav a.active {
  background: var(--cc-black);
  color: var(--cc-white);
  border-color: var(--cc-black);
}

/* Universal buttons */
.button,
.button.dark,
.pro-action,
.pro-small-btn,
.client-button-row .button,
.client-actions .button,
.client-media-actions .button,
.reference-card .button,
button.button,
a.button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 20px;
  border-radius: var(--cc-radius-pill);
  border: 1px solid var(--cc-border);
  background: var(--cc-white);
  color: var(--cc-black);
  text-decoration: none;
  font: inherit;
  font-weight: 800;
  line-height: 1;
  cursor: pointer;
  text-align: center;
  white-space: nowrap;
  box-sizing: border-box;
}

.button.dark,
.pro-action.primary,
.pro-small-btn.primary,
button.button.dark,
a.button.dark {
  background: var(--cc-black);
  color: var(--cc-white);
  border-color: var(--cc-black);
}

.button.warn {
  background: #fff8ed;
  color: #6a4815;
  border-color: rgba(106,72,21,.18);
}

.button.danger {
  background: #fff2f2;
  color: #742424;
  border-color: rgba(116,36,36,.18);
}

/* Button rows */
.client-actions,
.client-button-row,
.client-media-actions,
.pro-actions,
.pro-action-row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}

.client-button-row .button,
.client-media-actions .button,
.pro-action,
.pro-small-btn {
  min-width: 132px;
}

/* Cards */
.client-summary-card,
.transaction-card,
.reference-card,
.client-card,
.client-form,
.client-row,
.client-closure-card,
.style-form-card,
.style-chip-panel,
.client-media-card,
.pro-card,
.pro-panel,
.pro-form,
.pro-row {
  border-radius: var(--cc-radius-card);
  border: 1px solid var(--cc-border-soft);
  background: var(--cc-white);
  box-shadow: var(--cc-shadow-card);
  box-sizing: border-box;
}

/* Inputs and text areas */
input,
select,
textarea,
.client-form input,
.client-form select,
.client-form textarea,
.style-form-card input,
.style-form-card textarea,
.pro-form input,
.pro-form select,
.pro-form textarea {
  width: 100%;
  box-sizing: border-box;
  min-height: 52px;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 16px;
  padding: 13px 14px;
  background: var(--cc-white);
  color: var(--cc-black);
  font: inherit;
  font-weight: 700;
  line-height: 1.35;
}

textarea,
.client-form textarea,
.style-form-card textarea,
.pro-form textarea {
  min-height: 96px;
  resize: vertical;
}

input::placeholder,
textarea::placeholder {
  color: rgba(0,0,0,.42);
  font-weight: 700;
}

/* Labels */
label,
.client-form label,
.style-form-card label,
.pro-form label {
  font-weight: 800;
  line-height: 1.35;
}

/* Chips and status pills */
.style-chip,
.client-filter,
.transaction-filter,
.client-status,
.transaction-meta span,
.style-status-card small,
.client-checkitem,
.pro-status,
.pro-chip {
  border-radius: var(--cc-radius-pill);
  font-weight: 900;
}

.style-chip,
.client-filter,
.transaction-filter {
  min-height: 38px;
  padding: 0 14px;
  border: 1px solid var(--cc-border);
  background: var(--cc-white);
  color: var(--cc-black);
  line-height: 1;
}

.style-chip.is-selected,
.style-chip[aria-pressed="true"],
.client-filter.active,
.transaction-filter.active {
  background: var(--cc-black);
  color: var(--cc-white);
  border-color: var(--cc-black);
}

/* Prevent one random first button or input from stretching differently */
.client-actions > *,
.client-button-row > *,
.client-media-actions > *,
.pro-actions > *,
.pro-action-row > * {
  flex: 0 0 auto;
}

.client-form button,
.style-form-card button,
.pro-form button {
  width: auto;
}

/* Mobile consistency */
@media (max-width: 820px) {
  .client-page,
  .pro-page,
  .pro-shell {
    width: min(100% - 22px, 1120px);
  }

  .client-rail,
  .pro-rail,
  .pro-nav,
  .pro-pill-row {
    flex-wrap: nowrap;
    overflow-x: auto;
    padding-bottom: 4px;
    scrollbar-width: none;
  }

  .client-rail::-webkit-scrollbar,
  .pro-rail::-webkit-scrollbar,
  .pro-nav::-webkit-scrollbar,
  .pro-pill-row::-webkit-scrollbar {
    display: none;
  }

  .client-rail-link,
  .pro-pill,
  .pro-nav a,
  .button,
  .button.dark,
  .pro-action,
  .pro-small-btn {
    min-height: 42px;
    padding: 0 16px;
  }

  .client-actions,
  .client-button-row,
  .client-media-actions,
  .pro-actions,
  .pro-action-row {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }

  .client-actions > *,
  .client-button-row > *,
  .client-media-actions > *,
  .pro-actions > *,
  .pro-action-row > *,
  .button,
  .pro-action,
  .pro-small-btn {
    width: 100%;
    min-width: 0;
  }
}

@media (max-width: 460px) {
  .client-actions,
  .client-button-row,
  .client-media-actions,
  .pro-actions,
  .pro-action-row {
    grid-template-columns: 1fr;
  }
}


/* tat.credit identity pass */
:root {
  --tat-black: #11100f;
  --tat-ink: #1b1715;
  --tat-charcoal: #26211f;
  --tat-parchment: #f4efe7;
  --tat-paper: #fffaf2;
  --tat-muted: #8a7b70;
  --tat-blood: #8f1f1b;
  --tat-blood-dark: #5f1512;
  --tat-copper: #b87333;
  --tat-copper-soft: #d7a56b;
  --tat-line: rgba(27, 23, 21, 0.14);
  --tat-shadow: 0 18px 44px rgba(17, 16, 15, 0.14);
  --tat-radius: 22px;
  --tat-font-display: "Cinzel", "Cormorant Garamond", Georgia, serif;
  --tat-font-body: "Inter", "Avenir Next", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html {
  background:
    radial-gradient(circle at top left, rgba(184, 115, 51, 0.18), transparent 34rem),
    linear-gradient(135deg, #f8f1e7 0%, #efe2d0 42%, #f9f3eb 100%);
}

body {
  font-family: var(--tat-font-body);
  color: var(--tat-ink);
  background:
    radial-gradient(circle at 12% 0%, rgba(143, 31, 27, 0.08), transparent 26rem),
    radial-gradient(circle at 88% 12%, rgba(184, 115, 51, 0.12), transparent 24rem),
    linear-gradient(180deg, rgba(255, 250, 242, 0.94), rgba(244, 239, 231, 0.98));
}

.logo,
.site-logo,
header .logo {
  font-family: var(--tat-font-display);
  letter-spacing: 0.08em;
  text-transform: lowercase;
}

.logo-dot {
  color: var(--tat-blood);
}

h1,
h2,
h3,
.pro-page-title,
.client-section-title h2,
.dashboard-booking-title strong,
.provider-heading strong,
.booking-heading strong,
.transaction-main strong {
  font-family: var(--tat-font-display);
  letter-spacing: 0.025em;
}

.button,
.pro-btn,
.pro-action,
.client-filter,
.transaction-filter,
.style-chip,
.admin-rail-link,
.client-rail-link,
.pro-pill {
  border-radius: 999px;
}

.button.dark,
.pro-btn:not(.secondary),
.pro-action,
.client-filter.active,
.transaction-filter.active,
.pro-pill.active {
  background: linear-gradient(135deg, var(--tat-black), var(--tat-blood-dark));
  color: var(--tat-paper);
  border-color: transparent;
  box-shadow: 0 10px 24px rgba(95, 21, 18, 0.18);
}

.button,
.pro-btn.secondary,
.client-filter,
.transaction-filter,
.style-chip {
  border: 1px solid var(--tat-line);
  background: rgba(255, 250, 242, 0.78);
  color: var(--tat-ink);
}

.button:hover,
.pro-btn:hover,
.pro-action:hover,
.client-filter:hover,
.transaction-filter:hover,
.style-chip:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(17, 16, 15, 0.12);
}

.client-page,
.pro-page,
.admin-page,
.dashboard-booking-card,
.dashboard-card,
.provider-card,
.booking-card,
.booking-compact,
.transaction-card,
.style-form-card,
.style-chip-panel,
.reference-card,
.client-media-card,
.pro-card,
.admin-card {
  border: 1px solid var(--tat-line);
  border-radius: var(--tat-radius);
  background:
    linear-gradient(180deg, rgba(255, 250, 242, 0.92), rgba(244, 239, 231, 0.82));
  box-shadow: var(--tat-shadow);
}

.client-rail,
.pro-nav,
.admin-rail {
  border: 1px solid var(--tat-line);
  background: rgba(255, 250, 242, 0.72);
  backdrop-filter: blur(16px);
}

.client-rail-link.active,
.admin-rail-link.active {
  background: var(--tat-ink);
  color: var(--tat-paper);
}

.client-status.good,
.good {
  background: rgba(45, 115, 72, 0.12);
  color: #245d3b;
}

.client-status.warn,
.warn {
  background: rgba(184, 115, 51, 0.16);
  color: #7a4a18;
}

.client-status.dark,
.dark {
  background: var(--tat-ink);
  color: var(--tat-paper);
}

.client-status.cancel,
.cancel,
.button.danger,
.danger {
  background: rgba(143, 31, 27, 0.12);
  color: var(--tat-blood-dark);
}

input,
textarea,
select {
  border-radius: 16px;
  border: 1px solid var(--tat-line);
  background: rgba(255, 250, 242, 0.92);
  color: var(--tat-ink);
}

footer {
  border-top: 1px solid var(--tat-line);
  background: rgba(17, 16, 15, 0.96);
  color: var(--tat-paper);
}

footer a {
  color: var(--tat-copper-soft);
}

.client-media-placeholder,
.pro-gallery-placeholder,
.media-placeholder {
  background:
    linear-gradient(135deg, rgba(17, 16, 15, 0.92), rgba(95, 21, 18, 0.82)),
    radial-gradient(circle at top right, rgba(184, 115, 51, 0.36), transparent 16rem);
  color: var(--tat-paper);
  border-radius: 18px;
}


/* tat.credit modern cleanup pass */
:root{
  --tat-ink:#111111;
  --tat-paper:#f7f3ea;
  --tat-panel:#ffffff;
  --tat-soft:#f3eee4;
  --tat-line:#e3dbcf;
  --tat-muted:#6f6a61;
  --tat-red:#b11226;
  --tat-gold:#c4a945;
  --tat-steel:#6f7378;
  --tat-font-ui:"Inter",system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --tat-font-display:"Cinzel",Georgia,serif;
}

html,
body{
  font-family:var(--tat-font-ui) !important;
  background:
    radial-gradient(circle at top left, rgba(196,169,69,.10), transparent 28rem),
    linear-gradient(180deg, #fbf8f1 0%, #f5efe4 100%) !important;
  color:var(--tat-ink) !important;
}

body::before{
  content:none !important;
}

.logo,
.site-logo,
.site-header-centered .logo,
.footer-logo{
  font-family:var(--tat-font-ui) !important;
  font-weight:900 !important;
  letter-spacing:-.04em !important;
  text-transform:none !important;
}

.logo-dot{
  color:var(--tat-red) !important;
}

h1,h2,h3,
.hero-title,
.section-title,
.client-section-title h2,
.pro-page-title h1,
.admin-page-title h1{
  font-family:var(--tat-font-display) !important;
  letter-spacing:.02em !important;
  text-transform:none !important;
}

p,span,input,textarea,select,button,a,small,label{
  font-family:var(--tat-font-ui) !important;
}

main,
.page-shell,
.client-page,
.pro-shell,
.admin-shell{
  background:transparent !important;
}

.search-panel,
.marketplace-search,
.hero-search,
.card,
.provider-card,
.booking-card,
.client-card,
.pro-card,
.admin-card,
.reference-card,
.style-form-card,
.style-chip-panel,
.bookings-section,
.pro-service-card,
.pro-gallery-post,
.pro-client-card,
.pro-transaction-card{
  background:rgba(255,255,255,.88) !important;
  border:1px solid var(--tat-line) !important;
  box-shadow:0 18px 55px rgba(17,17,17,.07) !important;
}

input,
textarea,
select{
  background:#fffdf8 !important;
  border:1px solid var(--tat-line) !important;
  color:var(--tat-ink) !important;
}

input:focus,
textarea:focus,
select:focus{
  outline:2px solid rgba(177,18,38,.18) !important;
  border-color:rgba(177,18,38,.45) !important;
}

button,
.button,
.pro-btn,
.client-actions .button,
.admin-actions .button,
.pro-action,
.pro-small-btn{
  border-radius:999px !important;
  font-weight:800 !important;
  letter-spacing:-.01em !important;
}

.button.dark,
.pro-btn:not(.secondary),
button[type="submit"],
.search button,
[data-action="search"],
.primary-button{
  background:var(--tat-ink) !important;
  color:#fff !important;
  border-color:var(--tat-ink) !important;
}

.button.dark:hover,
.pro-btn:not(.secondary):hover,
button[type="submit"]:hover,
.search button:hover,
[data-action="search"]:hover{
  background:#2b2b2b !important;
}

.button,
.pro-btn.secondary,
.pro-small-btn,
.secondary-button{
  background:#fffdf8 !important;
  color:var(--tat-ink) !important;
  border:1px solid var(--tat-line) !important;
}

.pro-badge,
.appt-label-pill,
.style-chip,
.filter-chip-row button,
.client-rail-link,
.pro-pill,
.admin-rail-link{
  border:1px solid var(--tat-line) !important;
  background:#fffdf8 !important;
  color:var(--tat-ink) !important;
}

.pro-badge.dark,
.appt-label-pill.good,
.client-rail-link.active,
.pro-pill.active,
.admin-rail-link.active,
.filter-chip-row button.active,
.style-chip[aria-pressed="true"]{
  background:var(--tat-ink) !important;
  color:#fff !important;
  border-color:var(--tat-ink) !important;
}

.pro-badge.copper,
.warn,
.cancel{
  background:rgba(177,18,38,.08) !important;
  color:var(--tat-red) !important;
  border-color:rgba(177,18,38,.22) !important;
}

footer{
  background:#111 !important;
  color:#f7f3ea !important;
  border-top:1px solid rgba(196,169,69,.22) !important;
}

footer a{
  color:#f7f3ea !important;
  opacity:.78;
}

footer a:hover{
  opacity:1;
}

.no-results,
.empty-state,
[data-empty-state]{
  background:rgba(255,255,255,.72) !important;
  border:1px dashed var(--tat-line) !important;
  color:var(--tat-muted) !important;
}

.no-results strong,
.empty-state strong,
[data-empty-state] strong{
  font-family:var(--tat-font-display) !important;
  color:var(--tat-ink) !important;
}

@media (max-width:760px){
  body{
    background:#f7f3ea !important;
  }

  .search-panel,
  .marketplace-search,
  .hero-search{
    margin-inline:1rem !important;
  }

  footer{
    margin-top:4rem !important;
  }
}

/* tat.credit final clean UI pass */
:root{
  --tat-ink:#141414;
  --tat-paper:#faf8f3;
  --tat-panel:#ffffff;
  --tat-soft:#f5f1e8;
  --tat-line:#e6ded2;
  --tat-muted:#6f6a61;
  --tat-red:#9f1424;
  --tat-gold:#b89a3d;
  --tat-steel:#6f7378;
}

html,
body{
  background:#faf8f3 !important;
  color:#141414 !important;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif !important;
}

h1,h2,h3,
.logo,
.brand,
.site-logo,
.pro-card-title,
.pro-section-title,
.pro-name-line strong,
.pro-day-item strong,
.pro-closeout-item strong,
.admin-title,
.client-title{
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif !important;
  letter-spacing:-.015em !important;
  text-transform:none !important;
}

.logo,
.site-logo,
.brand{
  font-weight:800 !important;
}

input,
select,
textarea,
button,
.button,
.pro-btn,
.pro-pill,
.admin-pill,
.client-pill{
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif !important;
}

button,
.button,
.pro-btn,
.search-button,
.primary-button,
.btn-primary{
  background:#111111 !important;
  color:#ffffff !important;
  border-color:#111111 !important;
  border-radius:999px !important;
}

button:hover,
.button:hover,
.pro-btn:hover,
.search-button:hover,
.primary-button:hover,
.btn-primary:hover{
  background:#9f1424 !important;
  border-color:#9f1424 !important;
}

.card,
.panel,
.pro-card,
.client-card,
.admin-card,
.provider-card,
.result-card,
.search-panel,
.filter-panel,
.pro-client-card,
.pro-gallery-post,
.pro-transaction-card{
  background:#ffffff !important;
  border:1px solid #e6ded2 !important;
  box-shadow:0 18px 45px rgba(17,17,17,.06) !important;
}

input,
select,
textarea,
.search-input{
  background:#ffffff !important;
  color:#141414 !important;
  border:1px solid #e6ded2 !important;
  box-shadow:none !important;
}

.badge,
.tag,
.chip,
.pro-badge{
  border-radius:999px !important;
  border:1px solid #e6ded2 !important;
  background:#f5f1e8 !important;
  color:#141414 !important;
}

.badge.dark,
.pro-badge.dark,
.active,
.is-active{
  background:#111111 !important;
  color:#ffffff !important;
  border-color:#111111 !important;
}

a{
  color:#141414;
}

a:hover{
  color:#9f1424;
}

footer{
  background:#111111 !important;
  color:#ffffff !important;
}

footer a{
  color:#ffffff !important;
}

/* tat.credit true brand system */
:root{
  --tat-ink:#111111;
  --tat-bone:#f3e7d3;
  --tat-bone-soft:#f7f3ea;
  --tat-paper:#fbf8f1;
  --tat-red:#b11226;
  --tat-smoke:#2b2b2b;
  --tat-steel:#6f7378;
  --tat-gold:#c4a945;
  --tat-line:rgba(17,17,17,.14);
  --tat-muted:#706a60;

  --tat-font-logo:"UnifrakturCook", Georgia, serif;
  --tat-font-heading:"Cinzel", Georgia, serif;
  --tat-font-body:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

html,
body{
  background:var(--tat-bone-soft) !important;
  color:var(--tat-ink) !important;
  font-family:var(--tat-font-body) !important;
}

body{
  background:
    radial-gradient(circle at top left, rgba(177,18,38,.08), transparent 28rem),
    linear-gradient(180deg, var(--tat-paper), var(--tat-bone-soft)) !important;
}

header,
.site-header,
.app-header,
.topbar,
.navbar{
  background:rgba(251,248,241,.94) !important;
  border-bottom:1px solid var(--tat-line) !important;
  color:var(--tat-ink) !important;
}

.logo,
.brand,
.brand-mark,
.site-logo,
.header-logo,
.footer-logo,
.nav-logo,
.logo a,
.brand a{
  font-family:var(--tat-font-logo) !important;
  font-weight:700 !important;
  letter-spacing:.01em !important;
  text-transform:none !important;
  color:var(--tat-ink) !important;
}

.logo::first-letter,
.brand::first-letter,
.site-logo::first-letter{
  color:var(--tat-ink) !important;
}

h1,
h2,
h3,
.hero-title,
.section-title,
.card-title,
.page-title,
.pro-card-title,
.admin-card-title{
  font-family:var(--tat-font-heading) !important;
  letter-spacing:.04em !important;
  color:var(--tat-ink) !important;
}

h4,
h5,
h6,
label,
summary,
.nav-link,
.nav a,
.pro-pill,
.filter-chip,
.badge,
.pro-badge,
button,
.btn,
.primary-button,
.secondary-button{
  font-family:var(--tat-font-body) !important;
}

.card,
.panel,
.pro-card,
.admin-card,
.client-card,
.profile-card,
.search-card,
.result-card,
.booking-card,
.service-card,
.gallery-card,
.market-card,
form,
.search-shell,
.filter-panel{
  background:rgba(255,255,255,.72) !important;
  border:1px solid var(--tat-line) !important;
  box-shadow:0 18px 45px rgba(17,17,17,.06) !important;
}

input,
select,
textarea,
.search-input{
  background:rgba(255,255,255,.8) !important;
  border:1px solid var(--tat-line) !important;
  color:var(--tat-ink) !important;
  font-family:var(--tat-font-body) !important;
}

button,
.btn,
.primary-button,
.cta,
[data-action],
input[type="submit"]{
  background:var(--tat-ink) !important;
  color:var(--tat-paper) !important;
  border:1px solid var(--tat-ink) !important;
  font-family:var(--tat-font-body) !important;
  font-weight:800 !important;
}

button:hover,
.btn:hover,
.primary-button:hover,
.cta:hover{
  background:var(--tat-red) !important;
  border-color:var(--tat-red) !important;
}

.secondary-button,
.btn.secondary,
button.secondary{
  background:transparent !important;
  color:var(--tat-ink) !important;
  border:1px solid var(--tat-line) !important;
}

a{
  color:var(--tat-ink);
}

a:hover{
  color:var(--tat-red);
}

.badge,
.pro-badge,
.status,
.tag,
.chip{
  border-color:var(--tat-line) !important;
}

.badge.red,
.pro-badge.red,
.danger,
.alert{
  color:var(--tat-red) !important;
}

.badge.gold,
.pro-badge.gold,
.highlight{
  color:#7a6217 !important;
  background:rgba(196,169,69,.15) !important;
  border-color:rgba(196,169,69,.35) !important;
}

footer,
.site-footer{
  background:var(--tat-ink) !important;
  color:var(--tat-paper) !important;
}

footer .logo,
footer .brand,
footer .footer-logo{
  font-family:var(--tat-font-logo) !important;
  color:var(--tat-paper) !important;
}

footer a{
  color:var(--tat-paper) !important;
}

/* tat.credit final brand lock */
:root{
  --font-heading:"Cinzel", Georgia, serif !important;
  --font-body:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif !important;

  --tat-ink:#111111;
  --tat-bone:#f3e7d3;
  --tat-bone-soft:#f7f3ea;
  --tat-paper:#fbf8f1;
  --tat-red:#b11226;
  --tat-smoke:#2b2b2b;
  --tat-steel:#6f7378;
  --tat-gold:#c4a945;
  --tat-line:rgba(17,17,17,.14);
  --tat-muted:#706a60;

  --tat-font-logo:"UnifrakturCook", Georgia, serif;
  --tat-font-heading:"Cinzel", Georgia, serif;
  --tat-font-body:"Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

body{
  background:
    radial-gradient(circle at 0 0, rgba(177,18,38,.055), transparent 24rem),
    linear-gradient(180deg, var(--tat-paper), var(--tat-bone-soft)) !important;
  color:var(--tat-ink) !important;
  font-family:var(--tat-font-body) !important;
}

.logo,
.brand,
.site-logo,
.header-logo,
.footer-logo,
.nav-logo,
.logo a,
.brand a,
.site-brand,
.footer-brand{
  font-family:var(--tat-font-logo) !important;
  font-weight:700 !important;
  letter-spacing:.01em !important;
  text-transform:none !important;
}

h1,
h2,
h3,
.page-title,
.section-title,
.hero-title,
.card-title,
.pro-card-title,
.admin-card-title{
  font-family:var(--tat-font-heading) !important;
  letter-spacing:.045em !important;
}

p,
span,
li,
label,
input,
textarea,
select,
button,
a,
small,
strong,
.card,
.panel,
.pro-card,
.admin-card,
.client-card{
  font-family:var(--tat-font-body);
}

button,
.btn,
.primary-button,
.cta,
input[type="submit"]{
  background:var(--tat-ink) !important;
  border-color:var(--tat-ink) !important;
  color:var(--tat-paper) !important;
}

button:hover,
.btn:hover,
.primary-button:hover,
.cta:hover{
  background:var(--tat-red) !important;
  border-color:var(--tat-red) !important;
}

input,
textarea,
select,
.card,
.panel,
.pro-card,
.admin-card,
.client-card,
.search-card,
.result-card,
.booking-card,
.service-card,
.gallery-card{
  border-color:var(--tat-line) !important;
}

footer,
.site-footer{
  background:var(--tat-ink) !important;
  color:var(--tat-paper) !important;
}

footer .logo,
footer .brand,
footer .footer-logo,
footer .site-brand{
  font-family:var(--tat-font-logo) !important;
}

/* tat.credit footer paper correction */
footer,
.site-footer,
.app-footer,
.footer,
.page-footer,
.tat-footer{
  background:transparent !important;
  background-color:transparent !important;
  color:var(--tat-ink, #111111) !important;
  border-top:1px solid rgba(17,17,17,.14) !important;
  box-shadow:none !important;
}

footer *,
.site-footer *,
.app-footer *,
.footer *,
.page-footer *,
.tat-footer *{
  color:var(--tat-ink, #111111) !important;
}

footer a,
.site-footer a,
.app-footer a,
.footer a,
.page-footer a,
.tat-footer a{
  color:var(--tat-ink, #111111) !important;
  text-decoration:none !important;
}

footer a:hover,
.site-footer a:hover,
.app-footer a:hover,
.footer a:hover,
.page-footer a:hover,
.tat-footer a:hover{
  color:var(--tat-red, #b11226) !important;
}

footer .brand,
footer .logo,
footer .site-logo,
.site-footer .brand,
.site-footer .logo,
.site-footer .site-logo,
.app-footer .brand,
.app-footer .logo,
.app-footer .site-logo,
.footer .brand,
.footer .logo,
.footer .site-logo{
  font-family:var(--tat-font-logo, "UnifrakturCook", Georgia, serif) !important;
  color:var(--tat-ink, #111111) !important;
}

footer::before,
footer::after,
.site-footer::before,
.site-footer::after,
.app-footer::before,
.app-footer::after,
.footer::before,
.footer::after,
.page-footer::before,
.page-footer::after,
.tat-footer::before,
.tat-footer::after{
  background:transparent !important;
  box-shadow:none !important;
}

/* tat.credit final footer flatten */
body footer,
body .site-footer,
body .app-footer,
body .footer,
body .page-footer,
body .tat-footer{
  display:block !important;
  max-width:1120px !important;
  width:calc(100% - 32px) !important;
  margin:3rem auto 1.5rem !important;
  padding:1.35rem 1rem 1.1rem !important;
  background:transparent !important;
  background-color:transparent !important;
  background-image:none !important;
  color:var(--tat-ink, #111111) !important;
  border:0 !important;
  border-top:1px solid rgba(17,17,17,.16) !important;
  border-radius:0 !important;
  box-shadow:none !important;
}

body footer *,
body .site-footer *,
body .app-footer *,
body .footer *,
body .page-footer *,
body .tat-footer *{
  background:transparent !important;
  background-color:transparent !important;
  background-image:none !important;
  box-shadow:none !important;
  color:var(--tat-ink, #111111) !important;
  border-color:transparent !important;
}

body footer nav,
body footer .footer-nav,
body footer .footer-nav-primary,
body footer .footer-nav-account,
body .site-footer nav,
body .site-footer .footer-nav,
body .app-footer nav,
body .app-footer .footer-nav{
  display:flex !important;
  flex-wrap:wrap !important;
  justify-content:center !important;
  gap:.65rem 1rem !important;
  margin:.45rem auto !important;
  padding:0 !important;
  background:transparent !important;
}

body footer a,
body .site-footer a,
body .app-footer a,
body .footer a,
body .page-footer a,
body .tat-footer a{
  color:var(--tat-ink, #111111) !important;
  font-family:var(--tat-font-heading, "Cinzel", Georgia, serif) !important;
  font-size:.72rem !important;
  font-weight:700 !important;
  letter-spacing:.08em !important;
  text-transform:uppercase !important;
  text-decoration:none !important;
  opacity:.82 !important;
}

body footer a:hover,
body .site-footer a:hover,
body .app-footer a:hover,
body .footer a:hover,
body .page-footer a:hover,
body .tat-footer a:hover{
  color:var(--tat-red, #b11226) !important;
  opacity:1 !important;
}

body footer .footer-logo,
body footer .footer-brand,
body footer .brand,
body footer .logo,
body .site-footer .footer-logo,
body .site-footer .footer-brand,
body .site-footer .brand,
body .site-footer .logo{
  display:block !important;
  margin:0 auto .55rem !important;
  color:var(--tat-ink, #111111) !important;
  font-family:var(--tat-font-logo, "UnifrakturCook", Georgia, serif) !important;
  font-size:1.35rem !important;
  line-height:1 !important;
  letter-spacing:0 !important;
  text-align:center !important;
  text-transform:none !important;
}

body footer .footer-legal,
body .site-footer .footer-legal,
body .app-footer .footer-legal,
body .footer .footer-legal{
  margin:.7rem auto 0 !important;
  color:rgba(17,17,17,.56) !important;
  font-family:var(--tat-font-body, "Inter", system-ui, sans-serif) !important;
  font-size:.78rem !important;
  line-height:1.4 !important;
  text-align:center !important;
}

body footer::before,
body footer::after,
body .site-footer::before,
body .site-footer::after,
body .app-footer::before,
body .app-footer::after,
body .footer::before,
body .footer::after,
body .page-footer::before,
body .page-footer::after,
body .tat-footer::before,
body .tat-footer::after{
  display:none !important;
  content:none !important;
}
