:root {
    --bg: #ffffff;
    --bg-strong: #ffffff;
    --surface: #ffffff;
    --surface-border: rgba(15, 23, 42, 0.08);
    --text: #111827;
    --muted: #667085;
    --accent: #0b6e4f;
    --accent-2: #db5a42;
    --shadow: 0 18px 48px rgba(15, 23, 42, 0.06);
    --radius: 24px;
    --max-width: 1180px;
    --font-sans: "Space Grotesk", "Segoe UI", sans-serif;
}

* {
    box-sizing: border-box;
}

html {
    scroll-behavior: smooth;
}

body {
    margin: 0;
    font-family: var(--font-sans);
    color: var(--text);
    background: #ffffff;
}

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

main {
    padding-bottom: 64px;
}

.page-shell {
    width: min(var(--max-width), calc(100% - 32px));
    margin: 0 auto;
}

.site-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 24px 0;
    gap: 16px;
}

.site-header-tools,
.language-toggle {
    display: flex;
    align-items: center;
    gap: 10px;
}

.brand {
    display: inline-flex;
    align-items: center;
}

.brand img {
    display: block;
    width: auto;
    height: 38px;
    object-fit: contain;
}

.brand-drawer img {
    height: 32px;
}

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

.site-nav {
    display: none;
}

.language-toggle {
    padding: 4px;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.05);
}

.language-toggle a {
    min-width: 40px;
    min-height: 36px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 999px;
    color: var(--muted);
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.language-toggle a.is-active {
    background: var(--text);
    color: white;
}

.drawer-language-toggle {
    margin-bottom: 18px;
}

.inline-form {
    margin: 0;
}

.nav-button {
    border: 0;
    background: transparent;
    color: var(--muted);
    font: inherit;
    cursor: pointer;
    padding: 0;
}

.hero,
.microsite-hero {
    display: grid;
    grid-template-columns: 1.5fr 1fr;
    gap: 24px;
    align-items: stretch;
    padding: 28px 0 24px;
}

.auth-shell {
    display: grid;
    place-items: center;
    min-height: 70vh;
}

.hero-copy,
.hero-panel,
.contact-card,
.search-panel,
.business-card,
.story-card,
.form-card {
    background: var(--surface);
    border: 1px solid var(--surface-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    backdrop-filter: blur(10px);
}

.hero-copy,
.contact-card,
.story-card,
.form-card,
.auth-card {
    padding: 28px;
    backdrop-filter: none;
}

.hero-panel {
    display: grid;
    gap: 16px;
    padding: 18px;
    background: #ffffff;
}

.hero h1,
.microsite-hero h1,
.section-header h1 {
    font-size: clamp(2rem, 4vw, 4rem);
    line-height: 0.95;
    margin: 12px 0;
}

.eyebrow {
    display: inline-block;
    font-size: 0.82rem;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--accent);
}

.hero p,
.lead,
.form-card p,
.empty-state p,
.business-card p {
    color: var(--muted);
    line-height: 1.6;
}

.hero-actions,
.section-header,
.card-top,
.keywords,
.billing-summary,
.publish-grid,
.content-grid,
.offering-list,
.search-grid,
.stack {
    display: grid;
    gap: 16px;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    margin-top: 24px;
}

.stack-tight {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 18px;
    border-radius: 999px;
    border: 1px solid transparent;
    font-weight: 700;
}

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

.button.secondary {
    background: transparent;
    border-color: rgba(11, 110, 79, 0.2);
    color: var(--accent);
}

.google-auth-button {
    gap: 12px;
    width: 100%;
    border-color: rgba(15, 23, 42, 0.12);
    background: #ffffff;
    color: #111827;
    box-shadow: 0 8px 22px rgba(15, 23, 42, 0.06);
}

.google-auth-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 22px;
    height: 22px;
}

.google-auth-mark svg {
    width: 22px;
    height: 22px;
    display: block;
}

.auth-divider {
    position: relative;
    display: grid;
    place-items: center;
    margin: 4px 0;
    color: var(--muted);
    font-size: 0.84rem;
    font-weight: 700;
}

.auth-divider::before {
    content: "";
    position: absolute;
    inset: 50% 0 auto;
    border-top: 1px solid rgba(15, 23, 42, 0.1);
}

.auth-divider span {
    position: relative;
    z-index: 1;
    padding: 0 12px;
    background: var(--surface);
}

.stat-card {
    border-radius: calc(var(--radius) - 8px);
    background: rgba(255, 255, 255, 0.68);
    padding: 18px;
}

.stat-card strong {
    display: block;
    font-size: 1.1rem;
    margin-bottom: 8px;
}

.search-panel {
    padding: 20px;
    margin: 16px 0 28px;
}

.search-grid {
    grid-template-columns: repeat(6, minmax(0, 1fr));
    align-items: end;
}

label,
.stack {
    display: grid;
    gap: 8px;
}

label span {
    font-size: 0.92rem;
    font-weight: 700;
}

input,
textarea,
select {
    width: 100%;
    border: 1px solid rgba(31, 26, 21, 0.14);
    border-radius: 14px;
    padding: 14px 16px;
    background: rgba(255, 255, 255, 0.9);
    color: var(--text);
    font: inherit;
}

textarea {
    resize: vertical;
}

fieldset {
    border: 1px solid rgba(31, 26, 21, 0.1);
    border-radius: 20px;
    padding: 18px;
    margin: 0;
}

legend {
    padding: 0 8px;
    font-weight: 800;
}

.checkbox-row {
    grid-template-columns: auto 1fr;
    align-items: center;
    gap: 12px;
}

.checkbox-row input {
    width: auto;
    margin: 0;
}

.hint-text {
    margin: 0;
    color: var(--muted);
    font-size: 0.92rem;
}

.premium-fieldset {
    display: grid;
    gap: 14px;
    background: rgba(11, 110, 79, 0.04);
}

.premium-note {
    border-radius: 16px;
    padding: 14px 16px;
    background: rgba(11, 110, 79, 0.08);
    color: var(--text);
}

.media-preview,
.gallery-preview-item {
    overflow: hidden;
    border-radius: 20px;
    border: 1px solid rgba(31, 26, 21, 0.1);
    background: rgba(255, 255, 255, 0.72);
}

.media-preview img,
.gallery-preview-item img {
    display: block;
    width: 100%;
    height: 210px;
    object-fit: cover;
}

.gallery-preview-item {
    display: grid;
    gap: 10px;
    padding: 12px;
}

.gallery-preview-toggle {
    margin: 0;
    font-size: 0.92rem;
}

.media-preview.logo img {
    object-fit: contain;
    padding: 16px;
    background: white;
}

.media-source-picker {
    display: grid;
    gap: 10px;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: rgba(255, 255, 255, 0.82);
}

.media-source-picker.compact {
    padding: 12px;
}

.media-source-head {
    display: grid;
    gap: 4px;
}

.media-source-head > span {
    font-weight: 700;
    color: var(--text);
}

.media-source-head small,
.media-source-status {
    color: var(--muted);
    line-height: 1.5;
}

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

.media-source-button {
    min-height: 42px;
    padding-inline: 16px;
}

.media-source-picker input[type="file"] {
    width: 100%;
    font: inherit;
}

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

.compact-head {
    margin-bottom: 12px;
}

.home-ad-results {
    margin: 0 0 26px;
}

.home-ad-stage,
.home-ad-preview-frame {
    display: grid;
    place-items: center;
    padding: 20px;
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(11, 110, 79, 0.12), transparent 28%),
        radial-gradient(circle at bottom right, rgba(219, 90, 66, 0.15), transparent 28%),
        rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(31, 26, 21, 0.08);
}

.editor-preview-panel {
    display: grid;
    gap: 14px;
    margin: 8px 0 18px;
}

.editor-save-bar {
    position: sticky;
    top: 82px;
    z-index: 20;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 14px;
    align-items: center;
    padding: 14px 16px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(31, 26, 21, 0.1);
    box-shadow: 0 14px 28px rgba(20, 20, 20, 0.08);
    backdrop-filter: blur(14px);
}

.stack.tight {
    gap: 4px;
}

.editor-preview-meta {
    display: grid;
    gap: 8px;
}

.editor-microsite-preview-frame {
    display: grid;
    place-items: center;
    padding: 20px;
    border-radius: 28px;
    background:
        radial-gradient(circle at top left, rgba(11, 110, 79, 0.12), transparent 28%),
        radial-gradient(circle at bottom right, rgba(219, 90, 66, 0.15), transparent 28%),
        rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(31, 26, 21, 0.08);
}

.editor-microsite-preview-frame .industry-microsite {
    width: 100%;
    max-width: 380px;
    padding-bottom: 0;
}

.home-ad-panel-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
}

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

.palette-card {
    width: 100%;
    padding: 14px;
    border-radius: 20px;
    border: 1px solid rgba(31, 26, 21, 0.08);
    background: rgba(255, 255, 255, 0.82);
    text-align: left;
    cursor: pointer;
    display: grid;
    gap: 12px;
    font: inherit;
    color: inherit;
}

.palette-card.is-active {
    border-color: rgba(11, 110, 79, 0.34);
    box-shadow: 0 14px 28px rgba(11, 110, 79, 0.12);
}

.palette-card-head {
    display: grid;
    gap: 4px;
}

.palette-card-head small {
    color: var(--muted);
    line-height: 1.5;
}

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

.palette-swatch-row span {
    height: 34px;
    border-radius: 999px;
    border: 1px solid rgba(31, 26, 21, 0.08);
}

.home-ad-purchase-box {
    display: grid;
    gap: 12px;
}

.editor-advanced-toggle {
    border: 1px solid rgba(31, 26, 21, 0.08);
    border-radius: 22px;
    padding: 16px 18px;
    background: rgba(255, 255, 255, 0.7);
}

.editor-advanced-toggle summary {
    cursor: pointer;
    font-weight: 700;
    color: var(--ink);
}

.editor-advanced-toggle[open] summary {
    margin-bottom: 14px;
}

.home-ad-unit {
    --home-ad-bg: #102a43;
    --home-ad-accent: #f97316;
    position: relative;
    width: min(100%, 420px);
    min-height: min(92vh, 820px);
    border-radius: 34px;
    overflow: hidden;
    background: linear-gradient(180deg, color-mix(in srgb, var(--home-ad-bg) 94%, black), var(--home-ad-bg));
    color: white;
    box-shadow: 0 30px 70px rgba(15, 15, 15, 0.24);
}

.home-ad-results .home-ad-unit {
    width: min(100%, 520px);
}

.home-ad-overlay,
.home-ad-media {
    position: absolute;
    inset: 0;
}

.home-ad-overlay {
    background:
        radial-gradient(circle at 12% 18%, color-mix(in srgb, var(--home-ad-accent) 40%, transparent), transparent 28%),
        radial-gradient(circle at 82% 88%, color-mix(in srgb, white 12%, transparent), transparent 22%);
    z-index: 1;
}

.home-ad-media {
    background-size: cover;
    background-position: center;
    opacity: 0.76;
}

.home-ad-content {
    position: relative;
    z-index: 2;
    display: grid;
    align-content: end;
    gap: 14px;
    min-height: inherit;
    padding: 28px;
    background: linear-gradient(180deg, rgba(10, 10, 10, 0.12), rgba(10, 10, 10, 0.78));
}

.home-ad-kicker {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    width: fit-content;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(12px);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.home-ad-unit h2,
.home-ad-unit h3,
.home-ad-offer strong,
.home-ad-cta {
    margin: 0;
}

.home-ad-unit h3 {
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: rgba(255, 255, 255, 0.82);
}

.home-ad-unit h2 {
    font-size: clamp(2rem, 7vw, 3.4rem);
    line-height: 0.92;
}

.home-ad-subtitle {
    margin: 0;
    color: rgba(255, 255, 255, 0.88);
    line-height: 1.6;
    font-size: 1rem;
}

.home-ad-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.home-ad-chips span {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.14);
    font-size: 0.84rem;
}

.home-ad-offers {
    display: grid;
    gap: 12px;
}

.home-ad-offer {
    padding: 16px;
    border-radius: 22px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(10px);
}

.home-ad-offer p {
    margin: 8px 0 0;
    color: rgba(255, 255, 255, 0.84);
    line-height: 1.5;
}

.home-ad-footer {
    display: flex;
    gap: 12px;
    align-items: center;
    justify-content: space-between;
    margin-top: 8px;
}

.home-ad-cta {
    font-size: 1rem;
    font-weight: 800;
    color: white;
}

.home-ad-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 48px;
    padding: 0 20px;
    border-radius: 999px;
    background: var(--home-ad-accent);
    color: #101010;
    font-weight: 800;
}

.home-ad-style-editorial .home-ad-content {
    justify-items: start;
}

.home-ad-style-editorial .home-ad-offers {
    grid-template-columns: 1fr 1fr;
}

.home-ad-style-catalog .home-ad-offers {
    grid-template-columns: 1fr 1fr;
}

.home-ad-style-acai-delivery {
    background:
        radial-gradient(circle at 50% 28%, rgba(255, 132, 236, 0.4), transparent 20%),
        linear-gradient(180deg, #6d004e 0%, var(--home-ad-bg) 58%, #93006b 100%);
}

.home-ad-style-acai-delivery .home-ad-content {
    justify-items: center;
    align-content: start;
    padding-top: 22px;
    background: linear-gradient(180deg, rgba(120, 0, 88, 0.08), rgba(62, 0, 49, 0.1));
}

.home-ad-acai-chip {
    position: absolute;
    top: 18px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 3;
    min-height: 56px;
    min-width: 240px;
    padding: 0 28px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border-radius: 0 0 26px 26px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--home-ad-accent) 92%, white), #5b8f00);
    color: white;
    font-size: 1.05rem;
    font-weight: 800;
    box-shadow: 0 10px 24px rgba(40, 65, 0, 0.28);
}

.home-ad-acai-glow {
    position: absolute;
    width: 180px;
    height: 180px;
    border-radius: 999px;
    filter: blur(20px);
    opacity: 0.5;
    background: rgba(255, 255, 255, 0.12);
    z-index: 1;
}

.home-ad-acai-glow.glow-top {
    top: 90px;
    left: 50%;
    transform: translateX(-50%);
}

.home-ad-acai-glow.glow-bottom {
    right: -30px;
    bottom: 120px;
    background: rgba(255, 126, 220, 0.22);
}

.home-ad-style-acai-delivery h3 {
    margin-top: 10px;
    letter-spacing: 0.16em;
}

.home-ad-acai-kicker {
    margin-top: 58px;
}

.home-ad-acai-title {
    font-family: "Brush Script MT", "Segoe Script", cursive;
    font-size: clamp(3rem, 10vw, 5rem);
    line-height: 0.92;
    text-align: center;
    text-shadow: 0 10px 24px rgba(43, 0, 34, 0.36);
}

.home-ad-acai-bowl {
    width: min(84%, 320px);
    aspect-ratio: 1 / 1;
    display: grid;
    place-items: center;
    margin: 10px auto 4px;
    border-radius: 999px;
    background: radial-gradient(circle, rgba(255, 255, 255, 0.18), transparent 70%);
}

.home-ad-acai-bowl img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    filter: drop-shadow(0 18px 28px rgba(25, 0, 17, 0.34));
}

.home-ad-acai-chips {
    justify-content: center;
}

.home-ad-style-acai-delivery .home-ad-chips span {
    background: rgba(255, 255, 255, 0.14);
}

.home-ad-acai-cta-row {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 10px;
    align-items: stretch;
    margin-top: 8px;
}

.home-ad-acai-cta,
.home-ad-acai-wa {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 62px;
    border-radius: 999px;
    background: linear-gradient(180deg, color-mix(in srgb, var(--home-ad-accent) 92%, white), #628f00);
    color: white;
    font-weight: 800;
    box-shadow: 0 12px 24px rgba(43, 70, 0, 0.28);
}

.home-ad-acai-cta {
    font-size: 1.35rem;
}

.home-ad-acai-wa {
    min-width: 72px;
}

.home-ad-acai-wave {
    width: calc(100% + 56px);
    height: 74px;
    margin: 8px -28px 0;
    background:
        radial-gradient(circle at 15% 0%, #de2cba 0 24%, transparent 25%),
        radial-gradient(circle at 38% 0%, #de2cba 0 24%, transparent 25%),
        radial-gradient(circle at 61% 0%, #de2cba 0 24%, transparent 25%),
        radial-gradient(circle at 84% 0%, #de2cba 0 24%, transparent 25%);
}

.home-ad-acai-icons {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 12px;
    margin-top: 8px;
}

.home-ad-acai-icons span {
    min-height: 58px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(25, 0, 18, 0.38);
    border: 2px solid rgba(255, 255, 255, 0.12);
    font-size: 0.8rem;
    font-weight: 800;
}

.home-ad-acai-note {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 54px;
    padding: 0 18px;
    border-radius: 999px;
    margin-top: 10px;
    background: rgba(255, 255, 255, 0.92);
    color: #532544;
    text-align: center;
    font-weight: 700;
}

.home-ad-acai-link {
    margin-top: 12px;
    background: rgba(255, 255, 255, 0.14);
    color: white;
    border: 1px solid rgba(255, 255, 255, 0.16);
}

.home-ad-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
}

.toggle {
    justify-items: start;
}

.toggle input {
    width: auto;
    transform: scale(1.15);
}

.section-header {
    grid-template-columns: 1fr auto;
    align-items: center;
    margin: 22px 0 18px;
}

.section-header h2,
.story-card h2,
.form-card h2,
.contact-card h2 {
    margin: 0;
}

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

.card-grid {
    display: grid;
    gap: 18px;
}

.business-card {
    padding: 22px;
}

.dashboard-controls {
    display: grid;
    grid-template-columns: minmax(240px, 1fr) minmax(180px, 280px) auto;
    gap: 12px;
    align-items: end;
    margin: 0 0 14px;
    padding: 14px;
    border: 1px solid var(--surface-border);
    border-radius: 26px;
    background:
        linear-gradient(135deg, rgba(11, 110, 79, 0.08), rgba(255, 255, 255, 0.86)),
        var(--surface);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.06);
}

.dashboard-search,
.dashboard-industry-filter {
    display: grid;
    gap: 7px;
}

.dashboard-search span,
.dashboard-industry-filter span {
    color: var(--muted);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.dashboard-search input,
.dashboard-industry-filter select {
    min-height: 48px;
    border: 1px solid var(--surface-border);
    border-radius: 999px;
    padding: 0 16px;
    background: #fff;
    color: var(--text);
    font: inherit;
    outline: none;
}

.dashboard-search input:focus,
.dashboard-industry-filter select:focus {
    border-color: rgba(11, 110, 79, 0.5);
    box-shadow: 0 0 0 4px rgba(11, 110, 79, 0.12);
}

.dashboard-view-toggle {
    display: inline-flex;
    gap: 6px;
    padding: 5px;
    border: 1px solid var(--surface-border);
    border-radius: 999px;
    background: #f7faf8;
}

.dashboard-view-toggle button {
    min-height: 38px;
    border: 0;
    border-radius: 999px;
    padding: 0 14px;
    background: transparent;
    color: var(--muted);
    cursor: pointer;
    font: inherit;
    font-weight: 800;
}

.dashboard-view-toggle button.is-active {
    background: var(--accent);
    color: #fff;
    box-shadow: 0 10px 22px rgba(11, 110, 79, 0.2);
}

.dashboard-results-meta {
    display: flex;
    gap: 6px;
    align-items: center;
    margin: 0 0 14px;
    color: var(--muted);
    font-size: 0.95rem;
}

.dashboard-results-meta [data-dashboard-count] {
    color: var(--text);
    font-weight: 900;
}

.dashboard-business-grid.is-list-view {
    grid-template-columns: 1fr;
}

.dashboard-business-grid.is-list-view .dashboard-business-card {
    display: grid;
    grid-template-columns: minmax(190px, 0.8fr) minmax(240px, 1.2fr) auto;
    gap: 14px 22px;
    align-items: center;
}

.dashboard-business-grid.is-list-view .dashboard-business-card .card-top,
.dashboard-business-grid.is-list-view .dashboard-business-card .keywords,
.dashboard-business-grid.is-list-view .dashboard-business-card .owner-meta,
.dashboard-business-grid.is-list-view .dashboard-business-card .hero-actions {
    margin: 0;
}

.dashboard-business-grid.is-list-view .dashboard-business-card h3 {
    align-self: end;
}

.dashboard-business-grid.is-list-view .dashboard-business-card .headline,
.dashboard-business-grid.is-list-view .dashboard-business-card p:not(.headline) {
    margin: 0;
}

.dashboard-business-grid.is-list-view .dashboard-business-card .hero-actions {
    justify-content: flex-end;
}

.business-card h3,
.offering-item h3 {
    margin: 0;
}

.headline {
    font-weight: 700;
    color: var(--text);
}

.pill,
.keywords span,
.location {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    min-height: 30px;
    border-radius: 999px;
    padding: 0 12px;
    font-size: 0.85rem;
}

.pill {
    background: rgba(11, 110, 79, 0.12);
    color: var(--accent);
}

.premium-star-badge {
    width: 28px;
    height: 28px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(180deg, #ffe28f, #d4a11d);
    color: #5f4100;
    box-shadow: 0 10px 18px rgba(170, 122, 22, 0.24);
    font-size: 1rem;
    font-weight: 900;
}

.premium-star-badge-inline {
    flex: 0 0 auto;
}

.featured-badge {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    border-radius: 999px;
    padding: 0 12px;
    background: rgba(219, 90, 66, 0.14);
    color: var(--accent-2);
    font-size: 0.85rem;
    font-weight: 700;
}

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

.keywords span,
.location {
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.06);
    color: var(--muted);
}

.text-link {
    color: var(--accent-2);
    font-weight: 700;
}

.contact-card ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 12px;
}

.offering-list {
    margin-top: 8px;
}

.offering-item {
    padding: 18px;
    border: 1px solid rgba(31, 26, 21, 0.08);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.65);
}

.empty-state {
    padding: 28px;
    background: rgba(255, 255, 255, 0.68);
    border-radius: var(--radius);
    border: 1px dashed rgba(31, 26, 21, 0.15);
}

.form-alert {
    border-radius: 14px;
    padding: 12px 14px;
    background: rgba(219, 90, 66, 0.12);
    color: #8a2d1d;
}

.form-alert-success {
    background: rgba(11, 110, 79, 0.12);
    color: #0f5b42;
}

.owner-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    color: var(--muted);
    font-size: 0.92rem;
}

.campaign-list {
    display: grid;
    gap: 16px;
    margin-top: 20px;
}

.plan-meta {
    font-size: 0.92rem;
    color: var(--muted);
}

.plan-option {
    grid-template-columns: auto 1fr;
    align-items: start;
    padding: 16px;
    border: 1px solid rgba(31, 26, 21, 0.1);
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.65);
}

.plan-option input {
    width: auto;
    margin-top: 4px;
}

.plan-option strong,
.plan-option small {
    display: block;
}

.billing-summary {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
}

.premium-monitor-grid {
    margin-top: 22px;
}

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

.analytics-metric {
    padding: 16px;
    border-radius: 18px;
    background: rgba(255, 255, 255, 0.72);
    border: 1px solid rgba(31, 26, 21, 0.08);
}

.analytics-metric strong {
    display: block;
}

.analytics-metric span {
    color: var(--muted);
    line-height: 1.5;
}

.module-card,
.crm-status-form,
.quote-photo-grid {
    display: grid;
    gap: 14px;
}

.module-card {
    padding: 18px;
    border-radius: 20px;
    border: 1px solid rgba(31, 26, 21, 0.08);
    background: rgba(255, 255, 255, 0.72);
}

.module-card-head {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 16px;
    align-items: start;
}

.module-card-head h3 {
    margin: 8px 0;
}

.module-toggle {
    align-self: start;
}

.crm-status-form {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
}

.quote-photo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.quote-photo-item {
    overflow: hidden;
    border-radius: 16px;
    border: 1px solid rgba(31, 26, 21, 0.08);
}

.quote-photo-item img {
    display: block;
    width: 100%;
    height: 112px;
    object-fit: cover;
}

.crm-overview-grid,
.crm-shell,
.crm-filter-form,
.crm-pipeline-grid,
.crm-inbox-list,
.crm-contact-grid,
.crm-action-grid,
.crm-timeline {
    display: grid;
    gap: 16px;
}

.crm-overview-grid {
    grid-template-columns: 1.15fr 1fr;
    margin-bottom: 18px;
}

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

.crm-stage-card,
.crm-inbox-item {
    display: grid;
    gap: 8px;
    padding: 16px;
    border-radius: 18px;
    border: 1px solid rgba(31, 26, 21, 0.08);
    background: rgba(255, 255, 255, 0.72);
}

.crm-stage-card.is-active,
.crm-inbox-item.is-active {
    border-color: rgba(11, 110, 79, 0.24);
    box-shadow: 0 14px 28px rgba(11, 110, 79, 0.08);
}

.crm-stage-card strong,
.crm-panel-head h2,
.crm-detail-block h3 {
    margin: 0;
}

.crm-stage-card span {
    font-size: 1.4rem;
    font-weight: 800;
}

.crm-stage-card small,
.crm-block-head small,
.crm-inbox-top small {
    color: var(--muted);
}

.crm-filter-card {
    margin-bottom: 18px;
}

.crm-filter-head,
.crm-panel-head,
.crm-inbox-top,
.crm-block-head {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 16px;
}

.crm-filter-form {
    grid-template-columns: minmax(0, 1.7fr) repeat(3, minmax(0, 1fr)) auto;
    align-items: end;
}

.crm-shell {
    grid-template-columns: 380px minmax(0, 1fr);
    align-items: start;
}

.crm-inbox-panel,
.crm-detail-panel {
    min-width: 0;
}

.crm-inbox-list {
    margin-top: 12px;
    max-height: 920px;
    overflow: auto;
}

.crm-inbox-item strong {
    font-size: 1rem;
}

.crm-inbox-item p,
.crm-detail-block p {
    margin: 0;
    color: var(--muted);
    line-height: 1.6;
}

.crm-contact-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.crm-contact-grid div {
    display: grid;
    gap: 6px;
    padding: 16px;
    border-radius: 18px;
    border: 1px solid rgba(31, 26, 21, 0.08);
    background: rgba(255, 255, 255, 0.62);
}

.crm-contact-grid strong {
    font-size: 0.82rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--muted);
}

.crm-action-grid {
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center;
    margin-top: 16px;
}

.crm-detail-block + .crm-detail-block {
    margin-top: 18px;
}

.crm-timeline-item {
    display: grid;
    gap: 10px;
    padding: 16px;
    border-radius: 18px;
    border: 1px solid rgba(31, 26, 21, 0.08);
    background: rgba(255, 255, 255, 0.62);
}

.crm-timeline-head {
    display: flex;
    justify-content: space-between;
    align-items: start;
    gap: 14px;
}

@media (max-width: 980px) {
    .crm-overview-grid,
    .crm-shell {
        grid-template-columns: 1fr;
    }

    .crm-filter-form {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .crm-pipeline-grid,
    .crm-contact-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

.section-space {
    margin-top: 18px;
}

.hero-actions.compact {
    margin-top: 8px;
}

.industry-microsite {
    max-width: 460px;
    margin: 0 auto;
    padding-bottom: 110px;
    --microsite-bg: #fff8f1;
    --microsite-card: #ffffff;
    --microsite-card-alt: #f7eee2;
    --microsite-text: #241b16;
    --microsite-muted: #7a6658;
    --microsite-accent: #0b6e4f;
    --microsite-accent-strong: #db5a42;
    --microsite-outline: rgba(36, 27, 22, 0.12);
    --microsite-chip: rgba(255, 255, 255, 0.18);
    --microsite-display: "Georgia", "Times New Roman", serif;
    --microsite-body: "Segoe UI", sans-serif;
    --microsite-dock: rgba(255, 249, 242, 0.92);
    --microsite-shadow: 0 28px 60px rgba(44, 26, 16, 0.18);
    --microsite-cover-overlay-start: rgba(10, 10, 10, 0.14);
    --microsite-cover-overlay-end: rgba(10, 10, 10, 0.62);
    --microsite-showcase-overlay-start: rgba(12, 12, 12, 0.08);
    --microsite-showcase-overlay-end: rgba(12, 12, 12, 0.2);
}

.theme-love {
    --microsite-bg: #3f1768;
    --microsite-card: rgba(72, 30, 116, 0.95);
    --microsite-card-alt: #ff5e9b;
    --microsite-text: #fff5fa;
    --microsite-muted: #e8cbe8;
    --microsite-accent: #ff6fa7;
    --microsite-accent-strong: #ff4f88;
    --microsite-outline: rgba(255, 170, 206, 0.18);
    --microsite-chip: rgba(255, 255, 255, 0.16);
    --microsite-display: "Georgia", serif;
    --microsite-body: "Trebuchet MS", sans-serif;
    --microsite-dock: rgba(101, 49, 143, 0.84);
    --microsite-cover-overlay-start: rgba(120, 33, 109, 0.2);
    --microsite-cover-overlay-end: rgba(38, 11, 63, 0.74);
    --microsite-showcase-overlay-start: rgba(255, 86, 156, 0.08);
    --microsite-showcase-overlay-end: rgba(46, 13, 74, 0.32);
}

.theme-wedding {
    --microsite-bg: #fff8f6;
    --microsite-card: rgba(255, 253, 250, 0.96);
    --microsite-card-alt: #f4e2c4;
    --microsite-text: #3d2931;
    --microsite-muted: #765b66;
    --microsite-accent: #b23b72;
    --microsite-accent-strong: #cf5b8c;
    --microsite-outline: rgba(178, 59, 114, 0.16);
    --microsite-chip: rgba(255, 255, 255, 0.7);
    --microsite-display: "Palatino Linotype", serif;
    --microsite-body: "Segoe UI", sans-serif;
    --microsite-dock: rgba(206, 89, 138, 0.9);
    --microsite-cover-overlay-start: rgba(172, 87, 124, 0.12);
    --microsite-cover-overlay-end: rgba(87, 43, 61, 0.5);
    --microsite-showcase-overlay-start: rgba(244, 226, 196, 0.02);
    --microsite-showcase-overlay-end: rgba(146, 55, 92, 0.18);
}

.theme-restaurant {
    --microsite-bg: #fff5ef;
    --microsite-card: rgba(255, 253, 250, 0.98);
    --microsite-card-alt: #ff2742;
    --microsite-text: #261512;
    --microsite-muted: #7a564f;
    --microsite-accent: #ea2f54;
    --microsite-accent-strong: #ff7b34;
    --microsite-outline: rgba(234, 47, 84, 0.16);
    --microsite-chip: rgba(255, 243, 240, 0.8);
    --microsite-display: "Trebuchet MS", sans-serif;
    --microsite-body: "Segoe UI", sans-serif;
    --microsite-dock: rgba(255, 233, 236, 0.94);
    --microsite-cover-overlay-start: rgba(95, 23, 16, 0.12);
    --microsite-cover-overlay-end: rgba(57, 12, 8, 0.6);
    --microsite-showcase-overlay-start: rgba(255, 108, 52, 0.05);
    --microsite-showcase-overlay-end: rgba(88, 17, 13, 0.28);
}

.theme-taxi {
    --microsite-bg: #fff4aa;
    --microsite-card: rgba(255, 241, 112, 0.98);
    --microsite-card-alt: #ffd248;
    --microsite-text: #17130a;
    --microsite-muted: #453c18;
    --microsite-accent: #111111;
    --microsite-accent-strong: #e09e00;
    --microsite-outline: rgba(17, 17, 17, 0.22);
    --microsite-chip: rgba(255, 218, 0, 0.32);
    --microsite-display: "Arial Black", sans-serif;
    --microsite-body: "Trebuchet MS", sans-serif;
    --microsite-dock: rgba(255, 219, 83, 0.95);
    --microsite-cover-overlay-start: rgba(16, 16, 16, 0.06);
    --microsite-cover-overlay-end: rgba(16, 16, 16, 0.42);
    --microsite-showcase-overlay-start: rgba(255, 210, 72, 0.02);
    --microsite-showcase-overlay-end: rgba(17, 17, 17, 0.16);
}

.theme-architect {
    --microsite-bg: #fbf7ef;
    --microsite-card: rgba(255, 252, 247, 0.98);
    --microsite-card-alt: #f4ede1;
    --microsite-text: #2f2b27;
    --microsite-muted: #8d8378;
    --microsite-accent: #b9a589;
    --microsite-accent-strong: #8b7763;
    --microsite-outline: rgba(112, 95, 73, 0.18);
    --microsite-chip: rgba(240, 232, 220, 0.88);
    --microsite-display: "Gill Sans MT", sans-serif;
    --microsite-body: "Segoe UI", sans-serif;
    --microsite-dock: rgba(252, 247, 238, 0.95);
    --microsite-cover-overlay-start: rgba(62, 55, 49, 0.08);
    --microsite-cover-overlay-end: rgba(45, 39, 34, 0.42);
    --microsite-showcase-overlay-start: rgba(244, 237, 225, 0.03);
    --microsite-showcase-overlay-end: rgba(69, 58, 49, 0.16);
}

.theme-gym {
    --microsite-bg: #e8e8e8;
    --microsite-card: rgba(255, 255, 255, 0.96);
    --microsite-card-alt: #f3f3f3;
    --microsite-text: #111111;
    --microsite-muted: #505050;
    --microsite-accent: #1d1d1d;
    --microsite-accent-strong: #404040;
    --microsite-outline: rgba(17, 17, 17, 0.2);
    --microsite-chip: rgba(255, 255, 255, 0.9);
    --microsite-display: "Impact", sans-serif;
    --microsite-body: "Trebuchet MS", sans-serif;
    --microsite-dock: rgba(56, 56, 56, 0.92);
    --microsite-cover-overlay-start: rgba(10, 10, 10, 0.16);
    --microsite-cover-overlay-end: rgba(10, 10, 10, 0.76);
    --microsite-showcase-overlay-start: rgba(255, 255, 255, 0.01);
    --microsite-showcase-overlay-end: rgba(8, 8, 8, 0.3);
}

.theme-spa {
    --microsite-bg: #f1fff7;
    --microsite-card: rgba(255, 255, 255, 0.96);
    --microsite-card-alt: #e3fff4;
    --microsite-text: #204235;
    --microsite-muted: #658f80;
    --microsite-accent: #3fcb82;
    --microsite-accent-strong: #7fe3b0;
    --microsite-outline: rgba(63, 203, 130, 0.18);
    --microsite-chip: rgba(225, 255, 245, 0.95);
    --microsite-display: "Palatino Linotype", serif;
    --microsite-body: "Segoe UI", sans-serif;
    --microsite-dock: rgba(219, 255, 236, 0.95);
    --microsite-cover-overlay-start: rgba(33, 103, 76, 0.06);
    --microsite-cover-overlay-end: rgba(27, 75, 56, 0.32);
    --microsite-showcase-overlay-start: rgba(227, 255, 244, 0.02);
    --microsite-showcase-overlay-end: rgba(27, 103, 76, 0.12);
}

.theme-barber {
    --microsite-bg: #171214;
    --microsite-card: rgba(33, 26, 29, 0.96);
    --microsite-card-alt: #2a1f22;
    --microsite-text: #f4ece4;
    --microsite-muted: #c8b4a4;
    --microsite-accent: #b78652;
    --microsite-accent-strong: #e1b681;
    --microsite-outline: rgba(183, 134, 82, 0.2);
    --microsite-chip: rgba(255, 248, 241, 0.12);
    --microsite-display: "Arial Black", sans-serif;
    --microsite-body: "Trebuchet MS", sans-serif;
    --microsite-dock: rgba(31, 24, 27, 0.94);
    --microsite-cover-overlay-start: rgba(95, 62, 31, 0.12);
    --microsite-cover-overlay-end: rgba(18, 13, 15, 0.78);
    --microsite-showcase-overlay-start: rgba(225, 182, 129, 0.05);
    --microsite-showcase-overlay-end: rgba(25, 18, 20, 0.34);
}

.theme-contractor {
    --microsite-bg: #edf4f7;
    --microsite-card: rgba(255, 255, 255, 0.98);
    --microsite-card-alt: #dce7ee;
    --microsite-text: #173140;
    --microsite-muted: #5d7380;
    --microsite-accent: #114f72;
    --microsite-accent-strong: #ff6f3c;
    --microsite-outline: rgba(17, 79, 114, 0.14);
    --microsite-chip: rgba(255, 255, 255, 0.84);
    --microsite-display: "Franklin Gothic Medium", "Arial Narrow", sans-serif;
    --microsite-body: "Segoe UI", sans-serif;
    --microsite-dock: rgba(245, 250, 252, 0.95);
    --microsite-cover-overlay-start: rgba(17, 79, 114, 0.12);
    --microsite-cover-overlay-end: rgba(13, 40, 58, 0.54);
    --microsite-showcase-overlay-start: rgba(255, 111, 60, 0.04);
    --microsite-showcase-overlay-end: rgba(17, 79, 114, 0.18);
}

.theme-clinic {
    --microsite-bg: #f4fbff;
    --microsite-card: rgba(255, 255, 255, 0.99);
    --microsite-card-alt: #e5f4fb;
    --microsite-text: #173847;
    --microsite-muted: #668694;
    --microsite-accent: #2b8fbf;
    --microsite-accent-strong: #6fc7d9;
    --microsite-outline: rgba(43, 143, 191, 0.14);
    --microsite-chip: rgba(255, 255, 255, 0.9);
    --microsite-display: "Gill Sans MT", sans-serif;
    --microsite-body: "Segoe UI", sans-serif;
    --microsite-dock: rgba(244, 251, 255, 0.96);
    --microsite-cover-overlay-start: rgba(43, 143, 191, 0.07);
    --microsite-cover-overlay-end: rgba(18, 58, 76, 0.36);
    --microsite-showcase-overlay-start: rgba(255, 255, 255, 0.02);
    --microsite-showcase-overlay-end: rgba(43, 143, 191, 0.12);
}

.industry-phone-shell {
    background:
        radial-gradient(circle at top left, color-mix(in srgb, var(--microsite-accent-strong) 24%, transparent), transparent 34%),
        radial-gradient(circle at top right, color-mix(in srgb, var(--microsite-accent) 18%, transparent), transparent 28%),
        var(--microsite-bg);
    border-radius: 34px;
    box-shadow: var(--microsite-shadow);
    overflow: hidden;
    color: var(--microsite-text);
}

.industry-cover {
    height: 220px;
    background-size: cover;
    background-position: center;
    position: relative;
}

.industry-cover::after {
    content: "";
    position: absolute;
    inset: auto 0 0;
    height: 52px;
    background: linear-gradient(180deg, transparent, var(--microsite-bg));
}

.industry-cover-bar {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 18px;
    position: relative;
    z-index: 1;
}

.industry-cover-chip {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: var(--microsite-chip);
    color: var(--microsite-text);
    backdrop-filter: blur(12px);
    font-size: 0.86rem;
    font-weight: 700;
}

.industry-cover-chip.accent {
    background: var(--microsite-accent);
    color: white;
}

.industry-cover-chip.accent-alt {
    background: color-mix(in srgb, var(--microsite-accent-strong) 82%, white);
    color: white;
}

.premium-star-chip {
    min-width: 40px;
    justify-content: center;
    padding: 0 12px;
    background: linear-gradient(180deg, #ffe291, #cf991b) !important;
    color: #5e4206 !important;
}

.industry-language-toggle {
    margin-left: auto;
    background: rgba(255, 255, 255, 0.18);
    border-color: rgba(255, 255, 255, 0.24);
    backdrop-filter: blur(12px);
}

.industry-language-toggle a {
    color: white;
}

.industry-language-toggle a.is-active {
    background: white;
    color: var(--text);
}

.industry-page-card {
    padding: 0 18px 22px;
    margin-top: -34px;
    position: relative;
    z-index: 1;
}

.industry-profile,
.industry-info-card,
.industry-content-card {
    background: var(--microsite-card);
    border: 1px solid var(--microsite-outline);
    box-shadow: 0 10px 28px rgba(21, 16, 12, 0.08);
}

.industry-profile {
    display: grid;
    grid-template-columns: 92px 1fr;
    gap: 16px;
    align-items: center;
    border-radius: 26px;
    padding: 18px;
}

.industry-avatar-wrap {
    width: 92px;
    height: 92px;
    border-radius: 999px;
    padding: 4px;
    background: linear-gradient(160deg, var(--microsite-accent-strong), var(--microsite-accent));
}

.industry-avatar {
    width: 100%;
    height: 100%;
    border-radius: 999px;
    display: grid;
    place-items: center;
    overflow: hidden;
    background: rgba(255, 255, 255, 0.98);
    border: 3px solid rgba(255, 255, 255, 0.86);
}

.industry-avatar-image {
    width: 100%;
    height: 100%;
    object-fit: contain;
    padding: 10px;
}

.industry-avatar-monogram {
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at 24% 24%, color-mix(in srgb, var(--microsite-accent-strong) 38%, white), transparent 34%),
        linear-gradient(145deg, color-mix(in srgb, var(--microsite-accent) 94%, white), color-mix(in srgb, var(--microsite-accent-strong) 92%, black));
    color: white;
    font-family: var(--font-sans);
    font-size: 1.7rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.industry-profile-copy h1,
.industry-profile-copy h2,
.industry-content-card h3,
.industry-offering h4 {
    margin: 0;
}

.industry-kicker,
.industry-section-kicker {
    display: inline-block;
    color: var(--microsite-accent);
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.industry-profile-copy h1 {
    margin-top: 6px;
    font-family: var(--microsite-display);
    font-size: clamp(1.8rem, 7vw, 2.7rem);
    line-height: 0.95;
}

.industry-profile-copy h2 {
    margin-top: 8px;
    font-size: 1.02rem;
}

.industry-profile-copy p,
.industry-content-card p,
.industry-info-card p,
.industry-contact-list span,
.industry-contact-link,
.industry-offering p {
    color: var(--microsite-muted);
    line-height: 1.55;
}

.industry-action-row {
    display: flex;
    gap: 14px;
    justify-content: center;
    flex-wrap: wrap;
    margin: 20px 0;
}

.industry-action-button {
    min-width: 68px;
    min-height: 68px;
    padding: 10px 12px;
    border-radius: 22px;
    display: inline-grid;
    place-items: center;
    gap: 4px;
    background: var(--microsite-card);
    border: 1px solid var(--microsite-outline);
    box-shadow: 0 8px 20px rgba(25, 17, 10, 0.08);
}

.industry-action-icon {
    width: 22px;
    height: 22px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: var(--microsite-accent);
}

.industry-action-icon svg,
.industry-info-icon svg,
.industry-dock-button span svg {
    width: 100%;
    height: 100%;
}

.industry-cover-chip svg {
    width: 14px;
    height: 14px;
}

.industry-action-button small {
    font-size: 0.66rem;
    font-weight: 700;
    color: var(--microsite-muted);
}

.industry-showcase-card {
    height: 190px;
    border-radius: 24px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.18), 0 18px 30px rgba(14, 10, 8, 0.18);
}

.industry-info-card,
.industry-content-card {
    border-radius: 24px;
    padding: 20px;
    margin-top: 18px;
}

.industry-info-card {
    display: grid;
    grid-template-columns: 42px 1fr;
    gap: 14px;
    background: var(--microsite-card-alt);
}

.industry-info-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 255, 255, 0.22);
    color: var(--microsite-text);
}

.industry-info-label {
    display: block;
    font-size: 0.76rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 800;
    margin-bottom: 4px;
}

.industry-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    margin-top: 14px;
}

.industry-chip-row span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    border-radius: 999px;
    padding: 0 12px;
    background: color-mix(in srgb, var(--microsite-accent) 12%, white);
    color: var(--microsite-accent);
    font-size: 0.84rem;
    font-weight: 700;
}

.industry-offering-list {
    display: grid;
    gap: 14px;
    margin-top: 14px;
}

.industry-offering {
    padding: 16px;
    border-radius: 20px;
    background: color-mix(in srgb, var(--microsite-card-alt) 58%, white);
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 75%, transparent);
}

.industry-offering h4 {
    font-size: 1.05rem;
}

.industry-offering small {
    display: block;
    margin-top: 8px;
    color: var(--microsite-accent);
    font-weight: 700;
}

.industry-contact-list {
    display: grid;
    gap: 12px;
    margin-top: 10px;
}

.industry-contact-list div {
    display: grid;
    gap: 4px;
}

.industry-contact-list strong {
    color: var(--microsite-text);
}

.industry-contact-link {
    text-decoration: none;
    word-break: break-word;
}

.industry-contact-link:hover,
.industry-contact-link:focus-visible {
    color: var(--microsite-accent-strong);
    text-decoration: underline;
}

.industry-address-stack {
    display: grid;
    gap: 2px;
}

.industry-gallery-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 14px;
}

.industry-gallery-item {
    border-radius: 20px;
    overflow: hidden;
    min-height: 132px;
    background: color-mix(in srgb, var(--microsite-card-alt) 54%, white);
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 75%, transparent);
}

.industry-gallery-item img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.industry-premium-actions,
.industry-hours-grid {
    display: grid;
    gap: 12px;
    margin-top: 14px;
}

.industry-chat-shell {
    display: grid;
    gap: 12px;
    margin-top: 14px;
}

.industry-form-shell {
    margin-top: 18px;
    padding: 18px;
    border-radius: 22px;
    background: color-mix(in srgb, var(--microsite-card-alt) 32%, white);
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 65%, transparent);
    display: grid;
    gap: 14px;
}

.industry-disclosure {
    margin-top: 16px;
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 70%, transparent);
    border-radius: 22px;
    background: color-mix(in srgb, var(--microsite-card-alt) 34%, white);
}

.industry-disclosure summary {
    list-style: none;
    cursor: pointer;
    padding: 16px 18px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

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

.industry-disclosure summary::after {
    content: "+";
    color: var(--microsite-accent);
    font-size: 1.1rem;
    font-weight: 800;
}

.industry-disclosure[open] summary::after {
    content: "−";
}

.industry-disclosure-copy {
    display: grid;
    gap: 4px;
}

.industry-disclosure-copy strong {
    color: var(--microsite-text);
}

.industry-disclosure-body {
    padding: 0 18px 18px;
}

.industry-disclosure-intro {
    margin: 0;
    color: var(--microsite-muted);
}

.industry-disclosure-body .industry-form-shell {
    margin-top: 0;
    padding: 0;
    border: 0;
    background: transparent;
}

.industry-review-summary {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin: 10px 0 16px;
}

.industry-review-summary strong {
    display: block;
}

.industry-review-summary span {
    color: var(--microsite-muted);
}

.industry-review-list {
    display: grid;
    gap: 12px;
}

.industry-review-card {
    padding: 16px;
    border-radius: 20px;
    background: color-mix(in srgb, var(--microsite-card-alt) 40%, white);
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 65%, transparent);
}

.industry-review-card p,
.industry-review-card small {
    margin: 0;
}

.industry-review-card p {
    margin: 10px 0 8px;
}

.industry-review-card small {
    color: var(--microsite-muted);
}

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

.industry-review-stars {
    color: #d4a11d;
    font-weight: 900;
    letter-spacing: 0.08em;
}

.industry-chat-toolbar,
.industry-chat-actions {
    display: grid;
    gap: 10px;
}

.industry-chat-toolbar {
    grid-template-columns: minmax(0, 1fr);
}

.industry-chat-log {
    display: grid;
    gap: 10px;
    max-height: 280px;
    overflow: auto;
    padding-right: 4px;
}

.industry-chat-bubble {
    max-width: 90%;
    padding: 12px 14px;
    border-radius: 18px;
    line-height: 1.5;
    font-size: 0.95rem;
}

.industry-chat-bubble.assistant {
    background: color-mix(in srgb, var(--microsite-card-alt) 54%, white);
    color: var(--microsite-text);
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 75%, transparent);
}

.industry-chat-bubble.user {
    justify-self: end;
    background: var(--microsite-accent);
    color: white;
}

.industry-chat-form {
    display: grid;
    gap: 10px;
}

.voice-toggle {
    align-items: center;
}

.industry-qr-card {
    display: flex;
    justify-content: center;
}

.industry-qr-box {
    width: min(180px, 100%);
    padding: 14px;
    border-radius: 24px;
    background: white;
    box-shadow: inset 0 0 0 1px rgba(20, 20, 20, 0.08);
}

.industry-qr-box img {
    display: block;
    width: 100%;
    height: auto;
}

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

.industry-signal-grid div {
    border-radius: 18px;
    padding: 14px;
    background: color-mix(in srgb, var(--microsite-card-alt) 46%, white);
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 65%, transparent);
}

.industry-signal-grid strong,
.industry-hour-row {
    display: block;
    color: var(--microsite-text);
    font-weight: 800;
}

.industry-signal-grid small {
    color: var(--microsite-muted);
}

.industry-hour-row {
    border-radius: 18px;
    padding: 14px 16px;
    background: color-mix(in srgb, var(--microsite-card-alt) 42%, white);
    border: 1px solid color-mix(in srgb, var(--microsite-outline) 65%, transparent);
}

.industry-dock {
    position: sticky;
    bottom: 12px;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 8px;
    margin: 18px auto 0;
    padding: 10px;
    width: min(430px, calc(100% - 12px));
    border-radius: 999px;
    background: var(--microsite-dock);
    border: 1px solid var(--microsite-outline);
    backdrop-filter: blur(14px);
    box-shadow: 0 10px 24px rgba(15, 10, 7, 0.18);
}

.industry-dock-button {
    min-height: 54px;
    border-radius: 999px;
    display: grid;
    place-items: center;
    color: var(--microsite-accent);
    text-align: center;
}

.industry-dock-button span {
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.industry-dock-button small {
    font-size: 0.68rem;
    margin-top: 2px;
}

.theme-taxi .industry-profile,
.theme-gym .industry-profile,
.theme-taxi .industry-info-card,
.theme-gym .industry-info-card,
.theme-taxi .industry-content-card,
.theme-gym .industry-content-card,
.theme-taxi .industry-dock,
.theme-gym .industry-dock {
    border-width: 2px;
}

.theme-restaurant .industry-showcase-card {
    border-radius: 28px;
}

.theme-love .industry-profile,
.theme-wedding .industry-profile {
    box-shadow: 0 18px 36px rgba(41, 12, 57, 0.18);
}

.theme-architect .industry-phone-shell {
    background:
        linear-gradient(180deg, rgba(255, 255, 255, 0.96), rgba(250, 246, 238, 0.98)),
        var(--microsite-bg);
}

.theme-gym .industry-profile-copy h1,
.theme-taxi .industry-profile-copy h1 {
    letter-spacing: 0.01em;
    text-transform: uppercase;
}

.theme-barber .industry-profile-copy h1 {
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.theme-barber .industry-action-button,
.theme-barber .industry-showcase-card {
    border-radius: 18px;
}

.theme-contractor .industry-profile,
.theme-contractor .industry-info-card,
.theme-contractor .industry-content-card,
.theme-barber .industry-profile,
.theme-barber .industry-info-card,
.theme-barber .industry-content-card {
    border-width: 2px;
}

.theme-contractor .industry-cover-chip.accent {
    background: linear-gradient(135deg, var(--microsite-accent), var(--microsite-accent-strong));
}

.theme-clinic .industry-profile,
.theme-clinic .industry-info-card,
.theme-clinic .industry-content-card {
    box-shadow: 0 14px 32px rgba(26, 78, 102, 0.09);
}

.theme-clinic .industry-showcase-card {
    border-radius: 30px;
}

@media (max-width: 980px) {
    .hero,
    .microsite-hero,
    .card-grid,
    .publish-grid,
    .content-grid,
    .search-grid {
        grid-template-columns: 1fr;
    }

    .dashboard-controls,
    .dashboard-business-grid.is-list-view .dashboard-business-card {
        grid-template-columns: 1fr;
    }

    .dashboard-business-grid.is-list-view .dashboard-business-card .hero-actions {
        justify-content: flex-start;
    }

    .site-header {
        flex-direction: column;
        gap: 14px;
        align-items: flex-start;
    }
}

@media (max-width: 640px) {
    .page-shell {
        width: min(var(--max-width), calc(100% - 20px));
    }

    .hero-copy,
    .contact-card,
    .story-card,
    .form-card,
    .search-panel {
        padding: 20px;
    }

    .industry-microsite {
        max-width: 100%;
    }

    .industry-phone-shell {
        border-radius: 30px;
    }

    .industry-cover {
        height: 200px;
    }

    .industry-profile {
        grid-template-columns: 78px 1fr;
        gap: 12px;
        padding: 16px;
    }

    .industry-avatar-wrap {
        width: 78px;
        height: 78px;
    }

    .industry-page-card {
        padding: 0 14px 18px;
    }

    .industry-info-card,
    .industry-content-card {
        padding: 18px;
    }

    .industry-showcase-card {
        height: 170px;
    }

    .gallery-preview-grid,
    .industry-gallery-grid,
    .industry-signal-grid,
    .palette-grid,
    .analytics-strip {
        grid-template-columns: 1fr;
    }

    .editor-save-bar {
        top: 72px;
        padding: 12px;
    }

    .home-ad-stage,
    .home-ad-preview-frame {
        padding: 10px;
        border-radius: 24px;
    }

    .home-ad-unit,
    .home-ad-results .home-ad-unit {
        width: 100%;
        min-height: 78vh;
        border-radius: 28px;
    }

    .home-ad-style-editorial .home-ad-offers,
    .home-ad-style-catalog .home-ad-offers {
        grid-template-columns: 1fr;
    }

    .crm-overview-grid,
    .crm-shell,
    .module-card-head,
    .crm-status-form,
    .quote-photo-grid,
    .crm-filter-form,
    .crm-contact-grid,
    .crm-action-grid,
    .crm-pipeline-grid {
        grid-template-columns: 1fr;
    }

    .crm-filter-head,
    .crm-panel-head,
    .crm-inbox-top,
    .crm-block-head,
    .crm-timeline-head {
        flex-direction: column;
        align-items: stretch;
    }

    .industry-chat-actions {
        grid-template-columns: 1fr;
    }

    .industry-dock {
        position: fixed;
        left: 50%;
        transform: translateX(-50%);
        bottom: 10px;
        width: min(410px, calc(100% - 18px));
        z-index: 30;
    }
}

.drawer-open {
    overflow: hidden;
}

.menu-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 48px;
    height: 48px;
    border: 1px solid rgba(31, 26, 21, 0.12);
    border-radius: 16px;
    background: #ffffff;
    box-shadow: 0 12px 30px rgba(15, 23, 42, 0.08);
    cursor: pointer;
    padding: 0;
}

.menu-toggle span {
    display: block;
    width: 18px;
    height: 2px;
    margin: 4px auto;
    border-radius: 999px;
    background: var(--text);
}

.drawer-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(17, 14, 11, 0.42);
    backdrop-filter: blur(8px);
    z-index: 50;
}

.site-drawer {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    width: min(380px, calc(100% - 28px));
    padding: 22px;
    background: #ffffff;
    border-left: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: -24px 0 60px rgba(15, 23, 42, 0.12);
    transform: translateX(105%);
    transition: transform 0.24s ease;
    z-index: 60;
}

.site-drawer.is-open {
    transform: translateX(0);
}

.drawer-head,
.drawer-links,
.explorer-card-head,
.explorer-card-actions,
.search-shell-tools,
.location-strip,
.section-header-wide {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
}

.drawer-head {
    align-items: flex-start;
    margin-bottom: 16px;
}

.drawer-close {
    width: 40px;
    height: 40px;
    border: 0;
    border-radius: 12px;
    background: rgba(31, 26, 21, 0.06);
    color: var(--text);
    font-size: 1.4rem;
    cursor: pointer;
}

.drawer-copy {
    color: var(--muted);
    line-height: 1.6;
    margin-bottom: 20px;
}

.drawer-section {
    display: grid;
    gap: 12px;
    margin-top: 18px;
    padding-top: 18px;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
}

.drawer-mini-links {
    display: grid;
    gap: 10px;
}

.drawer-mini-links a {
    display: flex;
    align-items: center;
    min-height: 44px;
    padding: 0 14px;
    border-radius: 14px;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.08);
    color: #0f172a;
    font-weight: 700;
}

.drawer-address-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    padding: 14px;
    border-radius: 18px;
    background: #f8fafc;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.drawer-address-icon,
.drawer-social-row a {
    width: 40px;
    height: 40px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.drawer-address-icon svg,
.drawer-social-row a svg {
    width: 20px;
    height: 20px;
}

.drawer-address-lines {
    display: grid;
    gap: 3px;
}

.drawer-address-lines strong {
    font-size: 0.88rem;
    line-height: 1.4;
}

.drawer-social-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.drawer-links {
    display: grid;
    justify-content: stretch;
}

.drawer-links a,
.drawer-action {
    min-height: 48px;
}

.drawer-links a {
    display: flex;
    align-items: center;
    padding: 0 14px;
    border-radius: 14px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.drawer-form {
    margin: 0;
}

.drawer-action {
    width: 100%;
}

.assistant-nav-button {
    min-height: 48px;
    padding: 0 16px;
    border-radius: 16px;
    border: 1px solid rgba(11, 110, 79, 0.18);
    background: rgba(11, 110, 79, 0.08);
    color: #0b6e4f;
    font-weight: 700;
    cursor: pointer;
}

.platform-assistant-mobile-launcher {
    display: none;
}

.assistant-open {
    overflow: hidden;
}

.platform-assistant-backdrop {
    position: fixed;
    inset: 0;
    background: rgba(17, 14, 11, 0.46);
    backdrop-filter: blur(10px);
    z-index: 70;
}

.platform-assistant-sheet {
    position: fixed;
    right: 20px;
    bottom: 20px;
    width: min(430px, calc(100% - 24px));
    max-height: calc(100vh - 40px);
    padding: 18px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.98);
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 24px 80px rgba(15, 23, 42, 0.2);
    transform: translateY(112%);
    transition: transform 0.24s ease;
    z-index: 80;
    display: grid;
    grid-template-rows: auto auto auto minmax(0, 1fr) auto;
    gap: 14px;
    overflow: hidden;
}

.platform-assistant-sheet.is-open {
    transform: translateY(0);
}

.platform-assistant-head,
.platform-assistant-meta,
.platform-assistant-toolbar,
.platform-assistant-actions,
.platform-assistant-links {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.platform-assistant-head {
    align-items: flex-start;
}

.platform-assistant-head h2 {
    margin: 2px 0 4px;
}

.platform-assistant-head p {
    margin: 0;
    color: var(--muted);
    line-height: 1.55;
}

.platform-assistant-meta {
    flex-wrap: wrap;
}

.platform-assistant-area {
    min-height: 24px;
    padding: 2px 10px;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.06);
    color: var(--muted);
    font-size: 0.88rem;
}

.platform-assistant-chips {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.platform-assistant-chip {
    padding: 10px 12px;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #f8fafc;
    color: var(--text);
    font: inherit;
    cursor: pointer;
}

.platform-assistant-log {
    display: grid;
    gap: 12px;
    max-height: min(48vh, 430px);
    overflow-y: auto;
    padding-right: 4px;
    min-height: 0;
}

.platform-assistant-bubble {
    display: grid;
    gap: 8px;
    padding: 14px 16px;
    border-radius: 20px;
    max-width: 92%;
    line-height: 1.55;
}

.platform-assistant-bubble.assistant {
    justify-self: start;
    background: #f8fafc;
    color: var(--text);
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.platform-assistant-bubble.user {
    justify-self: end;
    background: #0b6e4f;
    color: #ffffff;
}

.platform-assistant-links {
    justify-content: flex-start;
    flex-wrap: wrap;
}

.platform-assistant-link {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(11, 110, 79, 0.08);
    color: #0b6e4f;
    font-size: 0.9rem;
    font-weight: 700;
    text-decoration: none;
}

.platform-assistant-form {
    display: grid;
    gap: 12px;
}

.platform-assistant-footer {
    display: grid;
    gap: 12px;
    padding-top: 6px;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.78) 0%, #ffffff 34%);
}

.platform-assistant-form input[type="text"] {
    min-height: 52px;
    width: 100%;
}

.platform-assistant-actions {
    justify-content: flex-end;
}

@media (max-width: 820px) {
    .assistant-nav-button {
        display: none;
    }

    .platform-assistant-mobile-launcher {
        position: fixed;
        left: 50%;
        bottom: calc(env(safe-area-inset-bottom, 0px) + 72px);
        transform: translateX(-50%);
        z-index: 82;
        display: inline-flex;
        align-items: center;
        gap: 10px;
        min-height: 56px;
        padding: 0 18px 0 14px;
        border: 0;
        border-radius: 999px;
        background: linear-gradient(135deg, #0b6e4f 0%, #0f5132 100%);
        color: #ffffff;
        box-shadow: 0 18px 34px rgba(11, 110, 79, 0.28);
        font: inherit;
        font-weight: 800;
        cursor: pointer;
    }

    .platform-assistant-mobile-launcher-icon {
        width: 34px;
        height: 34px;
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.16);
        display: inline-flex;
        align-items: center;
        justify-content: center;
        font-size: 0.82rem;
        letter-spacing: 0.06em;
    }

    .assistant-open .platform-assistant-mobile-launcher {
        opacity: 0;
        pointer-events: none;
        transform: translateX(-50%) translateY(10px);
    }

    .platform-assistant-sheet {
        right: 12px;
        left: 12px;
        bottom: calc(env(safe-area-inset-bottom, 0px) + 84px);
        width: auto;
        max-height: calc(100vh - 112px - env(safe-area-inset-bottom, 0px));
        border-radius: 24px;
        padding-bottom: calc(14px + env(safe-area-inset-bottom, 0px));
    }

    .platform-assistant-actions {
        width: 100%;
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    .platform-assistant-actions .button {
        width: 100%;
    }

    .platform-assistant-footer {
        position: sticky;
        bottom: 0;
        margin: 0 -18px calc(-18px - env(safe-area-inset-bottom, 0px));
        padding: 10px 18px calc(16px + env(safe-area-inset-bottom, 0px));
    }
}

.home-minimal-shell {
    display: grid;
    gap: 18px;
    padding: 14px 0 8px;
}

.home-minimal-shell-pro {
    gap: 22px;
    padding: 10px 0 2px;
}

.home-desktop-search {
    display: block;
}

body.home-mobile-sheet-open {
    overflow: hidden;
}

.home-mobile-dock,
.home-mobile-sheet,
.home-mobile-sheet-backdrop {
    display: none;
}

.home-mobile-dock {
    position: fixed;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 96;
    width: 100%;
    max-width: none;
    transform: none;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 0;
    padding: 4px 8px calc(4px + env(safe-area-inset-bottom));
    background: #ffffff;
    border-top: 1px solid rgba(15, 23, 42, 0.1);
    box-shadow: 0 -8px 24px rgba(15, 23, 42, 0.08);
}

.home-mobile-dock-link {
    min-width: 0;
    min-height: 48px;
    border: 0;
    border-radius: 0;
    background: transparent;
    display: grid;
    justify-items: center;
    align-content: center;
    gap: 2px;
    padding: 5px 2px 4px;
    color: #667085;
    font: inherit;
    font-size: 0.66rem;
    font-weight: 700;
    cursor: pointer;
    position: relative;
}

.home-mobile-dock-link.is-active,
.home-mobile-dock-link:hover,
.home-mobile-dock-link:focus-visible {
    background: transparent;
    color: #111827;
    outline: none;
}

.home-mobile-dock-link.is-active::before,
.home-mobile-dock-link:hover::before,
.home-mobile-dock-link:focus-visible::before {
    content: "";
    position: absolute;
    top: -4px;
    left: 18%;
    right: 18%;
    height: 3px;
    border-radius: 0 0 999px 999px;
    background: #111827;
}

.home-mobile-dock-button {
    appearance: none;
}

.home-mobile-dock-icon,
.home-mobile-shortcut-icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.home-mobile-dock-icon svg,
.home-mobile-shortcut-icon svg {
    width: 100%;
    height: 100%;
    display: block;
}

.home-mobile-sheet-backdrop {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    bottom: calc(57px + env(safe-area-inset-bottom));
    z-index: 80;
    background: rgba(15, 23, 42, 0.14);
    backdrop-filter: blur(2px);
}

.home-mobile-sheet {
    position: fixed;
    inset: 0 0 calc(57px + env(safe-area-inset-bottom)) 0;
    z-index: 90;
    padding: 0;
}

.home-mobile-sheet-card {
    width: 100%;
    height: 100%;
    margin: 0;
    border-radius: 0;
    background: #ffffff;
    border: 0;
    box-shadow: none;
    transform: translateY(16px);
    opacity: 0;
    transition: transform 0.2s ease, opacity 0.2s ease;
}

.home-mobile-sheet.is-open .home-mobile-sheet-card {
    transform: translateY(0);
    opacity: 1;
}

.home-mobile-sheet-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    padding: 14px 16px 10px;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.home-mobile-sheet-head h2 {
    margin: 0;
    font-size: 1.02rem;
}

.home-mobile-sheet-close {
    width: 36px;
    height: 36px;
    border: 0;
    border-radius: 999px;
    background: #f3f4f6;
    color: #111827;
    font-size: 1.35rem;
    line-height: 1;
    cursor: pointer;
}

.home-mobile-sheet-body {
    padding: 12px 16px 16px;
}

.home-mobile-search-body {
    padding: 0;
    height: calc(100% - 61px);
}

.home-mobile-search-form {
    display: grid;
    grid-template-rows: auto auto auto 1fr;
    gap: 12px;
    min-height: 100%;
    padding: 14px 16px 0;
}

.home-mobile-search-stack {
    grid-template-columns: 1fr;
    gap: 10px;
}

.home-mobile-search-tools {
    display: grid;
    grid-template-columns: 1fr;
    gap: 10px;
}

.home-mobile-search-tools .button,
.home-mobile-search-tools .exact-toggle,
.home-mobile-search-form .search-submit {
    width: 100%;
}

.home-mobile-search-hint {
    margin: -2px 0 0;
    color: #6b7280;
    font-size: 0.88rem;
    line-height: 1.45;
}

.home-mobile-suggestions {
    position: static;
    left: auto;
    right: auto;
    top: auto;
    box-shadow: none;
    padding: 10px 0 calc(14px + env(safe-area-inset-bottom));
    border: 0;
    border-radius: 0;
    display: grid;
    align-content: start;
    gap: 12px;
    overflow: auto;
}

.home-mobile-shortcut-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.home-mobile-shortcut,
.home-mobile-shortcut-button {
    min-width: 0;
    border: 0;
    border-radius: 22px;
    background: #f8fafc;
    padding: 14px 12px;
    display: grid;
    justify-items: start;
    gap: 10px;
    font: inherit;
    color: #111827;
    font-weight: 700;
}

.home-mobile-shortcut-form {
    margin: 0;
}

.home-mobile-shortcut-button {
    width: 100%;
    cursor: pointer;
}

.home-mobile-shortcut-icon {
    width: 28px;
    height: 28px;
    padding: 5px;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

@media (max-width: 760px) {
    .home-mobile-nav-page main {
        padding-bottom: 74px;
    }

    .home-desktop-search {
        display: none;
    }

    .home-minimal-shell-pro {
        padding-top: 2px;
        gap: 10px;
    }

    .home-mobile-dock {
        display: grid;
    }

    .home-mobile-sheet-backdrop:not([hidden]),
    .home-mobile-sheet:not([hidden]) {
        display: block;
    }

    .directory-results-plain {
        margin-top: 0;
    }
}

@media (max-width: 420px) {
    .home-mobile-sheet-head {
        padding-inline: 14px;
    }

    .home-mobile-search-form {
        padding-inline: 14px;
    }

    .home-mobile-shortcut-grid {
        grid-template-columns: 1fr 1fr;
        gap: 10px;
    }
}

.home-minimal-copy {
    display: grid;
    gap: 10px;
    max-width: 780px;
}

.home-minimal-copy h1 {
    margin: 0;
    font-size: clamp(2.2rem, 4vw, 3.9rem);
    line-height: 0.94;
}

.home-minimal-copy p {
    margin: 0;
    color: var(--muted);
    line-height: 1.7;
}

.explorer-hero {
    position: relative;
    min-height: 72vh;
    padding: 26px 0 20px;
    border-radius: 36px;
    overflow: clip;
    background:
        radial-gradient(circle at 12% 14%, rgba(219, 90, 66, 0.28), transparent 26%),
        radial-gradient(circle at 82% 16%, rgba(17, 131, 96, 0.22), transparent 28%),
        linear-gradient(135deg, #0e1317 0%, #18242d 55%, #1f2d37 100%);
    box-shadow: 0 22px 80px rgba(15, 22, 28, 0.26);
}

.explorer-backdrop {
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(7, 10, 12, 0.68), rgba(12, 17, 23, 0.3)),
        radial-gradient(circle at 24% 72%, rgba(255, 255, 255, 0.08), transparent 20%);
    pointer-events: none;
}

.explorer-content {
    position: relative;
    z-index: 1;
    padding: 28px;
    display: grid;
    gap: 28px;
}

.explorer-copy {
    max-width: 760px;
    color: rgba(255, 255, 255, 0.94);
}

.explorer-copy .eyebrow,
.directory-results .eyebrow {
    color: #9be6c8;
}

.explorer-copy h1 {
    margin: 14px 0 16px;
    font-size: clamp(2.4rem, 5vw, 4.8rem);
    line-height: 0.92;
}

.explorer-copy p {
    max-width: 58ch;
    margin: 0;
    color: rgba(238, 244, 247, 0.8);
    line-height: 1.7;
}

.search-shell-card,
.location-strip,
.result-shell-note {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 30px;
    box-shadow: 0 18px 52px rgba(15, 23, 42, 0.06);
    backdrop-filter: none;
}

.search-shell-card {
    padding: 18px;
}

.search-shell-card-minimal {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.06);
}

.search-shell-card-pro {
    padding: 14px;
    border-radius: 34px;
    box-shadow: 0 28px 70px rgba(15, 23, 42, 0.06);
    transition: margin-bottom 0.18s ease;
}

.search-shell-card-pro.is-suggesting {
    z-index: 4;
}

.search-shell {
    position: relative;
    display: grid;
    gap: 14px;
}

.search-shell-minimal {
    gap: 16px;
}

.search-shell-main {
    display: grid;
    grid-template-columns: minmax(0, 1.4fr) minmax(240px, 0.9fr) auto;
    gap: 12px;
    align-items: stretch;
}

.search-shell-main-pro {
    grid-template-columns: minmax(0, 1.5fr) minmax(280px, 0.9fr) auto;
    gap: 10px;
}

.search-field {
    display: grid;
    gap: 8px;
    padding: 14px 16px;
    border-radius: 24px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
}

.search-field span {
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #667085;
}

.search-field input {
    border: 0;
    padding: 0;
    background: transparent;
    font-size: 1.08rem;
    font-weight: 600;
}

.search-field input:focus {
    outline: none;
}

.search-field input::placeholder {
    color: #98a2b3;
}

.search-submit {
    min-width: 132px;
    border: 0;
    border-radius: 24px;
    background: linear-gradient(180deg, #161616, #2f2f2f);
    color: white;
    font: inherit;
    font-weight: 800;
    cursor: pointer;
    box-shadow: 0 16px 26px rgba(20, 20, 20, 0.14);
}

.search-locate {
    white-space: nowrap;
}

.search-shell-tools-minimal {
    justify-content: flex-start;
}

.search-shell-tools-pro {
    gap: 12px;
}

.exact-toggle {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    min-height: 44px;
    padding: 0 14px;
    border-radius: 999px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    color: var(--muted);
    font-weight: 700;
}

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

.search-caption,
.section-caption,
.result-shell-note span,
.network-mini-stats span {
    color: var(--muted);
    line-height: 1.6;
}

.search-suggestions {
    position: absolute;
    left: 0;
    right: 0;
    top: calc(100% + 8px);
    z-index: 10;
    display: grid;
    gap: 16px;
    padding: 18px;
    border-radius: 26px;
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 24px 50px rgba(15, 23, 42, 0.1);
}

.search-suggestions-minimal {
    top: calc(100% + 4px);
    border-radius: 22px;
    background: #ffffff;
}

.search-suggestions-pro {
    gap: 12px;
    padding: 14px;
    border-radius: 28px;
    box-shadow: 0 24px 60px rgba(15, 23, 42, 0.1);
}

.suggestion-chip-row-pro {
    gap: 8px;
}

.suggestion-list-pro {
    gap: 8px;
}

.suggestion-list-inline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.suggestion-group {
    display: grid;
    gap: 10px;
}

.suggestion-label {
    font-size: 0.82rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: #786654;
}

.suggestion-chip-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.suggestion-chip-button,
.search-chip {
    display: inline-flex;
    align-items: center;
    min-height: 40px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(31, 26, 21, 0.08);
    background: rgba(255, 255, 255, 0.94);
    color: var(--text);
    font: inherit;
    font-weight: 700;
    cursor: pointer;
}

.search-chip-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.search-chip {
    color: var(--muted);
}

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

.suggestion-item {
    display: grid;
    gap: 4px;
    padding: 14px 16px;
    border-radius: 18px;
    border: 1px solid rgba(15, 23, 42, 0.07);
    background: #ffffff;
}

.suggestion-item span {
    color: var(--muted);
    font-size: 0.95rem;
}

.suggestion-item-kind {
    width: fit-content;
    min-height: 24px;
    padding: 0 10px;
    border-radius: 999px;
    font-size: 0.7rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.suggestion-item-business .suggestion-item-kind {
    background: rgba(11, 110, 79, 0.12);
    color: #0b6e4f;
}

.suggestion-item-listing .suggestion-item-kind {
    background: rgba(24, 119, 242, 0.12);
    color: #1877f2;
}

.suggestion-item-location {
    text-align: left;
    font: inherit;
    color: inherit;
    cursor: pointer;
}

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

.network-mini-stats {
    display: grid;
    justify-items: end;
    gap: 2px;
}

.network-mini-stats strong {
    font-size: 1.5rem;
}

.location-strip {
    margin: 22px 0 28px;
    padding: 18px 20px;
}

.location-strip-copy p {
    margin: 6px 0 0;
    color: var(--muted);
}

.location-strip-copy a {
    color: var(--accent);
    font-weight: 700;
}

.location-strip-actions {
    display: flex;
    gap: 12px;
    flex-wrap: wrap;
}

.home-ad-home-surface {
    margin-bottom: 30px;
}

.home-ad-inline-card .home-ad-stage {
    background: rgba(255, 255, 255, 0.92);
}

.directory-results {
    display: grid;
    gap: 18px;
}

.directory-results-plain {
    gap: 0;
    margin-top: 8px;
}

.section-header-minimal h2 {
    margin: 0;
}

.network-mini-stats-minimal {
    min-width: 150px;
}

.section-header-wide {
    align-items: flex-end;
}

.result-shell-note {
    max-width: 320px;
    padding: 16px 18px;
}

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

.directory-result-list-pro {
    gap: 16px;
}

.explorer-card {
    display: grid;
    gap: 20px;
    min-height: 360px;
    padding: 26px;
    background: #ffffff;
}

.explorer-card-minimal {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.05);
}

.explorer-card-pro {
    position: relative;
    isolation: isolate;
    overflow: hidden;
    border-radius: 30px;
    box-shadow: 0 22px 56px rgba(15, 23, 42, 0.06);
}

.explorer-card-pro::before {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(248, 250, 252, 0.9), rgba(255, 255, 255, 0.98) 28%);
    pointer-events: none;
    z-index: 0;
}

.explorer-card-pro > * {
    position: relative;
    z-index: 1;
}

.home-ad-inline-card-pro .home-ad-stage {
    padding: 0;
    background: transparent;
    border: 0;
}

.explorer-card-location,
.plan-meta {
    color: var(--muted);
}

.explorer-card-head {
    align-items: flex-start;
}

.explorer-card-brand {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 16px;
    align-items: center;
    min-width: 0;
}

.explorer-card-logo {
    width: 78px;
    height: 78px;
    border-radius: 24px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: linear-gradient(145deg, #f8fafc, #ffffff);
    box-shadow:
        inset 0 1px 0 rgba(255, 255, 255, 0.92),
        0 14px 28px rgba(15, 23, 42, 0.08);
    display: grid;
    place-items: center;
    overflow: hidden;
}

.explorer-card-logo span {
    font-size: 1.35rem;
    font-weight: 900;
    letter-spacing: 0.06em;
    color: var(--text);
}

.explorer-card-logo.has-image {
    padding: 10px;
    background: #ffffff;
}

.explorer-card-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
}

.explorer-card-titleblock,
.explorer-card-body,
.explorer-card-copy,
.explorer-card-meta,
.platform-story-grid {
    display: grid;
    gap: 16px;
}

.explorer-card-titleblock {
    gap: 8px;
    min-width: 0;
}

.explorer-card-pills {
    gap: 8px;
}

.explorer-card-aside {
    display: grid;
    justify-items: end;
    gap: 8px;
    text-align: right;
}

.platform-story-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.explorer-card-body {
    padding-top: 18px;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
    align-content: space-between;
    flex: 1;
}

.explorer-card-titleblock h3 {
    margin: 0;
    font-size: clamp(1.65rem, 2vw, 2rem);
    line-height: 0.98;
    letter-spacing: -0.03em;
}

.explorer-card-titleblock .headline {
    margin: 0;
    font-weight: 700;
    color: #475467;
}

.explorer-card-description {
    margin: 0;
    color: #475467;
    line-height: 1.72;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4;
    overflow: hidden;
}

.explorer-card-location {
    display: inline-flex;
    align-items: center;
    min-height: 36px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: #ffffff;
    font-weight: 700;
}

.explorer-card-actions {
    margin-top: auto;
    padding-top: 4px;
}

.explorer-card-post {
    gap: 14px;
    min-height: auto;
    padding: 18px;
}

.explorer-card-post-media {
    position: relative;
    display: block;
    overflow: hidden;
    aspect-ratio: 4 / 5;
    border-radius: 26px;
    background: linear-gradient(180deg, #eef2ff, #e2e8f0);
    text-decoration: none;
    color: inherit;
}

.explorer-card-post-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.explorer-card-post-media::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg, rgba(15, 23, 42, 0.06), rgba(15, 23, 42, 0.02) 42%, rgba(15, 23, 42, 0.28));
    pointer-events: none;
}

.explorer-card-post-fallback {
    width: 100%;
    height: 100%;
    display: grid;
    place-items: center;
    background:
        radial-gradient(circle at top left, rgba(16, 185, 129, 0.22), transparent 30%),
        radial-gradient(circle at bottom right, rgba(249, 115, 22, 0.18), transparent 34%),
        linear-gradient(180deg, #f8fafc, #e2e8f0);
}

.explorer-card-post-fallback-logo {
    width: min(42%, 168px);
    aspect-ratio: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 18px;
    border-radius: 28px;
    background: rgba(255, 255, 255, 0.94);
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.12);
}

.explorer-card-post-fallback-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.explorer-card-post-fallback-mark {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 136px;
    min-height: 136px;
    padding: 18px;
    border-radius: 36px;
    background: rgba(17, 24, 39, 0.9);
    color: #fff;
    font-size: 3rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.18);
}

.explorer-card-post-top,
.explorer-card-post-bottom {
    position: absolute;
    left: 14px;
    right: 14px;
    z-index: 1;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
}

.explorer-card-post-top {
    top: 14px;
}

.explorer-card-post-bottom {
    bottom: 14px;
}

.explorer-card-post-location {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.92);
    color: #111827;
    font-size: 0.78rem;
    font-weight: 800;
    box-shadow: 0 8px 18px rgba(15, 23, 42, 0.12);
}

.explorer-card-post-body {
    display: grid;
    gap: 12px;
}

.explorer-card-post-brandline {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    align-items: center;
    min-width: 0;
}

.explorer-card-post-avatar {
    width: 48px;
    height: 48px;
    border-radius: 16px;
    display: grid;
    place-items: center;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background: linear-gradient(145deg, #f8fafc, #ffffff);
    box-shadow: 0 10px 22px rgba(15, 23, 42, 0.08);
}

.explorer-card-post-avatar.has-image {
    padding: 8px;
}

.explorer-card-post-avatar img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}

.explorer-card-post-avatar span {
    font-size: 1rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    color: #111827;
}

.explorer-card-post-copy {
    display: grid;
    gap: 4px;
    min-width: 0;
}

.explorer-card-post-title {
    color: var(--text);
    text-decoration: none;
    font-size: 1.06rem;
    font-weight: 900;
    letter-spacing: -0.02em;
}

.explorer-card-post-copy p {
    margin: 0;
    color: #475467;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
    overflow: hidden;
}

.explorer-card-post-actions {
    display: flex;
    align-items: center;
}

.explorer-card-post-actions .button {
    width: 100%;
}

.home-reel-card {
    display: none;
}

.home-reel-logo {
    width: 54px;
    height: 54px;
    border-radius: 18px;
    overflow: hidden;
    border: 1px solid rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.14);
    backdrop-filter: blur(14px);
    flex: 0 0 auto;
}

.home-reel-logo img {
    width: 100%;
    height: 100%;
    object-fit: contain;
    display: block;
    padding: 8px;
}

.video-preview video {
    width: 100%;
    border-radius: 18px;
    display: block;
    background: #111;
}

.explorer-empty {
    padding: 34px;
}

.story-card-rich {
    min-height: 220px;
    background: #ffffff;
}

.home-directory-shell,
.info-hero,
.info-grid,
.info-stack {
    margin-bottom: 24px;
}

.home-directory-shell {
    display: grid;
    gap: 18px;
    padding: 18px 0 6px;
}

.home-directory-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    gap: 16px;
}

.home-directory-top h1,
.info-hero h1 {
    margin: 10px 0 0;
    font-size: clamp(2rem, 4vw, 3.3rem);
    line-height: 0.95;
}

.info-hero {
    display: grid;
    grid-template-columns: 1.6fr 0.8fr;
    gap: 20px;
    align-items: stretch;
}

.info-hero-copy,
.info-hero-panel,
.info-panel {
    background: var(--surface);
    border: 1px solid var(--surface-border);
    border-radius: var(--radius);
    box-shadow: var(--shadow);
    backdrop-filter: none;
}

.info-hero-copy,
.info-hero-panel,
.info-panel {
    padding: 26px;
}

.premium-hero .info-hero-copy {
    background: #ffffff;
}

.platform-hero .info-hero-copy {
    background: #ffffff;
}

.info-hero-copy p,
.info-panel p,
.feature-list li {
    color: var(--muted);
    line-height: 1.7;
}

.info-hero-panel {
    display: grid;
    align-content: center;
    gap: 12px;
    background: #ffffff;
}

.info-hero-panel strong {
    font-size: 1.25rem;
}

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

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

.feature-list {
    margin: 0;
    padding-left: 18px;
}

@media (max-width: 920px) {
    .site-header {
        flex-direction: row;
        gap: 12px;
        align-items: center;
    }

    .site-nav {
        display: none;
    }

    .site-header-tools {
        margin-left: auto;
    }

    .explorer-content {
        padding: 22px;
    }

    .search-shell-main,
    .search-shell-footer,
    .directory-result-list,
    .platform-story-grid,
    .info-grid,
    .info-stack {
        grid-template-columns: 1fr;
    }

    .network-mini-stats {
        justify-items: start;
    }
}

@media (max-width: 760px) {
    .menu-toggle {
        display: none;
    }

    body.has-public-mobile-dock main {
        padding-bottom: 92px;
    }
}

@media (max-width: 720px) {
    .explorer-hero {
        min-height: auto;
        border-radius: 28px;
    }

    .info-hero,
    .explorer-content,
    .search-shell-card,
    .location-strip,
    .explorer-card {
        grid-template-columns: 1fr;
    }

    .home-directory-top,
    .search-shell-tools,
    .location-strip,
    .section-header-wide,
    .explorer-card-head,
    .explorer-card-actions {
        flex-direction: column;
        align-items: stretch;
    }

    .search-shell-card,
    .location-strip,
    .explorer-card,
    .info-hero-copy,
    .info-hero-panel,
    .info-panel {
        padding: 18px;
    }

    .search-shell-main {
        grid-template-columns: 1fr;
    }

    .search-submit {
        min-height: 54px;
    }

    .directory-result-list {
        scroll-snap-type: y proximity;
    }

    .explorer-card {
        min-height: calc(100svh - 130px);
        scroll-snap-align: start;
    }

    .explorer-card.explorer-card-post:not(.explorer-card-has-reel) {
        min-height: auto;
        padding: 12px;
        border-radius: 20px;
    }

    .explorer-card-has-reel {
        position: relative;
        padding: 0;
        overflow: hidden;
        background: #111;
        border: 0;
        box-shadow: 0 18px 40px rgba(12, 12, 12, 0.18);
    }

    .explorer-card-has-reel .explorer-card-head,
    .explorer-card-has-reel .explorer-card-body,
    .explorer-card-has-reel .explorer-card-actions,
    .explorer-card-has-reel .explorer-card-post-media,
    .explorer-card-has-reel .explorer-card-post-body {
        display: none;
    }

    .home-reel-card {
        position: relative;
        min-height: calc(100svh - 130px);
        display: grid;
        text-decoration: none;
        color: #fff;
        isolation: isolate;
    }

    .home-reel-video,
    .home-reel-overlay,
    .home-reel-content {
        grid-area: 1 / 1;
    }

    .home-reel-video {
        width: 100%;
        height: 100%;
        object-fit: cover;
        background: #111;
    }

    .home-reel-overlay {
        background:
            linear-gradient(180deg, rgba(6, 6, 6, 0.12), rgba(6, 6, 6, 0.2) 32%, rgba(6, 6, 6, 0.78));
        z-index: 1;
    }

    .home-reel-content {
        position: relative;
        z-index: 2;
        display: grid;
        align-content: space-between;
        min-height: inherit;
        padding: 16px;
    }

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

    .home-reel-bottom {
        display: grid;
        gap: 8px;
        align-content: end;
    }

    .home-reel-location {
        font-size: 0.92rem;
        color: rgba(255, 255, 255, 0.82);
    }

    .home-reel-bottom h3 {
        margin: 0;
        font-size: 2rem;
        line-height: 0.98;
    }

    .home-reel-bottom .headline {
        margin: 0;
        font-size: 1rem;
        color: rgba(255, 255, 255, 0.92);
    }

    .home-reel-cta {
        justify-self: start;
        display: inline-flex;
        align-items: center;
        border-radius: 999px;
        padding: 10px 16px;
        background: rgba(255, 255, 255, 0.16);
        border: 1px solid rgba(255, 255, 255, 0.22);
        backdrop-filter: blur(12px);
        font-weight: 700;
    }

    .explorer-card-titleblock h3 {
        font-size: 1.55rem;
    }

    .explorer-card-post-media {
        aspect-ratio: 1 / 1.16;
        border-radius: 18px;
    }

    .explorer-card-post-top,
    .explorer-card-post-bottom {
        left: 10px;
        right: 10px;
    }

    .explorer-card-post-location {
        min-height: 28px;
        padding: 0 10px;
        font-size: 0.72rem;
    }

    .explorer-card-post-brandline {
        grid-template-columns: 42px minmax(0, 1fr);
        gap: 10px;
    }

    .explorer-card-post-avatar {
        width: 42px;
        height: 42px;
        border-radius: 13px;
    }

    .explorer-card-post-title {
        font-size: 0.94rem;
    }

    .explorer-card-post-copy p {
        font-size: 0.8rem;
    }

    .explorer-card-post-actions .button {
        min-height: 42px;
        padding-inline: 14px;
    }

    .explorer-card-brand {
        grid-template-columns: 68px minmax(0, 1fr);
        align-items: start;
    }

    .explorer-card-logo {
        width: 68px;
        height: 68px;
        border-radius: 20px;
    }

    .explorer-card-aside {
        justify-items: start;
        text-align: left;
    }

    .home-minimal-copy h1 {
        font-size: 2rem;
    }

    .site-header {
        gap: 10px;
    }

    .language-toggle a {
        min-width: 36px;
    }

    .brand img {
        height: 30px;
    }

    .brand-drawer img {
        height: 28px;
    }
}

.market-shell {
    display: grid;
    gap: 1.5rem;
}

.market-main,
.market-side,
.market-detail-main,
.market-detail-side,
.market-copy,
.market-card-body,
.market-detail-copy {
    min-width: 0;
}

.market-hero {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 1rem;
    padding-top: 0.5rem;
}

.market-copy h1 {
    margin: 0.15rem 0 0.35rem;
    font-size: clamp(2rem, 5vw, 3.6rem);
}

.market-copy p {
    max-width: 44rem;
    color: #5b5248;
}

.market-search-card,
.market-detail-card,
.market-map-card {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    border-radius: 1.75rem;
    box-shadow: 0 22px 46px rgba(15, 23, 42, 0.06);
}

.market-search-card {
    padding: 1.2rem;
}

.market-search-grid {
    display: grid;
    grid-template-columns: 2fr 1.1fr 1.25fr 0.65fr auto auto;
    gap: 0.9rem;
    align-items: end;
}

.search-field-radius {
    min-width: 110px;
}

.market-category-row {
    display: flex;
    gap: 0.65rem;
    overflow-x: auto;
    padding-top: 1rem;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.market-category-row::-webkit-scrollbar,
.market-quick-question-row::-webkit-scrollbar,
.market-thumb-row::-webkit-scrollbar,
.market-video-row::-webkit-scrollbar {
    display: none;
}

.market-category-chip {
    border: 1px solid rgba(17, 24, 39, 0.1);
    background: #fff;
    color: #1a1917;
    border-radius: 999px;
    padding: 0.72rem 1rem;
    font: inherit;
    white-space: nowrap;
    cursor: pointer;
}

.market-category-chip.is-active {
    background: #171717;
    color: #fff;
    border-color: #171717;
}

.market-layout,
.market-detail-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.6fr) minmax(300px, 0.8fr);
    gap: 1.5rem;
}

.market-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: 1rem;
}

.market-card {
    display: block;
    color: inherit;
    text-decoration: none;
    background: #ffffff;
    border-radius: 1.5rem;
    overflow: hidden;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.06);
}

.market-card-media {
    position: relative;
    aspect-ratio: 1 / 1;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
}

.market-card-media img,
.market-thumb-row img,
.gallery-preview-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.market-card-fallback,
.market-detail-empty-cover {
    display: grid;
    place-items: center;
    width: 100%;
    height: 100%;
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: #171717;
    background: linear-gradient(135deg, #ffffff, #f8fafc);
}

.market-badge {
    position: absolute;
    top: 0.9rem;
    left: 0.9rem;
    border-radius: 999px;
    padding: 0.38rem 0.7rem;
    font-size: 0.78rem;
    font-weight: 700;
}

.market-badge.is-live {
    background: rgba(14, 116, 82, 0.12);
    color: #0f766e;
}

.market-badge.is-muted {
    background: rgba(120, 113, 108, 0.12);
    color: #57534e;
}

.market-card-body {
    padding: 1rem;
    display: grid;
    gap: 0.28rem;
}

.market-price {
    font-size: 1.15rem;
    font-weight: 800;
    color: #171717;
}

.market-price.hero {
    font-size: 1.6rem;
}

.market-card-body h3,
.market-detail-copy h1 {
    margin: 0;
    line-height: 1.05;
    overflow-wrap: anywhere;
}

.market-card-body p,
.market-detail-copy p {
    margin: 0;
    color: #5b5248;
}

.market-card-meta,
.market-seller-meta,
.market-detail-meta {
    display: flex;
    flex-wrap: wrap;
    gap: 0.55rem 1rem;
    color: #6b635b;
    font-size: 0.92rem;
}

.market-map-card {
    padding: 1rem;
    position: sticky;
    top: 1rem;
}

.market-map-card iframe {
    width: 100%;
    min-height: 280px;
    border: 0;
    border-radius: 1.2rem;
    margin-bottom: 0.85rem;
}

.market-map-placeholder {
    min-height: 220px;
    border-radius: 1.2rem;
    background: linear-gradient(180deg, #ffffff, #f8fafc);
    display: grid;
    place-items: center;
    text-align: center;
    padding: 1rem;
    margin-bottom: 0.85rem;
}

.market-detail-main {
    display: grid;
    gap: 1rem;
}

.market-detail-card {
    padding: 1rem;
}

.market-detail-gallery {
    display: grid;
    gap: 0.75rem;
}

.market-detail-cover {
    width: 100%;
    aspect-ratio: 1.2 / 1;
    border-radius: 1.2rem;
    object-fit: cover;
}

.market-thumb-row,
.market-video-row {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
    gap: 0.65rem;
}

.market-thumb-row img,
.market-video-row video {
    border-radius: 1rem;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    background: #111;
}

.market-detail-copy {
    display: grid;
    gap: 0.65rem;
    padding-top: 1rem;
}

.market-quick-question-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.6rem;
    margin: 1rem 0;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.market-question-chip {
    border: 1px solid rgba(17, 24, 39, 0.08);
    background: #f7f3ee;
    border-radius: 999px;
    padding: 0.72rem 0.95rem;
    font: inherit;
    cursor: pointer;
}

.market-distance {
    color: #0f766e;
    font-weight: 700;
}

@media (max-width: 1100px) {
    .market-search-grid,
    .market-layout,
    .market-detail-grid {
        grid-template-columns: 1fr;
    }

    .market-map-card {
        position: static;
    }
}

@media (max-width: 720px) {
    .market-shell {
        gap: 1rem;
    }

    .market-hero {
        flex-direction: column;
        align-items: start;
    }

    .market-copy h1 {
        font-size: clamp(1.85rem, 8vw, 2.45rem);
    }

    .market-copy p {
        font-size: 0.96rem;
    }

    .market-search-card,
    .market-detail-card,
    .market-map-card {
        border-radius: 1.3rem;
    }

    .market-search-grid {
        grid-template-columns: 1fr;
        gap: 0.75rem;
    }

    .market-search-grid > * {
        min-width: 0;
    }

    .market-search-grid .button,
    .market-search-grid .search-submit {
        width: 100%;
        min-width: 0;
    }

    .market-category-row {
        margin-inline: -0.1rem;
        padding-top: 0.8rem;
        padding-bottom: 0.2rem;
    }

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

    .market-card {
        border-radius: 1.25rem;
    }

    .market-card-media {
        aspect-ratio: 1.15 / 1;
    }

    .market-card-body {
        padding: 0.85rem;
        gap: 0.45rem;
    }

    .market-card-body h3 {
        font-size: 1.05rem;
    }

    .market-card-meta,
    .market-seller-meta,
    .market-detail-meta {
        display: grid;
        gap: 0.35rem;
        font-size: 0.88rem;
    }

    .market-detail-card {
        padding: 0.9rem;
    }

    .market-detail-cover {
        aspect-ratio: 1 / 1;
    }

    .market-thumb-row,
    .market-video-row {
        grid-auto-flow: column;
        grid-auto-columns: 68%;
        grid-template-columns: none;
        overflow-x: auto;
        padding-bottom: 0.2rem;
        scroll-snap-type: x proximity;
    }

    .market-thumb-row img,
    .market-video-row video {
        scroll-snap-align: start;
    }

    .market-detail-copy {
        gap: 0.8rem;
    }

    .market-detail-copy h1 {
        font-size: 1.75rem;
    }

    .market-quick-question-row {
        flex-wrap: nowrap;
        overflow-x: auto;
        padding-bottom: 0.25rem;
    }

    .market-question-chip {
        white-space: nowrap;
    }

    .market-detail-shell .hero-actions.compact,
    #market-form .hero-actions.compact,
    .market-form-shell .hero-actions.compact {
        display: grid;
        grid-template-columns: 1fr;
    }

    .market-detail-shell .hero-actions.compact .button,
    #market-form .hero-actions.compact .button,
    .market-form-shell .hero-actions.compact .button {
        width: 100%;
    }

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

    .analytics-strip {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 540px) {
    .market-search-card,
    .market-detail-card,
    .market-map-card {
        padding: 0.9rem;
    }

    .market-category-chip,
    .market-question-chip {
        padding: 0.68rem 0.9rem;
    }

    .market-card-body p,
    .market-card-meta {
        font-size: 0.85rem;
    }

    .market-thumb-row,
    .market-video-row {
        grid-auto-columns: 82%;
    }
}

.marketplace-page {
    background: #ffffff;
}

.marketplace-page .site-header,
.marketplace-page .drawer-backdrop,
.marketplace-page .site-drawer {
    display: none !important;
}

.marketplace-page main {
    padding: 14px 0 36px;
}

.marketplace-page .page-shell {
    width: min(1520px, calc(100% - 18px));
}

.marketplace-page .hero-actions.compact {
    gap: 10px;
}

.marketplace-page .hero-actions.compact .button {
    min-height: 44px;
}

.marketplace-app-shell {
    display: grid;
    gap: 14px;
}

.marketplace-topbar,
.marketplace-app-bar,
.marketplace-toolbar-card,
.marketplace-panel-card,
.marketplace-card,
.marketplace-summary-card,
.marketplace-stage-card,
.marketplace-empty-state,
.marketplace-modal-card,
.marketplace-editor-card {
    background: #ffffff;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 14px 38px rgba(15, 23, 42, 0.06);
}

.marketplace-topbar,
.marketplace-app-bar,
.marketplace-toolbar-card,
.marketplace-panel-card,
.marketplace-empty-state {
    border-radius: 24px;
}

.marketplace-topbar {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: center;
    padding: 14px 16px;
}

.marketplace-topbar-title,
.marketplace-app-branding {
    min-width: 0;
    display: grid;
    gap: 4px;
}

.marketplace-topbar-kicker,
.marketplace-app-kicker {
    display: inline-flex;
    align-items: center;
    width: fit-content;
    min-height: 28px;
    padding: 0 12px;
    border-radius: 999px;
    background: #f3f4f6;
    color: #111827;
    font-size: 0.78rem;
    font-weight: 700;
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

.marketplace-topbar-title h1,
.marketplace-app-branding h1 {
    margin: 0;
    font-size: clamp(1.8rem, 4vw, 2.45rem);
    line-height: 1.02;
}

.marketplace-topbar-title p,
.marketplace-app-branding p {
    margin: 0;
    color: #6b7280;
}

.marketplace-topbar-actions,
.marketplace-app-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    align-items: center;
    justify-content: flex-end;
}

.marketplace-topbar-iconlink,
.marketplace-app-link {
    min-width: 44px;
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 14px;
    border-radius: 999px;
    background: #f3f4f6;
    color: #111827;
    font-weight: 700;
}

.marketplace-topbar-iconlink svg {
    width: 18px;
    height: 18px;
}

.marketplace-topbar-primary {
    min-height: 46px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0 18px;
    border-radius: 999px;
    background: #1877f2;
    color: #ffffff;
    font-weight: 800;
}

.marketplace-app-bar {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    align-items: flex-start;
    padding: 14px 16px;
}

.marketplace-toolbar-card {
    position: sticky;
    top: 10px;
    z-index: 25;
    padding: 14px;
}

.marketplace-toolbar {
    display: grid;
    gap: 12px;
}

.marketplace-toolbar-main,
.marketplace-toolbar-utility {
    display: grid;
    gap: 10px;
    align-items: end;
}

.marketplace-toolbar-main-market {
    grid-template-columns: minmax(0, 1.8fr) minmax(230px, 1fr) auto;
}

.marketplace-toolbar-utility-market {
    grid-template-columns: minmax(180px, 1fr) 120px auto auto auto;
}

.marketplace-inline-field {
    display: grid;
    gap: 6px;
}

.marketplace-inline-field span {
    font-size: 0.74rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #6b7280;
}

.marketplace-inline-field input,
.marketplace-inline-field select {
    min-height: 52px;
    border-radius: 16px;
    border: 1px solid rgba(15, 23, 42, 0.1);
    background: #ffffff;
    padding: 0 14px;
    font: inherit;
}

.marketplace-inline-field input:focus,
.marketplace-inline-field select:focus {
    outline: none;
    border-color: rgba(24, 119, 242, 0.45);
    box-shadow: 0 0 0 4px rgba(24, 119, 242, 0.08);
}

.marketplace-search-field-shell {
    position: relative;
}

.marketplace-search-field-shell input {
    padding-left: 46px;
}

.marketplace-field-icon {
    position: absolute;
    left: 16px;
    bottom: 16px;
    width: 18px;
    height: 18px;
    color: #6b7280;
}

.marketplace-field-icon svg {
    width: 18px;
    height: 18px;
}

.marketplace-submit {
    min-width: 126px;
    min-height: 52px;
    background: #1877f2;
}

.marketplace-category-row {
    display: flex;
    gap: 10px;
    overflow-x: auto;
    padding-top: 2px;
    scrollbar-width: none;
    -ms-overflow-style: none;
}

.marketplace-category-row::-webkit-scrollbar {
    display: none;
}

.market-category-chip {
    border: 1px solid rgba(17, 24, 39, 0.1);
    background: #fff;
    color: #1a1917;
    border-radius: 999px;
    padding: 0.72rem 1rem;
    font: inherit;
    white-space: nowrap;
    cursor: pointer;
}

.market-category-chip.is-active {
    background: #111827;
    color: #fff;
    border-color: #111827;
}

.marketplace-layout {
    display: grid;
    grid-template-columns: 250px minmax(0, 1fr) 320px;
    gap: 14px;
    align-items: start;
}

.marketplace-filter-rail,
.marketplace-map-rail {
    min-width: 0;
}

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

.marketplace-panel-card-sticky,
.marketplace-map-desktop-card {
    position: sticky;
    top: 112px;
}

.marketplace-panel-head {
    display: grid;
    gap: 4px;
    margin-bottom: 14px;
}

.marketplace-panel-head h2 {
    margin: 0;
    font-size: 1.18rem;
}

.marketplace-filter-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px;
}

.marketplace-filter-pill {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: #f3f4f6;
    color: #374151;
    font-size: 0.84rem;
    font-weight: 700;
}

.marketplace-filter-links {
    display: grid;
    gap: 6px;
}

.marketplace-filter-link {
    width: 100%;
    border: 0;
    background: transparent;
    color: #111827;
    font: inherit;
    text-align: left;
    padding: 10px 12px;
    border-radius: 14px;
    cursor: pointer;
}

.marketplace-filter-link:hover,
.marketplace-filter-link.is-active {
    background: #f3f4f6;
}

.marketplace-feed {
    min-width: 0;
    display: grid;
    gap: 14px;
}

.marketplace-list-head {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: end;
}

.marketplace-list-head h2 {
    margin: 4px 0;
    font-size: 1.55rem;
    line-height: 1.05;
}

.marketplace-list-head p {
    margin: 0;
    color: #6b7280;
}

.marketplace-list-head-actions {
    display: flex;
    gap: 10px;
    align-items: center;
}

.mobile-only {
    display: none;
}

.marketplace-grid {
    grid-template-columns: repeat(auto-fill, minmax(196px, 1fr));
    gap: 12px;
}

.marketplace-card {
    border-radius: 18px;
    overflow: hidden;
}

.marketplace-card-media {
    position: relative;
    aspect-ratio: 0.96 / 1;
}

.marketplace-card-body {
    padding: 10px 11px 12px;
    gap: 4px;
}

.marketplace-card-price-row {
    display: flex;
    justify-content: space-between;
    gap: 8px;
    align-items: center;
}

.marketplace-card .market-price {
    font-size: 1.18rem;
    line-height: 1.05;
}

.marketplace-card h3 {
    font-size: 0.95rem;
    line-height: 1.28;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.marketplace-card-location {
    font-size: 0.84rem;
    color: #4b5563;
}

.marketplace-card-meta,
.marketplace-card-submeta {
    display: flex;
    flex-wrap: wrap;
    gap: 4px 8px;
    font-size: 0.76rem;
    color: #6b7280;
}

.marketplace-card-corner {
    position: absolute;
    top: 10px;
    right: 10px;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(15, 23, 42, 0.82);
    color: #ffffff;
    font-size: 0.76rem;
    font-weight: 700;
}

.marketplace-empty-state {
    padding: 26px;
}

.marketplace-empty-state .button {
    margin-top: 8px;
}

.marketplace-map-desktop-card iframe,
.marketplace-modal-card iframe {
    min-height: 340px;
}

.marketplace-location-note-card {
    display: grid;
    gap: 10px;
}

.marketplace-location-note-copy,
.marketplace-location-note-meta {
    margin: 0;
}

.marketplace-location-note-copy {
    color: #111827;
    font-weight: 700;
}

.marketplace-location-note-meta {
    color: #6b7280;
    font-size: 0.9rem;
    line-height: 1.5;
}

.marketplace-location-link {
    width: fit-content;
}

.marketplace-mobile-location-card {
    display: none;
}

.marketplace-modal {
    position: fixed;
    inset: 0;
    z-index: 80;
}

.marketplace-modal-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(17, 24, 39, 0.52);
    backdrop-filter: blur(4px);
}

.marketplace-modal-panel {
    position: relative;
    z-index: 1;
    width: min(560px, calc(100% - 20px));
    margin: 24px auto;
    background: #ffffff;
    border-radius: 24px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    box-shadow: 0 28px 90px rgba(15, 23, 42, 0.22);
    padding: 16px;
}

.marketplace-filter-modal-panel {
    width: min(520px, calc(100% - 20px));
}

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

.marketplace-modal-head h2 {
    margin: 4px 0 0;
    font-size: 1.2rem;
}

.marketplace-modal-close {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    border: 0;
    background: #f3f4f6;
    color: #111827;
    font-size: 1.6rem;
    cursor: pointer;
}

.marketplace-modal-card {
    border-radius: 18px;
    box-shadow: none;
    padding: 0;
}

.marketplace-modal-card-padded {
    padding: 16px;
}

.marketplace-modal-open {
    overflow: hidden;
}

.marketplace-detail-overview {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) minmax(320px, 0.8fr);
    gap: 16px;
    align-items: start;
}

.marketplace-stage-card,
.marketplace-summary-card {
    border-radius: 24px;
    padding: 16px;
}

.marketplace-summary-card h2 {
    margin: 0;
    font-size: clamp(1.6rem, 3vw, 2.3rem);
    line-height: 1.06;
}

.marketplace-summary-actions {
    margin-top: 4px;
}

.marketplace-detail-grid-modern {
    grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr);
}

.marketplace-form-shell .marketplace-app-branding h1 {
    font-size: clamp(1.7rem, 4vw, 2.3rem);
}

.marketplace-editor-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.18fr) minmax(280px, 0.82fr);
    gap: 16px;
    align-items: start;
}

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

.marketplace-editor-side {
    display: grid;
    gap: 16px;
}

.marketplace-editor-card {
    border-radius: 24px;
}

.marketplace-scan-card {
    display: grid;
    gap: 14px;
    padding: 18px;
    border-radius: 24px;
    border: 1px solid rgba(15, 23, 42, 0.08);
    background:
        linear-gradient(180deg, rgba(248, 250, 252, 0.96), rgba(255, 255, 255, 0.98)),
        rgba(255, 255, 255, 0.98);
    box-shadow: 0 18px 44px rgba(15, 23, 42, 0.08);
}

.marketplace-scan-card p {
    margin: 0;
    color: var(--muted);
    line-height: 1.65;
}

.marketplace-form-divider {
    margin: 24px 0;
    border: 0;
    border-top: 1px solid rgba(15, 23, 42, 0.08);
}

@media (max-width: 1380px) {
    .marketplace-layout {
        grid-template-columns: 228px minmax(0, 1fr) 300px;
    }

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

@media (max-width: 1080px) {
    .marketplace-layout {
        grid-template-columns: 220px minmax(0, 1fr);
    }

    .marketplace-map-rail {
        display: none;
    }

    .marketplace-detail-overview,
    .marketplace-detail-grid-modern,
    .marketplace-editor-grid {
        grid-template-columns: 1fr;
    }

    .marketplace-mobile-location-card {
        display: grid;
    }
}

@media (max-width: 760px) {
    .marketplace-page .page-shell {
        width: min(100%, calc(100% - 10px));
    }

    .marketplace-page main {
        padding-top: 8px;
    }

    .marketplace-topbar {
        padding: 10px 12px;
        border-radius: 18px;
    }

    .marketplace-topbar-title h1 {
        font-size: 1.55rem;
    }

    .marketplace-topbar-title p {
        font-size: 0.84rem;
    }

    .marketplace-topbar-actions {
        gap: 8px;
    }

    .marketplace-topbar-iconlink {
        min-width: 40px;
        min-height: 40px;
        padding: 0 12px;
    }

    .marketplace-topbar-primary {
        min-height: 40px;
        padding-inline: 14px;
        font-size: 0.9rem;
    }

    .marketplace-app-bar {
        flex-direction: column;
        align-items: stretch;
        gap: 12px;
    }

    .marketplace-app-actions {
        justify-content: flex-start;
    }

    .marketplace-app-link,
    .marketplace-app-actions .button {
        min-height: 40px;
        padding-inline: 14px;
    }

    .marketplace-toolbar-card {
        top: 6px;
        padding: 10px;
        border-radius: 18px;
    }

    .marketplace-toolbar-main-market,
    .marketplace-toolbar-utility-market {
        grid-template-columns: 1fr;
    }

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

    .marketplace-filter-rail {
        display: none;
    }

    .marketplace-list-head {
        align-items: center;
    }

    .mobile-only {
        display: inline-flex;
    }

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

    .marketplace-card {
        border-radius: 14px;
    }

    .marketplace-card-media {
        aspect-ratio: 0.88 / 1;
    }

    .marketplace-card-body {
        padding: 8px 9px 10px;
        gap: 3px;
    }

    .marketplace-card .market-price {
        font-size: 1rem;
    }

    .marketplace-card h3 {
        font-size: 0.84rem;
    }

    .marketplace-card-location,
    .marketplace-card-meta,
    .marketplace-card-submeta {
        font-size: 0.7rem;
    }

    .marketplace-card-corner,
    .market-badge {
        font-size: 0.68rem;
        min-height: 24px;
        padding-inline: 8px;
    }

    .marketplace-stage-card,
    .marketplace-summary-card,
    .marketplace-editor-card,
    .marketplace-panel-card,
    .marketplace-empty-state {
        border-radius: 18px;
        padding: 12px;
    }

    .marketplace-scan-card {
        padding: 14px;
        border-radius: 18px;
    }

    .marketplace-form-divider {
        margin: 18px 0;
    }

    .marketplace-modal-panel {
        width: min(100%, calc(100% - 10px));
        margin: auto 5px 8px;
        border-radius: 18px 18px 0 0;
        padding: 12px;
    }

    .marketplace-modal {
        display: grid;
        align-items: end;
    }

    .marketplace-modal-card iframe {
        min-height: 68vh;
    }

    .marketplace-location-link {
        width: 100%;
    }
}

@media (max-width: 420px) {
    .marketplace-topbar-title h1 {
        font-size: 1.4rem;
    }

    .marketplace-topbar-primary {
        padding-inline: 12px;
        font-size: 0.84rem;
    }

    .marketplace-grid {
        gap: 7px;
    }

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

    .marketplace-card .market-price {
        font-size: 0.96rem;
    }

    .marketplace-card h3 {
        font-size: 0.8rem;
    }

    .marketplace-card-location,
    .marketplace-card-meta,
    .marketplace-card-submeta {
        font-size: 0.68rem;
    }
}

.admin-hero {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 18px;
}

.admin-hero-copy {
    display: grid;
    gap: 8px;
}

.admin-hero-copy h1 {
    margin: 0;
}

.admin-hero-copy p {
    margin: 0;
    max-width: 72ch;
    color: #5b6474;
}

.admin-hero-actions {
    margin-top: 0;
}

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

.admin-nav-link {
    display: grid;
    gap: 6px;
    padding: 16px;
    border-radius: 20px;
    border: 1px solid #dce3ef;
    background: linear-gradient(180deg, #ffffff, #f8fbff);
    color: #162033;
    text-decoration: none;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.05);
    transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.admin-nav-link:hover {
    transform: translateY(-2px);
    border-color: #bfd2ef;
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}

.admin-nav-link strong {
    font-size: 0.98rem;
}

.admin-nav-link small {
    color: #5b6474;
    font-size: 0.78rem;
}

.admin-nav-link.is-alert {
    border-color: #f3c8c8;
    background: linear-gradient(180deg, #fff8f8, #fff1f1);
}

.admin-nav-icon,
.admin-stat-icon,
.admin-section-icon,
.admin-toolbar-icon,
.admin-action-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.admin-nav-icon,
.admin-stat-icon,
.admin-section-icon,
.admin-toolbar-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: #edf4ff;
    color: #1d4ed8;
}

.admin-nav-icon svg,
.admin-stat-icon svg,
.admin-section-icon svg,
.admin-toolbar-icon svg,
.admin-action-icon svg,
.admin-button-with-icon svg {
    width: 18px;
    height: 18px;
}

.admin-button-with-icon {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}

.admin-button-with-icon.is-active {
    border-color: #bfd2ef;
    background: #eef5ff;
}

.admin-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: 18px;
    margin-bottom: 24px;
}

.admin-stat-card {
    display: grid;
    gap: 10px;
}

.admin-stat-card h2 {
    margin: 0;
    font-size: 2rem;
}

.admin-stat-card p {
    margin: 0;
}

.admin-stat-head {
    display: flex;
    align-items: center;
    gap: 12px;
}

.admin-section-shell {
    display: grid;
    gap: 18px;
    margin-bottom: 28px;
    padding: 22px;
    border-radius: 28px;
    background: linear-gradient(180deg, rgba(255, 255, 255, 0.98), rgba(247, 250, 255, 0.98));
    border: 1px solid #dde5f1;
    box-shadow: 0 12px 28px rgba(15, 23, 42, 0.05);
}

.admin-section-header {
    margin: 0;
}

.admin-section-title {
    display: flex;
    align-items: flex-start;
    gap: 14px;
}

.admin-section-title h2 {
    margin: 0;
}

.admin-section-title p {
    margin: 4px 0 0;
    color: #5b6474;
}

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

.admin-toolbar-card {
    display: grid;
    gap: 14px;
}

.admin-toolbar-head,
.admin-card-title,
.admin-action-group-head {
    display: flex;
    align-items: flex-start;
    gap: 12px;
}

.admin-toolbar-head h3,
.admin-card-title h3,
.admin-action-group-head h4 {
    margin: 0;
}

.admin-toolbar-head p,
.admin-card-title p,
.admin-action-group-head p {
    margin: 4px 0 0;
    color: #5b6474;
    font-size: 0.86rem;
}

.admin-toolbar-metric {
    font-size: 2rem;
    line-height: 1;
    font-weight: 800;
    color: #162033;
}

.admin-process-list {
    margin: 0;
    padding-left: 18px;
    color: #314056;
    display: grid;
    gap: 10px;
}

.admin-block {
    gap: 18px;
}

.admin-filter-shell {
    gap: 16px;
}

.admin-filter-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
}

.admin-filter-head h3 {
    margin: 0;
}

.admin-filter-head p {
    margin: 4px 0 0;
}

.admin-settings-grid {
    align-items: start;
}

.admin-settings-group {
    display: grid;
    gap: 6px;
    padding: 16px 18px;
    border-radius: 18px;
    border: 1px solid #e4e9f2;
    background: #f8fbff;
}

.admin-settings-group h3,
.admin-settings-group p {
    margin: 0;
}

.admin-settings-group p {
    color: #5b6474;
    line-height: 1.55;
}

.admin-textarea-span,
.admin-actions-span {
    grid-column: 1 / -1;
}

.admin-item-card {
    display: grid;
    gap: 14px;
}

.admin-meta-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.admin-meta-grid span {
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: #f5f7fb;
    border: 1px solid #e4e9f2;
    color: #41506a;
    font-size: 0.78rem;
    font-weight: 700;
}

.admin-pill-row span {
    background: #eef4ff;
}

.admin-inline-actions {
    margin-top: 0;
}

.admin-inline-actions form,
.admin-subscription-form,
.admin-action-group {
    margin: 0;
}

.admin-card-actions {
    display: grid;
    gap: 12px;
}

.admin-action-group {
    display: grid;
    gap: 12px;
    padding: 14px;
    border-radius: 18px;
    border: 1px solid #e6ebf3;
    background: #fbfdff;
}

.admin-action-icon {
    width: 36px;
    height: 36px;
    border-radius: 12px;
    background: #f2f6ff;
    color: #1d4ed8;
}

.admin-subscription-form {
    display: grid;
    gap: 10px;
}

.admin-note-box {
    display: grid;
    gap: 6px;
    padding: 14px;
    border-radius: 16px;
    background: #f8fafc;
    border: 1px solid #e3e8ef;
}

.admin-note-box strong,
.admin-note-box p {
    margin: 0;
}

.admin-empty-state {
    min-height: 180px;
}

.admin-danger-button {
    border-color: #f0c9c9;
    color: #b42318;
    background: #fff7f7;
}

.admin-danger-button:hover {
    background: #ffecec;
}

.admin-claim-filter-bar {
    margin-top: 0;
}

@media (max-width: 1100px) {
    .admin-toolbar-grid {
        grid-template-columns: 1fr;
    }
}

@media (max-width: 980px) {
    .admin-hero,
    .admin-filter-head,
    .admin-section-header {
        flex-direction: column;
        align-items: stretch;
    }
}

@media (max-width: 640px) {
    .admin-section-shell {
        padding: 18px;
        border-radius: 22px;
    }

    .admin-nav-grid,
    .admin-stats-grid {
        grid-template-columns: 1fr;
    }

    .admin-section-title,
    .admin-toolbar-head,
    .admin-card-title,
    .admin-action-group-head {
        align-items: flex-start;
    }
}

.marketplace-index-page {
    background: #f0f2f5;
}

.marketplace-index-page main {
    width: 100%;
    max-width: none;
    padding: 0 0 96px;
    background: #f0f2f5;
}

.fb-marketplace {
    max-width: 1440px;
    margin: 0 auto;
    padding: 18px 18px 112px;
    color: #111827;
}

.fb-marketplace-route-form {
    display: none;
}

.desktop-only {
    display: inline-flex;
}

.mobile-only {
    display: none !important;
}

.fb-marketplace-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin-bottom: 14px;
}

.fb-marketplace-branding {
    display: grid;
    gap: 6px;
}

.fb-marketplace-brand-row {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
}

.fb-marketplace-brand-row h1 {
    margin: 0;
    font-size: 2rem;
    line-height: 1;
    font-weight: 800;
    letter-spacing: -0.04em;
    color: #111827;
}

.fb-marketplace-branding p {
    margin: 0;
    font-size: 0.96rem;
    color: #6b7280;
}

.fb-marketplace-location-pill {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 14px;
    border-radius: 999px;
    background: #e7f3ff;
    color: #1666d3;
    font-size: 0.84rem;
    font-weight: 700;
}

.fb-marketplace-header-actions {
    display: flex;
    align-items: center;
    gap: 10px;
}

.fb-icon-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border: 0;
    border-radius: 999px;
    background: #e4e6eb;
    color: #111827;
    cursor: pointer;
    text-decoration: none;
    transition: background-color 160ms ease, transform 160ms ease;
}

.fb-icon-button:hover {
    background: #d8dbe1;
}

.fb-icon-button svg {
    width: 20px;
    height: 20px;
}

.fb-marketplace-launch-row {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.fb-marketplace-search-launcher {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 58px;
    padding: 0 18px;
    border: 1px solid #d9dde5;
    border-radius: 18px;
    background: #fff;
    color: #111827;
    cursor: pointer;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.fb-marketplace-search-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #606770;
}

.fb-marketplace-search-icon svg {
    width: 20px;
    height: 20px;
}

.fb-marketplace-search-copy {
    display: grid;
    gap: 4px;
    text-align: left;
}

.fb-marketplace-search-copy strong {
    font-size: 1rem;
    font-weight: 700;
}

.fb-marketplace-search-copy span {
    font-size: 0.84rem;
    color: #6b7280;
}

.fb-marketplace-launch-chip,
.fb-marketplace-primary-action,
.fb-marketplace-panel-button,
.fb-marketplace-sidebar-search,
.fb-marketplace-shortcut,
.fb-marketplace-bottom-item,
.fb-marketplace-text-action,
.fb-marketplace-link-button {
    appearance: none;
    border: 0;
    text-decoration: none;
}

.fb-marketplace-launch-chip,
.fb-marketplace-panel-button,
.fb-marketplace-link-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 16px;
    border-radius: 12px;
    background: #fff;
    color: #111827;
    font-size: 0.9rem;
    font-weight: 700;
    border: 1px solid #d9dde5;
    cursor: pointer;
}

.fb-marketplace-primary-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 44px;
    padding: 0 18px;
    border-radius: 12px;
    background: #1877f2;
    color: #fff;
    font-size: 0.95rem;
    font-weight: 700;
    cursor: pointer;
}

.fb-marketplace-primary-action:hover {
    background: #1666d3;
}

.fb-marketplace-launch-chip-passive,
.fb-marketplace-panel-badge {
    cursor: default;
    color: #1666d3;
    background: #eef4ff;
    border-color: #cfe0ff;
}

.fb-marketplace-mobile-strip {
    display: none;
}

.fb-marketplace-search-context {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 16px;
    padding: 14px 16px;
    border: 1px solid #dde2ea;
    border-radius: 18px;
    background: #fff;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.fb-marketplace-search-context-copy {
    display: grid;
    gap: 4px;
}

.fb-marketplace-search-context-copy span {
    font-size: 0.76rem;
    font-weight: 800;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    color: #1877f2;
}

.fb-marketplace-search-context-copy strong {
    font-size: 1rem;
    font-weight: 800;
    color: #111827;
}

.fb-marketplace-search-context-copy small {
    font-size: 0.84rem;
    color: #6b7280;
}

.fb-marketplace-radius-picker {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.fb-marketplace-radius-picker.compact {
    justify-content: flex-start;
}

.fb-marketplace-radius-chip {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 36px;
    padding: 0 12px;
    border: 1px solid #d9dde5;
    border-radius: 999px;
    background: #fff;
    color: #475467;
    font-size: 0.8rem;
    font-weight: 700;
    cursor: pointer;
    transition: background-color 160ms ease, border-color 160ms ease, color 160ms ease;
}

.fb-marketplace-radius-chip:hover,
.fb-marketplace-radius-chip.is-active {
    background: #e7f3ff;
    border-color: #bfdbfe;
    color: #1666d3;
}

.fb-marketplace-layout {
    display: grid;
    grid-template-columns: 304px minmax(0, 1fr) 318px;
    gap: 18px;
    align-items: start;
}

.fb-marketplace-sidebar,
.fb-marketplace-feed,
.fb-marketplace-map-rail {
    min-width: 0;
}

.fb-marketplace-panel {
    display: grid;
    gap: 14px;
    padding: 16px;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #dde2ea;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
}

.fb-marketplace-panel + .fb-marketplace-panel {
    margin-top: 14px;
}

.fb-marketplace-panel-sticky {
    position: sticky;
    top: 18px;
}

.fb-marketplace-panel-head {
    display: grid;
    gap: 4px;
}

.fb-marketplace-panel-head h2,
.fb-marketplace-panel-head h3,
.fb-marketplace-feed-head h2,
.fb-marketplace-section-head h3,
.fb-marketplace-sheet-head h2 {
    margin: 0;
    color: #111827;
}

.fb-marketplace-panel-head h2 {
    font-size: 1.3rem;
    font-weight: 800;
}

.fb-marketplace-panel-head h3,
.fb-marketplace-section-head h3 {
    font-size: 1rem;
    font-weight: 800;
}

.fb-marketplace-panel-head p,
.fb-marketplace-feed-head p,
.fb-marketplace-sheet-head p,
.fb-marketplace-map-placeholder p {
    margin: 0;
    color: #6b7280;
    font-size: 0.88rem;
}

.fb-marketplace-panel-head.compact {
    gap: 2px;
}

.fb-marketplace-sidebar-search {
    display: flex;
    align-items: center;
    gap: 10px;
    width: 100%;
    min-height: 48px;
    padding: 0 14px;
    border-radius: 999px;
    background: #f0f2f5;
    color: #606770;
    font-size: 0.95rem;
    font-weight: 700;
    cursor: pointer;
}

.fb-marketplace-sidebar-search span:first-child {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}

.fb-marketplace-sidebar-search svg {
    width: 18px;
    height: 18px;
}

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

.fb-marketplace-category-list,
.fb-marketplace-category-stack {
    display: grid;
    gap: 6px;
}

.fb-marketplace-category-list.compact {
    max-height: 520px;
    overflow: auto;
    padding-right: 2px;
}

.fb-marketplace-category-row {
    display: flex;
    align-items: center;
    gap: 12px;
    width: 100%;
    min-height: 52px;
    padding: 0 12px;
    border: 0;
    border-radius: 14px;
    background: transparent;
    color: #111827;
    text-align: left;
    cursor: pointer;
}

.fb-marketplace-category-row:hover,
.fb-marketplace-category-row.is-active {
    background: #eef3ff;
}

.fb-marketplace-category-icon,
.fb-marketplace-mini-icon,
.fb-marketplace-history-clock {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    border-radius: 999px;
    background: #f0f2f5;
    color: #111827;
}

.fb-marketplace-category-icon svg,
.fb-marketplace-mini-icon svg {
    width: 18px;
    height: 18px;
}

.fb-marketplace-category-label {
    font-size: 0.96rem;
    font-weight: 700;
}

.fb-marketplace-feed-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 14px;
    margin-bottom: 14px;
}

.fb-marketplace-feed-kicker {
    display: inline-block;
    margin-bottom: 4px;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.02em;
    text-transform: uppercase;
    color: #1877f2;
}

.fb-marketplace-feed-head h2 {
    font-size: 1.55rem;
    font-weight: 800;
    letter-spacing: -0.03em;
}

.fb-marketplace-feed-pills {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 8px;
}

.fb-marketplace-feed-pill {
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 0 12px;
    border-radius: 999px;
    background: #fff;
    border: 1px solid #d9dde5;
    color: #475467;
    font-size: 0.8rem;
    font-weight: 700;
}

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

.fb-marketplace-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 18px;
    background: #fff;
    border: 1px solid #dde2ea;
    box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    color: inherit;
    text-decoration: none;
    transition: transform 160ms ease, box-shadow 160ms ease;
}

.fb-marketplace-card:hover {
    transform: translateY(-2px);
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.09);
}

.fb-marketplace-card-media {
    position: relative;
    overflow: hidden;
    aspect-ratio: 1 / 1;
    background: #d7dde8;
}

.fb-marketplace-card-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.fb-marketplace-card-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    background: linear-gradient(135deg, #dfe7f3, #c9d5e9);
    color: #334155;
    font-size: 1.65rem;
    font-weight: 800;
    letter-spacing: 0.08em;
}

.fb-marketplace-card-distance,
.fb-marketplace-card-state {
    position: absolute;
    left: 10px;
    z-index: 1;
    display: inline-flex;
    align-items: center;
    min-height: 28px;
    padding: 0 10px;
    border-radius: 999px;
    background: rgba(17, 24, 39, 0.78);
    color: #fff;
    font-size: 0.74rem;
    font-weight: 700;
    backdrop-filter: blur(8px);
}

.fb-marketplace-card-distance {
    top: 10px;
}

.fb-marketplace-card-state {
    bottom: 10px;
    background: rgba(24, 119, 242, 0.92);
}

.fb-marketplace-card-body {
    display: grid;
    gap: 4px;
    padding: 12px 12px 14px;
}

.fb-marketplace-card-price {
    font-size: 1.02rem;
    font-weight: 800;
    color: #111827;
}

.fb-marketplace-card-body h3 {
    margin: 0;
    font-size: 0.94rem;
    line-height: 1.3;
    font-weight: 700;
    color: #111827;
}

.fb-marketplace-card-location,
.fb-marketplace-card-meta {
    margin: 0;
    font-size: 0.78rem;
    color: #6b7280;
}

.fb-marketplace-empty {
    display: grid;
    gap: 12px;
    justify-items: start;
    padding: 22px;
    border-radius: 18px;
    border: 1px solid #dde2ea;
    background: #fff;
}

.fb-marketplace-mobile-map-card {
    display: none;
}

.fb-marketplace-map-rail iframe,
.fb-marketplace-map-panel iframe,
.fb-marketplace-mobile-map-card iframe {
    width: 100%;
    min-height: 580px;
    border: 0;
    border-radius: 16px;
    background: #e5e7eb;
}

.fb-marketplace-map-placeholder {
    display: grid;
    gap: 8px;
    place-items: center;
    min-height: 280px;
    padding: 24px;
    text-align: center;
    border-radius: 16px;
    background: linear-gradient(180deg, #edf2f7, #e2e8f0);
}

.fb-marketplace-map-placeholder strong {
    font-size: 1.05rem;
    font-weight: 800;
}

.fb-marketplace-search-overlay,
.fb-marketplace-sheet,
.fb-marketplace-map-modal {
    position: fixed;
    inset: 0;
    z-index: 1200;
}

.fb-marketplace-search-overlay {
    background: rgba(17, 24, 39, 0.34);
    padding: 18px;
}

.fb-marketplace-search-shell {
    display: flex;
    flex-direction: column;
    width: min(920px, 100%);
    height: min(100%, 900px);
    margin: 0 auto;
    border-radius: 24px;
    overflow: hidden;
    background: #fff;
    box-shadow: 0 24px 56px rgba(15, 23, 42, 0.2);
}

.fb-marketplace-search-head {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 14px 16px;
    border-bottom: 1px solid #edf0f5;
    background: #fff;
}

.fb-marketplace-search-bar {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 10px;
    min-height: 48px;
    padding: 0 14px;
    border-radius: 999px;
    background: #f0f2f5;
}

.fb-marketplace-search-bar input {
    width: 100%;
    min-width: 0;
    border: 0;
    outline: 0;
    background: transparent;
    color: #111827;
    font-size: 1rem;
}

.fb-marketplace-search-clear,
.fb-marketplace-text-action,
.fb-marketplace-link-button,
.fb-marketplace-history-main,
.fb-marketplace-history-remove,
.fb-marketplace-bottom-item {
    cursor: pointer;
}

.fb-marketplace-search-clear,
.fb-marketplace-text-action,
.fb-marketplace-link-button,
.fb-marketplace-history-remove {
    border: 0;
    background: transparent;
    color: #1877f2;
    font-weight: 700;
}

.fb-marketplace-search-clear {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 28px;
    height: 28px;
    border-radius: 999px;
    background: #e4e6eb;
    color: #111827;
    font-size: 1.1rem;
}

.fb-marketplace-search-tabs {
    display: flex;
    gap: 20px;
    padding: 0 18px;
    border-bottom: 1px solid #edf0f5;
    background: #fff;
}

.fb-marketplace-search-tabs button {
    min-height: 48px;
    padding: 0;
    border: 0;
    border-bottom: 2px solid transparent;
    background: transparent;
    color: #6b7280;
    font-size: 0.92rem;
    font-weight: 800;
    cursor: pointer;
}

.fb-marketplace-search-tabs button.is-active {
    color: #1877f2;
    border-bottom-color: #1877f2;
}

.fb-marketplace-live-results,
.fb-marketplace-search-panels {
    flex: 1;
    min-height: 0;
    overflow: auto;
    padding: 16px 18px 28px;
    background: #fff;
}

.fb-marketplace-search-panel,
.fb-marketplace-search-section {
    display: grid;
    gap: 12px;
}

.fb-marketplace-search-section + .fb-marketplace-search-section {
    margin-top: 18px;
}

.fb-marketplace-section-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}

.fb-marketplace-history-list,
.fb-marketplace-live-list {
    display: grid;
    gap: 4px;
}

.fb-marketplace-history-item,
.fb-marketplace-live-item {
    display: flex;
    align-items: center;
    gap: 12px;
    min-height: 56px;
    padding: 0 10px;
    border-radius: 14px;
    color: inherit;
    text-decoration: none;
}

.fb-marketplace-history-item:hover,
.fb-marketplace-live-item:hover {
    background: #f6f7f9;
}

.fb-marketplace-history-main {
    flex: 1;
    display: flex;
    align-items: center;
    gap: 12px;
    min-width: 0;
    border: 0;
    background: transparent;
    padding: 0;
    text-align: left;
}

.fb-marketplace-history-main span:last-child,
.fb-marketplace-live-copy {
    min-width: 0;
    display: grid;
    gap: 2px;
}

.fb-marketplace-history-main strong,
.fb-marketplace-live-copy strong {
    font-size: 0.95rem;
    font-weight: 700;
    color: #111827;
}

.fb-marketplace-history-main small,
.fb-marketplace-live-copy small,
.fb-marketplace-empty-copy {
    font-size: 0.8rem;
    color: #6b7280;
}

.fb-marketplace-history-clock::before {
    content: "";
    width: 14px;
    height: 14px;
    border: 2px solid #111827;
    border-radius: 999px;
    display: block;
}

.fb-marketplace-live-thumb {
    flex: 0 0 auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 52px;
    height: 52px;
    overflow: hidden;
    border-radius: 12px;
    background: #dbe3ef;
    color: #334155;
    font-size: 0.94rem;
    font-weight: 800;
}

.fb-marketplace-live-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.fb-marketplace-live-empty {
    padding: 18px 2px;
    color: #6b7280;
    font-size: 0.92rem;
}

.fb-marketplace-sheet-backdrop {
    position: absolute;
    inset: 0;
    background: rgba(17, 24, 39, 0.44);
}

.fb-marketplace-sheet-panel {
    position: relative;
    z-index: 1;
    width: min(420px, 100%);
    height: 100%;
    margin-left: auto;
    overflow: auto;
    padding: 18px;
    background: #fff;
    box-shadow: -12px 0 30px rgba(15, 23, 42, 0.18);
}

.fb-marketplace-sheet-head {
    display: flex;
    align-items: start;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
}

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

.fb-marketplace-shortcut {
    display: grid;
    gap: 10px;
    justify-items: start;
    min-height: 114px;
    padding: 16px;
    border-radius: 18px;
    background: #f6f7f9;
    color: #111827;
}

.fb-marketplace-shortcut span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    border-radius: 999px;
    background: #fff;
    color: #111827;
}

.fb-marketplace-shortcut svg {
    width: 20px;
    height: 20px;
}

.fb-marketplace-shortcut strong {
    font-size: 0.94rem;
    font-weight: 800;
}

.fb-marketplace-sheet-section {
    display: grid;
    gap: 12px;
}

.fb-marketplace-map-panel {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 16px;
    width: min(920px, 100%);
    max-height: min(92vh, 900px);
    margin: auto;
    padding: 18px;
    border-radius: 24px;
    overflow: auto;
    background: #fff;
    box-shadow: 0 24px 56px rgba(15, 23, 42, 0.2);
}

.fb-marketplace-bottom-nav {
    display: none;
}

.fb-marketplace-no-scroll {
    overflow: hidden;
}

@media (max-width: 1320px) {
    .fb-marketplace-layout {
        grid-template-columns: 286px minmax(0, 1fr) 300px;
    }

    .fb-marketplace-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 1100px) {
    .fb-marketplace-layout {
        grid-template-columns: 280px minmax(0, 1fr);
    }

    .fb-marketplace-map-rail {
        display: none;
    }
}

@media (max-width: 860px) {
    .fb-marketplace {
        padding-inline: 12px;
    }

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

    .fb-marketplace-sidebar {
        display: none;
    }

    .fb-marketplace-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}

@media (max-width: 760px) {
    .desktop-only {
        display: none !important;
    }

    .mobile-only {
        display: inline-flex !important;
    }

    .marketplace-index-page main {
        padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
    }

    .fb-marketplace {
        padding: 10px 0 calc(80px + env(safe-area-inset-bottom, 0px));
    }

    .fb-marketplace-header {
        padding: 0 12px;
        margin-bottom: 10px;
    }

    .fb-marketplace-brand-row h1 {
        font-size: 1.55rem;
    }

    .fb-marketplace-branding p {
        font-size: 0.82rem;
    }

    .fb-marketplace-header-actions {
        gap: 8px;
    }

    .fb-icon-button {
        width: 38px;
        height: 38px;
    }

    .fb-marketplace-launch-row {
        display: none;
    }

    .fb-marketplace-search-context {
        margin: 0 12px 12px;
        padding: 12px;
        border-radius: 16px;
        align-items: start;
        flex-direction: column;
    }

    .fb-marketplace-search-context-copy strong {
        font-size: 0.96rem;
    }

    .fb-marketplace-radius-picker,
    .fb-marketplace-radius-picker.compact {
        width: 100%;
        justify-content: flex-start;
        flex-wrap: nowrap;
        overflow: auto;
        scrollbar-width: none;
    }

    .fb-marketplace-radius-picker::-webkit-scrollbar {
        display: none;
    }

    .fb-marketplace-radius-chip {
        flex: 0 0 auto;
    }

    .fb-marketplace-mobile-strip {
        display: flex;
        gap: 8px;
        overflow: auto;
        padding: 0 12px 12px;
        scrollbar-width: none;
    }

    .fb-marketplace-mobile-strip::-webkit-scrollbar {
        display: none;
    }

    .fb-marketplace-strip-chip {
        flex: 0 0 auto;
        display: inline-flex;
        align-items: center;
        gap: 8px;
        min-height: 38px;
        padding: 0 12px;
        border: 0;
        border-radius: 999px;
        background: #fff;
        color: #111827;
        font-size: 0.8rem;
        font-weight: 700;
        box-shadow: 0 1px 2px rgba(15, 23, 42, 0.06);
    }

    .fb-marketplace-strip-chip.is-active {
        background: #e7f3ff;
        color: #1666d3;
    }

    .fb-marketplace-mini-icon {
        width: 24px;
        height: 24px;
        background: transparent;
    }

    .fb-marketplace-feed {
        padding: 0 12px;
    }

    .fb-marketplace-feed-head {
        align-items: start;
        margin-bottom: 10px;
    }

    .fb-marketplace-feed-head h2 {
        font-size: 1.22rem;
    }

    .fb-marketplace-feed-head p {
        font-size: 0.8rem;
    }

    .fb-marketplace-feed-pills {
        display: none;
    }

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

    .fb-marketplace-mobile-map-card {
        display: grid;
        gap: 12px;
        margin-top: 14px;
    }

    .fb-marketplace-mobile-map-card iframe {
        min-height: 220px;
    }

    .fb-marketplace-card {
        border-radius: 14px;
    }

    .fb-marketplace-card-body {
        gap: 3px;
        padding: 9px 9px 11px;
    }

    .fb-marketplace-card-price {
        font-size: 0.92rem;
    }

    .fb-marketplace-card-body h3 {
        font-size: 0.8rem;
    }

    .fb-marketplace-card-location,
    .fb-marketplace-card-meta {
        font-size: 0.7rem;
    }

    .fb-marketplace-card-distance,
    .fb-marketplace-card-state {
        min-height: 24px;
        padding: 0 8px;
        font-size: 0.65rem;
    }

    .fb-marketplace-empty {
        padding: 18px 16px;
        border-radius: 16px;
    }

    .fb-marketplace-bottom-nav {
        position: fixed;
        left: 0;
        right: 0;
        bottom: 0;
        z-index: 1100;
        display: grid;
        grid-template-columns: repeat(5, minmax(0, 1fr));
        align-items: center;
        height: calc(60px + env(safe-area-inset-bottom, 0px));
        padding: 0 0 env(safe-area-inset-bottom, 0px);
        background: #fff;
        border-top: 1px solid #dde2ea;
    }

    .fb-marketplace-bottom-item {
        display: inline-flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4px;
        width: 100%;
        height: 100%;
        padding: 4px 0 2px;
        background: transparent;
        color: #65676b;
        font-size: 0.67rem;
        font-weight: 700;
        text-decoration: none;
    }

    .fb-marketplace-bottom-item svg {
        width: 20px;
        height: 20px;
    }

    .fb-marketplace-bottom-item.is-active {
        color: #1877f2;
    }

    .fb-marketplace-search-overlay {
        padding: 0;
        background: #fff;
    }

    .fb-marketplace-search-shell {
        width: 100%;
        height: 100%;
        border-radius: 0;
        box-shadow: none;
    }

    .fb-marketplace-search-head {
        padding: 10px 12px;
        gap: 8px;
    }

    .fb-marketplace-search-bar {
        min-height: 42px;
        padding: 0 12px;
    }

    .fb-marketplace-search-bar input {
        font-size: 0.96rem;
    }

    .fb-marketplace-text-action {
        display: none;
    }

    .fb-marketplace-search-tabs {
        padding: 0 12px;
        gap: 22px;
    }

    .fb-marketplace-live-results,
    .fb-marketplace-search-panels {
        padding: 12px 12px calc(84px + env(safe-area-inset-bottom, 0px));
    }

    .fb-marketplace-history-item,
    .fb-marketplace-live-item {
        min-height: 52px;
        padding: 0 6px;
    }

    .fb-marketplace-history-main strong,
    .fb-marketplace-live-copy strong {
        font-size: 0.9rem;
    }

    .fb-marketplace-history-main small,
    .fb-marketplace-live-copy small {
        font-size: 0.76rem;
    }

    .fb-marketplace-sheet-panel {
        width: 100%;
        height: 100%;
        padding: 16px 14px calc(86px + env(safe-area-inset-bottom, 0px));
        border-radius: 0;
        box-shadow: none;
    }

    .fb-marketplace-shortcuts {
        gap: 10px;
    }

    .fb-marketplace-shortcut {
        min-height: 104px;
        padding: 14px;
        border-radius: 16px;
    }

    .fb-marketplace-map-panel {
        width: 100%;
        max-height: none;
        height: 100%;
        padding: 14px;
        border-radius: 0;
        box-shadow: none;
    }

    .fb-marketplace-map-panel iframe {
        min-height: 68vh;
    }
}

@media (max-width: 420px) {
    .fb-marketplace-brand-row h1 {
        font-size: 1.42rem;
    }

    .fb-marketplace-branding p {
        font-size: 0.78rem;
    }

    .fb-marketplace-grid {
        gap: 7px;
    }

    .fb-marketplace-card-body {
        padding: 8px 8px 10px;
    }

    .fb-marketplace-card-price {
        font-size: 0.88rem;
    }

    .fb-marketplace-card-body h3 {
        font-size: 0.77rem;
    }
}

.event-hub {
    max-width: 1380px;
    margin: 0 auto;
    padding: 24px 18px 96px;
    display: grid;
    gap: 18px;
}

.event-hero-card {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    padding: 26px;
    border-radius: 28px;
    background: linear-gradient(135deg, #0f172a 0%, #1d4ed8 55%, #f97316 100%);
    color: #fff;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.18);
}

.event-hero-copy {
    display: grid;
    gap: 10px;
    max-width: 760px;
}

.event-hero-copy .eyebrow {
    color: rgba(255, 255, 255, 0.8);
}

.event-hero-copy h1 {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3.4rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
}

.event-hero-copy p {
    margin: 0;
    max-width: 68ch;
    color: rgba(255, 255, 255, 0.9);
}

.event-hub-layout,
.event-detail-grid,
.event-toolkit-grid {
    display: grid;
    gap: 18px;
}

.event-hub-layout {
    grid-template-columns: 320px minmax(0, 1fr);
    align-items: start;
}

.event-detail-grid {
    grid-template-columns: minmax(0, 1.1fr) 360px;
    align-items: start;
}

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

.event-sidebar,
.event-feed,
.event-detail-stage,
.event-detail-summary {
    min-width: 0;
}

.event-filter-card,
.event-detail-stage {
    display: grid;
    gap: 16px;
    padding: 18px;
    border-radius: 24px;
    background: #fff;
    border: 1px solid #dbe3ef;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.event-sticky-card {
    position: sticky;
    top: 18px;
}

.event-card-head {
    display: grid;
    gap: 4px;
}

.event-card-head h2,
.event-card-head h3 {
    margin: 0;
    color: #0f172a;
}

.event-card-head p {
    margin: 0;
    color: #64748b;
    font-size: 0.92rem;
}

.event-radius-row {
    display: grid;
    gap: 10px;
}

.event-category-list {
    display: grid;
    gap: 8px;
}

.event-category-chip {
    appearance: none;
    min-height: 44px;
    padding: 0 14px;
    border-radius: 999px;
    border: 1px solid #dbe3ef;
    background: #f8fafc;
    color: #1e293b;
    text-align: left;
    font-weight: 700;
    cursor: pointer;
}

.event-category-chip.is-active,
.event-category-chip:hover {
    background: #eff6ff;
    border-color: #bfdbfe;
    color: #1d4ed8;
}

.event-feed-head {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 16px;
}

.event-feed-kicker {
    display: inline-block;
    margin-bottom: 6px;
    font-size: 0.8rem;
    font-weight: 800;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: #2563eb;
}

.event-feed-head h2 {
    margin: 0;
    font-size: 2rem;
    line-height: 1;
    letter-spacing: -0.04em;
    color: #0f172a;
}

.event-feed-head p {
    margin: 8px 0 0;
    color: #64748b;
}

.event-feed-pills,
.event-detail-tags,
.event-card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

.event-pill,
.event-detail-tags span,
.event-card-tags span {
    display: inline-flex;
    align-items: center;
    min-height: 32px;
    padding: 0 12px;
    border-radius: 999px;
    background: #eef2ff;
    color: #1d4ed8;
    font-size: 0.8rem;
    font-weight: 700;
}

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

.event-card {
    display: flex;
    flex-direction: column;
    overflow: hidden;
    border-radius: 24px;
    background: #fff;
    border: 1px solid #dbe3ef;
    box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.event-card-media {
    position: relative;
    display: block;
    aspect-ratio: 4 / 5;
    overflow: hidden;
    background: linear-gradient(135deg, #dbeafe, #fef3c7);
}

.event-card-media img,
.event-detail-poster img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.event-card-fallback {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 320px;
    background: linear-gradient(135deg, #dbeafe, #fed7aa);
    color: #1e293b;
    font-size: 2rem;
    font-weight: 800;
    letter-spacing: 0.1em;
}

.event-card-date,
.event-card-distance {
    position: absolute;
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 0 10px;
    border-radius: 999px;
    color: #fff;
    font-size: 0.76rem;
    font-weight: 700;
    backdrop-filter: blur(12px);
}

.event-card-date {
    top: 12px;
    left: 12px;
    background: rgba(30, 41, 59, 0.8);
}

.event-card-distance {
    right: 12px;
    bottom: 12px;
    background: rgba(37, 99, 235, 0.88);
}

.event-card-body {
    display: grid;
    gap: 8px;
    padding: 16px;
}

.event-card-time,
.event-card-venue,
.event-card-location {
    margin: 0;
    color: #64748b;
    font-size: 0.9rem;
}

.event-card-body h3 {
    margin: 0;
    font-size: 1.08rem;
    line-height: 1.2;
    color: #0f172a;
}

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

.event-map-card iframe,
.event-detail-summary iframe {
    width: 100%;
    min-height: 320px;
    border: 0;
    border-radius: 18px;
}

.event-detail-poster {
    overflow: hidden;
    border-radius: 20px;
    background: #dbeafe;
    min-height: 520px;
}

.event-detail-summary {
    display: grid;
    gap: 18px;
}

.event-meta-list {
    display: grid;
    gap: 12px;
}

.event-meta-list div {
    display: grid;
    gap: 4px;
}

.event-meta-list strong {
    color: #0f172a;
}

.event-meta-list span {
    color: #475569;
}

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

.event-share-preview {
    display: grid;
    grid-template-columns: 132px minmax(0, 1fr);
    gap: 14px;
    padding: 14px;
    border-radius: 18px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.event-share-preview-media {
    overflow: hidden;
    border-radius: 16px;
    background: #dbeafe;
    min-height: 132px;
}

.event-share-preview-media img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

.event-share-preview-copy {
    display: grid;
    gap: 6px;
    align-content: start;
}

.event-share-preview-copy strong {
    color: #0f172a;
}

.event-share-preview-copy span,
.event-share-preview-copy small {
    color: #64748b;
}

.event-share-copy {
    min-height: 180px;
    width: 100%;
    border-radius: 18px;
    border: 1px solid #dbe3ef;
    background: #f8fafc;
    color: #0f172a;
    padding: 14px;
    resize: vertical;
}

.event-format-list {
    display: grid;
    gap: 12px;
}

.event-format-item {
    display: grid;
    gap: 4px;
    padding: 14px;
    border-radius: 18px;
    background: #f8fafc;
    border: 1px solid #e2e8f0;
}

.event-format-item strong {
    color: #0f172a;
}

.event-format-item span,
.event-format-item small {
    color: #64748b;
}

.form-help {
    display: block;
    margin-top: -6px;
    color: #64748b;
    font-size: 0.86rem;
    line-height: 1.45;
}

.event-empty-state {
    justify-items: start;
}

.event-quick-card {
    background:
        radial-gradient(circle at top right, rgba(59, 130, 246, 0.12), transparent 30%),
        linear-gradient(180deg, #ffffff, #f8fbff);
}

.event-quick-grid,
.event-support-links,
.event-legal-links,
.site-link-grid {
    display: grid;
    gap: 10px;
}

.event-quick-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.event-quick-link,
.event-support-link,
.event-legal-links a,
.site-link-chip {
    min-height: 48px;
    padding: 0 14px;
    border-radius: 16px;
    display: inline-flex;
    align-items: center;
    gap: 10px;
    border: 1px solid #dbe3ef;
    background: #ffffff;
    color: #0f172a;
    font-weight: 700;
    text-decoration: none;
}

.event-quick-link {
    justify-content: center;
    width: 100%;
    font: inherit;
    cursor: pointer;
}

.event-quick-link.is-primary {
    background: #0f172a;
    color: #ffffff;
    border-color: #0f172a;
}

.event-quick-link-icon,
.event-support-link-icon,
.site-link-chip-icon,
.site-card-icon {
    width: 20px;
    height: 20px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
}

.event-quick-link-icon svg,
.event-support-link-icon svg,
.site-link-chip-icon svg,
.site-card-icon svg {
    width: 100%;
    height: 100%;
    display: block;
}

.event-support-card,
.site-legal-stack,
.site-address-lines {
    display: grid;
    gap: 12px;
}

.event-support-head,
.site-card-head {
    display: flex;
    align-items: center;
    gap: 12px;
}

.event-support-head strong,
.site-card-head h2 {
    color: #0f172a;
}

.event-support-head span,
.site-card-head p,
.site-legal-section p {
    color: #64748b;
}

.event-support-icon,
.site-card-icon {
    width: 42px;
    height: 42px;
    border-radius: 14px;
    background: #eff6ff;
    color: #2563eb;
    flex: 0 0 auto;
}

.event-support-address,
.site-address-card {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 12px;
    padding: 14px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid #dbe3ef;
}

.event-support-address-lines strong,
.site-address-lines strong {
    font-size: 0.88rem;
    line-height: 1.45;
    color: #0f172a;
}

.event-support-socials,
.site-social-row {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.event-support-socials a,
.site-social-link {
    width: 42px;
    height: 42px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #ffffff;
    border: 1px solid #dbe3ef;
    color: #0f172a;
}

.event-support-socials a svg,
.site-social-link svg {
    width: 20px;
    height: 20px;
}

.site-page-shell {
    display: grid;
    gap: 18px;
    padding: 24px 0 96px;
}

.site-page-hero {
    display: flex;
    align-items: end;
    justify-content: space-between;
    gap: 18px;
    padding: 24px 26px;
    border-radius: 28px;
    background:
        radial-gradient(circle at top right, rgba(249, 115, 22, 0.18), transparent 26%),
        linear-gradient(135deg, #0f172a 0%, #134e4a 52%, #0b6e4f 100%);
    color: #ffffff;
    box-shadow: 0 20px 40px rgba(15, 23, 42, 0.16);
}

.site-page-hero-copy {
    display: grid;
    gap: 10px;
    max-width: 760px;
}

.site-page-hero-copy .eyebrow,
.site-page-hero-copy p {
    color: rgba(255, 255, 255, 0.86);
}

.site-page-hero-copy h1 {
    margin: 0;
    font-size: clamp(2rem, 4vw, 3.2rem);
    line-height: 0.96;
    letter-spacing: -0.04em;
}

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

.site-page-grid-legal {
    grid-template-columns: minmax(0, 1.4fr) 360px;
    align-items: start;
}

.site-page-card {
    display: grid;
    gap: 16px;
}

.site-page-card-wide {
    grid-column: 1 / -1;
}

.site-card-head {
    align-items: flex-start;
}

.site-card-head h2 {
    margin: 0 0 4px;
}

.site-card-head p {
    margin: 0;
}

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

.site-link-form {
    margin: 0;
}

.site-link-chip-button {
    width: 100%;
    font: inherit;
    cursor: pointer;
}

.site-legal-stack {
    gap: 18px;
}

.site-legal-section {
    display: grid;
    gap: 8px;
    padding-bottom: 18px;
    border-bottom: 1px solid rgba(15, 23, 42, 0.08);
}

.site-legal-section:last-child {
    padding-bottom: 0;
    border-bottom: 0;
}

.site-legal-section h2 {
    margin: 0;
    color: #0f172a;
}

.site-legal-section p {
    margin: 0;
    line-height: 1.65;
}

@media (max-width: 1080px) {
    .event-hub-layout,
    .event-detail-grid,
    .event-toolkit-grid,
    .site-page-grid,
    .site-page-grid-legal {
        grid-template-columns: 1fr;
    }

    .event-sticky-card {
        position: static;
    }

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

@media (max-width: 720px) {
    .event-hub {
        padding-inline: 14px;
        padding-bottom: 84px;
    }

    .event-hero-card,
    .site-page-hero,
    .event-feed-head {
        grid-template-columns: 1fr;
        display: grid;
        align-items: start;
    }

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

    .event-detail-poster {
        min-height: 360px;
    }

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

    .event-share-preview-media {
        min-height: 220px;
    }

    .event-quick-grid,
    .site-link-grid {
        grid-template-columns: 1fr;
    }

    .site-page-shell {
        padding-bottom: 92px;
    }
}
