.page-hero {
    background:
        linear-gradient(120deg, rgba(29, 78, 216, 0.045) 0 1px, transparent 1px 72px),
        linear-gradient(180deg, #FFFFFF, var(--background));
    border-bottom: 1px solid var(--border);
}

.page-hero h1,
.demo-hero h1 {
    font-size: clamp(2.05rem, 3.7vw, .35rem);
    line-height: 1.14;
}

.feature-list {
    display: grid;
    gap: 22px;
}

.feature-list article {
    padding: 34px;
    transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.feature-list h2 {
    font-size: 1.3rem;
    line-height: 1.22;
}

.demo-hero {
    background:
        linear-gradient(120deg, rgba(29, 78, 216, 0.045) 0 1px, transparent 1px 72px),
        linear-gradient(180deg, #FFFFFF, var(--background));
    border-bottom: 1px solid var(--border);
}

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

.contact-form,
.contact-aside {
    padding: 34px;
}

.contact-form {
    display: grid;
    gap: 20px;
}

.form-row {
    display: grid;
    gap: 8px;
}

.form-row.two-columns {
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

.form-row.two-columns > div {
    display: grid;
    gap: 8px;
}

.contact-form label {
    color: var(--text);
    font-size: 0.94rem;
    font-weight: 600;
    line-height: 1.4;
}

.contact-form input,
.contact-form select,
.contact-form textarea {
    width: 100%;
    min-height: 48px;
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 12px 14px;
    color: var(--text);
    background: var(--surface-warm);
}

.contact-form textarea {
    resize: vertical;
}

.contact-form input:focus,
.contact-form select:focus,
.contact-form textarea:focus {
    outline: 3px solid var(--primary-soft);
    border-color: var(--primary-dark);
}

.consent-row {
    display: grid;
    grid-template-columns: 20px 1fr;
    gap: 10px;
    align-items: start;
    color: var(--muted);
}

.consent-row input {
    width: 18px;
    min-height: 18px;
    margin-top: 4px;
}

.consent-row label {
    color: var(--muted);
    font-weight: 500;
}

.errorlist {
    margin: 4px 0 0;
    padding: 0;
    list-style: none;
    color: #B42318;
    font-size: 0.9rem;
}

.form-messages {
    padding: 14px 16px;
    border: 1px solid #BBF7D0;
    border-radius: var(--radius);
    background: #F0FDF4;
}

.form-messages p {
    margin: 0;
    color: #166534;
}

.contact-aside a {
    display: block;
    color: var(--primary-dark);
    font-weight: 650;
    margin-top: 10px;
}

.legal-content h2 {
    margin-top: 32px;
    font-size: 1.3rem;
    line-height: 1.22;
}

.agency-home-hero,
.agency-home-section {
    position: relative;
    overflow: hidden;
}

.agency-home-hero {
    padding: 104px 0 84px;
    background:
        linear-gradient(180deg, #FFFFFF 0%, #FFFFFF 58%, #F8FAFC 100%);
}

.agency-home-hero::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 0;
    width: min(100% - 2rem, var(--container));
    height: 1px;
    background: linear-gradient(90deg, transparent, #E2E8F0 16%, #E2E8F0 84%, transparent);
    transform: translateX(-50%);
}

.agency-home-hero h1,
.agency-home-section h2,
.agency-home-section h3 {
    letter-spacing: 0;
}

@media (min-width: 768px) {
    .page-hero .narrow {
        max-width: 960px;
    }
}

.agency-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(380px, 0.92fr);
    gap: 54px;
    align-items: center;
}

.agency-hero-copy {
    min-width: 0;
}

.agency-hero-copy h1 {
    max-width: 820px;
    margin-bottom: 24px;
    font-size: clamp(2.3rem, 4.51vw, 3.4rem);
    line-height: 1.06;
}

.agency-hero-text {
    max-width: 680px;
    font-size: 1.12rem;
    line-height: 1.75;
}

.agency-action-row,
.agency-contact-actions,
.agency-whatsapp-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
}

.agency-action-row {
    margin-top: 34px;
}

.agency-section-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
    justify-content: center;
    margin-top: 34px;
    text-align: center;
}

.agency-section-cta p {
    flex-basis: 100%;
    max-width: 560px;
    margin: 0 auto 2px;
    color: #64748B;
    font-size: 0.98rem;
    font-weight: 560;
    line-height: 1.6;
}

.agency-section-cta--paired {
    margin-top: 38px;
}

.agency-section-cta--service {
    display: grid;
    justify-items: center;
    width: 100%;
    max-width: none;
    margin-right: auto;
    margin-left: auto;
    padding: 30px;
    text-align: center;
    border: 1px solid #E2E8F0;
    border-radius: 24px;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 58%, #F1F5F9 100%);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.06);
}

.agency-section-cta--service h3 {
    flex-basis: 100%;
    margin-bottom: 0;
    color: #0F172A;
    font-size: clamp(1.35rem, 2.4vw, 1.75rem);
    line-height: 1.18;
}

.agency-section-cta--service p {
    max-width: 620px;
    margin-right: auto;
    margin-bottom: 4px;
    margin-left: auto;
    font-size: 1rem;
}

.agency-section-cta--service .btn {
    flex-basis: auto;
    margin-right: auto;
    margin-left: auto;
}

.agency-hero-trust {
    display: grid;
    grid-column: 1 / -1;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    width: 100%;
    margin-top: 2px;
    padding-top: 18px;
    border-top: 1px solid #E2E8F0;
}

.agency-hero-trust span {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: 9px;
    min-height: 28px;
    padding: 0;
    color: #0F172A;
    border: 0;
    border-radius: 0;
    background: transparent;
    font-size: 0.9rem;
    font-weight: 680;
    line-height: 1.25;
    box-shadow: none;
}

.agency-hero-trust span::before {
    content: "";
    flex: 0 0 auto;
    width: 18px;
    height: 18px;
    border: 1px solid rgba(37, 99, 235, 0.24);
    border-radius: 999px;
    background: #F1F5F9;
    box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.06);
}

.agency-hero-trust span::after {
    content: "";
    position: absolute;
    left: 5px;
    top: 50%;
    width: 7px;
    height: 4px;
    border-left: 2px solid #2563EB;
    border-bottom: 2px solid #2563EB;
    transform: translateY(-60%) rotate(-45deg);
}

.agency-hero-media {
    min-width: 0;
    transform: translateX(-18px);
}

.agency-image-slot {
    position: relative;
    min-height: 220px;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 24px;
    background: #F8FAFC;
    overflow: hidden;
    box-shadow: none;
}

.agency-image-slot > img,
.agency-image-slot > picture,
.agency-image-slot > picture > img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
}

.agency-image-slot > picture {
    display: block;
}

.agency-image-slot > img,
.agency-image-slot > picture > img {
    object-fit: cover;
    object-position: center;
}

.agency-image-badge {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 3;
    display: inline-flex;
    max-width: calc(100% - 28px);
    padding: 7px 11px;
    color: #2563EB;
    border: 1px solid rgba(226, 232, 240, 0.95);
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.9);
    font-size: 0.76rem;
    font-weight: 760;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    box-shadow: 0 12px 24px rgba(15, 23, 42, 0.08);
}

.agency-image-slot--swap .agency-image-primary,
.agency-image-slot--swap .agency-image-secondary {
    transition:
        opacity 420ms ease,
        transform 620ms cubic-bezier(0.22, 1, 0.36, 1);
}

.agency-image-slot--swap .agency-image-primary {
    opacity: 1;
    transform: scale(1);
}

.agency-image-slot--swap .agency-image-secondary {
    opacity: 0;
    transform: scale(1.035);
}

@media (hover: hover) and (pointer: fine) {
    .agency-showcase-tile:hover .agency-image-slot--swap .agency-image-primary {
        opacity: 0;
        transform: scale(1.025);
    }

    .agency-showcase-tile:hover .agency-image-slot--swap .agency-image-secondary {
        opacity: 1;
        transform: scale(1);
    }
}

.agency-showcase-tile.is-active .agency-image-slot--swap .agency-image-primary {
    opacity: 0;
    transform: scale(1.025);
}

.agency-showcase-tile.is-active .agency-image-slot--swap .agency-image-secondary {
    opacity: 1;
    transform: scale(1);
}

.agency-image-slot:has(img)::before,
.agency-image-slot:has(picture)::before {
    display: none;
}

.agency-image-slot:has(img)::after,
.agency-image-slot:has(picture)::after {
    display: none;
    background: transparent;
}

.agency-image-slot::before {
    content: attr(data-label);
    position: absolute;
    left: 1rem;
    bottom: 1rem;
    z-index: 1;
    max-width: calc(100% - 2rem);
    padding: 0.35rem 0.65rem;
    color: #2563EB;
    border: 1px solid #E2E8F0;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.84);
    font-size: 0.78rem;
    font-weight: 700;
    line-height: 1.25;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.agency-image-slot::after {
    content: "";
    position: absolute;
    inset: 18px;
    border-radius: 20px;
    border: 1px solid rgba(191, 219, 254, 0.48);
    background:
        linear-gradient(135deg, rgba(255, 255, 255, 0.74), rgba(239, 246, 255, 0.34));
    pointer-events: none;
}

.agency-image-slot--hero {
    aspect-ratio: 4 / 3;
    width: calc(100% + 56px) * 1.05;
    min-height: 500px;
    max-height: 580px;
    margin-left: -28px;
    border: 0;
    border-radius: 0;
    background: transparent;
    overflow: visible;
    box-shadow: none;
}

.agency-image-slot--hero > img,
.agency-image-slot--hero > picture > img {
    object-fit: contain;
    object-position: center;
}

.agency-showcase {
    margin-top: 64px;
}

.agency-showcase-stage {
    position: relative;
    min-height: 490px;
    overflow: hidden;
}

.agency-showcase-card {
    position: absolute;
    top: 24px;
    left: 50%;
    width: min(620px, 68%);
    opacity: 0;
    pointer-events: none;
    transform: translateX(-50%) scale(0.88);
    transition:
        opacity 520ms ease,
        transform 520ms ease,
        z-index 520ms ease;
    z-index: 1;
    will-change: transform, opacity;
}

.agency-showcase-card .agency-image-slot {
    aspect-ratio: 1.4 / 1;
    min-height: 0;
    border-radius: 26px;
    box-shadow: 0 22px 54px rgba(15, 23, 42, 0.08);
}

.agency-showcase-card .agency-image-slot > img {
    object-fit: contain;
    object-position: center;
}

.agency-showcase-card.is-active {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) scale(1);
    z-index: 3;
}

.agency-showcase-card.is-left {
    opacity: 0.46;
    pointer-events: auto;
    transform: translateX(-92%) scale(0.82);
    z-index: 2;
}

.agency-showcase-card.is-right {
    opacity: 0.46;
    pointer-events: auto;
    transform: translateX(-8%) scale(0.82);
    z-index: 2;
}

.agency-showcase-card.is-far-left {
    opacity: 0;
    pointer-events: none;
    transform: translateX(-140%) scale(0.72);
}

.agency-showcase-card.is-far-right {
    opacity: 0;
    pointer-events: none;
    transform: translateX(40%) scale(0.72);
}

.agency-hero-highlights {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 72px;
}

.agency-highlight-card,
.agency-showcase-tile,
.agency-benefit-card,
.agency-why-block,
.agency-whatsapp-box,
.agency-contact-box {
    border: 1px solid #E2E8F0;
    background: #FFFFFF;
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.06);
}

.agency-highlight-card {
    position: relative;
    overflow: hidden;
    min-height: 176px;
    padding: 26px;
    border-radius: 22px;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 42%, #F1F5F9 78%, rgba(37, 99, 235, 0.08) 100%);
    transition:
        border-color 220ms ease,
        box-shadow 220ms ease,
        transform 220ms ease,
        background 220ms ease;
    will-change: transform;
}

.agency-highlight-card span,
.agency-showcase-content span,
.agency-benefit-number {
    display: inline-flex;
    color: #2563EB;
    font-size: 0.78rem;
    font-weight: 760;
    line-height: 1.2;
}

.agency-highlight-card span {
    position: relative;
    z-index: 1;
    align-items: center;
    justify-content: center;
    width: 42px;
    height: 42px;
    margin-bottom: 28px;
    color: #FFFFFF;
    border: 1px solid #1D4ED8;
    border-radius: 14px;
    background: #2563EB;
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.16);
    transition:
        color 220ms ease,
        background 220ms ease,
        border-color 220ms ease,
        box-shadow 220ms ease,
        transform 220ms ease;
}

.agency-highlight-card h3,
.agency-highlight-card p {
    position: relative;
    z-index: 1;
}

.agency-highlight-card h3,
.agency-benefit-card h3,
.agency-showcase-content h3,
.agency-why-points h3 {
    margin-bottom: 10px;
}

.agency-highlight-card h3 {
    font-size: 1.15rem;
}

.agency-highlight-card p,
.agency-benefit-card p,
.agency-showcase-content p,
.agency-why-points p {
    font-size: 0.95rem;
    line-height: 1.6;
}

.agency-highlight-card p {
    color: #64748B;
    font-weight: 520;
}

.agency-highlight-card:hover {
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 34%, #F1F5F9 68%, rgba(37, 99, 235, 0.12) 100%);
}

.agency-highlight-card:hover span {
    color: #2563EB;
    border-color: rgba(37, 99, 235, 0.22);
    background: #FFFFFF;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.10);
    transform: translateY(-2px);
}

.agency-highlight-card:hover,
.agency-showcase-tile:hover,
.agency-showcase-tile:focus-visible,
.agency-showcase-tile.is-active,
.agency-benefit-card:focus-visible,
.agency-benefit-card.is-active,
.agency-why-points article:hover,
.agency-why-points article:focus-visible {
    border-color: rgba(37, 99, 235, 0.32);
    box-shadow: 0 26px 64px rgba(15, 23, 42, 0.09);
    transform: translateY(-4px);
}

.agency-home-section {
    padding: 100px 0;
}

.agency-services-preview,
.agency-demo-preview,
.agency-whatsapp-section {
    background: #FFFFFF;
}

.agency-benefits-section,
.agency-why-section,
.agency-final-cta-section {
    background:
        linear-gradient(180deg, #F8FAFC 0%, #FFFFFF 48%, #F8FAFC 100%);
    border-top: 1px solid #E2E8F0;
    border-bottom: 1px solid #E2E8F0;
}

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

.demo-directory-cta {
    margin-top: 48px;
}

.agency-showcase-tile {
    display: flex;
    flex-direction: column;
    min-height: 440px;
    padding: 0;
    border-radius: 26px;
    overflow: hidden;
    transition:
        border-color 220ms ease,
        box-shadow 220ms ease,
        transform 220ms ease,
        background 220ms ease;
    will-change: transform;
}

.agency-showcase-tile:hover .agency-image-slot,
.agency-showcase-tile:focus-visible .agency-image-slot,
.agency-showcase-tile.is-active .agency-image-slot {
    border-color: rgba(37, 99, 235, 0.24);
}

.agency-showcase-tile .agency-image-slot {
    aspect-ratio: 3 / 2;
    min-height: 0;
    border-width: 0 0 1px;
    border-radius: 0;
    box-shadow: none;
}

.agency-showcase-content {
    display: flex;
    flex: 1;
    flex-direction: column;
    gap: 10px;
    padding: 22px 22px 24px;
}

.agency-showcase-content .btn {
    align-self: flex-start;
    margin-top: auto;
}

.agency-service-group .agency-showcase-tile {
    background:
        linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);
}

.agency-service-group .agency-showcase-tile .agency-image-slot {
    aspect-ratio: 3 / 2;
}

.agency-service-group .agency-showcase-content {
    gap: 12px;
    padding-top: 24px;
}

.agency-demo-group .agency-showcase-tile {
    background: #FFFFFF;
}

.agency-demo-group .agency-showcase-tile .agency-image-slot {
    aspect-ratio: 3 / 2;
}

.agency-demo-group .agency-showcase-content {
    border-top: 1px solid rgba(226, 232, 240, 0.76);
    background:
        linear-gradient(180deg, #FFFFFF 0%, #F8FAFC 100%);
}

.agency-benefit-list {
    display: grid;
    gap: 18px;
}

.agency-benefit-card {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    min-height: 124px;
    padding: 26px 28px;
    border-radius: 24px;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 44%, #F1F5F9 78%, rgba(37, 99, 235, 0.08) 100%);
    text-align: center;
    overflow: hidden;
    transition:
        border-color 220ms ease,
        box-shadow 220ms ease,
        transform 220ms ease,
        background 220ms ease,
        min-height 260ms ease;
    will-change: transform;
}

.agency-benefit-card::before {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background:
        linear-gradient(90deg, rgba(37, 99, 235, 0.10), transparent 42%),
        linear-gradient(180deg, rgba(255, 255, 255, 0.72), transparent);
    opacity: 0;
    transition: opacity 220ms ease;
    pointer-events: none;
}

@media (hover: hover) {
    .agency-benefit-card:hover {
        border-color: rgba(37, 99, 235, 0.32);
        box-shadow: 0 26px 64px rgba(15, 23, 42, 0.09);
        transform: translateY(-4px);
    }

    .agency-benefit-card:hover::before {
        opacity: 1;
    }
}

.agency-benefit-number {
    position: relative;
    z-index: 1;
    align-items: center;
    justify-content: center;
    width: 64px;
    height: 64px;
    min-height: 64px;
    padding: 0;
    border: 1px solid #1D4ED8;
    border-radius: 999px;
    color: #FFFFFF;
    background: #2563EB;
    font-size: 1rem;
    box-shadow: 0 14px 30px rgba(37, 99, 235, 0.18);
    transition:
        color 220ms ease,
        background 220ms ease,
        border-color 220ms ease,
        transform 220ms ease,
        box-shadow 220ms ease;
}

.agency-benefit-card > div {
    position: relative;
    z-index: 1;
    max-width: 620px;
    max-height: 0;
    margin-top: 0;
    opacity: 0;
    transform: translateY(12px);
    overflow: hidden;
    transition:
        max-height 280ms ease,
        margin-top 260ms ease,
        opacity 240ms ease,
        transform 260ms ease;
}

.agency-benefit-card:focus-visible .agency-benefit-number,
.agency-benefit-card:hover .agency-benefit-number,
.agency-benefit-card.is-active .agency-benefit-number {
    color: #2563EB;
    border-color: rgba(37, 99, 235, 0.22);
    background: #FFFFFF;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.10);
    transform: translateY(-8px) scale(0.94);
}

.agency-benefit-card:focus-visible::before,
.agency-benefit-card:hover::before,
.agency-benefit-card.is-active::before {
    opacity: 1;
}

.agency-benefit-card:focus-visible > div,
.agency-benefit-card:hover > div,
.agency-benefit-card.is-active > div {
    max-height: 180px;
    margin-top: 8px;
    opacity: 1;
    transform: translateY(0);
}

@media (hover: hover) {
    .agency-benefit-card:hover .agency-benefit-number {
        color: #2563EB;
        border-color: rgba(37, 99, 235, 0.22);
        background: #FFFFFF;
        box-shadow: 0 14px 28px rgba(15, 23, 42, 0.10);
        transform: translateY(-8px) scale(0.94);
    }

    .agency-benefit-card:hover > div {
        max-height: 180px;
        margin-top: 8px;
        opacity: 1;
        transform: translateY(0);
    }
}

.agency-why-block {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
    gap: 34px;
    align-items: center;
    padding: 42px;
    border-radius: 28px;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 42%, #F1F5F9 74%, rgba(29, 78, 216, 0.08) 100%);
    box-shadow:
        0 24px 64px rgba(15, 23, 42, 0.07),
        inset 0 1px 0 rgba(255, 255, 255, 0.84);
}

.agency-why-copy p {
    max-width: 620px;
}

.agency-why-points {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}

.agency-why-points article {
    position: relative;
    min-height: 154px;
    padding: 20px;
    border: 1px solid #E2E8F0;
    border-radius: 20px;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 44%, #F1F5F9 78%, rgba(37, 99, 235, 0.08) 100%);
    box-shadow: 0 14px 32px rgba(15, 23, 42, 0.045);
    transition:
        border-color 220ms ease,
        box-shadow 220ms ease,
        transform 220ms ease,
        background 220ms ease;
}

.agency-why-points article::before {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;
    height: 38px;
    margin-bottom: 18px;
    border: 1px solid #1D4ED8;
    border-radius: 14px;
    color: #FFFFFF;
    background: #2563EB;
    font-size: 0.9rem;
    font-weight: 760;
    line-height: 1;
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.16);
    transition:
        color 220ms ease,
        background 220ms ease,
        border-color 220ms ease,
        box-shadow 220ms ease;
}

.agency-why-points article:nth-child(1)::before {
    content: "1";
}

.agency-why-points article:nth-child(2)::before {
    content: "2";
}

.agency-why-points article:nth-child(3)::before {
    content: "3";
}

.agency-why-points article:hover::before,
.agency-why-points article:focus-visible::before {
    color: #2563EB;
    border-color: rgba(37, 99, 235, 0.22);
    background: #FFFFFF;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.10);
}

.agency-why-points article:hover,
.agency-why-points article:focus-visible {
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 32%, #F1F5F9 66%, rgba(37, 99, 235, 0.12) 100%);
}

.agency-whatsapp-box,
.agency-contact-box {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 34px;
    align-items: center;
    padding: 46px;
    border-radius: 28px;
}

.agency-whatsapp-box {
    position: relative;
    overflow: hidden;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 38%, #F1F5F9 72%, rgba(29, 78, 216, 0.09) 100%);
    box-shadow:
        0 24px 64px rgba(15, 23, 42, 0.075),
        inset 0 1px 0 rgba(255, 255, 255, 0.8);
}

.service-expand-list {
    display: grid;
    gap: 18px;
}

.service-expand-card {
    border: 1px solid #E2E8F0;
    border-radius: 24px;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F8FAFC 58%, #F1F5F9 100%);
    box-shadow: 0 20px 50px rgba(15, 23, 42, 0.06);
    overflow: hidden;
    transition:
        border-color 220ms ease,
        box-shadow 220ms ease,
        transform 220ms ease;
}

.service-expand-card:hover,
.service-expand-card.is-open {
    border-color: rgba(37, 99, 235, 0.30);
    box-shadow: 0 26px 64px rgba(15, 23, 42, 0.09);
    transform: translateY(-2px);
}

.service-expand-card:hover .service-expand-toggle span,
.service-expand-card.is-open .service-expand-toggle span,
.service-expand-toggle:focus-visible span {
    color: #2563EB;
    border-color: rgba(37, 99, 235, 0.22);
    background: #FFFFFF;
    box-shadow: 0 14px 28px rgba(15, 23, 42, 0.10);
}

.service-expand-toggle {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    width: 100%;
    padding: 24px 26px;
    color: #0F172A;
    border: 0;
    background: transparent;
    text-align: left;
    cursor: pointer;
}

.service-expand-toggle::after {
    content: "▼";
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 34px;
    height: 34px;
    color: #2563EB;
    border: 1px solid rgba(37, 99, 235, 0.18);
    border-radius: 999px;
    background: #FFFFFF;
    font-size: 0.78rem;
    font-weight: 760;
    line-height: 1;
    transition:
        color 180ms ease,
        background 180ms ease,
        border-color 180ms ease,
        transform 180ms ease;
}

.service-expand-card.is-open .service-expand-toggle::after {
    color: #FFFFFF;
    border-color: #2563EB;
    background: #2563EB;
    transform: rotate(180deg);
}

.service-expand-toggle span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 44px;
    height: 44px;
    border: 1px solid #1D4ED8;
    border-radius: 14px;
    color: #FFFFFF;
    background: #2563EB;
    font-size: 0.9rem;
    font-weight: 760;
    line-height: 1;
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.16);
    transition:
        color 220ms ease,
        background 220ms ease,
        border-color 220ms ease,
        box-shadow 220ms ease;
}

.service-expand-toggle strong {
    font-size: 1.15rem;
    line-height: 1.25;
}

.service-expand-toggle:focus-visible {
    outline: 3px solid rgba(37, 99, 235, 0.22);
    outline-offset: -6px;
}

.service-expand-panel {
    max-height: 0;
    padding: 0 26px;
    opacity: 0;
    overflow: hidden;
    transition:
        max-height 260ms ease,
        padding 260ms ease,
        opacity 220ms ease;
}

.service-expand-card.is-open .service-expand-panel {
    max-height: 680px;
    padding: 0 26px 26px 88px;
    opacity: 1;
}

.service-expand-content {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(250px, 0.48fr);
    gap: 28px;
    align-items: stretch;
}

.service-expand-copy {
    min-width: 0;
}

.service-expand-copy p {
    max-width: 760px;
    color: #475569;
    font-size: 1rem;
    line-height: 1.72;
}

.service-expand-copy ul {
    display: grid;
    gap: 10px;
    margin: 18px 0;
    padding: 0;
    list-style: none;
}

.service-expand-copy li {
    position: relative;
    padding-left: 22px;
    color: #0F172A;
    font-size: 0.96rem;
    font-weight: 620;
    line-height: 1.55;
}

.service-expand-copy li::before {
    content: "";
    position: absolute;
    top: 0.72em;
    left: 0;
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: #2563EB;
    box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.10);
    transform: translateY(-50%);
}

.service-fit {
    margin-top: 0;
    color: #64748B;
}

.service-fit strong {
    color: #0F172A;
}

.service-image-slot {
    display: block;
    align-self: center;
    aspect-ratio: 1672 / 941;
    min-height: 220px;
    overflow: hidden;
    border: 1px solid #E2E8F0;
    border-radius: 22px;
    background: #F8FAFC;
    box-shadow: 0 18px 42px rgba(15, 23, 42, 0.08);
}

.service-image-slot img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    object-fit: contain;
    object-position: center;
}

.agency-demo-directory {
    align-items: stretch;
}

.agency-demo-directory .agency-showcase-content h2 {
    margin-bottom: 0;
    font-size: 1.2rem;
    line-height: 1.26;
}

.agency-image-slot--placeholder {
    display: grid;
    place-items: center;
    background:
        linear-gradient(135deg, #F8FAFC 0%, #F1F5F9 100%);
}

.agency-image-slot--placeholder::before {
    display: inline-flex;
    position: static;
    max-width: calc(100% - 36px);
    color: #2563EB;
    background: #FFFFFF;
}

.agency-image-slot--placeholder::after {
    display: none;
}

.contact-whatsapp-note {
    display: grid;
    gap: 14px;
    margin-top: 26px;
    padding-top: 24px;
    border-top: 1px solid #E2E8F0;
}

.contact-whatsapp-note .btn {
    width: fit-content;
}

.contact-whatsapp-note .btn-primary {
    color: #FFFFFF;
}

.contact-whatsapp-note .btn-primary:hover,
.contact-whatsapp-note .btn-primary:focus-visible,
.contact-whatsapp-note .btn-primary:active {
    color: #2563EB;
}

.agency-whatsapp-box p,
.agency-contact-box p {
    max-width: 720px;
}

.agency-contact-box {
    color: #FFFFFF;
    border-color: rgba(255, 255, 255, 0.14);
    background:
        linear-gradient(135deg, #0F172A 0%, #0F172A 52%, #1D4ED8 118%);
    box-shadow: 0 30px 88px rgba(15, 23, 42, 0.20);
}

.agency-contact-box h2,
.agency-contact-box .eyebrow {
    color: #FFFFFF;
}

.agency-contact-box p {
    color: rgba(255, 255, 255, 0.78);
}

.agency-contact-box .btn-secondary {
    color: #FFFFFF;
    border-color: rgba(255, 255, 255, 0.22);
    background: rgba(255, 255, 255, 0.10);
}

.agency-contact-box .btn-secondary:hover,
.agency-contact-box .btn-secondary:focus-visible {
    color: #2563EB;
    border-color: #FFFFFF;
    background: #FFFFFF;
}

.agency-home-hero .btn-primary,
.agency-home-section .btn-primary {
    color: #FFFFFF;
    background: #2563EB;
    border-color: #2563EB;
    box-shadow: 0 14px 28px rgba(37, 99, 235, 0.16);
}

.agency-home-hero .btn-primary:hover,
.agency-home-hero .btn-primary:focus-visible,
.agency-home-section .btn-primary:hover,
.agency-home-section .btn-primary:focus-visible {
    color: #2563EB;
    background: #F1F5F9;
    border-color: #2563EB;
    box-shadow: 0 16px 34px rgba(37, 99, 235, 0.14);
}

.agency-home-hero .btn-secondary,
.agency-home-section .btn-secondary {
    color: #0F172A;
    border-color: #E2E8F0;
    background: #FFFFFF;
}

.agency-home-hero .btn-secondary:hover,
.agency-home-hero .btn-secondary:focus-visible,
.agency-home-section .btn-secondary:hover,
.agency-home-section .btn-secondary:focus-visible {
    color: #FFFFFF;
    border-color: #2563EB;
    background: #2563EB;
    box-shadow: 0 16px 34px rgba(37, 99, 235, 0.14);
}

.agency-home-hero .btn-disabled,
.agency-home-hero .btn-disabled:hover,
.agency-home-section .btn-disabled,
.agency-home-section .btn-disabled:hover {
    color: #64748B;
    background: #F8FAFC;
    border-color: #E2E8F0;
    box-shadow: none;
    cursor: not-allowed;
    opacity: 0.78;
    transform: none;
}

.demo-detail-shell {
    background:
        linear-gradient(180deg, #F8FAFC 0%, #FFFFFF 42%, #F8FAFC 100%);
}

.demo-detail-missing {
    padding: 48px;
    color: #0F172A;
    border: 1px solid #E2E8F0;
    border-radius: 16px;
    background: #FFFFFF;
}

.demo-detail-missing p {
    color: #64748B;
}

.demo-nouriom-cta {
    padding-top: 0;
    background: #F8FAFC;
}

.demo-business--handwerk {
    --handwerk-ink: #1F2523;
    --handwerk-slate: #111816;
    --handwerk-wood: #A66A2C;
    --handwerk-orange: #E46F2A;
    --handwerk-orange-dark: #C95D20;
    --handwerk-sand: #E8D5B5;
    --handwerk-beige: #F7F0E6;
    --handwerk-muted: #6F6257;
    overflow: hidden;
    color: var(--handwerk-ink);
    border: 1px solid rgba(31, 37, 35, 0.18);
    border-radius: 18px;
    background: var(--handwerk-beige);
    box-shadow: 0 28px 70px rgba(17, 24, 22, 0.16);
}

.demo-business--handwerk,
.demo-business--handwerk a {
    color: inherit;
}

.demo-business--handwerk h1,
.demo-business--handwerk h2,
.demo-business--handwerk h3,
.demo-business--handwerk p {
    margin: 0;
}

.demo-business--handwerk h1,
.demo-business--handwerk h2,
.demo-business--handwerk h3 {
    color: var(--handwerk-ink);
    letter-spacing: 0;
}

.demo-business--handwerk p {
    color: var(--handwerk-muted);
    line-height: 1.65;
}

.demo-business-header,
.demo-business-footer {
    display: grid;
    align-items: center;
    gap: 22px;
    color: #FFFFFF;
    background: var(--handwerk-slate);
}

.demo-business-header {
    grid-template-columns: minmax(190px, 0.9fr) minmax(0, 1fr) auto;
    padding: 20px 28px;
    border-bottom: 4px solid var(--handwerk-orange);
}

.demo-business-brand {
    display: grid;
    gap: 4px;
    font-weight: 820;
    line-height: 1.15;
}

.demo-business-brand span {
    font-size: 1.08rem;
}

.demo-business-brand small {
    color: var(--handwerk-sand);
    font-size: 0.74rem;
    font-weight: 720;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.demo-business-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 18px;
    color: rgba(255, 255, 255, 0.78);
    font-size: 0.88rem;
    font-weight: 760;
}

.demo-business-nav a:hover,
.demo-business-nav a:focus-visible,
.demo-business-footer a:hover,
.demo-business-footer a:focus-visible {
    color: var(--handwerk-sand);
}

.demo-business-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 13px 20px;
    border: 2px solid transparent;
    border-radius: 8px;
    font-size: 0.92rem;
    font-weight: 820;
    line-height: 1.15;
    transition:
        color 180ms ease,
        background 180ms ease,
        border-color 180ms ease,
        transform 180ms ease;
}

.demo-business-button--primary {
    color: #FFFFFF;
    border-color: var(--handwerk-orange);
    background: var(--handwerk-orange);
}

.demo-business-button--primary:hover,
.demo-business-button--primary:focus-visible {
    color: #FFFFFF;
    border-color: var(--handwerk-orange-dark);
    background: var(--handwerk-orange-dark);
    transform: translateY(-1px);
}

.demo-business-button--secondary {
    color: var(--handwerk-ink);
    border-color: rgba(31, 37, 35, 0.22);
    background: var(--handwerk-sand);
}

.demo-business-button--secondary:hover,
.demo-business-button--secondary:focus-visible {
    color: #FFFFFF;
    border-color: var(--handwerk-wood);
    background: var(--handwerk-wood);
    transform: translateY(-1px);
}

.demo-business-main {
    background:
        linear-gradient(90deg, rgba(31, 37, 35, 0.06) 1px, transparent 1px),
        linear-gradient(180deg, #F7F0E6 0%, #FFFFFF 46%, #E8D5B5 100%);
    background-size: 44px 44px, auto;
}

.demo-business-hero {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(360px, 1fr);
    gap: 46px;
    align-items: center;
    padding: 62px 54px 44px;
    background:
        linear-gradient(135deg, rgba(17, 24, 22, 0.96) 0%, rgba(31, 37, 35, 0.92) 52%, rgba(166, 106, 44, 0.82) 100%);
}

.demo-business-hero-copy {
    display: grid;
    align-content: center;
    gap: 22px;
}

.demo-business-kicker,
.demo-business-section-heading span,
.demo-business-proof-copy span,
.demo-business-region > div > span,
.demo-business-final-cta > div > span {
    color: var(--handwerk-orange);
    font-size: 0.76rem;
    font-weight: 860;
    letter-spacing: 0.08em;
    line-height: 1.3;
    text-transform: uppercase;
}

.demo-business-hero h1 {
    max-width: 760px;
    color: #FFFFFF;
    font-size: clamp(2.55rem, 5vw, 4.9rem);
    line-height: 0.98;
}

.demo-business-hero p {
    max-width: 620px;
    color: rgba(255, 255, 255, 0.82);
    font-size: 1.04rem;
}

.demo-business-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.demo-business-stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 12px;
    margin: 10px 0 0;
}

.demo-business-stats div {
    padding: 16px;
    border-left: 4px solid var(--handwerk-orange);
    background: rgba(255, 255, 255, 0.08);
}

.demo-business-stats dt {
    color: #FFFFFF;
    font-size: clamp(1.65rem, 3vw, 2.35rem);
    font-weight: 900;
    line-height: 1;
}

.demo-business-stats dd {
    margin: 7px 0 0;
    color: rgba(255, 255, 255, 0.74);
    font-size: 0.82rem;
    font-weight: 760;
}

.demo-business-hero-media {
    position: relative;
    min-height: 470px;
    overflow: hidden;
    border: 8px solid rgba(232, 213, 181, 0.36);
    border-radius: 10px;
    background: var(--handwerk-slate);
    box-shadow: 18px 18px 0 rgba(17, 24, 22, 0.32);
}

.demo-business-hero-media img,
.demo-business-proof-image img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business-project-badge {
    position: absolute;
    right: 22px;
    bottom: 22px;
    display: grid;
    gap: 5px;
    max-width: 250px;
    padding: 16px;
    color: #FFFFFF;
    border-left: 5px solid var(--handwerk-orange);
    background: rgba(17, 24, 22, 0.9);
}

.demo-business-project-badge span {
    color: var(--handwerk-sand);
    font-size: 0.72rem;
    font-weight: 820;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.demo-business-project-badge strong {
    font-size: 1rem;
    line-height: 1.25;
}

.demo-business-trust {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    background: rgba(31, 37, 35, 0.18);
}

.demo-business-trust span {
    min-height: 86px;
    padding: 22px 20px;
    color: var(--handwerk-ink);
    background: var(--handwerk-sand);
    font-size: 0.92rem;
    font-weight: 840;
}

.demo-business-section {
    padding: 66px 54px;
}

.demo-business-section-heading {
    display: grid;
    gap: 12px;
    max-width: 760px;
    margin-bottom: 34px;
}

.demo-business-section h2,
.demo-business-proof-copy h2,
.demo-business-region h2,
.demo-business-final-cta h2 {
    font-size: clamp(2rem, 3.6vw, 3.4rem);
    line-height: 1.04;
}

.demo-business-section-heading p,
.demo-business-proof-copy p,
.demo-business-region p,
.demo-business-final-cta p {
    max-width: 720px;
    font-size: 1rem;
}

.demo-business-service-layout {
    display: grid;
    grid-template-columns: minmax(280px, 0.9fr) minmax(0, 1.1fr);
    gap: 22px;
    align-items: stretch;
}

.demo-business-service-stack {
    display: grid;
    gap: 18px;
}

.demo-business-service-card {
    display: grid;
    align-content: start;
    gap: 12px;
    padding: 26px;
    border: 1px solid rgba(31, 37, 35, 0.16);
    border-radius: 10px;
    background:
        linear-gradient(135deg, #FFFFFF 0%, #F7F0E6 100%);
    box-shadow: 9px 9px 0 rgba(166, 106, 44, 0.12);
}

.demo-business-service-card--main {
    align-content: end;
    min-height: 430px;
    color: #FFFFFF;
    background:
        linear-gradient(145deg, rgba(31, 37, 35, 0.94) 0%, rgba(17, 24, 22, 0.96) 54%, rgba(166, 106, 44, 0.8) 100%);
    box-shadow: 12px 12px 0 rgba(17, 24, 22, 0.18);
}

.demo-business-service-card span {
    color: var(--handwerk-orange);
    font-size: 0.82rem;
    font-weight: 900;
}

.demo-business-service-card h3 {
    font-size: 1.35rem;
}

.demo-business-service-card--main h3 {
    color: #FFFFFF;
    font-size: clamp(2rem, 3vw, 3rem);
}

.demo-business-service-card--main p {
    color: rgba(255, 255, 255, 0.78);
}

.demo-business-proof {
    color: #FFFFFF;
    background: var(--handwerk-slate);
}

.demo-business-proof-copy {
    display: grid;
    gap: 12px;
    max-width: 820px;
    margin-bottom: 34px;
}

.demo-business-proof h2 {
    color: #FFFFFF;
}

.demo-business-proof p {
    color: rgba(255, 255, 255, 0.74);
}

.demo-business-proof-layout {
    display: grid;
    grid-template-columns: minmax(320px, 0.92fr) minmax(0, 1.08fr);
    gap: 24px;
    align-items: stretch;
}

.demo-business-proof-image {
    min-height: 430px;
    margin: 0;
    overflow: hidden;
    border: 6px solid rgba(232, 213, 181, 0.24);
    border-radius: 8px;
}

.demo-business-project-list {
    display: grid;
    gap: 16px;
}

.demo-business-project-list article {
    display: grid;
    gap: 8px;
    padding: 24px;
    border: 1px solid rgba(232, 213, 181, 0.18);
    border-left: 6px solid var(--handwerk-orange);
    background: rgba(255, 255, 255, 0.06);
}

.demo-business-project-list span {
    color: var(--handwerk-sand);
    font-size: 0.78rem;
    font-weight: 820;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.demo-business-project-list h3 {
    color: #FFFFFF;
    font-size: 1.35rem;
}

.demo-business-process {
    background: #FFFFFF;
}

.demo-business-process-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.demo-business-process-grid::before {
    content: "";
    position: absolute;
    top: 45px;
    right: 12%;
    left: 12%;
    height: 3px;
    background: var(--handwerk-sand);
}

.demo-business-process-grid article {
    position: relative;
    display: grid;
    gap: 12px;
    padding: 26px;
    border: 1px solid rgba(31, 37, 35, 0.14);
    border-radius: 8px;
    background: #FFFFFF;
    box-shadow: 8px 8px 0 rgba(31, 37, 35, 0.08);
}

.demo-business-process-grid article span {
    display: inline-grid;
    place-items: center;
    width: 58px;
    height: 58px;
    color: #FFFFFF;
    background: var(--handwerk-ink);
    font-size: 1.1rem;
    font-weight: 900;
}

.demo-business-region {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(300px, 0.65fr);
    gap: 30px;
    align-items: center;
    background: var(--handwerk-beige);
}

.demo-business-region > div:first-child,
.demo-business-final-cta > div:first-child {
    display: grid;
    gap: 12px;
}

.demo-business-region-panel {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    min-height: 240px;
    align-content: center;
    justify-content: center;
    padding: 28px;
    border: 2px dashed rgba(31, 37, 35, 0.28);
    background:
        radial-gradient(circle at 25% 30%, rgba(228, 111, 42, 0.16), transparent 30%),
        radial-gradient(circle at 72% 64%, rgba(166, 106, 44, 0.18), transparent 34%),
        #FFFFFF;
}

.demo-business-region-panel span {
    padding: 9px 12px;
    color: var(--handwerk-ink);
    border: 1px solid rgba(31, 37, 35, 0.12);
    background: var(--handwerk-sand);
    font-size: 0.85rem;
    font-weight: 820;
}

.demo-business-final-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 26px;
    align-items: center;
    color: #FFFFFF;
    background:
        linear-gradient(135deg, var(--handwerk-ink) 0%, var(--handwerk-slate) 58%, #5A351C 100%);
}

.demo-business-final-cta h2 {
    color: #FFFFFF;
}

.demo-business-final-cta p {
    color: rgba(255, 255, 255, 0.78);
}

.demo-business-final-cta .demo-business-button--secondary {
    color: #FFFFFF;
    border-color: rgba(255, 255, 255, 0.28);
    background: transparent;
}

.demo-business-footer {
    grid-template-columns: minmax(230px, 1fr) minmax(190px, 0.8fr) minmax(160px, 0.55fr);
    padding: 30px 28px;
    border-top: 4px solid var(--handwerk-orange);
}

.demo-business-footer div,
.demo-business-footer nav {
    display: grid;
    gap: 7px;
}

.demo-business-footer strong {
    color: #FFFFFF;
    font-size: 1.05rem;
}

.demo-business-footer p,
.demo-business-footer a,
.demo-business-footer span,
.demo-business-footer small {
    color: rgba(255, 255, 255, 0.72);
    font-size: 0.88rem;
}

.demo-business-footer span {
    color: var(--handwerk-sand);
    font-weight: 820;
}

.demo-business-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

@media (max-width: 1023px) {
    .demo-business-header {
        grid-template-columns: 1fr;
    }

    .demo-business-nav {
        justify-content: flex-start;
    }

    .demo-business-hero,
    .demo-business-service-layout,
    .demo-business-proof-layout,
    .demo-business-region,
    .demo-business-final-cta,
    .demo-business-footer {
        grid-template-columns: 1fr;
    }

    .demo-business-hero {
        padding: 46px 34px 38px;
    }

    .demo-business-section {
        padding: 52px 34px;
    }

    .demo-business-hero-media,
    .demo-business-proof-image {
        min-height: 340px;
    }

    .demo-business-final-cta .demo-business-actions {
        justify-content: flex-start;
    }
}

@media (max-width: 767px) {
    .demo-business--handwerk {
        border-radius: 14px;
    }

    .demo-business-header,
    .demo-business-footer {
        padding: 22px;
    }

    .demo-business-nav {
        gap: 12px;
        font-size: 0.82rem;
    }

    .demo-business-header > .demo-business-button {
        width: 100%;
    }

    .demo-business-hero {
        gap: 30px;
        padding: 36px 22px 30px;
    }

    .demo-business-hero h1 {
        font-size: clamp(2.3rem, 12vw, 3.6rem);
    }

    .demo-business-actions,
    .demo-business-button {
        width: 100%;
    }

    .demo-business-stats,
    .demo-business-trust,
    .demo-business-process-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-stats div {
        padding: 14px;
    }

    .demo-business-hero-media,
    .demo-business-proof-image {
        min-height: 260px;
        border-width: 5px;
        box-shadow: 10px 10px 0 rgba(17, 24, 22, 0.18);
    }

    .demo-business-project-badge {
        right: 12px;
        bottom: 12px;
        max-width: calc(100% - 24px);
    }

    .demo-business-section {
        padding: 42px 22px;
    }

    .demo-business-service-card,
    .demo-business-project-list article,
    .demo-business-process-grid article {
        padding: 22px;
    }

    .demo-business-service-card--main {
        min-height: 300px;
    }

    .demo-business-process-grid::before {
        display: none;
    }

    .demo-business-region-panel {
        min-height: 190px;
        padding: 20px;
    }
}

/* Gastronomie demo v2 */
.demo-business--gastro-v2 {
    --gastro-v2-black: #0E0F0C;
    --gastro-v2-anthracite: #1B1D18;
    --gastro-v2-olive: #303829;
    --gastro-v2-ivory: #F7F1E5;
    --gastro-v2-champagne: #E6D3AC;
    --gastro-v2-gold: #B88A44;
    --gastro-v2-gold-dark: #987038;
    --gastro-v2-muted: #766D60;
    color: var(--gastro-v2-anthracite);
    background: var(--gastro-v2-ivory);
}

.demo-business--gastro-v2,
.demo-business--gastro-v2 * {
    box-sizing: border-box;
}

.demo-business--gastro-v2 a {
    text-decoration: none;
}

.demo-business--gastro-v2 img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business--gastro-v2 h1,
.demo-business--gastro-v2 h2,
.demo-business--gastro-v2 h3,
.demo-business--gastro-v2 p,
.demo-business--gastro-v2 figure,
.demo-business--gastro-v2 ul {
    margin: 0;
}

.demo-business--gastro-v2 h1,
.demo-business--gastro-v2 h2,
.demo-business--gastro-v2 h3 {
    color: inherit;
    letter-spacing: 0;
}

.demo-business--gastro-v2 p {
    color: var(--gastro-v2-muted);
    line-height: 1.72;
}

.demo-business--gastro-v2 .demo-business-gastro-header--stacked {
    position: sticky;
    top: 0;
    z-index: 20;
    display: grid;
    grid-template-columns: minmax(210px, 0.8fr) minmax(260px, 0.9fr) minmax(0, 1.4fr);
    gap: 20px;
    align-items: center;
    padding: 20px 32px;
    color: var(--gastro-v2-ivory);
    background: rgba(14, 15, 12, 0.98);
    border-bottom: 1px solid rgba(230, 211, 172, 0.2);
    transform: translateY(0);
    transition: transform 220ms ease, box-shadow 220ms ease, opacity 220ms ease;
    will-change: transform;
}

.demo-business--gastro-v2 [data-demo-smart-header].is-demo-header-hidden {
    transform: translateY(calc(-100% - 2px));
    pointer-events: none;
}

.demo-business--gastro-v2 [data-demo-smart-header].is-demo-header-visible,
.demo-business--gastro-v2 [data-demo-smart-header]:focus-within {
    transform: translateY(0);
    pointer-events: auto;
}

.demo-business--gastro-v2 [data-demo-smart-header].is-demo-header-visible {
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.16);
}

.demo-business--gastro-v2 .demo-business-gastro-brand {
    display: grid;
    gap: 4px;
    color: var(--gastro-v2-ivory);
    line-height: 1.15;
}

.demo-business--gastro-v2 .demo-business-gastro-brand span {
    font-size: 1.18rem;
    font-weight: 860;
}

.demo-business--gastro-v2 .demo-business-gastro-brand small {
    color: var(--gastro-v2-champagne);
    font-size: 0.75rem;
    font-weight: 720;
    letter-spacing: 0.04em;
}

.demo-business--gastro-v2 .demo-business-gastro-header-info {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0;
    color: rgba(247, 241, 229, 0.82);
    font-size: 0.84rem;
    font-weight: 760;
    line-height: 1.4;
}

.demo-business--gastro-v2 .demo-business-gastro-header-info span + span::before {
    content: "·";
    display: inline-block;
    margin: 0 9px;
    color: rgba(230, 211, 172, 0.72);
}

.demo-business--gastro-v2 .demo-business-menu--gastro {
    display: flex;
    min-width: 0;
    align-items: center;
    justify-content: flex-end;
    gap: 18px;
}

.demo-business--gastro-v2 .demo-business-gastro-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 18px;
    color: rgba(247, 241, 229, 0.78);
    font-size: 0.9rem;
    font-weight: 760;
}

.demo-business--gastro-v2 .demo-business-gastro-nav a,
.demo-business--gastro-v2 .demo-business-gastro-footer a {
    transition: color 180ms ease, background-color 180ms ease, transform 180ms ease, border-color 180ms ease;
}

.demo-business--gastro-v2 .demo-business-gastro-brand:hover,
.demo-business--gastro-v2 .demo-business-gastro-brand:focus-visible,
.demo-business--gastro-v2 .demo-business-gastro-nav a:hover,
.demo-business--gastro-v2 .demo-business-gastro-nav a:focus-visible,
.demo-business--gastro-v2 .demo-business-gastro-footer a:hover,
.demo-business--gastro-v2 .demo-business-gastro-footer a:focus-visible {
    color: var(--gastro-v2-champagne);
}

.demo-business-menu-toggle--gastro {
    color: var(--gastro-v2-ivory);
    border-color: rgba(230, 211, 172, 0.34);
    background: rgba(247, 241, 229, 0.06);
}

.demo-business--gastro-v2 .demo-business-gastro-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 13px 20px;
    border: 1px solid transparent;
    border-radius: 8px;
    font-size: 0.92rem;
    font-weight: 820;
    line-height: 1.15;
    transition: color 180ms ease, background-color 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.demo-business--gastro-v2 .demo-business-gastro-button--primary {
    color: #FFFFFF;
    border-color: var(--gastro-v2-gold);
    background: var(--gastro-v2-gold);
}

.demo-business--gastro-v2 .demo-business-gastro-button--primary:hover,
.demo-business--gastro-v2 .demo-business-gastro-button--primary:focus-visible {
    color: #FFFFFF;
    border-color: var(--gastro-v2-gold-dark);
    background: var(--gastro-v2-gold-dark);
    transform: translateY(-1px);
}

.demo-business--gastro-v2 .demo-business-gastro-button--secondary {
    color: var(--gastro-v2-anthracite);
    border-color: rgba(48, 56, 41, 0.22);
    background: rgba(247, 241, 229, 0.86);
}

.demo-business--gastro-v2 .demo-business-gastro-button--secondary:hover,
.demo-business--gastro-v2 .demo-business-gastro-button--secondary:focus-visible {
    color: var(--gastro-v2-ivory);
    border-color: var(--gastro-v2-olive);
    background: var(--gastro-v2-olive);
    transform: translateY(-1px);
}

.demo-business--gastro-v2 .demo-business-gastro-main {
    display: grid;
    background: var(--gastro-v2-ivory);
}

.demo-business--gastro-v2 .demo-business-gastro-hero,
.demo-business--gastro-v2 .demo-business-gastro-split,
.demo-business--gastro-v2 .demo-business-gastro-moments,
.demo-business--gastro-v2 .demo-business-gastro-reservation-band,
.demo-business--gastro-v2 .demo-business-gastro-reservation-form-section,
.demo-business--gastro-v2 .demo-business-gastro-contact {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(340px, 1fr);
    gap: 44px;
    align-items: center;
    padding: 74px 52px;
}

.demo-business--gastro-v2 .demo-business-gastro-hero {
    color: var(--gastro-v2-ivory);
    background: linear-gradient(135deg, var(--gastro-v2-black) 0%, var(--gastro-v2-anthracite) 64%, var(--gastro-v2-olive) 100%);
}

.demo-business--gastro-v2 .demo-business-gastro-hero::after {
    content: none;
}

.demo-business--gastro-v2 .demo-business-gastro-hero img {
    position: static;
    inset: auto;
}

.demo-business--gastro-v2 .demo-business-gastro-hero-copy,
.demo-business--gastro-v2 .demo-business-gastro-section-copy,
.demo-business--gastro-v2 .demo-business-gastro-heading {
    display: grid;
    gap: 15px;
}

.demo-business--gastro-v2 .demo-business-gastro-hero-copy > span,
.demo-business--gastro-v2 .demo-business-gastro-section-copy > span,
.demo-business--gastro-v2 .demo-business-gastro-heading > span {
    color: var(--gastro-v2-gold);
    font-size: 0.78rem;
    font-weight: 860;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.demo-business--gastro-v2 .demo-business-gastro-hero h1 {
    color: #FFFFFF;
    font-size: clamp(3rem, 6vw, 5.6rem);
    line-height: 0.98;
}

.demo-business--gastro-v2 .demo-business-gastro-hero p {
    max-width: 650px;
    color: rgba(247, 241, 229, 0.82);
    font-size: 1.08rem;
}

.demo-business--gastro-v2 .demo-business-gastro-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.demo-business--gastro-v2 .demo-business-gastro-hero-visual,
.demo-business--gastro-v2 .demo-business-gastro-split figure,
.demo-business--gastro-v2 .demo-business-gastro-moments figure {
    aspect-ratio: 4 / 3;
    min-height: 500px;
    overflow: hidden;
    border-radius: 14px;
    box-shadow: 0 24px 62px rgba(14, 15, 12, 0.24);
}

.demo-business--gastro-v2 .demo-business-gastro-hero-visual img,
.demo-business--gastro-v2 .demo-business-gastro-split figure img,
.demo-business--gastro-v2 .demo-business-gastro-moments figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business--gastro-v2 .demo-business-gastro-hero-visual > picture,
.demo-business--gastro-v2 .demo-business-gastro-hero-visual > picture > img {
    display: block;
    width: 100%;
    height: 100%;
}

.demo-business--gastro-v2 .demo-business-gastro-split,
.demo-business--gastro-v2 .demo-business-gastro-menu-section,
.demo-business--gastro-v2 .demo-business-gastro-about {
    background: linear-gradient(180deg, var(--gastro-v2-ivory) 0%, #FFFFFF 100%);
}

.demo-business--gastro-v2 h2 {
    max-width: 760px;
    font-size: clamp(2.2rem, 4.2vw, 4.2rem);
    line-height: 1.02;
}

.demo-business--gastro-v2 h3 {
    font-size: 1.2rem;
    line-height: 1.18;
}

.demo-business--gastro-v2 .demo-business-gastro-featured,
.demo-business--gastro-v2 .demo-business-gastro-menu-section,
.demo-business--gastro-v2 .demo-business-gastro-gallery,
.demo-business--gastro-v2 .demo-business-gastro-about {
    padding: 74px 52px;
}

.demo-business--gastro-v2 .demo-business-gastro-dish-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 18px;
    margin-top: 34px;
}

.demo-business--gastro-v2 .demo-business-gastro-dish-grid article {
    display: grid;
    overflow: hidden;
    border: 1px solid rgba(48, 56, 41, 0.14);
    border-radius: 12px;
    background: #FFFFFF;
    transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease;
}

.demo-business--gastro-v2 .demo-business-gastro-dish-grid img {
    aspect-ratio: 4 / 3;
}

.demo-business--gastro-v2 .demo-business-gastro-dish-grid h3 {
    padding: 22px;
}

.demo-business--gastro-v2 .demo-business-gastro-center-action {
    display: flex;
    justify-content: center;
    margin-top: 28px;
}

.demo-business--gastro-v2 .demo-business-gastro-moments {
    grid-template-columns: minmax(0, 0.7fr) minmax(360px, 1fr);
    color: var(--gastro-v2-ivory);
    background: var(--gastro-v2-anthracite);
}

.demo-business--gastro-v2 .demo-business-gastro-moments h2 {
    color: #FFFFFF;
}

.demo-business--gastro-v2 .demo-business-gastro-moments p {
    color: rgba(247, 241, 229, 0.78);
}

.demo-business--gastro-v2 .demo-business-gastro-chef {
    background: var(--gastro-v2-champagne);
}

.demo-business--gastro-v2 .demo-business-gastro-chef figure img,
.demo-business--gastro-v2 .demo-business-gastro-team img {
    object-position: 70% top;
}

.demo-business--gastro-v2 .demo-business-gastro-reservation-band {
    grid-template-columns: minmax(0, 1fr) auto;
    color: var(--gastro-v2-ivory);
    background: linear-gradient(135deg, var(--gastro-v2-black) 0%, var(--gastro-v2-olive) 100%);
}

.demo-business--gastro-v2 .demo-business-gastro-reservation-band h2 {
    color: #FFFFFF;
}

.demo-business--gastro-v2 .demo-business-gastro-reservation-band p {
    color: rgba(247, 241, 229, 0.78);
}

.demo-business--gastro-v2 .demo-business-gastro-menu-board {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-top: 34px;
}

.demo-business--gastro-v2 .demo-business-gastro-menu-board article {
    display: grid;
    gap: 16px;
    padding: 26px;
    border: 1px solid rgba(48, 56, 41, 0.14);
    border-top: 4px solid var(--gastro-v2-gold);
    border-radius: 12px;
    background: #FFFFFF;
}

.demo-business--gastro-v2 .demo-business-gastro-menu-board-wide {
    grid-column: 1 / -1;
}

.demo-business--gastro-v2 .demo-business-gastro-menu-board ul {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px 18px;
    padding: 0;
    list-style: none;
}

.demo-business--gastro-v2 .demo-business-gastro-menu-board article:not(.demo-business-gastro-menu-board-wide) ul {
    grid-template-columns: 1fr;
}

.demo-business--gastro-v2 .demo-business-gastro-menu-board li {
    color: var(--gastro-v2-muted);
    font-weight: 740;
}

.demo-business--gastro-v2 .demo-business-gastro-masonry {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
    margin-top: 34px;
}

.demo-business--gastro-v2 .demo-business-gastro-masonry img {
    display: block;
    width: 100%;
    height: 100%;
    aspect-ratio: 4 / 3;
    border-radius: 12px;
    object-fit: cover;
    box-shadow: 0 16px 34px rgba(14, 15, 12, 0.12);
}

.demo-business--gastro-v2 .demo-business-gastro-masonry .demo-business-gastro-gallery-portrait {
    object-position: 70% top;
}

.demo-business--gastro-v2 .demo-business-gastro-about {
    display: grid;
    gap: 38px;
}

.demo-business--gastro-v2 .demo-business-gastro-team {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.demo-business--gastro-v2 .demo-business-gastro-team article {
    display: grid;
    gap: 10px;
    overflow: hidden;
    border: 1px solid rgba(48, 56, 41, 0.14);
    border-radius: 12px;
    background: #FFFFFF;
}

.demo-business--gastro-v2 .demo-business-gastro-team img {
    aspect-ratio: 4 / 5;
}

.demo-business--gastro-v2 .demo-business-gastro-team h3,
.demo-business--gastro-v2 .demo-business-gastro-team p {
    padding-inline: 22px;
}

.demo-business--gastro-v2 .demo-business-gastro-team p {
    padding-bottom: 22px;
    color: var(--gastro-v2-gold-dark);
    font-weight: 820;
}

.demo-business--gastro-v2 .demo-business-gastro-reservation-form-section {
    grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
    align-items: start;
    background: var(--gastro-v2-ivory);
}

.demo-business--gastro-v2 .demo-business-gastro-reservation-intro {
    display: grid;
    gap: 24px;
}

.demo-business--gastro-v2 .demo-business-gastro-reservation-image {
    width: 100%;
    aspect-ratio: 4 / 3;
    overflow: hidden;
    border-radius: 12px;
    box-shadow: 0 18px 48px rgba(14, 15, 12, 0.12);
}

.demo-business--gastro-v2 .demo-business-gastro-reservation-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business--gastro-v2 .demo-business-gastro-form {
    display: grid;
    gap: 16px;
    padding: 28px;
    border: 1px solid rgba(48, 56, 41, 0.14);
    border-radius: 12px;
    background: #FFFFFF;
    box-shadow: 0 18px 48px rgba(14, 15, 12, 0.1);
}

.demo-business--gastro-v2 .demo-business-gastro-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.demo-business--gastro-v2 .demo-business-gastro-form label {
    display: grid;
    gap: 7px;
}

.demo-business--gastro-v2 .demo-business-gastro-form label > span {
    color: var(--gastro-v2-anthracite);
    font-size: 0.84rem;
    font-weight: 820;
}

.demo-business--gastro-v2 .demo-business-gastro-form input,
.demo-business--gastro-v2 .demo-business-gastro-form textarea {
    width: 100%;
    min-height: 46px;
    padding: 12px 13px;
    color: var(--gastro-v2-anthracite);
    border: 1px solid rgba(48, 56, 41, 0.18);
    border-radius: 8px;
    background: #FFFFFF;
    font: inherit;
}

.demo-business--gastro-v2 .demo-business-gastro-form textarea {
    resize: vertical;
}

.demo-business--gastro-v2 .demo-business-gastro-form-success {
    display: grid;
    gap: 6px;
    padding: 16px;
    color: var(--gastro-v2-anthracite);
    border-left: 5px solid var(--gastro-v2-gold);
    background: var(--gastro-v2-ivory);
}

.demo-business--gastro-v2 .demo-business-gastro-form-success[hidden] {
    display: none;
}

.demo-business--gastro-v2 .demo-business-gastro-contact {
    background: #FFFFFF;
}

.demo-business--gastro-v2 .demo-business-gastro-contact address {
    color: var(--gastro-v2-muted);
    font-style: normal;
    line-height: 1.7;
}

.demo-business--gastro-v2 .demo-business-gastro-contact address a {
    color: var(--gastro-v2-anthracite);
    font-weight: 820;
}

.demo-business--gastro-v2 .demo-business-gastro-hours-card {
    display: grid;
    gap: 1px;
    overflow: hidden;
    border: 1px solid rgba(48, 56, 41, 0.14);
    border-radius: 12px;
    background: rgba(48, 56, 41, 0.14);
}

.demo-business--gastro-v2 .demo-business-gastro-hours-card h3 {
    padding: 22px;
    background: var(--gastro-v2-ivory);
}

.demo-business--gastro-v2 .demo-business-gastro-hours-card div {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    padding: 18px 22px;
    background: #FFFFFF;
}

.demo-business--gastro-v2 .demo-business-gastro-hours-card span {
    color: var(--gastro-v2-muted);
    font-weight: 760;
}

.demo-business--gastro-v2 .demo-business-gastro-hours-card strong {
    color: var(--gastro-v2-anthracite);
    white-space: nowrap;
}

.demo-business--gastro-v2 .demo-business-gastro-footer {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(210px, 0.85fr) minmax(190px, 0.7fr);
    gap: 24px;
    padding: 34px 52px;
    color: var(--gastro-v2-ivory);
    background: var(--gastro-v2-black);
}

.demo-business--gastro-v2 .demo-business-gastro-footer div,
.demo-business--gastro-v2 .demo-business-gastro-footer nav {
    display: grid;
    gap: 7px;
}

.demo-business--gastro-v2 .demo-business-gastro-footer-brand {
    color: #FFFFFF;
    font-size: clamp(1.25rem, 1.8vw, 1.55rem);
    font-weight: 940;
    line-height: 1.18;
}

.demo-business--gastro-v2 .demo-business-gastro-footer p,
.demo-business--gastro-v2 .demo-business-gastro-footer a,
.demo-business--gastro-v2 .demo-business-gastro-footer span,
.demo-business--gastro-v2 .demo-business-gastro-footer small {
    color: rgba(247, 241, 229, 0.74);
    font-size: 0.88rem;
}

.demo-business--gastro-v2 .demo-business-gastro-footer span {
    color: var(--gastro-v2-champagne);
    font-weight: 820;
}

.demo-business--gastro-v2 .demo-business-gastro-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(247, 241, 229, 0.12);
}

@media (hover: hover) and (pointer: fine) {
    .demo-business--gastro-v2 .demo-business-gastro-dish-grid article:hover,
    .demo-business--gastro-v2 .demo-business-gastro-team article:hover {
        transform: translateY(-5px);
        border-color: rgba(184, 138, 68, 0.34);
        box-shadow: 0 18px 38px rgba(14, 15, 12, 0.14);
    }
}

@media (max-width: 1180px) {
    .demo-business--gastro-v2 .demo-business-menu-toggle--gastro {
        display: inline-flex;
        grid-column: 2;
        grid-row: 1;
    }

    .demo-business--gastro-v2 .demo-business-gastro-header--stacked {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 12px 16px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-header-info {
        grid-column: 1 / -1;
        grid-row: 2;
        justify-content: center;
        text-align: center;
    }

    .demo-business--gastro-v2 .demo-business-menu--gastro {
        display: none;
        grid-column: 1 / -1;
        grid-row: 3;
        width: 100%;
        align-items: stretch;
        justify-content: stretch;
        gap: 14px;
        padding-top: 12px;
        border-top: 1px solid rgba(230, 211, 172, 0.16);
    }

    .demo-business--gastro-v2 .is-demo-menu-open .demo-business-menu--gastro {
        display: grid;
    }

    .demo-business--gastro-v2 .demo-business-gastro-nav {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        justify-content: stretch;
    }

    .demo-business--gastro-v2 .demo-business-gastro-nav a {
        padding: 11px 12px;
        border-radius: 8px;
        background: rgba(247, 241, 229, 0.08);
    }

    .demo-business--gastro-v2 .demo-business-menu--gastro > .demo-business-gastro-button {
        width: 100%;
    }

    .demo-business--gastro-v2 .demo-business-gastro-dish-grid,
    .demo-business--gastro-v2 .demo-business-gastro-menu-board,
    .demo-business--gastro-v2 .demo-business-gastro-team {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    .demo-business--gastro-v2 .demo-business-gastro-hero,
    .demo-business--gastro-v2 .demo-business-gastro-split,
    .demo-business--gastro-v2 .demo-business-gastro-moments,
    .demo-business--gastro-v2 .demo-business-gastro-reservation-band,
    .demo-business--gastro-v2 .demo-business-gastro-reservation-form-section,
    .demo-business--gastro-v2 .demo-business-gastro-contact,
    .demo-business--gastro-v2 .demo-business-gastro-footer {
        grid-template-columns: 1fr;
    }

    .demo-business--gastro-v2 .demo-business-gastro-hero,
    .demo-business--gastro-v2 .demo-business-gastro-split,
    .demo-business--gastro-v2 .demo-business-gastro-moments,
    .demo-business--gastro-v2 .demo-business-gastro-reservation-band,
    .demo-business--gastro-v2 .demo-business-gastro-reservation-form-section,
    .demo-business--gastro-v2 .demo-business-gastro-contact,
    .demo-business--gastro-v2 .demo-business-gastro-featured,
    .demo-business--gastro-v2 .demo-business-gastro-menu-section,
    .demo-business--gastro-v2 .demo-business-gastro-gallery,
    .demo-business--gastro-v2 .demo-business-gastro-about,
    .demo-business--gastro-v2 .demo-business-gastro-footer {
        padding: 58px 38px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-hero-visual,
    .demo-business--gastro-v2 .demo-business-gastro-split figure,
    .demo-business--gastro-v2 .demo-business-gastro-moments figure {
        min-height: 360px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-reservation-image {
        min-height: 340px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-masonry {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .demo-business--gastro-v2 .demo-business-gastro-header--stacked {
        padding: 22px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-header-info {
        font-size: 0.8rem;
    }

    .demo-business--gastro-v2 .demo-business-gastro-header-info span + span::before {
        margin: 0 6px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-hero,
    .demo-business--gastro-v2 .demo-business-gastro-split,
    .demo-business--gastro-v2 .demo-business-gastro-moments,
    .demo-business--gastro-v2 .demo-business-gastro-reservation-band,
    .demo-business--gastro-v2 .demo-business-gastro-reservation-form-section,
    .demo-business--gastro-v2 .demo-business-gastro-contact,
    .demo-business--gastro-v2 .demo-business-gastro-featured,
    .demo-business--gastro-v2 .demo-business-gastro-menu-section,
    .demo-business--gastro-v2 .demo-business-gastro-gallery,
    .demo-business--gastro-v2 .demo-business-gastro-about,
    .demo-business--gastro-v2 .demo-business-gastro-footer {
        padding: 44px 22px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-nav,
    .demo-business--gastro-v2 .demo-business-gastro-dish-grid,
    .demo-business--gastro-v2 .demo-business-gastro-masonry,
    .demo-business--gastro-v2 .demo-business-gastro-menu-board,
    .demo-business--gastro-v2 .demo-business-gastro-menu-board ul,
    .demo-business--gastro-v2 .demo-business-gastro-team,
    .demo-business--gastro-v2 .demo-business-gastro-form-grid {
        grid-template-columns: 1fr;
    }

    .demo-business--gastro-v2 .demo-business-gastro-hero h1 {
        font-size: clamp(2.55rem, 12vw, 3.65rem);
    }

    .demo-business--gastro-v2 h2 {
        font-size: clamp(1.9rem, 9vw, 2.8rem);
    }

    .demo-business--gastro-v2 .demo-business-gastro-actions,
    .demo-business--gastro-v2 .demo-business-gastro-button {
        width: 100%;
    }

    .demo-business--gastro-v2 .demo-business-gastro-hero-visual,
    .demo-business--gastro-v2 .demo-business-gastro-split figure,
    .demo-business--gastro-v2 .demo-business-gastro-moments figure {
        min-height: 300px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-reservation-image {
        min-height: 260px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-form,
    .demo-business--gastro-v2 .demo-business-gastro-menu-board article {
        padding: 22px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-hours-card div {
        grid-template-columns: 1fr;
        gap: 5px;
    }

    .demo-business--gastro-v2 .demo-business-gastro-hours-card strong {
        white-space: normal;
    }
}

.demo-business--handwerk .demo-business-image-slot {
    position: relative;
    display: grid;
    min-height: 260px;
    overflow: hidden;
    place-items: center;
    color: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(31, 37, 35, 0.16);
    background:
        linear-gradient(135deg, rgba(17, 24, 22, 0.78), rgba(166, 106, 44, 0.48)),
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 14px),
        var(--handwerk-slate);
}

.demo-business--handwerk .demo-business-image-slot::before {
    content: attr(data-slot);
    position: relative;
    z-index: 1;
    padding: 9px 12px;
    color: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(255, 255, 255, 0.18);
    background: rgba(17, 24, 22, 0.62);
    font-size: 0.76rem;
    font-weight: 820;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.demo-business--handwerk .demo-business-image-slot--hero-roof {
    min-height: 470px;
    border: 8px solid rgba(232, 213, 181, 0.36);
    border-radius: 10px;
    box-shadow: 18px 18px 0 rgba(17, 24, 22, 0.32);
}

.demo-business--handwerk .demo-business-image-slot--company-history,
.demo-business--handwerk .demo-business-image-slot--team-workshop,
.demo-business--handwerk .demo-business-image-slot--contact {
    min-height: 380px;
    border-radius: 10px;
}

.demo-business--handwerk .demo-business-image-slot--service,
.demo-business--handwerk .demo-business-image-slot--project,
.demo-business--handwerk .demo-business-image-slot--region-map {
    min-height: 250px;
    border-radius: 8px;
}

.demo-business-hero-trust {
    display: grid;
    gap: 9px;
    margin-top: 2px;
}

.demo-business-hero-trust span {
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.9rem;
    font-weight: 760;
}

.demo-business-history {
    background: #FFFFFF;
}

.demo-business-history-layout,
.demo-business-team-layout,
.demo-business-contact {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(320px, 1fr);
    gap: 30px;
    align-items: stretch;
}

.demo-business-team-layout {
    align-items: start;
}

.demo-business-team-layout .demo-business-image-slot--team-workshop {
    aspect-ratio: 3 / 2;
    min-height: 0;
}

.demo-business-history-copy {
    display: grid;
    align-content: center;
    gap: 16px;
    padding: 34px;
    border-left: 6px solid var(--handwerk-orange);
    background: var(--handwerk-beige);
}

.demo-business-service-detail-list {
    display: grid;
    gap: 22px;
}

.demo-business-service-detail {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.72fr);
    gap: 24px;
    align-items: stretch;
    padding: 26px;
    border: 1px solid rgba(31, 37, 35, 0.14);
    background: #FFFFFF;
    box-shadow: 10px 10px 0 rgba(166, 106, 44, 0.1);
}

.demo-business-service-detail > div:first-child {
    display: grid;
    align-content: start;
    gap: 12px;
}

.demo-business-service-detail span,
.demo-business-material-grid h3,
.demo-business-faq-list button {
    color: var(--handwerk-ink);
}

.demo-business-service-detail > div:first-child > span {
    color: var(--handwerk-orange);
    font-size: 0.82rem;
    font-weight: 900;
}

.demo-business-service-detail ul {
    display: grid;
    gap: 8px;
    margin: 6px 0 0;
    padding: 0;
    list-style: none;
}

.demo-business-service-detail li {
    color: var(--handwerk-muted);
    font-size: 0.92rem;
    font-weight: 720;
}

.demo-business-service-detail li::before {
    content: "✓";
    margin-right: 8px;
    color: var(--handwerk-orange);
    font-weight: 900;
}

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

.demo-business-project-grid article {
    display: grid;
    overflow: hidden;
    border: 1px solid rgba(232, 213, 181, 0.18);
    background: rgba(255, 255, 255, 0.06);
}

.demo-business-project-grid article > div:last-child {
    display: grid;
    gap: 10px;
    padding: 22px;
}

.demo-business-project-grid span {
    color: var(--handwerk-sand);
    font-size: 0.78rem;
    font-weight: 820;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.demo-business-project-grid h3,
.demo-business-project-grid strong {
    color: #FFFFFF;
}

.demo-business-project-grid p {
    color: rgba(255, 255, 255, 0.74);
}

.demo-business-team {
    background: var(--handwerk-beige);
}

.demo-business-team-list {
    display: grid;
    gap: 16px;
}

.demo-business-team-list article {
    display: grid;
    gap: 8px;
    padding: 26px;
    border: 1px solid rgba(31, 37, 35, 0.14);
    border-left: 6px solid var(--handwerk-orange);
    background: #FFFFFF;
}

.demo-business-team-list h3 {
    font-size: 1.32rem;
}

.demo-business-materials {
    background: #FFFFFF;
}

.demo-business-material-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 14px;
}

.demo-business-material-grid article {
    display: grid;
    gap: 10px;
    min-height: 190px;
    padding: 22px;
    border: 1px solid rgba(31, 37, 35, 0.14);
    background: linear-gradient(135deg, #FFFFFF 0%, var(--handwerk-beige) 100%);
}

.demo-business-region-layout {
    display: grid;
    gap: 16px;
}

.demo-business-faq {
    background: #FFFFFF;
}

.demo-business-faq-list {
    display: grid;
    gap: 12px;
}

.demo-business-faq-list article {
    border: 1px solid rgba(31, 37, 35, 0.14);
    background: var(--handwerk-beige);
}

.demo-business-faq-list button {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 22px 24px;
    border: 0;
    background: transparent;
    font: inherit;
    font-size: 1rem;
    font-weight: 860;
    text-align: left;
    cursor: pointer;
}

.demo-business-faq-list button::after {
    content: "+";
    display: inline-grid;
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    place-items: center;
    color: #FFFFFF;
    background: var(--handwerk-ink);
    font-weight: 900;
}

.demo-business-faq-list button[aria-expanded="true"]::after {
    content: "−";
}

.demo-business-faq-answer {
    padding: 0 24px 22px;
}

.demo-business-contact {
    color: #FFFFFF;
    background:
        linear-gradient(135deg, var(--handwerk-ink) 0%, var(--handwerk-slate) 58%, #5A351C 100%);
}

.demo-business-contact-copy {
    display: grid;
    gap: 14px;
}

.demo-business-contact-copy > span {
    color: var(--handwerk-orange);
    font-size: 0.76rem;
    font-weight: 860;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.demo-business-contact h2 {
    color: #FFFFFF;
    font-size: clamp(2rem, 3.6vw, 3.4rem);
    line-height: 1.04;
}

.demo-business-contact p {
    color: rgba(255, 255, 255, 0.78);
}

.demo-business-form {
    display: grid;
    gap: 16px;
    padding: 28px;
    color: var(--handwerk-ink);
    background: #FFFFFF;
}

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

.demo-business-form label {
    display: grid;
    gap: 7px;
}

.demo-business-form label > span {
    color: var(--handwerk-ink);
    font-size: 0.84rem;
    font-weight: 820;
}

.demo-business-form input,
.demo-business-form select,
.demo-business-form textarea {
    width: 100%;
    min-height: 46px;
    padding: 12px 13px;
    color: var(--handwerk-ink);
    border: 1px solid rgba(31, 37, 35, 0.18);
    border-radius: 8px;
    background: #FFFFFF;
    font: inherit;
}

.demo-business-form textarea {
    resize: vertical;
}

.demo-business-form-success {
    display: grid;
    gap: 6px;
    padding: 16px;
    color: var(--handwerk-ink);
    border-left: 5px solid var(--handwerk-orange);
    background: var(--handwerk-beige);
}

.demo-business-form-success[hidden] {
    display: none;
}

.demo-business-form-success strong {
    color: var(--handwerk-ink);
}

.demo-business-form-success small {
    color: var(--handwerk-muted);
}

@media (max-width: 1023px) {
    .demo-business-history-layout,
    .demo-business-team-layout,
    .demo-business-contact,
    .demo-business-service-detail {
        grid-template-columns: 1fr;
    }

    .demo-business-project-grid,
    .demo-business-material-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business--handwerk .demo-business-image-slot--hero-roof,
    .demo-business--handwerk .demo-business-image-slot--company-history,
    .demo-business--handwerk .demo-business-image-slot--team-workshop,
    .demo-business--handwerk .demo-business-image-slot--contact {
        min-height: 340px;
    }
}

@media (max-width: 767px) {
    .demo-business-hero-trust {
        gap: 8px;
    }

    .demo-business-history-copy,
    .demo-business-service-detail,
    .demo-business-team-list article,
    .demo-business-form {
        padding: 22px;
    }

    .demo-business-project-grid,
    .demo-business-material-grid,
    .demo-business-form-grid {
        grid-template-columns: 1fr;
    }

    .demo-business--handwerk .demo-business-image-slot,
    .demo-business--handwerk .demo-business-image-slot--hero-roof,
    .demo-business--handwerk .demo-business-image-slot--company-history,
    .demo-business--handwerk .demo-business-image-slot--team-workshop,
    .demo-business--handwerk .demo-business-image-slot--contact,
    .demo-business--handwerk .demo-business-image-slot--service,
    .demo-business--handwerk .demo-business-image-slot--project,
    .demo-business--handwerk .demo-business-image-slot--region-map {
        min-height: 230px;
        border-width: 1px;
        box-shadow: none;
    }

    .demo-business-faq-list button {
        padding: 18px;
    }

    .demo-business-faq-answer {
        padding: 0 18px 18px;
    }
}

.demo-business--gastronomie {
    --gastro-olive: #233128;
    --gastro-espresso: #2D241D;
    --gastro-cream: #F7F0E4;
    --gastro-sand: #DCC9A8;
    --gastro-gold: #B88A44;
    --gastro-gold-dark: #9A733A;
    overflow: hidden;
    color: var(--gastro-espresso);
    border: 1px solid rgba(45, 36, 29, 0.16);
    border-radius: 24px;
    background: var(--gastro-cream);
    box-shadow: 0 34px 90px rgba(45, 36, 29, 0.14);
}

.demo-business--gastronomie,
.demo-business--gastronomie a {
    color: inherit;
}

.demo-business--gastronomie h1,
.demo-business--gastronomie h2,
.demo-business--gastronomie h3,
.demo-business--gastronomie p,
.demo-business--gastronomie figure,
.demo-business--gastronomie ul {
    margin: 0;
}

.demo-business--gastronomie h1,
.demo-business--gastronomie h2,
.demo-business--gastronomie h3 {
    color: var(--gastro-espresso);
    letter-spacing: 0;
}

.demo-business--gastronomie p {
    color: rgba(45, 36, 29, 0.72);
    line-height: 1.72;
}

.demo-business-gastro-header {
    position: relative;
    z-index: 2;
    display: grid;
    grid-template-columns: minmax(190px, 0.85fr) minmax(0, 1fr) auto;
    align-items: center;
    gap: 24px;
    padding: 18px 28px;
    color: var(--gastro-cream);
    background: rgba(35, 49, 40, 0.98);
    border-bottom: 1px solid rgba(247, 240, 228, 0.16);
}

.demo-business-gastro-brand {
    display: grid;
    gap: 3px;
    line-height: 1.15;
}

.demo-business-gastro-brand span {
    color: #FFFFFF;
    font-size: 1.18rem;
    font-weight: 740;
}

.demo-business-gastro-brand small {
    color: var(--gastro-sand);
    font-size: 0.76rem;
    font-weight: 620;
}

.demo-business-gastro-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 22px;
    color: rgba(247, 240, 228, 0.78);
    font-size: 0.9rem;
    font-weight: 640;
}

.demo-business-gastro-nav a:hover,
.demo-business-gastro-nav a:focus-visible,
.demo-business-gastro-footer a:hover,
.demo-business-gastro-footer a:focus-visible {
    color: var(--gastro-sand);
}

.demo-business-gastro-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 13px 20px;
    border: 1px solid transparent;
    border-radius: 999px;
    font-size: 0.92rem;
    font-weight: 720;
    line-height: 1.15;
    transition:
        color 180ms ease,
        background 180ms ease,
        border-color 180ms ease,
        transform 180ms ease;
}

.demo-business-gastro-button--primary {
    color: #FFFFFF;
    border-color: var(--gastro-gold);
    background: var(--gastro-gold);
}

.demo-business-gastro-button--primary:hover,
.demo-business-gastro-button--primary:focus-visible {
    color: #FFFFFF;
    border-color: var(--gastro-gold-dark);
    background: var(--gastro-gold-dark);
    transform: translateY(-1px);
}

.demo-business-gastro-button--secondary {
    color: var(--gastro-cream);
    border-color: rgba(247, 240, 228, 0.42);
    background: rgba(247, 240, 228, 0.08);
}

.demo-business-gastro-button--secondary:hover,
.demo-business-gastro-button--secondary:focus-visible {
    color: var(--gastro-espresso);
    border-color: var(--gastro-sand);
    background: var(--gastro-sand);
    transform: translateY(-1px);
}

.demo-business-gastro-main {
    background: var(--gastro-cream);
}

.demo-business-gastro-hero {
    position: relative;
    display: grid;
    min-height: 680px;
    align-items: end;
    padding: 72px 58px;
    overflow: hidden;
    color: var(--gastro-cream);
    background: var(--gastro-espresso);
}

.demo-business-gastro-hero::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(90deg, rgba(45, 36, 29, 0.88) 0%, rgba(45, 36, 29, 0.54) 44%, rgba(35, 49, 40, 0.18) 100%),
        linear-gradient(180deg, rgba(45, 36, 29, 0.12) 0%, rgba(45, 36, 29, 0.72) 100%);
}

.demo-business-gastro-hero img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business-gastro-hero-copy {
    position: relative;
    z-index: 1;
    display: grid;
    gap: 22px;
    max-width: 760px;
}

.demo-business-gastro-hero-copy span,
.demo-business-gastro-intro span,
.demo-business-gastro-heading span,
.demo-business-gastro-gallery-copy span,
.demo-business-gastro-reservation span,
.demo-business-gastro-final span {
    color: var(--gastro-gold);
    font-size: 0.78rem;
    font-weight: 760;
    letter-spacing: 0.08em;
    line-height: 1.3;
    text-transform: uppercase;
}

.demo-business-gastro-hero h1 {
    color: #FFFFFF;
    font-size: clamp(3rem, 7vw, 6.5rem);
    line-height: 0.96;
}

.demo-business-gastro-hero p {
    max-width: 660px;
    color: rgba(247, 240, 228, 0.86);
    font-size: 1.08rem;
}

.demo-business-gastro-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.demo-business-gastro-intro,
.demo-business-gastro-gallery,
.demo-business-gastro-reservation,
.demo-business-gastro-hours,
.demo-business-gastro-final {
    padding: 72px 58px;
}

.demo-business-gastro-intro {
    display: grid;
    grid-template-columns: minmax(320px, 0.85fr) minmax(0, 1fr);
    gap: 52px;
    align-items: center;
    background: var(--gastro-cream);
}

.demo-business-gastro-intro figure {
    min-height: 520px;
    overflow: hidden;
    border-radius: 220px 220px 20px 20px;
}

.demo-business-gastro-intro img,
.demo-business-gastro-gallery img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business-gastro-intro > div {
    display: grid;
    gap: 16px;
}

.demo-business-gastro-intro h2,
.demo-business-gastro-heading h2,
.demo-business-gastro-gallery-copy h2,
.demo-business-gastro-reservation h2,
.demo-business-gastro-hours h2,
.demo-business-gastro-final h2 {
    font-size: clamp(2.2rem, 4.2vw, 4.3rem);
    line-height: 1;
}

.demo-business-gastro-intro ul {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 10px 0 0;
    list-style: none;
}

.demo-business-gastro-intro li {
    padding: 10px 13px;
    color: var(--gastro-espresso);
    border: 1px solid rgba(45, 36, 29, 0.14);
    border-radius: 999px;
    background: #FFFFFF;
    font-size: 0.88rem;
    font-weight: 680;
}

.demo-business-gastro-menu {
    padding: 78px 58px;
    color: var(--gastro-cream);
    background: var(--gastro-espresso);
}

.demo-business-gastro-heading {
    display: grid;
    gap: 12px;
    max-width: 760px;
    margin-bottom: 34px;
}

.demo-business-gastro-menu h2,
.demo-business-gastro-menu h3 {
    color: var(--gastro-cream);
}

.demo-business-gastro-menu-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1px;
    border-top: 1px solid rgba(247, 240, 228, 0.18);
    border-bottom: 1px solid rgba(247, 240, 228, 0.18);
}

.demo-business-gastro-menu-list article {
    display: grid;
    gap: 10px;
    padding: 28px 26px;
    border-top: 1px solid rgba(247, 240, 228, 0.12);
}

.demo-business-gastro-menu-list article:nth-child(-n + 2) {
    border-top: 0;
}

.demo-business-gastro-menu-list article:nth-child(odd) {
    border-right: 1px solid rgba(247, 240, 228, 0.12);
}

.demo-business-gastro-menu-list h3 {
    font-size: clamp(1.35rem, 2vw, 1.85rem);
    font-weight: 680;
}

.demo-business-gastro-menu-list p {
    max-width: 520px;
    color: rgba(247, 240, 228, 0.72);
}

.demo-business-gastro-gallery {
    background:
        linear-gradient(180deg, var(--gastro-cream) 0%, #FFFFFF 100%);
}

.demo-business-gastro-gallery-copy {
    display: grid;
    gap: 12px;
    max-width: 820px;
    margin-bottom: 36px;
}

.demo-business-gastro-gallery-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.55fr);
    gap: 22px;
    align-items: end;
}

.demo-business-gastro-gallery-layout figure {
    overflow: hidden;
}

.demo-business-gastro-gallery-main {
    min-height: 520px;
    border-radius: 22px;
}

.demo-business-gastro-gallery-side {
    min-height: 360px;
    border-radius: 180px 180px 20px 20px;
}

.demo-business-gastro-reservation {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 30px;
    align-items: center;
    background: var(--gastro-sand);
}

.demo-business-gastro-reservation > div:first-child,
.demo-business-gastro-final > div:first-child {
    display: grid;
    gap: 13px;
}

.demo-business-gastro-reservation .demo-business-gastro-button--secondary {
    color: var(--gastro-espresso);
    border-color: rgba(45, 36, 29, 0.28);
    background: transparent;
}

.demo-business-gastro-hours {
    background: var(--gastro-cream);
}

.demo-business-gastro-hours-list {
    display: grid;
    grid-template-columns: repeat(7, minmax(0, 1fr));
    gap: 1px;
    background: rgba(45, 36, 29, 0.14);
}

.demo-business-gastro-hours-list div {
    display: grid;
    gap: 8px;
    min-height: 118px;
    padding: 18px 14px;
    background: #FFFFFF;
}

.demo-business-gastro-hours-list span {
    color: rgba(45, 36, 29, 0.58);
    font-size: 0.78rem;
    font-weight: 700;
}

.demo-business-gastro-hours-list strong {
    color: var(--gastro-espresso);
    font-size: 0.95rem;
    line-height: 1.35;
}

.demo-business-gastro-final {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 30px;
    align-items: center;
    color: var(--gastro-cream);
    background:
        linear-gradient(135deg, rgba(35, 49, 40, 0.98) 0%, rgba(45, 36, 29, 0.98) 100%);
}

.demo-business-gastro-final h2 {
    color: #FFFFFF;
}

.demo-business-gastro-final p {
    color: rgba(247, 240, 228, 0.76);
}

.demo-business-gastro-footer {
    display: grid;
    grid-template-columns: minmax(230px, 1fr) minmax(190px, 0.8fr) minmax(160px, 0.55fr);
    gap: 24px;
    padding: 32px 28px;
    color: var(--gastro-cream);
    background: var(--gastro-espresso);
}

.demo-business-gastro-footer div,
.demo-business-gastro-footer nav {
    display: grid;
    gap: 7px;
}

.demo-business-gastro-footer strong {
    color: #FFFFFF;
    font-size: 1.08rem;
}

.demo-business-gastro-footer p,
.demo-business-gastro-footer a,
.demo-business-gastro-footer span,
.demo-business-gastro-footer small {
    color: rgba(247, 240, 228, 0.72);
    font-size: 0.88rem;
}

.demo-business-gastro-footer span {
    color: var(--gastro-sand);
    font-weight: 740;
}

.demo-business-gastro-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(247, 240, 228, 0.12);
}

@media (max-width: 1023px) {
    .demo-business-gastro-header,
    .demo-business-gastro-intro,
    .demo-business-gastro-reservation,
    .demo-business-gastro-final,
    .demo-business-gastro-footer {
        grid-template-columns: 1fr;
    }

    .demo-business-gastro-nav {
        justify-content: flex-start;
    }

    .demo-business-gastro-hero {
        min-height: 620px;
        padding: 58px 38px;
    }

    .demo-business-gastro-intro,
    .demo-business-gastro-gallery,
    .demo-business-gastro-reservation,
    .demo-business-gastro-hours,
    .demo-business-gastro-final {
        padding: 58px 38px;
    }

    .demo-business-gastro-intro figure {
        min-height: 360px;
        border-radius: 160px 160px 18px 18px;
    }

    .demo-business-gastro-menu {
        padding: 62px 38px;
    }

    .demo-business-gastro-gallery-layout {
        grid-template-columns: minmax(0, 1fr);
    }

    .demo-business-gastro-gallery-main,
    .demo-business-gastro-gallery-side {
        min-height: 340px;
    }

    .demo-business-gastro-hours-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .demo-business--gastronomie {
        border-radius: 16px;
    }

    .demo-business-gastro-header,
    .demo-business-gastro-footer {
        padding: 22px;
    }

    .demo-business-gastro-nav {
        gap: 12px;
        font-size: 0.82rem;
    }

    .demo-business-gastro-header > .demo-business-gastro-button {
        width: 100%;
    }

    .demo-business-gastro-hero {
        min-height: 590px;
        padding: 42px 22px;
    }

    .demo-business-gastro-hero h1 {
        font-size: clamp(2.55rem, 12vw, 4rem);
    }

    .demo-business-gastro-actions,
    .demo-business-gastro-button {
        width: 100%;
    }

    .demo-business-gastro-intro,
    .demo-business-gastro-gallery,
    .demo-business-gastro-reservation,
    .demo-business-gastro-hours,
    .demo-business-gastro-final {
        padding: 44px 22px;
    }

    .demo-business-gastro-menu {
        padding: 48px 22px;
    }

    .demo-business-gastro-intro figure,
    .demo-business-gastro-gallery-main,
    .demo-business-gastro-gallery-side {
        min-height: 260px;
        border-radius: 18px;
    }

    .demo-business-gastro-menu-list,
    .demo-business-gastro-hours-list {
        grid-template-columns: 1fr;
    }

    .demo-business-gastro-menu-list article,
    .demo-business-gastro-menu-list article:nth-child(odd) {
        border-right: 0;
    }

    .demo-business-gastro-menu-list article:nth-child(2) {
        border-top: 1px solid rgba(247, 240, 228, 0.12);
    }

    .demo-business-gastro-hours-list div {
        min-height: auto;
    }
}

.demo-business--beauty {
    --beauty-creme: #FAF4EC;
    --beauty-rose: #D8A7A7;
    --beauty-champagne: #E7D2B8;
    --beauty-brown: #3A2A24;
    --beauty-mocha: #6E5148;
    --beauty-soft: #F3E6D8;
    --beauty-white: #FFFFFF;
    --beauty-button: #B98282;
    --beauty-button-hover: #9F6D6D;
    overflow: hidden;
    color: var(--beauty-brown);
    background: var(--beauty-creme);
    border-radius: 26px;
    box-shadow: 0 26px 80px rgba(58, 42, 36, 0.14);
}

.demo-business--beauty a {
    text-decoration: none;
}

.demo-business--beauty img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business-beauty-header {
    display: grid;
    grid-template-columns: minmax(190px, 1fr) auto auto;
    gap: 24px;
    align-items: center;
    padding: 22px 36px;
    background: rgba(250, 244, 236, 0.94);
    border-bottom: 1px solid rgba(58, 42, 36, 0.08);
}

.demo-business-beauty-brand {
    display: grid;
    gap: 4px;
    color: var(--beauty-brown);
}

.demo-business-beauty-brand span {
    font-family: Georgia, "Times New Roman", serif;
    font-size: 1.28rem;
    font-weight: 700;
}

.demo-business-beauty-brand small {
    color: var(--beauty-mocha);
    font-size: 0.76rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.demo-business-beauty-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    justify-content: center;
}

.demo-business-beauty-nav a,
.demo-business-beauty-footer a {
    color: var(--beauty-mocha);
    font-size: 0.9rem;
    font-weight: 700;
}

.demo-business-beauty-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 22px;
    color: var(--beauty-brown);
    font-weight: 800;
    border-radius: 999px;
    border: 1px solid rgba(185, 130, 130, 0.42);
    transition: background-color 180ms ease, color 180ms ease, border-color 180ms ease;
}

.demo-business-beauty-button--primary {
    color: var(--beauty-white);
    background: var(--beauty-button);
    border-color: var(--beauty-button);
}

.demo-business-beauty-button--primary:hover {
    background: var(--beauty-button-hover);
    border-color: var(--beauty-button-hover);
}

.demo-business-beauty-button--secondary {
    background: rgba(255, 255, 255, 0.48);
}

.demo-business-beauty-main {
    display: grid;
}

.demo-business-beauty-hero {
    display: grid;
    grid-template-columns: minmax(0, 0.86fr) minmax(320px, 1fr);
    gap: 54px;
    align-items: center;
    padding: 76px 52px 86px;
    background:
        radial-gradient(circle at 12% 8%, rgba(216, 167, 167, 0.34) 0, transparent 34%),
        linear-gradient(135deg, var(--beauty-creme) 0%, var(--beauty-soft) 100%);
}

.demo-business-beauty-hero-copy,
.demo-business-beauty-section-copy,
.demo-business-beauty-lookbook-copy {
    display: grid;
    gap: 16px;
}

.demo-business-beauty-kicker {
    color: var(--beauty-button);
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.demo-business--beauty h1,
.demo-business--beauty h2,
.demo-business--beauty h3,
.demo-business--beauty p {
    margin: 0;
}

.demo-business--beauty h1,
.demo-business--beauty h2 {
    max-width: 760px;
    color: var(--beauty-brown);
    font-family: Georgia, "Times New Roman", serif;
    line-height: 1.02;
}

.demo-business--beauty h1 {
    font-size: clamp(3.4rem, 7vw, 6.35rem);
}

.demo-business--beauty h2 {
    font-size: clamp(2.2rem, 4.2vw, 4rem);
}

.demo-business--beauty h3 {
    color: var(--beauty-brown);
    font-size: 1.1rem;
}

.demo-business--beauty p {
    color: #7C645C;
    font-size: 1.03rem;
    line-height: 1.72;
}

.demo-business-beauty-hero-copy > p {
    max-width: 590px;
    font-size: 1.12rem;
}

.demo-business-beauty-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.demo-business-beauty-hero-visual {
    position: relative;
    min-height: 590px;
    margin: 0;
    overflow: hidden;
    border-radius: 230px 230px 26px 26px;
    box-shadow: 0 28px 70px rgba(58, 42, 36, 0.18);
}

.demo-business-beauty-hero-visual figcaption {
    position: absolute;
    right: 24px;
    bottom: 24px;
    max-width: 260px;
    padding: 16px 20px;
    color: var(--beauty-brown);
    font-size: 0.86rem;
    font-weight: 800;
    background: rgba(250, 244, 236, 0.9);
    border: 1px solid rgba(255, 255, 255, 0.74);
    border-radius: 999px;
}

.demo-business-beauty-services,
.demo-business-beauty-prices,
.demo-business-beauty-lookbook {
    padding: 76px 52px;
}

.demo-business-beauty-services {
    background: var(--beauty-white);
}

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

.demo-business-beauty-service-grid article {
    display: grid;
    gap: 13px;
    min-height: 250px;
    padding: 34px;
    background: linear-gradient(145deg, var(--beauty-creme) 0%, var(--beauty-white) 100%);
    border: 1px solid rgba(216, 167, 167, 0.32);
    border-radius: 34px;
}

.demo-business-beauty-service-grid article:nth-child(2),
.demo-business-beauty-service-grid article:nth-child(3) {
    transform: translateY(28px);
}

.demo-business-beauty-service-grid span {
    color: var(--beauty-rose);
    font-family: Georgia, "Times New Roman", serif;
    font-size: 2.6rem;
    font-weight: 700;
    line-height: 1;
}

.demo-business-beauty-salon {
    display: grid;
    grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1fr);
    gap: 34px;
    align-items: center;
    padding: 82px 52px;
    background: var(--beauty-soft);
}

.demo-business-beauty-salon figure,
.demo-business-beauty-lookbook-grid figure {
    margin: 0;
    overflow: hidden;
}

.demo-business-beauty-salon figure {
    min-height: 500px;
    border-radius: 28px 160px 28px 28px;
}

.demo-business-beauty-salon-card {
    display: grid;
    gap: 17px;
    padding: 46px;
    background: rgba(255, 255, 255, 0.66);
    border: 1px solid rgba(216, 167, 167, 0.24);
    border-radius: 36px;
}

.demo-business-beauty-salon-card ul {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 0;
    margin: 12px 0 0;
    list-style: none;
}

.demo-business-beauty-salon-card li {
    padding: 13px 16px;
    color: var(--beauty-brown);
    font-weight: 800;
    background: var(--beauty-creme);
    border-radius: 999px;
}

.demo-business-beauty-prices {
    background: linear-gradient(180deg, var(--beauty-white) 0%, var(--beauty-creme) 100%);
}

.demo-business-beauty-price-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1px;
    margin-top: 34px;
    overflow: hidden;
    background: rgba(58, 42, 36, 0.1);
    border-radius: 28px;
}

.demo-business-beauty-price-list div {
    display: flex;
    gap: 18px;
    align-items: baseline;
    justify-content: space-between;
    padding: 24px 28px;
    background: rgba(255, 255, 255, 0.78);
}

.demo-business-beauty-price-list span {
    color: var(--beauty-brown);
    font-weight: 800;
}

.demo-business-beauty-price-list strong {
    color: var(--beauty-button);
    white-space: nowrap;
}

.demo-business-beauty-price-note {
    margin-top: 20px;
}

.demo-business-beauty-lookbook {
    background: var(--beauty-brown);
}

.demo-business-beauty-lookbook h2 {
    color: var(--beauty-white);
}

.demo-business-beauty-lookbook p {
    color: rgba(250, 244, 236, 0.76);
}

.demo-business-beauty-lookbook-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.1fr) minmax(260px, 0.72fr);
    gap: 22px;
    align-items: end;
    margin-top: 38px;
}

.demo-business-beauty-lookbook-grid figure:first-child {
    min-height: 520px;
    border-radius: 34px;
}

.demo-business-beauty-lookbook-grid figure:last-child {
    min-height: 390px;
    border-radius: 180px 180px 34px 34px;
}

.demo-business-beauty-appointment,
.demo-business-beauty-final {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    padding: 58px 52px;
}

.demo-business-beauty-appointment {
    background:
        radial-gradient(circle at 88% 18%, rgba(216, 167, 167, 0.28) 0, transparent 32%),
        var(--beauty-creme);
}

.demo-business-beauty-appointment > div:first-child,
.demo-business-beauty-final > div:first-child {
    display: grid;
    gap: 13px;
}

.demo-business-beauty-final {
    background: var(--beauty-champagne);
}

.demo-business-beauty-footer {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(210px, 0.85fr) minmax(160px, 0.55fr);
    gap: 24px;
    padding: 34px 52px;
    background: var(--beauty-soft);
    border-top: 1px solid rgba(58, 42, 36, 0.08);
}

.demo-business-beauty-footer div,
.demo-business-beauty-footer nav {
    display: grid;
    gap: 7px;
}

.demo-business-beauty-footer strong {
    color: var(--beauty-brown);
    font-family: Georgia, "Times New Roman", serif;
    font-size: 1.16rem;
}

.demo-business-beauty-footer p,
.demo-business-beauty-footer span,
.demo-business-beauty-footer small {
    color: var(--beauty-mocha);
    font-size: 0.88rem;
}

.demo-business-beauty-footer span {
    font-weight: 800;
}

.demo-business-beauty-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(58, 42, 36, 0.08);
}

@media (max-width: 1023px) {
    .demo-business-beauty-header,
    .demo-business-beauty-hero,
    .demo-business-beauty-salon,
    .demo-business-beauty-appointment,
    .demo-business-beauty-final,
    .demo-business-beauty-footer {
        grid-template-columns: 1fr;
    }

    .demo-business-beauty-nav {
        justify-content: flex-start;
    }

    .demo-business-beauty-hero,
    .demo-business-beauty-services,
    .demo-business-beauty-salon,
    .demo-business-beauty-prices,
    .demo-business-beauty-lookbook {
        padding: 58px 38px;
    }

    .demo-business-beauty-hero-visual,
    .demo-business-beauty-salon figure {
        min-height: 420px;
    }

    .demo-business-beauty-service-grid article:nth-child(2),
    .demo-business-beauty-service-grid article:nth-child(3) {
        transform: none;
    }

    .demo-business-beauty-lookbook-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-beauty-lookbook-grid figure:first-child,
    .demo-business-beauty-lookbook-grid figure:last-child {
        min-height: 360px;
        border-radius: 28px;
    }

    .demo-business-beauty-appointment,
    .demo-business-beauty-final,
    .demo-business-beauty-footer {
        padding: 46px 38px;
    }
}

@media (max-width: 767px) {
    .demo-business--beauty {
        border-radius: 16px;
    }

    .demo-business-beauty-header {
        padding: 22px;
    }

    .demo-business-beauty-nav {
        gap: 12px;
        font-size: 0.84rem;
    }

    .demo-business-beauty-header > .demo-business-beauty-button,
    .demo-business-beauty-actions,
    .demo-business-beauty-button {
        width: 100%;
    }

    .demo-business-beauty-hero,
    .demo-business-beauty-services,
    .demo-business-beauty-salon,
    .demo-business-beauty-prices,
    .demo-business-beauty-lookbook {
        padding: 44px 22px;
    }

    .demo-business--beauty h1 {
        font-size: clamp(2.8rem, 15vw, 4rem);
    }

    .demo-business--beauty h2 {
        font-size: clamp(2rem, 11vw, 3rem);
    }

    .demo-business-beauty-hero-visual,
    .demo-business-beauty-salon figure,
    .demo-business-beauty-lookbook-grid figure:first-child,
    .demo-business-beauty-lookbook-grid figure:last-child {
        min-height: 280px;
        border-radius: 24px;
    }

    .demo-business-beauty-hero-visual figcaption {
        right: 14px;
        bottom: 14px;
        max-width: calc(100% - 28px);
    }

    .demo-business-beauty-service-grid,
    .demo-business-beauty-salon-card ul,
    .demo-business-beauty-price-list {
        grid-template-columns: 1fr;
    }

    .demo-business-beauty-service-grid article {
        min-height: auto;
        padding: 28px;
    }

    .demo-business-beauty-salon-card {
        padding: 30px 24px;
        border-radius: 28px;
    }

    .demo-business-beauty-price-list div {
        padding: 20px 22px;
    }

    .demo-business-beauty-appointment,
    .demo-business-beauty-final,
    .demo-business-beauty-footer {
        padding: 38px 22px;
    }
}

.demo-business--beauty-v2 {
    --beauty-v2-white: #FFFDF9;
    --beauty-v2-warm: #F7EFE6;
    --beauty-v2-soft: #EADBD0;
    --beauty-v2-rose: #C99A91;
    --beauty-v2-accent: #C99A91;
    --beauty-v2-accent-hover: #C99A91;
    --beauty-v2-gold: #B99A67;
    --beauty-v2-taupe: #6F625A;
    --beauty-v2-brown: #3A302C;
    --beauty-v2-anthracite: #242222;
    --beauty-v2-line: rgba(58, 48, 44, 0.12);
    overflow: hidden;
    color: var(--beauty-v2-brown);
    background: var(--beauty-v2-white);
    border-radius: 0;
    box-shadow: none;
}

.demo-business--beauty-v2,
.demo-business--beauty-v2 * {
    box-sizing: border-box;
}

.demo-business--beauty-v2 a {
    text-decoration: none;
}

.demo-business--beauty-v2 img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business--beauty-v2 h1,
.demo-business--beauty-v2 h2,
.demo-business--beauty-v2 h3,
.demo-business--beauty-v2 p,
.demo-business--beauty-v2 figure,
.demo-business--beauty-v2 address {
    margin: 0;
}

.demo-business--beauty-v2 h1,
.demo-business--beauty-v2 h2,
.demo-business--beauty-v2 h3 {
    max-width: none;
    color: inherit;
    font-family: Georgia, "Times New Roman", serif;
    letter-spacing: 0;
}

.demo-business--beauty-v2 h1 {
    font-size: 4.5rem;
    line-height: 0.98;
}

.demo-business--beauty-v2 h2 {
    font-size: 3.25rem;
    line-height: 1.04;
}

.demo-business--beauty-v2 h3 {
    font-size: 1.16rem;
    line-height: 1.25;
}

.demo-business--beauty-v2 p,
.demo-business--beauty-v2 address {
    color: var(--beauty-v2-taupe);
    font-size: 1rem;
    line-height: 1.72;
    font-style: normal;
}

.demo-business--beauty-v2 .demo-business-beauty-header--stacked {
    position: sticky;
    top: 0;
    z-index: 20;
    display: grid;
    grid-template-columns: minmax(220px, 0.85fr) minmax(260px, 0.9fr) minmax(0, 1.45fr);
    gap: 18px;
    align-items: center;
    padding: 18px 34px;
    background: rgba(255, 253, 249, 0.97);
    border-bottom: 1px solid var(--beauty-v2-line);
    transform: translateY(0);
    transition: transform 220ms ease, box-shadow 220ms ease;
    will-change: transform;
}

.demo-business--beauty-v2 [data-demo-smart-header].is-demo-header-hidden {
    transform: translateY(calc(-100% - 2px));
    pointer-events: none;
}

.demo-business--beauty-v2 [data-demo-smart-header].is-demo-header-visible,
.demo-business--beauty-v2 [data-demo-smart-header]:focus-within {
    transform: translateY(0);
    pointer-events: auto;
}

.demo-business--beauty-v2 [data-demo-smart-header].is-demo-header-visible {
    box-shadow: 0 14px 36px rgba(58, 48, 44, 0.08);
}

.demo-business--beauty-v2 .demo-business-beauty-brand {
    display: grid;
    gap: 3px;
    color: var(--beauty-v2-brown);
    line-height: 1.12;
    transition: color 180ms ease;
}

.demo-business--beauty-v2 .demo-business-beauty-brand span,
.demo-business--beauty-v2 .demo-business-beauty-footer-brand {
    font-family: Georgia, "Times New Roman", serif;
    font-size: 1.35rem;
    font-weight: 800;
}

.demo-business--beauty-v2 .demo-business-beauty-brand small {
    color: var(--beauty-v2-taupe);
    font-size: 0.74rem;
    font-weight: 760;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.demo-business--beauty-v2 .demo-business-beauty-header-info {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    color: var(--beauty-v2-taupe);
    font-size: 0.84rem;
    font-weight: 760;
    line-height: 1.4;
}

.demo-business--beauty-v2 .demo-business-beauty-header-info span + span::before {
    content: "·";
    display: inline-block;
    margin: 0 8px;
    color: var(--beauty-v2-rose);
}

.demo-business--beauty-v2 .demo-business-menu--beauty {
    display: flex;
    min-width: 0;
    align-items: center;
    justify-content: flex-end;
    gap: 16px;
}

.demo-business--beauty-v2 .demo-business-beauty-nav {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    gap: 16px;
}

.demo-business--beauty-v2 .demo-business-beauty-nav a,
.demo-business--beauty-v2 .demo-business-beauty-footer a {
    color: var(--beauty-v2-taupe);
    font-size: 0.9rem;
    font-weight: 760;
    transition: color 180ms ease, background-color 180ms ease, border-color 180ms ease;
}

.demo-business--beauty-v2 .demo-business-beauty-brand:hover,
.demo-business--beauty-v2 .demo-business-beauty-brand:focus-visible,
.demo-business--beauty-v2 .demo-business-beauty-nav a:hover,
.demo-business--beauty-v2 .demo-business-beauty-nav a:focus-visible,
.demo-business--beauty-v2 .demo-business-beauty-footer a:hover,
.demo-business--beauty-v2 .demo-business-beauty-footer a:focus-visible {
    color: var(--beauty-v2-accent-hover);
}

.demo-business-menu-toggle--beauty {
    color: var(--beauty-v2-brown);
    border-color: rgba(58, 48, 44, 0.34);
    background: rgba(255, 253, 249, 0.9);
    box-shadow: 0 8px 20px rgba(58, 48, 44, 0.08);
}

.demo-business-menu-toggle--beauty:hover,
.demo-business-menu-toggle--beauty:focus-visible {
    color: #FFFFFF;
    border-color: var(--beauty-v2-accent-hover);
    background: var(--beauty-v2-accent-hover);
}

.demo-business--beauty-v2 .demo-business-beauty-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 12px 20px;
    color: var(--beauty-v2-brown);
    font-size: 0.93rem;
    font-weight: 820;
    line-height: 1.15;
    border: 1px solid rgba(111, 98, 90, 0.25);
    border-radius: 8px;
    background: rgba(255, 253, 249, 0.72);
    transition: color 180ms ease, background-color 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.demo-business--beauty-v2 .demo-business-beauty-button--primary {
    color: #FFFFFF;
    border-color: var(--beauty-v2-anthracite);
    background: var(--beauty-v2-anthracite);
}

.demo-business--beauty-v2 .demo-business-beauty-button--primary:hover,
.demo-business--beauty-v2 .demo-business-beauty-button--primary:focus-visible {
    color: #FFFFFF;
    border-color: var(--beauty-v2-accent-hover);
    background: var(--beauty-v2-accent-hover);
    transform: translateY(-1px);
}

.demo-business--beauty-v2 .demo-business-beauty-button--secondary:hover,
.demo-business--beauty-v2 .demo-business-beauty-button--secondary:focus-visible {
    color: #FFFFFF;
    border-color: var(--beauty-v2-accent-hover);
    background: var(--beauty-v2-accent-hover);
    transform: translateY(-1px);
}

.demo-business--beauty-v2 .demo-business-beauty-main {
    display: grid;
    background: var(--beauty-v2-white);
}

.demo-business--beauty-v2 .demo-business-beauty-hero,
.demo-business--beauty-v2 .demo-business-beauty-philosophy,
.demo-business--beauty-v2 .demo-business-beauty-appointment,
.demo-business--beauty-v2 .demo-business-beauty-contact {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(340px, 1fr);
    gap: 44px;
    align-items: center;
    padding: 76px 52px;
}

.demo-business--beauty-v2 .demo-business-beauty-hero {
    background: linear-gradient(135deg, var(--beauty-v2-white) 0%, var(--beauty-v2-warm) 100%);
    align-items: start;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-copy,
.demo-business--beauty-v2 .demo-business-beauty-section-copy {
    display: grid;
    gap: 16px;
}

.demo-business--beauty-v2 .demo-business-beauty-kicker {
    color: var(--beauty-v2-rose);
    font-size: 0.78rem;
    font-weight: 840;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-copy > p {
    max-width: 590px;
    font-size: 1.1rem;
}

.demo-business--beauty-v2 .demo-business-beauty-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.demo-business--beauty-v2 .demo-business-beauty-trust {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding-top: 10px;
    color: var(--beauty-v2-taupe);
    border-top: 1px solid rgba(58, 48, 44, 0.1);
}

.demo-business--beauty-v2 .demo-business-beauty-trust span {
    display: inline-flex;
    gap: 7px;
    align-items: center;
    padding: 0;
    color: var(--beauty-v2-taupe);
    font-size: 0.9rem;
    font-weight: 780;
    background: transparent;
    border: 0;
    border-radius: 0;
}

.demo-business--beauty-v2 .demo-business-beauty-trust span::before {
    content: "✓";
    color: var(--beauty-v2-accent);
    font-weight: 900;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-visual,
.demo-business--beauty-v2 .demo-business-beauty-image,
.demo-business--beauty-v2 .demo-business-beauty-service-grid img,
.demo-business--beauty-v2 .demo-business-beauty-lookbook-grid figure,
.demo-business--beauty-v2 .demo-business-beauty-team-grid img {
    overflow: hidden;
    border-radius: 8px;
    box-shadow: 0 18px 46px rgba(58, 48, 44, 0.12);
}

.demo-business--beauty-v2 .demo-business-beauty-hero-visual,
.demo-business--beauty-v2 .demo-business-beauty-image {
    position: relative;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-visual > img,
.demo-business--beauty-v2 .demo-business-beauty-image > img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-visual {
    align-self: start;
    width: 100%;
    min-height: 0;
    aspect-ratio: 3 / 2;
    max-height: 460px;
    margin-top: 34px;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-visual > picture,
.demo-business--beauty-v2 .demo-business-beauty-hero-visual > picture > img {
    display: block;
    width: 100%;
    height: 100%;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-visual > picture > img {
    object-fit: contain;
}

.demo-business--beauty-v2 .demo-business-beauty-hero-visual img {
    object-position: center center;
}

.demo-business--beauty-v2 .demo-business-beauty-image--salon {
    min-height: 500px;
}

.demo-business--beauty-v2 .demo-business-beauty-philosophy {
    background: var(--beauty-v2-soft);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 30px 52px;
    background: var(--beauty-v2-anthracite);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta p {
    color: #FFFFFF;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 1.32rem;
    line-height: 1.25;
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta .demo-business-beauty-button--primary {
    color: #FFFFFF;
    border-color: rgba(255, 253, 249, 0.72);
    background: rgba(255, 253, 249, 0.08);
    box-shadow: inset 0 0 0 1px rgba(255, 253, 249, 0.14);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta .demo-business-beauty-button--primary:hover,
.demo-business--beauty-v2 .demo-business-beauty-inline-cta .demo-business-beauty-button--primary:focus-visible {
    color: #FFFFFF;
    border-color: var(--beauty-v2-accent-hover);
    background: var(--beauty-v2-accent-hover);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta--soft {
    background: var(--beauty-v2-warm);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta--soft p {
    color: var(--beauty-v2-brown);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta--soft .demo-business-beauty-button--primary {
    color: var(--beauty-v2-anthracite);
    border-color: rgba(36, 34, 34, 0.34);
    background: rgba(255, 253, 249, 0.62);
    box-shadow: inset 0 0 0 1px rgba(36, 34, 34, 0.08);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta--soft .demo-business-beauty-button--primary:hover,
.demo-business--beauty-v2 .demo-business-beauty-inline-cta--soft .demo-business-beauty-button--primary:focus-visible {
    color: #FFFFFF;
    border-color: var(--beauty-v2-accent-hover);
    background: var(--beauty-v2-accent-hover);
}

.demo-business--beauty-v2 .demo-business-beauty-inline-cta--dark {
    background: #1F1D1B;
}

.demo-business--beauty-v2 .demo-business-beauty-services,
.demo-business--beauty-v2 .demo-business-beauty-prices,
.demo-business--beauty-v2 .demo-business-beauty-lookbook,
.demo-business--beauty-v2 .demo-business-beauty-team {
    padding: 76px 52px;
}

.demo-business--beauty-v2 .demo-business-beauty-services,
.demo-business--beauty-v2 .demo-business-beauty-team {
    background: var(--beauty-v2-white);
}

.demo-business--beauty-v2 .demo-business-beauty-service-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 34px;
}

.demo-business--beauty-v2 .demo-business-beauty-service-grid article {
    display: grid;
    grid-template-rows: auto 1fr;
    gap: 0;
    min-height: auto;
    padding: 0;
    overflow: hidden;
    background: #FFFFFF;
    border: 1px solid var(--beauty-v2-line);
    border-radius: 8px;
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.demo-business--beauty-v2 .demo-business-beauty-service-grid article:nth-child(2),
.demo-business--beauty-v2 .demo-business-beauty-service-grid article:nth-child(3) {
    transform: none;
}

.demo-business--beauty-v2 .demo-business-beauty-service-grid article > div {
    display: grid;
    gap: 10px;
    padding: 24px;
}

.demo-business--beauty-v2 .demo-business-beauty-service-grid img {
    aspect-ratio: 3 / 2;
    box-shadow: none;
    border-radius: 0;
}

.demo-business--beauty-v2 .demo-business-beauty-prices {
    display: grid;
    gap: 24px;
    background: linear-gradient(180deg, var(--beauty-v2-warm) 0%, #FFFFFF 100%);
}

.demo-business--beauty-v2 .demo-business-beauty-price-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1px;
    margin-top: 10px;
    overflow: hidden;
    background: var(--beauty-v2-line);
    border: 1px solid var(--beauty-v2-line);
    border-radius: 8px;
}

.demo-business--beauty-v2 .demo-business-beauty-price-list div {
    display: flex;
    gap: 18px;
    align-items: baseline;
    justify-content: space-between;
    padding: 22px 24px;
    background: rgba(255, 253, 249, 0.88);
}

.demo-business--beauty-v2 .demo-business-beauty-price-list span {
    color: var(--beauty-v2-brown);
    font-weight: 800;
}

.demo-business--beauty-v2 .demo-business-beauty-price-list strong {
    color: var(--beauty-v2-rose);
    white-space: nowrap;
}

.demo-business--beauty-v2 .demo-business-beauty-price-note {
    margin-top: 0;
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook {
    color: #FFFFFF;
    background: var(--beauty-v2-brown);
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook h2 {
    color: #FFFFFF;
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook p {
    color: rgba(255, 253, 249, 0.76);
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.2fr) repeat(2, minmax(0, 0.78fr));
    grid-template-rows: repeat(3, 210px);
    gap: 22px;
    margin-top: 34px;
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook-grid figure {
    position: relative;
    height: 100%;
    min-height: 0;
    box-shadow: none;
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook-item--tall {
    grid-column: 1;
    grid-row: 1 / span 2;
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook-item--wide {
    grid-column: 2 / 4;
    grid-row: 3;
}

.demo-business--beauty-v2 .demo-business-beauty-lookbook-grid figcaption {
    position: absolute;
    left: 16px;
    bottom: 16px;
    max-width: calc(100% - 32px);
    padding: 8px 10px;
    color: #FFFFFF;
    font-size: 0.84rem;
    font-weight: 820;
    background: rgba(36, 34, 34, 0.74);
    border-radius: 8px;
}

.demo-business--beauty-v2 .demo-business-beauty-team-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 34px;
}

.demo-business--beauty-v2 .demo-business-beauty-team-grid article {
    display: grid;
    grid-template-rows: auto auto auto 1fr;
    gap: 9px;
    padding: 14px;
    background: var(--beauty-v2-warm);
    border: 1px solid var(--beauty-v2-line);
    border-radius: 8px;
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.demo-business--beauty-v2 .demo-business-beauty-team-grid img {
    aspect-ratio: 5 / 4;
    object-position: center 28%;
    box-shadow: none;
}

.demo-business--beauty-v2 .demo-business-beauty-team-grid p {
    font-size: 0.94rem;
    line-height: 1.58;
}

.demo-business--beauty-v2 .demo-business-beauty-team-grid span {
    color: var(--beauty-v2-accent);
    font-size: 0.86rem;
    font-weight: 840;
}

.demo-business--beauty-v2 .demo-business-beauty-appointment {
    align-items: start;
    background: var(--beauty-v2-soft);
}

.demo-business--beauty-v2 .demo-business-beauty-image--contact {
    min-height: 300px;
    margin-top: 10px;
}

.demo-business--beauty-v2 .demo-business-beauty-form {
    display: grid;
    gap: 16px;
    padding: 28px;
    background: rgba(255, 253, 249, 0.82);
    border: 1px solid var(--beauty-v2-line);
    border-radius: 8px;
}

.demo-business--beauty-v2 .demo-business-beauty-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.demo-business--beauty-v2 .demo-business-beauty-form label {
    display: grid;
    gap: 7px;
}

.demo-business--beauty-v2 .demo-business-beauty-form label > span {
    color: var(--beauty-v2-brown);
    font-size: 0.84rem;
    font-weight: 820;
}

.demo-business--beauty-v2 .demo-business-beauty-form input,
.demo-business--beauty-v2 .demo-business-beauty-form select,
.demo-business--beauty-v2 .demo-business-beauty-form textarea {
    width: 100%;
    min-height: 46px;
    padding: 11px 12px;
    color: var(--beauty-v2-brown);
    font: inherit;
    border: 1px solid rgba(111, 98, 90, 0.22);
    border-radius: 8px;
    background: #FFFFFF;
}

.demo-business--beauty-v2 .demo-business-beauty-form textarea {
    resize: vertical;
}

.demo-business--beauty-v2 .demo-business-beauty-form-success {
    display: grid;
    gap: 5px;
    padding: 16px;
    color: var(--beauty-v2-brown);
    border-left: 4px solid var(--beauty-v2-accent);
    background: #FFFFFF;
    border-radius: 8px;
}

.demo-business--beauty-v2 .demo-business-beauty-form-success[hidden] {
    display: none;
}

.demo-business--beauty-v2 .demo-business-beauty-contact {
    background: #FFFFFF;
}

.demo-business--beauty-v2 .demo-business-beauty-contact address a,
.demo-business--beauty-v2 .demo-business-beauty-footer address a {
    color: var(--beauty-v2-brown);
    font-weight: 780;
}

.demo-business--beauty-v2 .demo-business-beauty-hours {
    display: grid;
    gap: 14px;
    padding: 28px;
    background: var(--beauty-v2-warm);
    border: 1px solid var(--beauty-v2-line);
    border-radius: 8px;
}

.demo-business--beauty-v2 .demo-business-beauty-hours div {
    display: grid;
    grid-template-columns: minmax(80px, 0.4fr) minmax(0, 1fr);
    gap: 16px;
    align-items: baseline;
    padding-top: 14px;
    border-top: 1px solid var(--beauty-v2-line);
}

.demo-business--beauty-v2 .demo-business-beauty-hours span {
    color: var(--beauty-v2-taupe);
}

.demo-business--beauty-v2 .demo-business-beauty-hours strong {
    color: var(--beauty-v2-brown);
    white-space: nowrap;
}

.demo-business--beauty-v2 .demo-business-beauty-footer {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(210px, 0.9fr) minmax(190px, 0.7fr);
    gap: 24px;
    padding: 36px 52px;
    background: var(--beauty-v2-anthracite);
    border-top: 0;
}

.demo-business--beauty-v2 .demo-business-beauty-footer div,
.demo-business--beauty-v2 .demo-business-beauty-footer nav,
.demo-business--beauty-v2 .demo-business-beauty-footer address {
    display: grid;
    gap: 7px;
}

.demo-business--beauty-v2 .demo-business-beauty-footer div:first-child {
    align-content: start;
    gap: 3px;
}

.demo-business--beauty-v2 .demo-business-beauty-footer-brand {
    color: #FFFFFF;
    font-size: 1.9rem;
    font-weight: 900;
    line-height: 1.02;
    transition: color 180ms ease, text-decoration-color 180ms ease;
}

.demo-business--beauty-v2 .demo-business-beauty-footer p {
    margin-top: 0;
}

.demo-business--beauty-v2 .demo-business-beauty-footer p,
.demo-business--beauty-v2 .demo-business-beauty-footer a,
.demo-business--beauty-v2 .demo-business-beauty-footer address,
.demo-business--beauty-v2 .demo-business-beauty-footer span,
.demo-business--beauty-v2 .demo-business-beauty-footer small {
    color: rgba(255, 253, 249, 0.75);
    font-size: 0.88rem;
}

.demo-business--beauty-v2 .demo-business-beauty-footer a,
.demo-business--beauty-v2 .demo-business-beauty-footer address a {
    color: rgba(255, 253, 249, 0.9);
}

.demo-business--beauty-v2 .demo-business-beauty-footer .demo-business-beauty-footer-brand {
    color: #FFFFFF;
    font-size: 1.9rem;
    font-weight: 900;
    line-height: 1.02;
}

.demo-business--beauty-v2 .demo-business-beauty-footer-brand:hover,
.demo-business--beauty-v2 .demo-business-beauty-footer-brand:focus-visible,
.demo-business--beauty-v2 .demo-business-beauty-footer a:hover,
.demo-business--beauty-v2 .demo-business-beauty-footer a:focus-visible {
    color: var(--beauty-v2-accent-hover);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 5px;
}

.demo-business--beauty-v2 .demo-business-beauty-footer span {
    color: var(--beauty-v2-soft);
    font-weight: 820;
}

.demo-business--beauty-v2 .demo-business-beauty-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 253, 249, 0.14);
}

.demo-business--gastro-v2 .demo-business-gastro-inline-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 30px 52px;
    color: var(--gastro-v2-ivory);
    background: linear-gradient(135deg, var(--gastro-v2-black) 0%, var(--gastro-v2-olive) 100%);
}

.demo-business--gastro-v2 .demo-business-gastro-inline-cta p {
    color: var(--gastro-v2-ivory);
    font-size: 1.18rem;
    font-weight: 760;
    line-height: 1.35;
}

.demo-business--gastro-v2 .demo-business-gastro-inline-cta--dark {
    background: var(--gastro-v2-anthracite);
}

.demo-business--gastro-v2 .demo-business-gastro-footer-brand {
    color: #FFFFFF;
    font-size: 2rem;
    font-weight: 980;
    line-height: 1.02;
    transition: color 180ms ease, text-decoration-color 180ms ease;
}

.demo-business--gastro-v2 .demo-business-gastro-footer-brand:hover,
.demo-business--gastro-v2 .demo-business-gastro-footer-brand:focus-visible {
    color: var(--gastro-v2-champagne);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 5px;
}

.demo-business--gastro-v2 .demo-business-gastro-footer p {
    margin-top: 0;
    color: rgba(247, 241, 229, 0.84);
}

.demo-business--gastro-v2 .demo-business-gastro-footer .demo-business-gastro-footer-brand {
    color: #FFFFFF;
    font-size: 2rem;
    font-weight: 980;
    line-height: 1.02;
}

.demo-business--gastro-v2 .demo-business-gastro-footer div:first-child {
    align-content: start;
    gap: 3px;
}

@media (hover: hover) and (pointer: fine) {
    .demo-business--beauty-v2 .demo-business-beauty-service-grid article:hover,
    .demo-business--beauty-v2 .demo-business-beauty-team-grid article:hover {
        transform: translateY(-4px);
        border-color: rgba(201, 154, 145, 0.45);
        box-shadow: 0 18px 40px rgba(58, 48, 44, 0.12);
    }
}

@media (max-width: 1180px) {
    .demo-business--beauty-v2 .demo-business-menu-toggle--beauty {
        display: inline-flex;
        grid-column: 2;
        grid-row: 1;
    }

    .demo-business--beauty-v2 .demo-business-beauty-header--stacked {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 12px 16px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-header-info {
        grid-column: 1 / -1;
        grid-row: 2;
        justify-content: center;
        text-align: center;
    }

    .demo-business--beauty-v2 .demo-business-menu--beauty {
        display: none;
        grid-column: 1 / -1;
        grid-row: 3;
        width: 100%;
        align-items: stretch;
        justify-content: stretch;
        gap: 14px;
        padding-top: 12px;
        border-top: 1px solid var(--beauty-v2-line);
    }

    .demo-business--beauty-v2 .is-demo-menu-open .demo-business-menu--beauty {
        display: grid;
    }

    .demo-business--beauty-v2 .demo-business-beauty-nav {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        justify-content: stretch;
    }

    .demo-business--beauty-v2 .demo-business-beauty-nav a {
        padding: 11px 12px;
        border-radius: 8px;
        background: rgba(234, 219, 208, 0.48);
    }

    .demo-business--beauty-v2 .demo-business-menu--beauty > .demo-business-beauty-button {
        width: 100%;
    }

    .demo-business--beauty-v2 .demo-business-beauty-service-grid,
    .demo-business--beauty-v2 .demo-business-beauty-team-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    .demo-business--beauty-v2 h1 {
        font-size: 3.5rem;
    }

    .demo-business--beauty-v2 h2 {
        font-size: 2.65rem;
    }

    .demo-business--beauty-v2 .demo-business-beauty-hero,
    .demo-business--beauty-v2 .demo-business-beauty-philosophy,
    .demo-business--beauty-v2 .demo-business-beauty-appointment,
    .demo-business--beauty-v2 .demo-business-beauty-contact,
    .demo-business--beauty-v2 .demo-business-beauty-footer {
        grid-template-columns: 1fr;
    }

    .demo-business--beauty-v2 .demo-business-beauty-hero,
    .demo-business--beauty-v2 .demo-business-beauty-philosophy,
    .demo-business--beauty-v2 .demo-business-beauty-services,
    .demo-business--beauty-v2 .demo-business-beauty-prices,
    .demo-business--beauty-v2 .demo-business-beauty-lookbook,
    .demo-business--beauty-v2 .demo-business-beauty-team,
    .demo-business--beauty-v2 .demo-business-beauty-appointment,
    .demo-business--beauty-v2 .demo-business-beauty-contact,
    .demo-business--beauty-v2 .demo-business-beauty-footer {
        padding: 58px 38px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-hero-visual,
    .demo-business--beauty-v2 .demo-business-beauty-image--salon {
        min-height: 390px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-lookbook-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        grid-template-rows: none;
        grid-auto-rows: 240px;
        gap: 18px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-lookbook-item--tall,
    .demo-business--beauty-v2 .demo-business-beauty-lookbook-item--wide {
        grid-column: 1 / -1;
        grid-row: auto;
    }

    .demo-business--gastro-v2 .demo-business-gastro-inline-cta {
        grid-template-columns: 1fr;
        padding: 30px 38px;
    }
}

@media (max-width: 767px) {
    .demo-business--beauty-v2 h1 {
        font-size: 2.7rem;
    }

    .demo-business--beauty-v2 h2 {
        font-size: 2.12rem;
    }

    .demo-business--beauty-v2 .demo-business-beauty-header--stacked {
        padding: 20px 22px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-header-info {
        justify-content: flex-start;
        font-size: 0.8rem;
        text-align: left;
    }

    .demo-business--beauty-v2 .demo-business-beauty-header-info span + span::before {
        margin: 0 6px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-hero,
    .demo-business--beauty-v2 .demo-business-beauty-philosophy,
    .demo-business--beauty-v2 .demo-business-beauty-services,
    .demo-business--beauty-v2 .demo-business-beauty-prices,
    .demo-business--beauty-v2 .demo-business-beauty-lookbook,
    .demo-business--beauty-v2 .demo-business-beauty-team,
    .demo-business--beauty-v2 .demo-business-beauty-appointment,
    .demo-business--beauty-v2 .demo-business-beauty-contact,
    .demo-business--beauty-v2 .demo-business-beauty-footer {
        padding: 44px 22px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-trust,
    .demo-business--beauty-v2 .demo-business-beauty-service-grid,
    .demo-business--beauty-v2 .demo-business-beauty-price-list,
    .demo-business--beauty-v2 .demo-business-beauty-team-grid,
    .demo-business--beauty-v2 .demo-business-beauty-form-grid,
    .demo-business--beauty-v2 .demo-business-beauty-nav {
        grid-template-columns: 1fr;
    }

    .demo-business--beauty-v2 .demo-business-beauty-actions,
    .demo-business--beauty-v2 .demo-business-beauty-button,
    .demo-business--beauty-v2 .demo-business-beauty-inline-cta .demo-business-beauty-button {
        width: 100%;
    }

    .demo-business--beauty-v2 .demo-business-beauty-hero-visual,
    .demo-business--beauty-v2 .demo-business-beauty-image--salon,
    .demo-business--beauty-v2 .demo-business-beauty-image--contact {
        min-height: 290px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-service-grid article {
        grid-template-rows: auto 1fr;
    }

    .demo-business--beauty-v2 .demo-business-beauty-lookbook-grid {
        grid-template-columns: 1fr;
        grid-auto-rows: 230px;
        gap: 16px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-lookbook-item--tall,
    .demo-business--beauty-v2 .demo-business-beauty-lookbook-item--wide {
        grid-column: auto;
        grid-row: auto;
    }

    .demo-business--beauty-v2 .demo-business-beauty-inline-cta,
    .demo-business--gastro-v2 .demo-business-gastro-inline-cta {
        grid-template-columns: 1fr;
        padding: 28px 22px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-form {
        padding: 22px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-hours div {
        grid-template-columns: 1fr;
        gap: 5px;
    }

    .demo-business--beauty-v2 .demo-business-beauty-hours strong {
        white-space: normal;
    }
}

.demo-business--praxis {
    --praxis-white: #FFFFFF;
    --praxis-blue: #EEF7FA;
    --praxis-mint: #DDEFE8;
    --praxis-petrol: #256B6F;
    --praxis-petrol-dark: #17474A;
    --praxis-gray: #F5F7F8;
    --praxis-text: #1E3335;
    --praxis-muted: #607174;
    --praxis-accent: #8FCDBA;
    overflow: hidden;
    color: var(--praxis-text);
    background: var(--praxis-white);
    border: 1px solid rgba(37, 107, 111, 0.12);
    border-radius: 22px;
    box-shadow: 0 24px 72px rgba(30, 51, 53, 0.12);
}

.demo-business--praxis a {
    text-decoration: none;
}

.demo-business--praxis img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business-praxis-header {
    display: grid;
    grid-template-columns: minmax(210px, 1fr) auto auto;
    gap: 24px;
    align-items: center;
    padding: 22px 36px;
    background: var(--praxis-white);
    border-bottom: 1px solid rgba(37, 107, 111, 0.12);
}

.demo-business-praxis-brand {
    display: grid;
    gap: 4px;
    color: var(--praxis-text);
}

.demo-business-praxis-brand span {
    font-size: 1.14rem;
    font-weight: 850;
}

.demo-business-praxis-brand small {
    color: var(--praxis-muted);
    font-size: 0.78rem;
    font-weight: 760;
}

.demo-business-praxis-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    justify-content: center;
}

.demo-business-praxis-nav a,
.demo-business-praxis-footer a {
    color: var(--praxis-muted);
    font-size: 0.9rem;
    font-weight: 760;
}

.demo-business-praxis-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 22px;
    color: var(--praxis-petrol);
    font-weight: 820;
    border: 1px solid rgba(37, 107, 111, 0.24);
    border-radius: 12px;
    background: var(--praxis-white);
    transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease;
}

.demo-business-praxis-button--primary {
    color: var(--praxis-white);
    background: var(--praxis-petrol);
    border-color: var(--praxis-petrol);
}

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

.demo-business-praxis-button--secondary:hover {
    color: var(--praxis-white);
    background: var(--praxis-petrol-dark);
    border-color: var(--praxis-petrol-dark);
}

.demo-business-praxis-main {
    display: grid;
    background: var(--praxis-white);
}

.demo-business-praxis-hero {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(340px, 1fr);
    gap: 44px;
    align-items: center;
    padding: 72px 52px;
    background:
        linear-gradient(135deg, var(--praxis-white) 0%, var(--praxis-blue) 100%);
}

.demo-business-praxis-hero-copy,
.demo-business-praxis-section-copy,
.demo-business-praxis-approach-copy {
    display: grid;
    gap: 15px;
}

.demo-business-praxis-kicker {
    color: var(--praxis-petrol);
    font-size: 0.78rem;
    font-weight: 860;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.demo-business--praxis h1,
.demo-business--praxis h2,
.demo-business--praxis h3,
.demo-business--praxis p {
    margin: 0;
}

.demo-business--praxis h1,
.demo-business--praxis h2,
.demo-business--praxis h3 {
    color: var(--praxis-text);
    line-height: 1.08;
}

.demo-business--praxis h1 {
    max-width: 720px;
    font-size: clamp(2.9rem, 5.8vw, 5rem);
}

.demo-business--praxis h2 {
    max-width: 740px;
    font-size: clamp(2rem, 3.8vw, 3.35rem);
}

.demo-business--praxis h3 {
    font-size: 1.18rem;
}

.demo-business--praxis p {
    color: var(--praxis-muted);
    font-size: 1rem;
    line-height: 1.72;
}

.demo-business-praxis-hero-copy > p {
    max-width: 620px;
    font-size: 1.08rem;
}

.demo-business-praxis-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.demo-business-praxis-hero-visual {
    position: relative;
    min-height: 500px;
    margin: 0;
    overflow: hidden;
    border: 12px solid var(--praxis-white);
    border-radius: 28px;
    box-shadow: 0 22px 56px rgba(30, 51, 53, 0.14);
}

.demo-business-praxis-hero-visual figcaption {
    position: absolute;
    right: 22px;
    bottom: 22px;
    max-width: 280px;
    padding: 15px 18px;
    color: var(--praxis-petrol-dark);
    font-size: 0.88rem;
    font-weight: 820;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(37, 107, 111, 0.14);
    border-radius: 14px;
}

.demo-business-praxis-quick {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    background: rgba(37, 107, 111, 0.12);
}

.demo-business-praxis-quick span {
    min-height: 86px;
    padding: 22px;
    color: var(--praxis-text);
    background: var(--praxis-white);
    font-size: 0.95rem;
    font-weight: 820;
}

.demo-business-praxis-services,
.demo-business-praxis-feel,
.demo-business-praxis-hours {
    padding: 72px 52px;
}

.demo-business-praxis-services {
    background: var(--praxis-white);
}

.demo-business-praxis-service-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 22px;
    margin-top: 34px;
}

.demo-business-praxis-service-grid article {
    display: grid;
    gap: 12px;
    min-height: 210px;
    padding: 30px;
    background: var(--praxis-gray);
    border: 1px solid rgba(37, 107, 111, 0.1);
    border-radius: 18px;
}

.demo-business-praxis-service-grid article::before {
    content: "";
    width: 42px;
    height: 4px;
    background: var(--praxis-accent);
    border-radius: 999px;
}

.demo-business-praxis-approach {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.72fr);
    gap: 34px;
    align-items: center;
    padding: 68px 52px;
    background: var(--praxis-mint);
}

.demo-business-praxis-approach-copy {
    padding: 40px;
    background: rgba(255, 255, 255, 0.68);
    border-radius: 22px;
}

.demo-business-praxis-process {
    display: grid;
    gap: 14px;
}

.demo-business-praxis-process span {
    padding: 18px 20px;
    color: var(--praxis-text);
    font-weight: 820;
    background: var(--praxis-white);
    border-left: 5px solid var(--praxis-petrol);
    border-radius: 14px;
}

.demo-business-praxis-feel {
    background: var(--praxis-blue);
}

.demo-business-praxis-image-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.7fr);
    gap: 22px;
    align-items: end;
    margin-top: 34px;
}

.demo-business-praxis-image-grid figure {
    margin: 0;
    overflow: hidden;
    border-radius: 24px;
    background: var(--praxis-white);
}

.demo-business-praxis-image-grid figure:first-child {
    min-height: 440px;
}

.demo-business-praxis-image-grid figure:last-child {
    min-height: 320px;
}

.demo-business-praxis-hours {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.55fr);
    gap: 28px;
    background: var(--praxis-white);
}

.demo-business-praxis-hours > div:first-child {
    display: grid;
    gap: 18px;
}

.demo-business-praxis-hours-list {
    display: grid;
    gap: 1px;
    overflow: hidden;
    background: rgba(37, 107, 111, 0.12);
    border-radius: 18px;
}

.demo-business-praxis-hours-list div {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    padding: 18px 20px;
    background: var(--praxis-gray);
}

.demo-business-praxis-hours-list span {
    color: var(--praxis-muted);
    font-weight: 760;
}

.demo-business-praxis-hours-list strong {
    color: var(--praxis-text);
    white-space: nowrap;
}

.demo-business-praxis-location {
    display: grid;
    align-content: start;
    gap: 15px;
    padding: 30px;
    margin: 0;
    background: var(--praxis-blue);
    border: 1px solid rgba(37, 107, 111, 0.12);
    border-radius: 20px;
}

.demo-business-praxis-location span {
    color: var(--praxis-petrol);
    font-weight: 820;
}

.demo-business-praxis-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    padding: 58px 52px;
    background:
        linear-gradient(135deg, var(--praxis-mint) 0%, var(--praxis-blue) 100%);
}

.demo-business-praxis-cta > div:first-child {
    display: grid;
    gap: 12px;
}

.demo-business-praxis-footer {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(210px, 0.85fr) minmax(160px, 0.55fr);
    gap: 24px;
    padding: 34px 52px;
    background: var(--praxis-petrol-dark);
}

.demo-business-praxis-footer div,
.demo-business-praxis-footer nav {
    display: grid;
    gap: 7px;
}

.demo-business-praxis-footer strong {
    color: var(--praxis-white);
    font-size: 1.12rem;
}

.demo-business-praxis-footer p,
.demo-business-praxis-footer a,
.demo-business-praxis-footer span,
.demo-business-praxis-footer small {
    color: rgba(255, 255, 255, 0.76);
    font-size: 0.88rem;
}

.demo-business-praxis-footer span {
    color: var(--praxis-accent);
    font-weight: 820;
}

.demo-business-praxis-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

@media (max-width: 1023px) {
    .demo-business-praxis-header,
    .demo-business-praxis-hero,
    .demo-business-praxis-approach,
    .demo-business-praxis-hours,
    .demo-business-praxis-cta,
    .demo-business-praxis-footer {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-nav {
        justify-content: flex-start;
    }

    .demo-business-praxis-hero,
    .demo-business-praxis-services,
    .demo-business-praxis-approach,
    .demo-business-praxis-feel,
    .demo-business-praxis-hours {
        padding: 58px 38px;
    }

    .demo-business-praxis-quick {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-praxis-hero-visual,
    .demo-business-praxis-image-grid figure:first-child,
    .demo-business-praxis-image-grid figure:last-child {
        min-height: 360px;
    }

    .demo-business-praxis-image-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-cta,
    .demo-business-praxis-footer {
        padding: 46px 38px;
    }
}

@media (max-width: 767px) {
    .demo-business--praxis {
        border-radius: 16px;
    }

    .demo-business-praxis-header {
        padding: 22px;
    }

    .demo-business-praxis-nav {
        gap: 12px;
        font-size: 0.84rem;
    }

    .demo-business-praxis-header > .demo-business-praxis-button,
    .demo-business-praxis-actions,
    .demo-business-praxis-button {
        width: 100%;
    }

    .demo-business-praxis-hero,
    .demo-business-praxis-services,
    .demo-business-praxis-approach,
    .demo-business-praxis-feel,
    .demo-business-praxis-hours {
        padding: 44px 22px;
    }

    .demo-business--praxis h1 {
        font-size: clamp(2.55rem, 12vw, 3.65rem);
    }

    .demo-business--praxis h2 {
        font-size: clamp(1.9rem, 9vw, 2.8rem);
    }

    .demo-business-praxis-hero-visual {
        min-height: 290px;
        border-width: 8px;
        border-radius: 20px;
    }

    .demo-business-praxis-hero-visual figcaption {
        right: 14px;
        bottom: 14px;
        max-width: calc(100% - 28px);
    }

    .demo-business-praxis-quick,
    .demo-business-praxis-service-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-quick span {
        min-height: auto;
    }

    .demo-business-praxis-service-grid article {
        min-height: auto;
        padding: 26px;
    }

    .demo-business-praxis-approach-copy {
        padding: 28px 24px;
    }

    .demo-business-praxis-image-grid figure:first-child,
    .demo-business-praxis-image-grid figure:last-child {
        min-height: 270px;
        border-radius: 18px;
    }

    .demo-business-praxis-hours-list div {
        grid-template-columns: 1fr;
        gap: 5px;
    }

    .demo-business-praxis-hours-list strong {
        white-space: normal;
    }

    .demo-business-praxis-cta,
    .demo-business-praxis-footer {
        padding: 38px 22px;
    }
}

.demo-business-praxis-image-slot {
    position: relative;
    display: grid;
    min-height: 260px;
    overflow: hidden;
    place-items: center;
    color: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(37, 107, 111, 0.14);
    background:
        linear-gradient(135deg, rgba(23, 71, 74, 0.78), rgba(143, 205, 186, 0.5)),
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.12) 0 1px, transparent 1px 14px),
        var(--praxis-petrol-dark);
}

.demo-business-praxis-image-slot::before {
    content: attr(data-slot);
    position: relative;
    z-index: 1;
    padding: 9px 12px;
    color: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(255, 255, 255, 0.2);
    border-radius: 999px;
    background: rgba(23, 71, 74, 0.66);
    font-size: 0.75rem;
    font-weight: 820;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.demo-business-praxis-image-slot--hero {
    min-height: 500px;
    border: 12px solid var(--praxis-white);
    border-radius: 28px;
    box-shadow: 0 22px 56px rgba(30, 51, 53, 0.14);
}

.demo-business-praxis-image-slot--philosophy,
.demo-business-praxis-image-slot--contact {
    min-height: 380px;
    border-radius: 24px;
}

.demo-business-praxis-image-slot--service,
.demo-business-praxis-image-slot--team {
    min-height: 260px;
    border-radius: 18px;
}

.demo-business-praxis-trust {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 8px;
}

.demo-business-praxis-trust span {
    padding: 12px 14px;
    color: var(--praxis-petrol-dark);
    background: rgba(255, 255, 255, 0.82);
    border: 1px solid rgba(37, 107, 111, 0.12);
    border-radius: 12px;
    font-size: 0.88rem;
    font-weight: 820;
}

.demo-business-praxis-philosophy,
.demo-business-praxis-appointment {
    display: grid;
    grid-template-columns: minmax(0, 0.88fr) minmax(320px, 1fr);
    gap: 34px;
    align-items: stretch;
    padding: 72px 52px;
}

.demo-business-praxis-philosophy {
    background: var(--praxis-mint);
}

.demo-business-praxis-conditions,
.demo-business-praxis-timeline,
.demo-business-praxis-team,
.demo-business-praxis-faq {
    padding: 72px 52px;
}

.demo-business-praxis-conditions {
    background: var(--praxis-white);
}

.demo-business-praxis-condition-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    margin-top: 34px;
}

.demo-business-praxis-condition-grid article {
    display: grid;
    gap: 12px;
    min-height: 190px;
    padding: 28px;
    border: 1px solid rgba(37, 107, 111, 0.1);
    border-radius: 18px;
    background: var(--praxis-gray);
}

.demo-business-praxis-service-detail-list {
    display: grid;
    gap: 22px;
    margin-top: 34px;
}

.demo-business-praxis-service-detail-list article {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.72fr);
    gap: 24px;
    align-items: stretch;
    padding: 26px;
    border: 1px solid rgba(37, 107, 111, 0.1);
    border-radius: 18px;
    background: var(--praxis-gray);
}

.demo-business-praxis-service-detail-list article > div:first-child {
    display: grid;
    align-content: start;
    gap: 12px;
}

.demo-business-praxis-service-detail-list ul {
    display: grid;
    gap: 8px;
    margin: 4px 0 0;
    padding: 0;
    list-style: none;
}

.demo-business-praxis-service-detail-list li {
    color: var(--praxis-muted);
    font-size: 0.92rem;
    font-weight: 720;
}

.demo-business-praxis-service-detail-list li::before {
    content: "✓";
    margin-right: 8px;
    color: var(--praxis-petrol);
    font-weight: 900;
}

.demo-business-praxis-timeline {
    background: var(--praxis-blue);
}

.demo-business-praxis-timeline-list {
    position: relative;
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-top: 36px;
}

.demo-business-praxis-timeline-list::before {
    content: "";
    position: absolute;
    top: 36px;
    right: 10%;
    left: 10%;
    height: 3px;
    background: var(--praxis-accent);
}

.demo-business-praxis-timeline-list article {
    position: relative;
    display: grid;
    gap: 14px;
    padding: 24px;
    border: 1px solid rgba(37, 107, 111, 0.1);
    border-radius: 18px;
    background: var(--praxis-white);
}

.demo-business-praxis-timeline-list span {
    display: inline-grid;
    width: 58px;
    height: 58px;
    place-items: center;
    color: var(--praxis-white);
    background: var(--praxis-petrol);
    border-radius: 999px;
    font-weight: 900;
}

.demo-business-praxis-team {
    background: var(--praxis-white);
}

.demo-business-praxis-team-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
    margin-top: 34px;
}

.demo-business-praxis-team-grid article {
    display: grid;
    overflow: hidden;
    border: 1px solid rgba(37, 107, 111, 0.1);
    border-radius: 20px;
    background: var(--praxis-gray);
}

.demo-business-praxis-team-grid article > div:last-child {
    display: grid;
    gap: 7px;
    padding: 24px;
}

.demo-business-praxis-team-grid span {
    color: var(--praxis-petrol);
    font-size: 0.9rem;
    font-weight: 820;
}

.demo-business-praxis-gallery {
    display: grid;
    grid-template-columns: minmax(0, 1.15fr) repeat(2, minmax(0, 0.62fr));
    gap: 16px;
    margin-top: 34px;
}

.demo-business-praxis-gallery .demo-business-praxis-image-slot {
    min-height: 230px;
    border-radius: 18px;
}

.demo-business-praxis-gallery-main {
    grid-row: span 2;
    min-height: 476px;
}

.demo-business-praxis-faq {
    background: var(--praxis-white);
}

.demo-business-praxis-faq-list {
    display: grid;
    gap: 12px;
    margin-top: 32px;
}

.demo-business-praxis-faq-list article {
    border: 1px solid rgba(37, 107, 111, 0.1);
    border-radius: 18px;
    background: var(--praxis-gray);
}

.demo-business-praxis-faq-list button {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 22px 24px;
    color: var(--praxis-text);
    border: 0;
    background: transparent;
    font: inherit;
    font-weight: 860;
    text-align: left;
    cursor: pointer;
}

.demo-business-praxis-faq-list button::after {
    content: "+";
    display: inline-grid;
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    place-items: center;
    color: var(--praxis-white);
    background: var(--praxis-petrol);
    border-radius: 999px;
    font-weight: 900;
}

.demo-business-praxis-faq-list button[aria-expanded="true"]::after {
    content: "−";
}

.demo-business-praxis-faq-list .demo-business-faq-answer {
    padding: 0 24px 22px;
}

.demo-business-praxis-appointment {
    background:
        linear-gradient(135deg, var(--praxis-mint) 0%, var(--praxis-blue) 100%);
}

.demo-business-praxis-appointment-copy {
    display: grid;
    gap: 15px;
}

.demo-business-praxis-form {
    display: grid;
    gap: 16px;
    padding: 28px;
    background: var(--praxis-white);
    border: 1px solid rgba(37, 107, 111, 0.12);
    border-radius: 20px;
}

.demo-business-praxis-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.demo-business-praxis-form label {
    display: grid;
    gap: 7px;
}

.demo-business-praxis-form label > span {
    color: var(--praxis-text);
    font-size: 0.84rem;
    font-weight: 820;
}

.demo-business-praxis-form input,
.demo-business-praxis-form select,
.demo-business-praxis-form textarea {
    width: 100%;
    min-height: 46px;
    padding: 12px 13px;
    color: var(--praxis-text);
    border: 1px solid rgba(37, 107, 111, 0.18);
    border-radius: 10px;
    background: var(--praxis-white);
    font: inherit;
}

.demo-business-praxis-form textarea {
    resize: vertical;
}

.demo-business-praxis-form-success {
    display: grid;
    gap: 6px;
    padding: 16px;
    color: var(--praxis-text);
    border-left: 5px solid var(--praxis-petrol);
    background: var(--praxis-blue);
}

.demo-business-praxis-form-success[hidden] {
    display: none;
}

.demo-business-praxis-form-success small {
    color: var(--praxis-muted);
}

@media (max-width: 1023px) {
    .demo-business-praxis-philosophy,
    .demo-business-praxis-appointment,
    .demo-business-praxis-service-detail-list article {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-condition-grid,
    .demo-business-praxis-team-grid,
    .demo-business-praxis-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-praxis-timeline-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-praxis-timeline-list::before {
        display: none;
    }

    .demo-business-praxis-gallery-main {
        grid-row: auto;
        min-height: 300px;
    }
}

@media (max-width: 767px) {
    .demo-business-praxis-trust,
    .demo-business-praxis-condition-grid,
    .demo-business-praxis-team-grid,
    .demo-business-praxis-gallery,
    .demo-business-praxis-timeline-list,
    .demo-business-praxis-form-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-philosophy,
    .demo-business-praxis-conditions,
    .demo-business-praxis-timeline,
    .demo-business-praxis-team,
    .demo-business-praxis-faq,
    .demo-business-praxis-appointment {
        padding: 44px 22px;
    }

    .demo-business-praxis-service-detail-list article,
    .demo-business-praxis-condition-grid article,
    .demo-business-praxis-form {
        padding: 22px;
    }

    .demo-business-praxis-image-slot,
    .demo-business-praxis-image-slot--hero,
    .demo-business-praxis-image-slot--philosophy,
    .demo-business-praxis-image-slot--contact,
    .demo-business-praxis-image-slot--service,
    .demo-business-praxis-image-slot--team,
    .demo-business-praxis-gallery .demo-business-praxis-image-slot {
        min-height: 230px;
        border-width: 1px;
        box-shadow: none;
    }

    .demo-business-praxis-faq-list button {
        padding: 18px;
    }

    .demo-business-praxis-faq-list .demo-business-faq-answer {
        padding: 0 18px 18px;
    }
}

.demo-business--gebaeudereinigung {
    --cleaning-white: #FFFFFF;
    --cleaning-ice: #EAF8FB;
    --cleaning-turquoise: #28B8C7;
    --cleaning-deep: #0F5E66;
    --cleaning-mint: #CFF3EA;
    --cleaning-gray: #F4F8F9;
    --cleaning-text: #17363A;
    --cleaning-muted: #5F777B;
    --cleaning-button: #0F9AAA;
    --cleaning-button-hover: #0B7F8C;
    --cleaning-green: #6ED6B5;
    overflow: hidden;
    color: var(--cleaning-text);
    background: var(--cleaning-white);
    border: 1px solid rgba(15, 94, 102, 0.12);
    border-radius: 20px;
    box-shadow: 0 24px 70px rgba(23, 54, 58, 0.12);
}

.demo-business--gebaeudereinigung a {
    text-decoration: none;
}

.demo-business--gebaeudereinigung img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business-cleaning-header {
    display: grid;
    grid-template-columns: minmax(230px, 1fr) auto auto;
    gap: 24px;
    align-items: center;
    padding: 22px 34px;
    background: var(--cleaning-white);
    border-bottom: 1px solid rgba(15, 94, 102, 0.12);
}

.demo-business-cleaning-brand {
    display: grid;
    gap: 4px;
    color: var(--cleaning-text);
}

.demo-business-cleaning-brand span {
    font-size: 1.14rem;
    font-weight: 880;
}

.demo-business-cleaning-brand small {
    color: var(--cleaning-muted);
    font-size: 0.78rem;
    font-weight: 760;
}

.demo-business-cleaning-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    justify-content: center;
}

.demo-business-cleaning-nav a,
.demo-business-cleaning-footer a {
    color: var(--cleaning-muted);
    font-size: 0.9rem;
    font-weight: 780;
}

.demo-business-cleaning-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 22px;
    color: var(--cleaning-deep);
    font-weight: 850;
    border: 1px solid rgba(15, 154, 170, 0.24);
    border-radius: 999px;
    background: var(--cleaning-white);
    transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease;
}

.demo-business-cleaning-button--primary {
    color: var(--cleaning-white);
    background: var(--cleaning-button);
    border-color: var(--cleaning-button);
}

.demo-business-cleaning-button--primary:hover {
    background: var(--cleaning-button-hover);
    border-color: var(--cleaning-button-hover);
}

.demo-business-cleaning-button--secondary:hover {
    color: var(--cleaning-white);
    background: var(--cleaning-deep);
    border-color: var(--cleaning-deep);
}

.demo-business-cleaning-main {
    display: grid;
}

.demo-business-cleaning-hero {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(340px, 1fr);
    gap: 44px;
    align-items: center;
    padding: 70px 52px;
    background:
        linear-gradient(130deg, var(--cleaning-white) 0%, var(--cleaning-ice) 72%),
        var(--cleaning-ice);
}

.demo-business-cleaning-hero-copy,
.demo-business-cleaning-section-copy,
.demo-business-cleaning-request-copy {
    display: grid;
    gap: 15px;
}

.demo-business-cleaning-kicker {
    color: var(--cleaning-button);
    font-size: 0.78rem;
    font-weight: 880;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.demo-business--gebaeudereinigung h1,
.demo-business--gebaeudereinigung h2,
.demo-business--gebaeudereinigung h3,
.demo-business--gebaeudereinigung p {
    margin: 0;
}

.demo-business--gebaeudereinigung h1,
.demo-business--gebaeudereinigung h2,
.demo-business--gebaeudereinigung h3 {
    color: var(--cleaning-text);
    line-height: 1.05;
}

.demo-business--gebaeudereinigung h1 {
    max-width: 760px;
    font-size: clamp(2.85rem, 5.8vw, 5rem);
}

.demo-business--gebaeudereinigung h2 {
    max-width: 760px;
    font-size: clamp(2rem, 3.8vw, 3.4rem);
}

.demo-business--gebaeudereinigung h3 {
    font-size: 1.16rem;
}

.demo-business--gebaeudereinigung p {
    color: var(--cleaning-muted);
    font-size: 1rem;
    line-height: 1.7;
}

.demo-business-cleaning-hero-copy > p {
    max-width: 650px;
    font-size: 1.08rem;
}

.demo-business-cleaning-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.demo-business-cleaning-hero-visual {
    position: relative;
    min-height: 500px;
    margin: 0;
    overflow: hidden;
    border: 10px solid var(--cleaning-white);
    border-radius: 28px;
    box-shadow: 0 22px 58px rgba(15, 94, 102, 0.14);
}

.demo-business--cleaning-v3 .demo-business-cleaning-hero-visual > picture,
.demo-business--cleaning-v3 .demo-business-cleaning-hero-visual > picture > img {
    display: block;
    width: 100%;
    height: 100%;
}

.demo-business-cleaning-hero-visual::before {
    content: "";
    position: absolute;
    inset: auto -18% -28% 18%;
    height: 44%;
    background: rgba(40, 184, 199, 0.2);
    border-radius: 999px 999px 0 0;
}

.demo-business-cleaning-hero-visual figcaption {
    position: absolute;
    right: 22px;
    bottom: 22px;
    max-width: 310px;
    padding: 15px 18px;
    color: var(--cleaning-deep);
    font-size: 0.88rem;
    font-weight: 850;
    background: rgba(255, 255, 255, 0.94);
    border: 1px solid rgba(15, 154, 170, 0.16);
    border-radius: 16px;
}

.demo-business-cleaning-types {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    background: rgba(15, 94, 102, 0.12);
}

.demo-business-cleaning-types span {
    min-height: 84px;
    padding: 22px;
    color: var(--cleaning-text);
    background: var(--cleaning-white);
    font-size: 0.95rem;
    font-weight: 850;
}

.demo-business-cleaning-services,
.demo-business-cleaning-quality,
.demo-business-cleaning-results,
.demo-business-cleaning-request {
    padding: 72px 52px;
}

.demo-business-cleaning-services {
    background: var(--cleaning-white);
}

.demo-business-cleaning-service-list {
    display: grid;
    gap: 16px;
    margin-top: 34px;
}

.demo-business-cleaning-service-list article {
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    gap: 22px;
    align-items: start;
    padding: 26px;
    background: var(--cleaning-gray);
    border: 1px solid rgba(15, 154, 170, 0.12);
    border-radius: 18px;
}

.demo-business-cleaning-service-list article > span {
    display: inline-grid;
    place-items: center;
    width: 54px;
    height: 54px;
    color: var(--cleaning-white);
    background: var(--cleaning-turquoise);
    font-weight: 900;
    border-radius: 16px;
}

.demo-business-cleaning-service-list article > div {
    display: grid;
    gap: 9px;
}

.demo-business-cleaning-quality {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(320px, 0.72fr);
    gap: 34px;
    align-items: center;
    background:
        linear-gradient(135deg, var(--cleaning-mint) 0%, var(--cleaning-ice) 100%);
}

.demo-business-cleaning-quality > div:first-child {
    display: grid;
    gap: 14px;
}

.demo-business-cleaning-checks {
    display: grid;
    gap: 12px;
}

.demo-business-cleaning-checks span {
    position: relative;
    padding: 18px 20px 18px 48px;
    color: var(--cleaning-text);
    font-weight: 850;
    background: var(--cleaning-white);
    border-radius: 16px;
}

.demo-business-cleaning-checks span::before {
    content: "";
    position: absolute;
    top: 22px;
    left: 20px;
    width: 12px;
    height: 12px;
    background: var(--cleaning-green);
    border-radius: 999px;
}

.demo-business-cleaning-results {
    background: var(--cleaning-ice);
}

.demo-business-cleaning-result-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(260px, 0.68fr);
    gap: 22px;
    align-items: end;
    margin-top: 34px;
}

.demo-business-cleaning-result-layout figure {
    margin: 0;
    overflow: hidden;
    background: var(--cleaning-white);
    border-radius: 22px;
}

.demo-business-cleaning-result-layout figure:first-child {
    min-height: 450px;
}

.demo-business-cleaning-result-layout figure:last-child {
    min-height: 330px;
}

.demo-business-cleaning-result-cards {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
    margin-top: 18px;
}

.demo-business-cleaning-result-cards article {
    padding: 18px;
    color: var(--cleaning-deep);
    font-weight: 850;
    background: var(--cleaning-white);
    border: 1px solid rgba(15, 154, 170, 0.14);
    border-radius: 16px;
}

.demo-business-cleaning-request {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(320px, 0.8fr);
    gap: 28px;
    align-items: center;
    background: var(--cleaning-white);
}

.demo-business-cleaning-form-preview {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 24px;
    background: var(--cleaning-gray);
    border: 1px solid rgba(15, 154, 170, 0.14);
    border-radius: 20px;
}

.demo-business-cleaning-form-preview span {
    min-height: 54px;
    padding: 16px;
    color: var(--cleaning-muted);
    font-weight: 780;
    background: var(--cleaning-white);
    border: 1px solid rgba(15, 94, 102, 0.1);
    border-radius: 14px;
}

.demo-business-cleaning-request .demo-business-cleaning-actions {
    grid-column: 1 / -1;
}

.demo-business-cleaning-final {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    padding: 58px 52px;
    background:
        linear-gradient(135deg, var(--cleaning-deep) 0%, #0B7F8C 100%);
}

.demo-business-cleaning-final h2 {
    color: var(--cleaning-white);
}

.demo-business-cleaning-final p {
    color: rgba(255, 255, 255, 0.78);
}

.demo-business-cleaning-final .demo-business-cleaning-button--secondary {
    color: var(--cleaning-white);
    background: transparent;
    border-color: rgba(255, 255, 255, 0.34);
}

.demo-business-cleaning-footer {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(210px, 0.85fr) minmax(160px, 0.55fr);
    gap: 24px;
    padding: 34px 52px;
    background: var(--cleaning-gray);
    border-top: 1px solid rgba(15, 94, 102, 0.1);
}

.demo-business-cleaning-footer div,
.demo-business-cleaning-footer nav {
    display: grid;
    gap: 7px;
}

.demo-business-cleaning-footer strong {
    color: var(--cleaning-text);
    font-size: 1.12rem;
}

.demo-business-cleaning-footer p,
.demo-business-cleaning-footer a,
.demo-business-cleaning-footer span,
.demo-business-cleaning-footer small {
    color: var(--cleaning-muted);
    font-size: 0.88rem;
}

.demo-business-cleaning-footer span {
    color: var(--cleaning-deep);
    font-weight: 850;
}

.demo-business-cleaning-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(15, 94, 102, 0.1);
}

@media (max-width: 1023px) {
    .demo-business-cleaning-header,
    .demo-business-cleaning-hero,
    .demo-business-cleaning-quality,
    .demo-business-cleaning-request,
    .demo-business-cleaning-final,
    .demo-business-cleaning-footer {
        grid-template-columns: 1fr;
    }

    .demo-business-cleaning-nav {
        justify-content: flex-start;
    }

    .demo-business-cleaning-hero,
    .demo-business-cleaning-services,
    .demo-business-cleaning-quality,
    .demo-business-cleaning-results,
    .demo-business-cleaning-request {
        padding: 58px 38px;
    }

    .demo-business-cleaning-types {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-cleaning-hero-visual,
    .demo-business-cleaning-result-layout figure:first-child,
    .demo-business-cleaning-result-layout figure:last-child {
        min-height: 360px;
    }

    .demo-business-cleaning-result-layout {
        grid-template-columns: 1fr;
    }

    .demo-business-cleaning-final,
    .demo-business-cleaning-footer {
        padding: 46px 38px;
    }
}

@media (max-width: 767px) {
    .demo-business--gebaeudereinigung {
        border-radius: 16px;
    }

    .demo-business-cleaning-header {
        padding: 22px;
    }

    .demo-business-cleaning-nav {
        gap: 12px;
        font-size: 0.84rem;
    }

    .demo-business-cleaning-header > .demo-business-cleaning-button,
    .demo-business-cleaning-actions,
    .demo-business-cleaning-button {
        width: 100%;
    }

    .demo-business-cleaning-hero,
    .demo-business-cleaning-services,
    .demo-business-cleaning-quality,
    .demo-business-cleaning-results,
    .demo-business-cleaning-request {
        padding: 44px 22px;
    }

    .demo-business--gebaeudereinigung h1 {
        font-size: clamp(2.5rem, 12vw, 3.55rem);
    }

    .demo-business--gebaeudereinigung h2 {
        font-size: clamp(1.9rem, 9vw, 2.8rem);
    }

    .demo-business-cleaning-hero-visual {
        min-height: 290px;
        border-width: 8px;
        border-radius: 20px;
    }

    .demo-business-cleaning-hero-visual figcaption {
        right: 14px;
        bottom: 14px;
        max-width: calc(100% - 28px);
    }

    .demo-business-cleaning-types,
    .demo-business-cleaning-form-preview,
    .demo-business-cleaning-result-cards {
        grid-template-columns: 1fr;
    }

    .demo-business-cleaning-types span {
        min-height: auto;
    }

    .demo-business-cleaning-service-list article {
        grid-template-columns: 1fr;
        padding: 24px;
    }

    .demo-business-cleaning-result-layout figure:first-child,
    .demo-business-cleaning-result-layout figure:last-child {
        min-height: 270px;
        border-radius: 18px;
    }

    .demo-business-cleaning-final,
    .demo-business-cleaning-footer {
        padding: 38px 22px;
    }
}

.demo-business--cleaning-v3 {
    --cleaning-v3-white: #FFFFFF;
    --cleaning-v3-ice: #EAF8FB;
    --cleaning-v3-soft: #F4FAFB;
    --cleaning-v3-turquoise: #16A7B5;
    --cleaning-v3-turquoise-dark: #0F7F8B;
    --cleaning-v3-deep: #103D55;
    --cleaning-v3-navy: #0D2838;
    --cleaning-v3-text: #17363A;
    --cleaning-v3-muted: #5F777B;
    --cleaning-v3-line: rgba(16, 61, 85, 0.13);
    overflow: hidden;
    color: var(--cleaning-v3-text);
    background: var(--cleaning-v3-white);
    border-radius: 0;
    box-shadow: none;
}

.demo-business--cleaning-v3,
.demo-business--cleaning-v3 * {
    box-sizing: border-box;
}

.demo-business--cleaning-v3 a {
    text-decoration: none;
}

.demo-business--cleaning-v3 img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business--cleaning-v3 h1,
.demo-business--cleaning-v3 h2,
.demo-business--cleaning-v3 h3,
.demo-business--cleaning-v3 p,
.demo-business--cleaning-v3 figure,
.demo-business--cleaning-v3 address {
    margin: 0;
}

.demo-business--cleaning-v3 h1,
.demo-business--cleaning-v3 h2,
.demo-business--cleaning-v3 h3 {
    color: inherit;
    letter-spacing: 0;
}

.demo-business--cleaning-v3 h1 {
    font-size: 4.15rem;
    line-height: 1.02;
}

.demo-business--cleaning-v3 h2 {
    font-size: 3rem;
    line-height: 1.06;
}

.demo-business--cleaning-v3 h3 {
    font-size: 1.12rem;
    line-height: 1.25;
}

.demo-business--cleaning-v3 p,
.demo-business--cleaning-v3 address {
    color: var(--cleaning-v3-muted);
    font-size: 1rem;
    line-height: 1.68;
    font-style: normal;
}

.demo-business--cleaning-v3 .demo-business-cleaning-header--stacked {
    position: sticky;
    top: 0;
    z-index: 20;
    display: grid;
    grid-template-columns: minmax(240px, 0.9fr) minmax(260px, 0.86fr) minmax(0, 1.55fr);
    gap: 18px;
    align-items: center;
    padding: 18px 34px;
    background: rgba(255, 255, 255, 0.98);
    border-bottom: 1px solid var(--cleaning-v3-line);
    transform: translateY(0);
    transition: transform 220ms ease, box-shadow 220ms ease;
    will-change: transform;
}

.demo-business--cleaning-v3 [data-demo-smart-header].is-demo-header-hidden {
    transform: translateY(calc(-100% - 2px));
    pointer-events: none;
}

.demo-business--cleaning-v3 [data-demo-smart-header].is-demo-header-visible,
.demo-business--cleaning-v3 [data-demo-smart-header]:focus-within {
    transform: translateY(0);
    pointer-events: auto;
}

.demo-business--cleaning-v3 [data-demo-smart-header].is-demo-header-visible {
    box-shadow: 0 14px 36px rgba(16, 61, 85, 0.1);
}

.demo-business--cleaning-v3 .demo-business-cleaning-brand {
    display: grid;
    gap: 3px;
    color: var(--cleaning-v3-deep);
    line-height: 1.12;
    transition: color 180ms ease;
}

.demo-business--cleaning-v3 .demo-business-cleaning-brand span {
    font-size: 1.18rem;
    font-weight: 900;
}

.demo-business--cleaning-v3 .demo-business-cleaning-brand small {
    color: var(--cleaning-v3-muted);
    font-size: 0.74rem;
    font-weight: 760;
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

.demo-business--cleaning-v3 .demo-business-cleaning-header-info {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    color: var(--cleaning-v3-muted);
    font-size: 0.84rem;
    font-weight: 760;
}

.demo-business--cleaning-v3 .demo-business-cleaning-header-info span + span::before {
    content: "·";
    display: inline-block;
    margin: 0 8px;
    color: var(--cleaning-v3-turquoise);
}

.demo-business--cleaning-v3 .demo-business-menu--cleaning {
    display: flex;
    min-width: 0;
    align-items: center;
    justify-content: flex-end;
    gap: 14px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    justify-content: flex-end;
}

.demo-business--cleaning-v3 .demo-business-cleaning-nav a,
.demo-business--cleaning-v3 .demo-business-cleaning-footer a {
    color: var(--cleaning-v3-muted);
    font-size: 0.9rem;
    font-weight: 780;
    transition: color 180ms ease, background-color 180ms ease, border-color 180ms ease;
}

.demo-business--cleaning-v3 .demo-business-cleaning-brand:hover,
.demo-business--cleaning-v3 .demo-business-cleaning-brand:focus-visible,
.demo-business--cleaning-v3 .demo-business-cleaning-nav a:hover,
.demo-business--cleaning-v3 .demo-business-cleaning-nav a:focus-visible,
.demo-business--cleaning-v3 .demo-business-cleaning-footer a:hover,
.demo-business--cleaning-v3 .demo-business-cleaning-footer a:focus-visible {
    color: var(--cleaning-v3-turquoise-dark);
}

.demo-business-menu-toggle--cleaning {
    color: var(--cleaning-v3-deep);
    border-color: rgba(16, 61, 85, 0.24);
    background: rgba(234, 248, 251, 0.9);
}

.demo-business-menu-toggle--cleaning:hover,
.demo-business-menu-toggle--cleaning:focus-visible {
    color: #FFFFFF;
    border-color: var(--cleaning-v3-turquoise-dark);
    background: var(--cleaning-v3-turquoise-dark);
}

.demo-business--cleaning-v3 .demo-business-cleaning-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 12px 20px;
    color: var(--cleaning-v3-deep);
    font-size: 0.93rem;
    font-weight: 840;
    line-height: 1.15;
    border: 1px solid rgba(16, 61, 85, 0.22);
    border-radius: 8px;
    background: #FFFFFF;
    transition: color 180ms ease, background-color 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.demo-business--cleaning-v3 .demo-business-cleaning-button--primary {
    color: #FFFFFF;
    border-color: var(--cleaning-v3-turquoise-dark);
    background: var(--cleaning-v3-turquoise-dark);
}

.demo-business--cleaning-v3 .demo-business-cleaning-button:hover,
.demo-business--cleaning-v3 .demo-business-cleaning-button:focus-visible {
    color: #FFFFFF;
    border-color: var(--cleaning-v3-deep);
    background: var(--cleaning-v3-deep);
    transform: translateY(-1px);
}

.demo-business--cleaning-v3 .demo-business-cleaning-main {
    display: grid;
}

.demo-business--cleaning-v3 .demo-business-cleaning-hero,
.demo-business--cleaning-v3 .demo-business-cleaning-quality,
.demo-business--cleaning-v3 .demo-business-cleaning-request,
.demo-business--cleaning-v3 .demo-business-cleaning-contact {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(340px, 1fr);
    gap: 44px;
    align-items: center;
    padding: 76px 52px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-hero {
    background: linear-gradient(135deg, #FFFFFF 0%, var(--cleaning-v3-ice) 100%);
}

.demo-business--cleaning-v3 .demo-business-cleaning-hero-copy,
.demo-business--cleaning-v3 .demo-business-cleaning-section-copy {
    display: grid;
    gap: 16px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-kicker {
    color: var(--cleaning-v3-turquoise-dark);
    font-size: 0.78rem;
    font-weight: 860;
    letter-spacing: 0.09em;
    text-transform: uppercase;
}

.demo-business--cleaning-v3 .demo-business-cleaning-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-hero-visual,
.demo-business--cleaning-v3 .demo-business-cleaning-card-grid img,
.demo-business--cleaning-v3 .demo-business-cleaning-object-layout figure,
.demo-business--cleaning-v3 .demo-business-cleaning-quality-panel figure,
.demo-business--cleaning-v3 .demo-business-cleaning-process-layout figure,
.demo-business--cleaning-v3 .demo-business-cleaning-team-grid img,
.demo-business--cleaning-v3 .demo-business-cleaning-request figure {
    overflow: hidden;
    border-radius: 8px;
    box-shadow: 0 18px 44px rgba(16, 61, 85, 0.13);
}

.demo-business--cleaning-v3 .demo-business-cleaning-hero-visual {
    align-self: center;
    min-height: 0;
    aspect-ratio: 3 / 2;
}

.demo-business--cleaning-v3 .demo-business-cleaning-hero-visual::before {
    content: none;
}

.demo-business--cleaning-v3 .demo-business-cleaning-trust {
    grid-column: 1 / -1;
    display: flex;
    flex-wrap: wrap;
    gap: 12px 24px;
    align-items: center;
    justify-content: center;
    width: 100%;
    padding-top: 10px;
    color: var(--cleaning-v3-muted);
    border-top: 1px solid var(--cleaning-v3-line);
}

.demo-business--cleaning-v3 .demo-business-cleaning-trust span {
    display: inline-flex;
    gap: 7px;
    align-items: center;
    color: var(--cleaning-v3-muted);
    font-size: 0.9rem;
    font-weight: 780;
}

.demo-business--cleaning-v3 .demo-business-cleaning-trust span::before {
    content: "✓";
    color: var(--cleaning-v3-turquoise-dark);
    font-weight: 900;
}

.demo-business--cleaning-v3 .demo-business-cleaning-services,
.demo-business--cleaning-v3 .demo-business-cleaning-objects,
.demo-business--cleaning-v3 .demo-business-cleaning-process,
.demo-business--cleaning-v3 .demo-business-cleaning-team {
    display: grid;
    gap: 34px;
    padding: 76px 52px;
    background: #FFFFFF;
}

.demo-business--cleaning-v3 .demo-business-cleaning-card-grid,
.demo-business--cleaning-v3 .demo-business-cleaning-team-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-card-grid article,
.demo-business--cleaning-v3 .demo-business-cleaning-team-grid article,
.demo-business--cleaning-v3 .demo-business-cleaning-object-grid article,
.demo-business--cleaning-v3 .demo-business-cleaning-process-grid article,
.demo-business--cleaning-v3 .demo-business-cleaning-checks span {
    border: 1px solid var(--cleaning-v3-line);
    border-radius: 8px;
    background: var(--cleaning-v3-soft);
    transition: transform 180ms ease, box-shadow 180ms ease, border-color 180ms ease;
}

.demo-business--cleaning-v3 .demo-business-cleaning-card-grid article {
    display: grid;
    grid-template-rows: auto 1fr;
    overflow: hidden;
}

.demo-business--cleaning-v3 .demo-business-cleaning-card-grid article div,
.demo-business--cleaning-v3 .demo-business-cleaning-team-grid article {
    display: grid;
    gap: 10px;
    padding: 22px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-card-grid img,
.demo-business--cleaning-v3 .demo-business-cleaning-team-grid img {
    border-radius: 0;
    box-shadow: none;
}

.demo-business--cleaning-v3 .demo-business-cleaning-card-grid img {
    aspect-ratio: 3 / 2;
}

.demo-business--cleaning-v3 .demo-business-cleaning-inline-cta {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 18px;
    align-items: center;
    padding: 30px 52px;
    color: #FFFFFF;
    background: var(--cleaning-v3-navy);
}

.demo-business--cleaning-v3 .demo-business-cleaning-inline-cta p {
    color: #FFFFFF;
    font-size: 1.22rem;
    font-weight: 780;
    line-height: 1.35;
}

.demo-business--cleaning-v3 .demo-business-cleaning-inline-cta .demo-business-cleaning-button {
    color: #FFFFFF;
    border-color: rgba(255, 255, 255, 0.72);
    background: rgba(255, 255, 255, 0.08);
}

.demo-business--cleaning-v3 .demo-business-cleaning-inline-cta .demo-business-cleaning-button:hover,
.demo-business--cleaning-v3 .demo-business-cleaning-inline-cta .demo-business-cleaning-button:focus-visible {
    border-color: var(--cleaning-v3-turquoise);
    background: var(--cleaning-v3-turquoise-dark);
}

.demo-business--cleaning-v3 .demo-business-cleaning-objects,
.demo-business--cleaning-v3 .demo-business-cleaning-team {
    background: var(--cleaning-v3-ice);
}

.demo-business--cleaning-v3 .demo-business-cleaning-object-layout,
.demo-business--cleaning-v3 .demo-business-cleaning-process-layout {
    display: grid;
    grid-template-columns: minmax(320px, 0.8fr) minmax(0, 1fr);
    gap: 24px;
    align-items: stretch;
}

.demo-business--cleaning-v3 .demo-business-cleaning-object-layout figure,
.demo-business--cleaning-v3 .demo-business-cleaning-process-layout figure {
    min-height: 430px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-object-grid,
.demo-business--cleaning-v3 .demo-business-cleaning-process-grid,
.demo-business--cleaning-v3 .demo-business-cleaning-checks {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-object-grid article {
    display: grid;
    min-height: 112px;
    place-items: center;
    padding: 22px;
    color: var(--cleaning-v3-deep);
    font-weight: 860;
    background: #FFFFFF;
}

.demo-business--cleaning-v3 .demo-business-cleaning-quality {
    background: linear-gradient(135deg, var(--cleaning-v3-soft) 0%, #FFFFFF 100%);
}

.demo-business--cleaning-v3 .demo-business-cleaning-quality {
    grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1fr);
    align-items: start;
}

.demo-business--cleaning-v3 .demo-business-cleaning-quality-panel {
    display: contents;
}

.demo-business--cleaning-v3 .demo-business-cleaning-quality-panel figure,
.demo-business--cleaning-v3 .demo-business-cleaning-request figure {
    min-height: 300px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-quality-panel figure {
    min-height: 360px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-checks {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 16px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-checks span {
    display: flex;
    min-height: 118px;
    align-items: flex-start;
    gap: 10px;
    padding: 20px 18px;
    color: var(--cleaning-v3-deep);
    font-weight: 800;
    background: #FFFFFF;
    border: 1px solid rgba(16, 61, 85, 0.08);
    transition: border-color 180ms ease, box-shadow 180ms ease, transform 180ms ease;
}

.demo-business--cleaning-v3 .demo-business-cleaning-checks span::before {
    content: "";
    position: static;
    flex: 0 0 auto;
    width: 10px;
    height: 10px;
    margin-top: 0.42em;
    background: var(--cleaning-v3-turquoise);
    border-radius: 999px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-checks span:hover,
.demo-business--cleaning-v3 .demo-business-cleaning-checks span:focus-visible {
    border-color: rgba(25, 167, 184, 0.36);
    box-shadow: 0 16px 34px rgba(16, 61, 85, 0.1);
    transform: translateY(-2px);
}

.demo-business--cleaning-v3 .demo-business-cleaning-process-grid article {
    display: grid;
    gap: 10px;
    padding: 20px;
    background: #FFFFFF;
}

.demo-business--cleaning-v3 .demo-business-cleaning-process-grid article > span {
    display: inline-grid;
    width: 38px;
    height: 38px;
    place-items: center;
    color: #FFFFFF;
    font-weight: 900;
    border-radius: 999px;
    background: var(--cleaning-v3-turquoise-dark);
    transition: background-color 180ms ease, transform 180ms ease;
}

.demo-business--cleaning-v3 .demo-business-cleaning-team-grid article {
    background: #FFFFFF;
}

.demo-business--cleaning-v3 .demo-business-cleaning-team-grid img {
    aspect-ratio: 5 / 4;
    object-position: center 30%;
    border-radius: 8px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-team-grid span {
    color: var(--cleaning-v3-turquoise-dark);
    font-size: 0.86rem;
    font-weight: 860;
}

.demo-business--cleaning-v3 .demo-business-cleaning-request {
    align-items: start;
    background: #FFFFFF;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form {
    display: grid;
    gap: 16px;
    padding: 28px;
    background: var(--cleaning-v3-soft);
    border: 1px solid var(--cleaning-v3-line);
    border-radius: 8px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form label {
    display: grid;
    gap: 7px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form label > span {
    color: var(--cleaning-v3-deep);
    font-size: 0.84rem;
    font-weight: 820;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form input,
.demo-business--cleaning-v3 .demo-business-cleaning-form select,
.demo-business--cleaning-v3 .demo-business-cleaning-form textarea {
    width: 100%;
    min-height: 46px;
    padding: 11px 12px;
    color: var(--cleaning-v3-text);
    font: inherit;
    border: 1px solid rgba(16, 61, 85, 0.22);
    border-radius: 8px;
    background: #FFFFFF;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form textarea {
    resize: vertical;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form-success {
    display: grid;
    gap: 5px;
    padding: 16px;
    color: var(--cleaning-v3-text);
    border-left: 4px solid var(--cleaning-v3-turquoise-dark);
    background: #FFFFFF;
    border-radius: 8px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-form-success[hidden] {
    display: none;
}

.demo-business--cleaning-v3 .demo-business-cleaning-contact {
    background: var(--cleaning-v3-ice);
}

.demo-business--cleaning-v3 .demo-business-cleaning-contact address a {
    color: var(--cleaning-v3-deep);
    font-weight: 800;
}

.demo-business--cleaning-v3 .demo-business-cleaning-contact-hours {
    display: grid;
    gap: 5px;
    margin-top: 18px;
    color: var(--cleaning-v3-muted);
    font-style: normal;
}

.demo-business--cleaning-v3 .demo-business-cleaning-contact-hours strong,
.demo-business--cleaning-v3 .demo-business-cleaning-contact-hours b {
    color: var(--cleaning-v3-deep);
    font-style: normal;
    font-weight: 820;
}

.demo-business--cleaning-v3 .demo-business-cleaning-contact-hours span {
    display: flex;
    gap: 12px;
    justify-content: space-between;
}

.demo-business--cleaning-v3 .demo-business-cleaning-contact-hours small {
    margin-top: 5px;
    color: var(--cleaning-v3-muted);
    font-size: 0.88rem;
    line-height: 1.55;
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer {
    display: grid;
    grid-template-columns: minmax(240px, 1fr) minmax(220px, 0.85fr) minmax(190px, 0.7fr);
    gap: 24px;
    padding: 36px 52px;
    color: #FFFFFF;
    background: var(--cleaning-v3-navy);
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer div,
.demo-business--cleaning-v3 .demo-business-cleaning-footer nav,
.demo-business--cleaning-v3 .demo-business-cleaning-footer address {
    display: grid;
    gap: 7px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer div:first-child {
    gap: 3px;
    align-content: start;
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer-brand {
    color: #FFFFFF;
    font-size: 1.72rem;
    font-weight: 920;
    line-height: 1.08;
    transition: color 180ms ease, text-decoration-color 180ms ease;
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer p,
.demo-business--cleaning-v3 .demo-business-cleaning-footer a,
.demo-business--cleaning-v3 .demo-business-cleaning-footer address,
.demo-business--cleaning-v3 .demo-business-cleaning-footer span,
.demo-business--cleaning-v3 .demo-business-cleaning-footer small {
    color: rgba(255, 255, 255, 0.8);
    font-size: 0.88rem;
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer address a,
.demo-business--cleaning-v3 .demo-business-cleaning-footer nav a {
    color: rgba(255, 255, 255, 0.88);
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer span {
    color: var(--cleaning-v3-ice);
    font-weight: 840;
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer a:hover,
.demo-business--cleaning-v3 .demo-business-cleaning-footer a:focus-visible {
    color: var(--cleaning-v3-turquoise);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 5px;
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(255, 255, 255, 0.14);
}

@media (min-width: 1024px) {
    .demo-business--cleaning-v3 .demo-business-cleaning-contact {
        grid-template-columns: 1fr;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-contact .demo-business-cleaning-section-copy {
        grid-template-columns: minmax(0, 1fr) minmax(280px, 0.72fr);
        column-gap: 56px;
        align-items: start;
        max-width: none;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-contact address {
        grid-column: 1;
        grid-row: 3;
        align-self: start;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-contact-hours {
        grid-column: 2;
        grid-row: 1 / span 3;
        align-self: center;
        margin-top: 0;
        padding: 24px;
        border: 1px solid rgba(25, 167, 184, 0.22);
        border-left: 4px solid var(--cleaning-v3-turquoise);
        border-radius: 8px;
        background: #FFFFFF;
        box-shadow: 0 18px 38px rgba(16, 61, 85, 0.1);
    }
}

@media (hover: hover) and (pointer: fine) {
    .demo-business--cleaning-v3 .demo-business-cleaning-card-grid article:hover,
    .demo-business--cleaning-v3 .demo-business-cleaning-team-grid article:hover,
    .demo-business--cleaning-v3 .demo-business-cleaning-object-grid article:hover,
    .demo-business--cleaning-v3 .demo-business-cleaning-process-grid article:hover,
    .demo-business--cleaning-v3 .demo-business-cleaning-checks span:hover {
        transform: translateY(-4px);
        border-color: rgba(22, 167, 181, 0.42);
        box-shadow: 0 18px 38px rgba(16, 61, 85, 0.12);
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-process-grid article:hover > span {
        background: var(--cleaning-v3-deep);
        transform: scale(1.04);
    }
}

@media (max-width: 1180px) {
    .demo-business--cleaning-v3 .demo-business-menu-toggle--cleaning {
        display: inline-flex;
        grid-column: 2;
        grid-row: 1;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-header--stacked {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 12px 16px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-header-info {
        grid-column: 1 / -1;
        grid-row: 2;
        justify-content: center;
        text-align: center;
    }

    .demo-business--cleaning-v3 .demo-business-menu--cleaning {
        display: none;
        grid-column: 1 / -1;
        grid-row: 3;
        width: 100%;
        align-items: stretch;
        justify-content: stretch;
        gap: 14px;
        padding-top: 12px;
        border-top: 1px solid var(--cleaning-v3-line);
    }

    .demo-business--cleaning-v3 .is-demo-menu-open .demo-business-menu--cleaning {
        display: grid;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-nav {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-nav a {
        padding: 11px 12px;
        border-radius: 8px;
        background: rgba(234, 248, 251, 0.9);
    }

    .demo-business--cleaning-v3 .demo-business-menu--cleaning > .demo-business-cleaning-button {
        width: 100%;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-card-grid,
    .demo-business--cleaning-v3 .demo-business-cleaning-team-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    .demo-business--cleaning-v3 h1 {
        font-size: 3.35rem;
    }

    .demo-business--cleaning-v3 h2 {
        font-size: 2.5rem;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-hero,
    .demo-business--cleaning-v3 .demo-business-cleaning-quality,
    .demo-business--cleaning-v3 .demo-business-cleaning-request,
    .demo-business--cleaning-v3 .demo-business-cleaning-contact,
    .demo-business--cleaning-v3 .demo-business-cleaning-footer,
    .demo-business--cleaning-v3 .demo-business-cleaning-object-layout,
    .demo-business--cleaning-v3 .demo-business-cleaning-process-layout {
        grid-template-columns: 1fr;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-hero,
    .demo-business--cleaning-v3 .demo-business-cleaning-services,
    .demo-business--cleaning-v3 .demo-business-cleaning-objects,
    .demo-business--cleaning-v3 .demo-business-cleaning-quality,
    .demo-business--cleaning-v3 .demo-business-cleaning-process,
    .demo-business--cleaning-v3 .demo-business-cleaning-team,
    .demo-business--cleaning-v3 .demo-business-cleaning-request,
    .demo-business--cleaning-v3 .demo-business-cleaning-contact,
    .demo-business--cleaning-v3 .demo-business-cleaning-footer {
        padding: 58px 38px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-hero-visual,
    .demo-business--cleaning-v3 .demo-business-cleaning-object-layout figure,
    .demo-business--cleaning-v3 .demo-business-cleaning-process-layout figure {
        min-height: 360px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-hero-visual {
        min-height: 0;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-inline-cta {
        grid-template-columns: 1fr;
        padding: 30px 38px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-quality-panel {
        display: grid;
        gap: 18px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-checks {
        grid-column: auto;
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .demo-business--cleaning-v3 h1 {
        font-size: 2.55rem;
    }

    .demo-business--cleaning-v3 h2 {
        font-size: 2rem;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-header--stacked {
        padding: 20px 22px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-header-info {
        justify-content: flex-start;
        font-size: 0.8rem;
        text-align: left;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-header-info span + span::before {
        margin: 0 6px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-hero,
    .demo-business--cleaning-v3 .demo-business-cleaning-services,
    .demo-business--cleaning-v3 .demo-business-cleaning-objects,
    .demo-business--cleaning-v3 .demo-business-cleaning-quality,
    .demo-business--cleaning-v3 .demo-business-cleaning-process,
    .demo-business--cleaning-v3 .demo-business-cleaning-team,
    .demo-business--cleaning-v3 .demo-business-cleaning-request,
    .demo-business--cleaning-v3 .demo-business-cleaning-contact,
    .demo-business--cleaning-v3 .demo-business-cleaning-footer {
        padding: 44px 22px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-card-grid,
    .demo-business--cleaning-v3 .demo-business-cleaning-team-grid,
    .demo-business--cleaning-v3 .demo-business-cleaning-object-grid,
    .demo-business--cleaning-v3 .demo-business-cleaning-process-grid,
    .demo-business--cleaning-v3 .demo-business-cleaning-checks,
    .demo-business--cleaning-v3 .demo-business-cleaning-form-grid,
    .demo-business--cleaning-v3 .demo-business-cleaning-nav {
        grid-template-columns: 1fr;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-actions,
    .demo-business--cleaning-v3 .demo-business-cleaning-button,
    .demo-business--cleaning-v3 .demo-business-cleaning-inline-cta .demo-business-cleaning-button {
        width: 100%;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-hero-visual,
    .demo-business--cleaning-v3 .demo-business-cleaning-object-layout figure,
    .demo-business--cleaning-v3 .demo-business-cleaning-process-layout figure,
    .demo-business--cleaning-v3 .demo-business-cleaning-quality-panel figure,
    .demo-business--cleaning-v3 .demo-business-cleaning-request figure {
        min-height: 290px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-hero-visual {
        min-height: 0;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-card-grid article {
        grid-template-rows: auto 1fr;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-form {
        padding: 22px;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-checks {
        grid-template-columns: 1fr;
    }

    .demo-business--cleaning-v3 .demo-business-cleaning-inline-cta {
        padding: 28px 22px;
    }
}

.demo-business--kfz {
    --kfz-graphite: #171A1F;
    --kfz-dark: #111827;
    --kfz-metal: #3F4652;
    --kfz-light: #F2F4F7;
    --kfz-steel: #2F6F9F;
    --kfz-red: #E03131;
    --kfz-red-hover: #C92A2A;
    --kfz-white: #FFFFFF;
    --kfz-muted: #AAB2BF;
    overflow: hidden;
    color: var(--kfz-light);
    background: var(--kfz-dark);
    border: 1px solid rgba(170, 178, 191, 0.16);
    border-radius: 18px;
    box-shadow: 0 28px 78px rgba(17, 24, 39, 0.26);
}

.demo-business--kfz a {
    text-decoration: none;
}

.demo-business--kfz img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.demo-business-kfz-header {
    display: grid;
    grid-template-columns: minmax(230px, 1fr) auto auto;
    gap: 24px;
    align-items: center;
    padding: 20px 32px;
    background: var(--kfz-graphite);
    border-bottom: 1px solid rgba(170, 178, 191, 0.14);
}

.demo-business-kfz-brand {
    display: grid;
    gap: 4px;
    color: var(--kfz-white);
}

.demo-business-kfz-brand span {
    font-size: 1.14rem;
    font-weight: 900;
}

.demo-business-kfz-brand small {
    color: var(--kfz-muted);
    font-size: 0.78rem;
    font-weight: 760;
}

.demo-business-kfz-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 18px;
    justify-content: center;
}

.demo-business-kfz-nav a,
.demo-business-kfz-footer a {
    color: var(--kfz-muted);
    font-size: 0.9rem;
    font-weight: 800;
}

.demo-business-kfz-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-height: 46px;
    padding: 0 22px;
    color: var(--kfz-light);
    font-weight: 900;
    border: 1px solid rgba(170, 178, 191, 0.28);
    border-radius: 8px;
    background: transparent;
    transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease;
}

.demo-business-kfz-button--primary {
    color: var(--kfz-white);
    background: var(--kfz-red);
    border-color: var(--kfz-red);
}

.demo-business-kfz-button--primary:hover {
    background: var(--kfz-red-hover);
    border-color: var(--kfz-red-hover);
}

.demo-business-kfz-button--secondary:hover {
    color: var(--kfz-white);
    border-color: var(--kfz-steel);
    background: var(--kfz-steel);
}

.demo-business-kfz-main {
    display: grid;
}

.demo-business-kfz-hero {
    display: grid;
    grid-template-columns: minmax(0, 0.95fr) minmax(360px, 1fr);
    gap: 44px;
    align-items: center;
    padding: 70px 52px;
    background:
        linear-gradient(135deg, rgba(17, 24, 39, 0.98) 0%, rgba(23, 26, 31, 0.96) 58%, rgba(47, 111, 159, 0.72) 100%);
}

.demo-business-kfz-hero-copy,
.demo-business-kfz-section-copy,
.demo-business-kfz-appointment-copy {
    display: grid;
    gap: 15px;
}

.demo-business-kfz-kicker {
    color: var(--kfz-red);
    font-size: 0.78rem;
    font-weight: 900;
    letter-spacing: 0.1em;
    text-transform: uppercase;
}

.demo-business--kfz h1,
.demo-business--kfz h2,
.demo-business--kfz h3,
.demo-business--kfz p {
    margin: 0;
}

.demo-business--kfz h1,
.demo-business--kfz h2,
.demo-business--kfz h3 {
    color: var(--kfz-white);
    line-height: 1.02;
}

.demo-business--kfz h1 {
    max-width: 760px;
    font-size: clamp(2.9rem, 5.8vw, 5rem);
}

.demo-business--kfz h2 {
    max-width: 760px;
    font-size: clamp(2rem, 3vw, 2.7rem);
}

.demo-business--kfz h3 {
    font-size: 1.16rem;
}

.demo-business--kfz p {
    color: var(--kfz-muted);
    font-size: 1rem;
    line-height: 1.68;
}

.demo-business-kfz-hero-copy > p {
    max-width: 650px;
    font-size: 1.08rem;
}

.demo-business-kfz-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    align-items: center;
}

.demo-business-kfz-hero-visual {
    position: relative;
    min-height: 500px;
    margin: 0;
    overflow: hidden;
    border: 8px solid rgba(170, 178, 191, 0.18);
    border-radius: 14px;
    background: var(--kfz-graphite);
    box-shadow: 16px 16px 0 rgba(224, 49, 49, 0.16);
}

.demo-business-kfz-hero-visual::before {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(135deg, transparent 0 48%, rgba(224, 49, 49, 0.22) 48% 52%, transparent 52% 100%);
    pointer-events: none;
}

.demo-business-kfz-hero-visual figcaption {
    position: absolute;
    right: 22px;
    bottom: 22px;
    max-width: 300px;
    padding: 15px 18px;
    color: var(--kfz-white);
    font-size: 0.88rem;
    font-weight: 900;
    background: rgba(23, 26, 31, 0.92);
    border-left: 5px solid var(--kfz-red);
}

.demo-business-kfz-fast {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 1px;
    background: rgba(170, 178, 191, 0.16);
}

.demo-business-kfz-fast span {
    min-height: 80px;
    padding: 22px;
    color: var(--kfz-white);
    background: var(--kfz-graphite);
    font-size: 0.95rem;
    font-weight: 900;
}

.demo-business-kfz-services,
.demo-business-kfz-diagnosis,
.demo-business-kfz-season,
.demo-business-kfz-appointment {
    padding: 72px 52px;
}

.demo-business-kfz-services {
    background: var(--kfz-dark);
}

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

.demo-business-kfz-service-grid article {
    display: grid;
    gap: 12px;
    min-height: 230px;
    padding: 28px;
    background:
        linear-gradient(145deg, rgba(63, 70, 82, 0.54) 0%, rgba(23, 26, 31, 0.92) 100%);
    border: 1px solid rgba(170, 178, 191, 0.14);
    border-top: 4px solid var(--kfz-red);
    border-radius: 12px;
}

.demo-business-kfz-service-grid article > span {
    color: var(--kfz-red);
    font-size: 0.9rem;
    font-weight: 900;
}

.demo-business-kfz-diagnosis {
    display: grid;
    grid-template-columns: minmax(0, 0.92fr) minmax(320px, 0.78fr);
    gap: 34px;
    align-items: center;
    background: var(--kfz-graphite);
}

.demo-business-kfz-diagnosis-copy {
    display: grid;
    gap: 16px;
}

.demo-business-kfz-checks {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    margin-top: 12px;
}

.demo-business-kfz-checks span {
    padding: 16px;
    color: var(--kfz-light);
    font-weight: 850;
    background: rgba(242, 244, 247, 0.06);
    border-left: 4px solid var(--kfz-red);
}

.demo-business-kfz-diagnosis-card {
    min-height: 430px;
    margin: 0;
    overflow: hidden;
    border-radius: 12px;
    border: 1px solid rgba(170, 178, 191, 0.2);
}

.demo-business-kfz-season {
    display: grid;
    grid-template-columns: minmax(0, 0.8fr) minmax(320px, 0.9fr);
    gap: 34px;
    align-items: center;
    background: var(--kfz-light);
}

.demo-business-kfz-season h2,
.demo-business-kfz-season h3,
.demo-business-kfz-appointment h2 {
    color: var(--kfz-graphite);
}

.demo-business-kfz-season p,
.demo-business-kfz-appointment p {
    color: #3F4652;
}

.demo-business-kfz-season-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.demo-business-kfz-season-list span {
    padding: 18px 20px;
    color: var(--kfz-graphite);
    font-weight: 900;
    background: var(--kfz-white);
    border: 1px solid rgba(63, 70, 82, 0.14);
    border-left: 5px solid var(--kfz-red);
    border-radius: 10px;
}

.demo-business-kfz-appointment {
    display: grid;
    grid-template-columns: minmax(0, 0.85fr) minmax(320px, 0.8fr);
    gap: 28px;
    align-items: center;
    background: var(--kfz-white);
}

.demo-business-kfz-form-preview {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
    padding: 24px;
    background: var(--kfz-light);
    border: 1px solid rgba(63, 70, 82, 0.14);
    border-radius: 12px;
}

.demo-business-kfz-form-preview span {
    min-height: 54px;
    padding: 16px;
    color: var(--kfz-metal);
    font-weight: 850;
    background: var(--kfz-white);
    border: 1px solid rgba(63, 70, 82, 0.12);
    border-radius: 8px;
}

.demo-business-kfz-appointment .demo-business-kfz-actions {
    grid-column: 1 / -1;
}

.demo-business-kfz-appointment .demo-business-kfz-button--secondary {
    color: var(--kfz-graphite);
}

.demo-business-kfz-final {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 28px;
    align-items: center;
    padding: 58px 52px;
    background:
        linear-gradient(135deg, var(--kfz-graphite) 0%, var(--kfz-dark) 70%, var(--kfz-steel) 150%);
}

.demo-business-kfz-final > div:first-child {
    display: grid;
    gap: 12px;
}

.demo-business-kfz-footer {
    display: grid;
    grid-template-columns: minmax(220px, 1fr) minmax(210px, 0.85fr) minmax(160px, 0.55fr);
    gap: 24px;
    padding: 34px 52px;
    background: var(--kfz-graphite);
    border-top: 1px solid rgba(170, 178, 191, 0.14);
}

.demo-business-kfz-footer div,
.demo-business-kfz-footer nav {
    display: grid;
    gap: 7px;
}

.demo-business-kfz-footer strong {
    color: var(--kfz-white);
    font-size: 1.12rem;
}

.demo-business-kfz-footer p,
.demo-business-kfz-footer a,
.demo-business-kfz-footer span,
.demo-business-kfz-footer small {
    color: var(--kfz-muted);
    font-size: 0.88rem;
}

.demo-business-kfz-footer span {
    color: var(--kfz-red);
    font-weight: 900;
}

.demo-business-kfz-footer small {
    grid-column: 1 / -1;
    padding-top: 16px;
    border-top: 1px solid rgba(170, 178, 191, 0.14);
}

@media (max-width: 1023px) {
    .demo-business-kfz-header,
    .demo-business-kfz-hero,
    .demo-business-kfz-diagnosis,
    .demo-business-kfz-season,
    .demo-business-kfz-appointment,
    .demo-business-kfz-final,
    .demo-business-kfz-footer {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-nav {
        justify-content: flex-start;
    }

    .demo-business-kfz-hero,
    .demo-business-kfz-services,
    .demo-business-kfz-diagnosis,
    .demo-business-kfz-season,
    .demo-business-kfz-appointment {
        padding: 58px 38px;
    }

    .demo-business-kfz-fast {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-kfz-hero-visual,
    .demo-business-kfz-diagnosis-card {
        min-height: 360px;
    }

    .demo-business-kfz-final,
    .demo-business-kfz-footer {
        padding: 46px 38px;
    }
}

@media (max-width: 767px) {
    .demo-business--kfz {
        border-radius: 16px;
    }

    .demo-business-kfz-header {
        padding: 22px;
    }

    .demo-business-kfz-nav {
        gap: 12px;
        font-size: 0.84rem;
    }

    .demo-business-kfz-header > .demo-business-kfz-button,
    .demo-business-kfz-actions,
    .demo-business-kfz-button {
        width: 100%;
    }

    .demo-business-kfz-hero,
    .demo-business-kfz-services,
    .demo-business-kfz-diagnosis,
    .demo-business-kfz-season,
    .demo-business-kfz-appointment {
        padding: 44px 22px;
    }

    .demo-business--kfz h1 {
        font-size: clamp(2.5rem, 12vw, 3.55rem);
    }

    .demo-business--kfz h2 {
        font-size: clamp(1.9rem, 9vw, 2.8rem);
    }

    .demo-business-kfz-hero-visual,
    .demo-business-kfz-diagnosis-card {
        min-height: 290px;
        border-radius: 10px;
    }

    .demo-business-kfz-hero-visual figcaption {
        right: 14px;
        bottom: 14px;
        max-width: calc(100% - 28px);
    }

    .demo-business-kfz-fast,
    .demo-business-kfz-service-grid,
    .demo-business-kfz-checks,
    .demo-business-kfz-season-list,
    .demo-business-kfz-form-preview {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-fast span {
        min-height: auto;
    }

    .demo-business-kfz-service-grid article {
        min-height: auto;
        padding: 24px;
    }

    .demo-business-kfz-final,
    .demo-business-kfz-footer {
        padding: 38px 22px;
    }
}

.demo-business-kfz-image-slot {
    position: relative;
    display: grid;
    min-height: 260px;
    overflow: hidden;
    place-items: center;
    color: rgba(255, 255, 255, 0.78);
    border: 1px solid rgba(170, 178, 191, 0.18);
    background:
        linear-gradient(135deg, rgba(17, 24, 39, 0.88), rgba(224, 49, 49, 0.32)),
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 14px),
        var(--kfz-graphite);
}

.demo-business-kfz-image-slot::before {
    content: attr(data-slot);
    position: relative;
    z-index: 1;
    padding: 9px 12px;
    color: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(255, 255, 255, 0.16);
    background: rgba(17, 24, 39, 0.72);
    font-size: 0.75rem;
    font-weight: 900;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.demo-business-kfz-image-slot--hero {
    min-height: 500px;
    border: 8px solid rgba(170, 178, 191, 0.18);
    border-radius: 14px;
    box-shadow: 16px 16px 0 rgba(224, 49, 49, 0.16);
}

.demo-business-kfz-image-slot--profile,
.demo-business-kfz-image-slot--diagnosis,
.demo-business-kfz-image-slot--tire,
.demo-business-kfz-image-slot--hours,
.demo-business-kfz-image-slot--contact {
    min-height: 360px;
    border-radius: 12px;
}

.demo-business-kfz-image-slot--service,
.demo-business-kfz-image-slot--team {
    min-height: 250px;
    border-radius: 10px;
}

.demo-business-kfz-trust {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 10px;
    margin-top: 8px;
}

.demo-business-kfz-trust span {
    padding: 12px 14px;
    color: var(--kfz-light);
    background: rgba(242, 244, 247, 0.07);
    border-left: 4px solid var(--kfz-red);
    font-size: 0.88rem;
    font-weight: 850;
}

.demo-business-kfz-profile {
    display: grid;
    grid-template-columns: minmax(0, 0.88fr) minmax(320px, 1fr);
    gap: 34px;
    align-items: stretch;
    padding: 72px 52px;
    background: var(--kfz-graphite);
}

.demo-business-kfz-fast {
    display: grid;
    grid-template-columns: minmax(260px, 0.55fr) minmax(0, 1fr);
    gap: 1px;
    align-items: stretch;
    padding: 0;
    background: rgba(170, 178, 191, 0.16);
}

.demo-business-kfz-fast-heading {
    display: grid;
    align-content: center;
    gap: 10px;
    padding: 28px;
    background: var(--kfz-graphite);
}

.demo-business-kfz-fast-heading .demo-business-kfz-kicker {
    min-height: auto;
    padding: 0;
    color: var(--kfz-red);
    background: transparent;
}

.demo-business-kfz-fast-list {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
}

.demo-business-kfz-fast-list span {
    min-height: 88px;
    padding: 22px;
    color: var(--kfz-white);
    background: var(--kfz-dark);
    border-top: 4px solid var(--kfz-red);
    font-size: 0.95rem;
    font-weight: 900;
}

.demo-business-kfz-service-detail-list {
    display: grid;
    gap: 22px;
    margin-top: 34px;
}

.demo-business-kfz-service-detail-list article {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(280px, 0.62fr);
    gap: 24px;
    align-items: stretch;
    padding: 26px;
    background:
        linear-gradient(145deg, rgba(63, 70, 82, 0.54) 0%, rgba(23, 26, 31, 0.92) 100%);
    border: 1px solid rgba(170, 178, 191, 0.14);
    border-top: 4px solid var(--kfz-red);
    border-radius: 12px;
}

.demo-business-kfz-service-detail-list article > div:first-child {
    display: grid;
    align-content: start;
    gap: 12px;
}

.demo-business-kfz-service-detail-list ul {
    display: grid;
    gap: 8px;
    margin: 4px 0 0;
    padding: 0;
    list-style: none;
}

.demo-business-kfz-service-detail-list li {
    color: var(--kfz-muted);
    font-size: 0.92rem;
    font-weight: 760;
}

.demo-business-kfz-service-detail-list li::before {
    content: "✓";
    margin-right: 8px;
    color: var(--kfz-red);
    font-weight: 900;
}

.demo-business-kfz-team,
.demo-business-kfz-packages,
.demo-business-kfz-faq,
.demo-business-kfz-hours {
    padding: 72px 52px;
}

.demo-business-kfz-team {
    background: var(--kfz-graphite);
}

.demo-business-kfz-team-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 20px;
    margin-top: 34px;
}

.demo-business-kfz-team-grid article {
    display: grid;
    overflow: hidden;
    background: var(--kfz-dark);
    border: 1px solid rgba(170, 178, 191, 0.14);
    border-radius: 12px;
}

.demo-business-kfz-team-grid article > div:last-child {
    display: grid;
    gap: 8px;
    padding: 24px;
}

.demo-business-kfz-packages {
    background: var(--kfz-light);
}

.demo-business-kfz-packages h2,
.demo-business-kfz-packages h3,
.demo-business-kfz-hours h2,
.demo-business-kfz-hours h3 {
    color: var(--kfz-graphite);
}

.demo-business-kfz-packages p,
.demo-business-kfz-hours p {
    color: var(--kfz-metal);
}

.demo-business-kfz-package-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
    margin-top: 34px;
}

.demo-business-kfz-package-grid article {
    display: grid;
    gap: 10px;
    min-height: 210px;
    padding: 24px;
    background: var(--kfz-white);
    border: 1px solid rgba(63, 70, 82, 0.14);
    border-left: 5px solid var(--kfz-red);
    border-radius: 10px;
}

.demo-business-kfz-package-note {
    margin-top: 18px;
}

.demo-business-kfz-faq {
    background: var(--kfz-dark);
}

.demo-business-kfz-faq-list {
    display: grid;
    gap: 12px;
    margin-top: 32px;
}

.demo-business-kfz-faq-list article {
    border: 1px solid rgba(170, 178, 191, 0.14);
    border-radius: 12px;
    background: var(--kfz-graphite);
}

.demo-business-kfz-faq-list button {
    display: flex;
    width: 100%;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    padding: 22px 24px;
    color: var(--kfz-white);
    border: 0;
    background: transparent;
    font: inherit;
    font-weight: 900;
    text-align: left;
    cursor: pointer;
}

.demo-business-kfz-faq-list button::after {
    content: "+";
    display: inline-grid;
    flex: 0 0 auto;
    width: 32px;
    height: 32px;
    place-items: center;
    color: var(--kfz-white);
    background: var(--kfz-red);
    font-weight: 900;
}

.demo-business-kfz-faq-list button[aria-expanded="true"]::after {
    content: "−";
}

.demo-business-kfz-faq-list .demo-business-faq-answer {
    padding: 0 24px 22px;
}

.demo-business-kfz-hours {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(260px, 0.58fr) minmax(260px, 0.68fr);
    gap: 24px;
    align-items: stretch;
    background: var(--kfz-light);
}

.demo-business-kfz-hours-list {
    display: grid;
    gap: 1px;
    margin-top: 22px;
    overflow: hidden;
    border-radius: 10px;
    background: rgba(63, 70, 82, 0.14);
}

.demo-business-kfz-hours-list div {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 16px;
    padding: 16px 18px;
    background: var(--kfz-white);
}

.demo-business-kfz-hours-list span,
.demo-business-kfz-location a {
    color: var(--kfz-metal);
    font-weight: 800;
}

.demo-business-kfz-hours-list strong {
    color: var(--kfz-graphite);
    white-space: nowrap;
}

.demo-business-kfz-location {
    display: grid;
    align-content: start;
    gap: 12px;
    padding: 26px;
    background: var(--kfz-white);
    border: 1px solid rgba(63, 70, 82, 0.14);
    border-radius: 12px;
}

.demo-business-kfz-appointment {
    align-items: stretch;
}

.demo-business-kfz-form {
    display: grid;
    gap: 16px;
    padding: 28px;
    background: var(--kfz-light);
    border: 1px solid rgba(63, 70, 82, 0.14);
    border-radius: 12px;
}

.demo-business-kfz-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.demo-business-kfz-form label {
    display: grid;
    gap: 7px;
}

.demo-business-kfz-form label > span {
    color: var(--kfz-graphite);
    font-size: 0.84rem;
    font-weight: 900;
}

.demo-business-kfz-form input,
.demo-business-kfz-form select,
.demo-business-kfz-form textarea {
    width: 100%;
    min-height: 46px;
    padding: 12px 13px;
    color: var(--kfz-graphite);
    border: 1px solid rgba(63, 70, 82, 0.18);
    border-radius: 8px;
    background: var(--kfz-white);
    font: inherit;
}

.demo-business-kfz-form textarea {
    resize: vertical;
}

.demo-business-kfz-form-success {
    display: grid;
    gap: 6px;
    padding: 16px;
    color: var(--kfz-graphite);
    border-left: 5px solid var(--kfz-red);
    background: var(--kfz-white);
}

.demo-business-kfz-form-success[hidden] {
    display: none;
}

.demo-business-kfz-form-success small {
    color: var(--kfz-metal);
}

@media (max-width: 1023px) {
    .demo-business-kfz-profile,
    .demo-business-kfz-fast,
    .demo-business-kfz-service-detail-list article,
    .demo-business-kfz-hours {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-team-grid,
    .demo-business-kfz-package-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-kfz-profile,
    .demo-business-kfz-team,
    .demo-business-kfz-packages,
    .demo-business-kfz-faq,
    .demo-business-kfz-hours {
        padding: 58px 38px;
    }
}

@media (max-width: 767px) {
    .demo-business-kfz-trust,
    .demo-business-kfz-fast-list,
    .demo-business-kfz-team-grid,
    .demo-business-kfz-package-grid,
    .demo-business-kfz-form-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-profile,
    .demo-business-kfz-team,
    .demo-business-kfz-packages,
    .demo-business-kfz-faq,
    .demo-business-kfz-hours {
        padding: 44px 22px;
    }

    .demo-business-kfz-service-detail-list article,
    .demo-business-kfz-form,
    .demo-business-kfz-location {
        padding: 22px;
    }

    .demo-business-kfz-image-slot,
    .demo-business-kfz-image-slot--hero,
    .demo-business-kfz-image-slot--profile,
    .demo-business-kfz-image-slot--diagnosis,
    .demo-business-kfz-image-slot--tire,
    .demo-business-kfz-image-slot--hours,
    .demo-business-kfz-image-slot--contact,
    .demo-business-kfz-image-slot--service,
    .demo-business-kfz-image-slot--team {
        min-height: 230px;
        border-width: 1px;
        box-shadow: none;
    }

    .demo-business-kfz-hours-list div {
        grid-template-columns: 1fr;
        gap: 5px;
    }

    .demo-business-kfz-hours-list strong {
        white-space: normal;
    }

    .demo-business-kfz-faq-list button {
        padding: 18px;
    }

    .demo-business-kfz-faq-list .demo-business-faq-answer {
        padding: 0 18px 18px;
    }
}

/* Demo business v3 scoped additions */
.demo-business--handwerk .demo-business-header--stacked,
.demo-business-praxis-header--stacked,
.demo-business-kfz-header--stacked {
    grid-template-columns: minmax(190px, 0.85fr) minmax(180px, auto) minmax(280px, 1.4fr) auto;
    align-items: center;
}

.demo-business--handwerk .demo-business-header-info,
.demo-business-praxis-header-info,
.demo-business-kfz-header-info {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    color: inherit;
    font-size: 0.78rem;
    font-weight: 800;
}

.demo-business--handwerk .demo-business-header-info span,
.demo-business-praxis-header-info span,
.demo-business-kfz-header-info span {
    display: inline-flex;
    align-items: center;
    min-height: 30px;
    padding: 7px 10px;
    border-radius: 999px;
    background: rgba(255, 255, 255, 0.68);
    border: 1px solid rgba(39, 51, 42, 0.12);
}

.demo-business--handwerk .demo-business-microcopy,
.demo-business-praxis-microcopy,
.demo-business-kfz-microcopy {
    margin: 12px 0 0;
    font-size: 0.92rem;
    font-weight: 800;
}

.demo-business--handwerk .demo-business-image-slot::before,
.demo-business-praxis-image-slot::before,
.demo-business-kfz-image-slot::before {
    content: "";
    position: absolute;
    inset: 18px;
    z-index: 1;
    padding: 0;
    color: transparent;
    border: 1px solid rgba(255, 255, 255, 0.22);
    border-radius: inherit;
    background: transparent;
    text-transform: none;
    pointer-events: none;
}

.demo-business--handwerk .demo-business-image-slot > span,
.demo-business-praxis-image-slot > span,
.demo-business-kfz-image-slot > span,
.demo-business-image-note {
    position: relative;
    z-index: 1;
    display: inline-flex;
    align-self: center;
    justify-self: center;
    width: fit-content;
    max-width: calc(100% - 36px);
    padding: 8px 12px;
    color: rgba(255, 255, 255, 0.82);
    background: rgba(0, 0, 0, 0.22);
    border: 1px solid rgba(255, 255, 255, 0.18);
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 800;
    letter-spacing: 0;
}

.demo-business--handwerk .demo-business-image-slot > img,
.demo-business--handwerk .demo-business-image-slot > picture,
.demo-business--handwerk .demo-business-image-slot > picture > img,
.demo-business-praxis-image-slot > img,
.demo-business-praxis-image-slot > picture,
.demo-business-praxis-image-slot > picture > img,
.demo-business-kfz-image-slot > img {
    position: absolute;
    inset: 0;
    z-index: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.demo-business-kfz-image-slot > picture,
.demo-business-kfz-image-slot > picture > img {
    position: absolute;
    inset: 0;
    z-index: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.demo-business--handwerk .demo-business-image-slot--region-map > img {
    object-fit: contain;
}

.demo-business--handwerk .demo-business-image-slot--region-map {
    background: rgba(248, 241, 229, 0.92);
}

.demo-business--handwerk .demo-business-image-slot[data-slot="project_roof_before"] > img,
.demo-business--handwerk .demo-business-image-slot[data-slot="project_roof_after"] > img,
.demo-business--handwerk .demo-business-image-slot[data-slot="project_carport"] > img,
.demo-business--handwerk .demo-business-image-slot[data-slot="project_storm"] > img {
    object-position: center top;
}

.demo-business--handwerk .demo-business-image-slot > img + span,
.demo-business--handwerk .demo-business-image-slot > img ~ .demo-business-image-note,
.demo-business-praxis-image-slot > img + span,
.demo-business-praxis-image-slot > img + figcaption,
.demo-business-kfz-image-slot > img + span,
.demo-business-kfz-image-slot > img + figcaption {
    display: none;
}

.demo-business--handwerk .demo-business-info-card,
.demo-business--handwerk .demo-business-project-badge {
    position: relative;
    z-index: 2;
}

.demo-business--handwerk .demo-business-info-card {
    align-self: end;
    justify-self: end;
    max-width: 260px;
    padding: 16px;
    color: var(--handwerk-ink);
    background: rgba(255, 255, 255, 0.9);
    border: 1px solid rgba(36, 47, 40, 0.14);
    border-radius: 10px;
    box-shadow: 0 18px 40px rgba(25, 33, 29, 0.18);
}

.demo-business--handwerk .demo-business-info-card strong {
    display: block;
    margin-bottom: 5px;
}

.demo-business--handwerk .demo-business-detail-list,
.demo-business-praxis-detail-list,
.demo-business-kfz-detail-list {
    display: grid;
    gap: 10px;
    margin: 18px 0 0;
}

.demo-business--handwerk .demo-business-detail-list dt,
.demo-business-praxis-detail-list dt,
.demo-business-kfz-detail-list dt {
    color: inherit;
    font-weight: 900;
}

.demo-business--handwerk .demo-business-detail-list dd,
.demo-business-praxis-detail-list dd,
.demo-business-kfz-detail-list dd {
    margin: -6px 0 0;
    color: inherit;
    opacity: 0.78;
}

.demo-business--handwerk .demo-business-reference-images {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 12px;
}

.demo-business--handwerk .demo-business-facts {
    display: grid;
    gap: 8px;
    margin: 18px 0 0;
    padding: 0;
    list-style: none;
}

.demo-business--handwerk .demo-business-facts li {
    display: flex;
    justify-content: space-between;
    gap: 16px;
    padding: 10px 0;
    border-top: 1px solid rgba(46, 59, 49, 0.14);
}

.demo-business--handwerk .demo-business-process-grid--six,
.demo-business-praxis-timeline-list--six,
.demo-business-kfz-process-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.demo-business--handwerk .demo-business-quality {
    background: linear-gradient(135deg, #243329 0%, #40503a 100%);
    color: #fff;
}

.demo-business--handwerk .demo-business-quality-layout {
    display: grid;
    grid-template-columns: minmax(0, 0.9fr) minmax(280px, 1.1fr);
    gap: 34px;
    align-items: center;
}

.demo-business--handwerk .demo-business-quality-list,
.demo-business-kfz-process-list {
    display: grid;
    gap: 12px;
    margin-top: 24px;
}

.demo-business--handwerk .demo-business-quality-list span,
.demo-business-kfz-process-list span {
    padding: 14px 16px;
    background: rgba(255, 255, 255, 0.1);
    border: 1px solid rgba(255, 255, 255, 0.16);
    border-radius: 10px;
    font-weight: 800;
}

.demo-business--handwerk .demo-business-image-slot--quality {
    min-height: 360px;
}

.demo-business--handwerk .demo-business-team-list article small,
.demo-business-praxis-team-grid article small,
.demo-business-kfz-team-grid article small {
    display: block;
    margin-top: 10px;
    color: inherit;
    opacity: 0.76;
    line-height: 1.55;
}

.demo-business--handwerk .demo-business-upload-placeholder {
    padding: 16px;
    color: rgba(36, 47, 40, 0.74);
    background: rgba(142, 96, 54, 0.08);
    border: 1px dashed rgba(142, 96, 54, 0.34);
    border-radius: 10px;
    font-weight: 800;
}

.demo-business--handwerk .demo-business-footer--expanded,
.demo-business-praxis-footer--expanded,
.demo-business-kfz-footer--expanded {
    display: grid;
    grid-template-columns: minmax(220px, 1.3fr) minmax(180px, 0.8fr) minmax(180px, 0.8fr) minmax(170px, 0.7fr);
    gap: 24px;
    align-items: start;
}

.demo-business--handwerk .demo-business-footer--expanded nav,
.demo-business-praxis-footer--expanded nav,
.demo-business-kfz-footer--expanded nav {
    display: grid;
    gap: 8px;
}

.demo-business-praxis-patient,
.demo-business-praxis-payment,
.demo-business-kfz-vehicle-check,
.demo-business-kfz-mobility {
    display: grid;
    gap: 28px;
    padding: 72px 56px;
}

.demo-business-praxis-patient,
.demo-business-kfz-vehicle-check {
    grid-template-columns: minmax(0, 0.9fr) minmax(260px, 0.85fr);
    align-items: center;
    background: rgba(255, 255, 255, 0.72);
}

.demo-business-praxis-patient .demo-business-praxis-info-grid,
.demo-business-kfz-vehicle-check .demo-business-kfz-info-grid {
    grid-column: 1 / -1;
}

.demo-business-praxis-info-grid,
.demo-business-kfz-info-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
}

.demo-business-praxis-info-grid article,
.demo-business-kfz-info-grid article {
    padding: 22px;
    background: rgba(255, 255, 255, 0.86);
    border: 1px solid rgba(45, 72, 67, 0.12);
    border-radius: 12px;
}

.demo-business-praxis-condition-grid article span,
.demo-business-kfz-team-grid article span {
    display: block;
    margin-top: 10px;
    font-weight: 800;
    line-height: 1.45;
}

.demo-business-kfz-team-grid article .demo-business-kfz-image-slot > img + span {
    display: none;
}

.demo-business-praxis-timeline-list--six article p {
    margin-top: 8px;
}

.demo-business-kfz-mobility .demo-business-kfz-info-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.demo-business-kfz-package-grid {
    grid-template-columns: repeat(5, minmax(0, 1fr));
}

.demo-business-inline-cta,
.demo-business-praxis-inline-cta,
.demo-business-kfz-inline-cta {
    display: flex;
    flex-wrap: wrap;
    gap: 14px;
    align-items: center;
    justify-content: space-between;
    margin-top: 28px;
    padding: 18px 20px;
}

.demo-business-inline-cta p,
.demo-business-praxis-inline-cta p,
.demo-business-kfz-inline-cta p {
    margin: 0;
    font-weight: 850;
}

.demo-business-inline-cta {
    color: var(--handwerk-ink);
    background: var(--handwerk-beige);
    border: 1px solid rgba(31, 37, 35, 0.14);
    border-left: 6px solid var(--handwerk-orange);
    border-radius: 10px;
}

.demo-business-inline-cta p {
    color: var(--handwerk-ink);
}

.demo-business-inline-cta--dark {
    color: #FFFFFF;
    background: rgba(255, 255, 255, 0.08);
    border-color: rgba(232, 213, 181, 0.22);
    border-left-color: var(--handwerk-orange);
}

.demo-business-inline-cta--dark p {
    color: #FFFFFF;
}

.demo-business-praxis-inline-cta {
    color: var(--praxis-text);
    background: var(--praxis-blue);
    border: 1px solid rgba(37, 107, 111, 0.14);
    border-left: 5px solid var(--praxis-petrol);
    border-radius: 16px;
}

.demo-business-praxis-inline-cta p {
    color: var(--praxis-text);
}

.demo-business-kfz-inline-cta {
    grid-column: 1 / -1;
    color: var(--kfz-white);
    background: rgba(242, 244, 247, 0.08);
    border: 1px solid rgba(170, 178, 191, 0.18);
    border-left: 5px solid var(--kfz-red);
    border-radius: 10px;
}

.demo-business-kfz-inline-cta p {
    color: var(--kfz-white);
}

.demo-business-kfz-inline-cta--light {
    color: var(--kfz-graphite);
    background: var(--kfz-white);
    border-color: rgba(63, 70, 82, 0.14);
}

.demo-business-kfz-inline-cta--light p {
    color: var(--kfz-graphite);
}

.demo-business-kfz-header-info span {
    color: var(--kfz-graphite);
    background: var(--kfz-light);
    border-color: rgba(242, 244, 247, 0.42);
}

.demo-business-kfz-vehicle-check,
.demo-business-kfz-vehicle-check h2,
.demo-business-kfz-vehicle-check h3,
.demo-business-kfz-vehicle-check p {
    color: var(--kfz-graphite);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-kicker {
    color: var(--kfz-steel);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-info-grid article,
.demo-business-kfz-mobility .demo-business-kfz-info-grid article {
    color: var(--kfz-graphite);
    background: var(--kfz-white);
    border-color: rgba(63, 70, 82, 0.16);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-info-grid article p,
.demo-business-kfz-mobility .demo-business-kfz-info-grid article p {
    color: var(--kfz-metal);
}

.demo-business-kfz-mobility .demo-business-kfz-info-grid article h3 {
    color: var(--kfz-graphite);
}

.demo-business-kfz-location {
    color: var(--kfz-graphite);
}

.demo-business-kfz-location a {
    color: var(--kfz-steel);
}

.demo-business-praxis-footer address {
    margin: 0;
    color: rgba(255, 255, 255, 0.82);
    font-size: 0.88rem;
    line-height: 1.6;
}

.demo-business-praxis-footer address a,
.demo-business-praxis-footer nav a {
    color: rgba(255, 255, 255, 0.86);
}

.demo-business-praxis-footer p,
.demo-business-praxis-footer small {
    color: rgba(255, 255, 255, 0.8);
}

.demo-business-material-grid,
.demo-business-praxis-team-grid,
.demo-business-kfz-team-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

.demo-business-praxis-condition-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.demo-business-praxis-team-grid,
.demo-business-kfz-team-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

@media (min-width: 1181px) {
    .demo-business-kfz-service-detail-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-kfz-service-detail-list article {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-service-detail-list article:last-child {
        grid-column: 1 / -1;
        grid-template-columns: minmax(0, 1fr) minmax(280px, 0.62fr);
    }
}

.demo-business [data-demo-smart-header] {
    position: sticky;
    top: 0;
    z-index: 20;
    transform: translateY(0);
    transition: transform 220ms ease, box-shadow 220ms ease, opacity 220ms ease;
    will-change: transform;
}

.demo-business [data-demo-smart-header].is-demo-header-hidden {
    transform: translateY(calc(-100% - 2px));
    pointer-events: none;
}

.demo-business [data-demo-smart-header].is-demo-header-visible,
.demo-business [data-demo-smart-header]:focus-within {
    transform: translateY(0);
    pointer-events: auto;
}

.demo-business [data-demo-smart-header].is-demo-header-visible {
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.14);
}

.demo-business--handwerk .demo-business-header-info,
.demo-business-praxis-header-info,
.demo-business-kfz-header-info {
    gap: 0;
    align-items: center;
    color: inherit;
    font-size: 0.86rem;
    font-weight: 760;
    line-height: 1.4;
}

.demo-business--handwerk .demo-business-header-info span,
.demo-business-praxis-header-info span,
.demo-business-kfz-header-info span {
    min-height: auto;
    padding: 0;
    color: inherit;
    border: 0;
    border-radius: 0;
    background: transparent;
}

.demo-business--handwerk .demo-business-header-info span + span::before,
.demo-business-praxis-header-info span + span::before,
.demo-business-kfz-header-info span + span::before {
    content: "·";
    display: inline-block;
    margin: 0 9px;
    opacity: 0.7;
}

.demo-business--handwerk .demo-business-header-info {
    color: rgba(255, 255, 255, 0.82);
}

.demo-business-praxis-header-info {
    color: var(--praxis-petrol-dark);
}

.demo-business-kfz-header-info {
    color: var(--kfz-light);
}

.demo-business--handwerk .demo-business-service-detail,
.demo-business--handwerk .demo-business-project-grid article,
.demo-business--handwerk .demo-business-process-grid article,
.demo-business--handwerk .demo-business-team-list article,
.demo-business--handwerk .demo-business-material-grid article,
.demo-business-praxis-condition-grid article,
.demo-business-praxis-service-detail-list article,
.demo-business-praxis-timeline-list article,
.demo-business-praxis-team-grid article,
.demo-business-praxis-gallery .demo-business-praxis-image-slot,
.demo-business-praxis-info-grid article,
.demo-business-kfz-service-detail-list article,
.demo-business-kfz-team-grid article,
.demo-business-kfz-package-grid article,
.demo-business-kfz-season-list span,
.demo-business-kfz-info-grid article {
    transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease, background-color 220ms ease;
}

.demo-business--handwerk .demo-business-image-slot,
.demo-business-praxis-image-slot,
.demo-business-kfz-image-slot {
    transition: transform 260ms ease, border-color 220ms ease, box-shadow 220ms ease;
}

@media (hover: hover) and (pointer: fine) {
    .demo-business--handwerk .demo-business-service-detail:hover,
    .demo-business--handwerk .demo-business-project-grid article:hover,
    .demo-business--handwerk .demo-business-process-grid article:hover,
    .demo-business--handwerk .demo-business-team-list article:hover,
    .demo-business--handwerk .demo-business-material-grid article:hover {
        transform: translateY(-6px);
        border-color: rgba(228, 111, 42, 0.38);
        box-shadow: 12px 14px 0 rgba(166, 106, 44, 0.14);
    }

    .demo-business-praxis-condition-grid article:hover,
    .demo-business-praxis-service-detail-list article:hover,
    .demo-business-praxis-timeline-list article:hover,
    .demo-business-praxis-team-grid article:hover,
    .demo-business-praxis-info-grid article:hover,
    .demo-business-praxis-gallery .demo-business-praxis-image-slot:hover {
        transform: translateY(-5px);
        border-color: rgba(37, 107, 111, 0.24);
        box-shadow: 0 18px 38px rgba(30, 51, 53, 0.11);
    }

    .demo-business-kfz-service-detail-list article:hover,
    .demo-business-kfz-team-grid article:hover,
    .demo-business-kfz-package-grid article:hover,
    .demo-business-kfz-season-list span:hover,
    .demo-business-kfz-info-grid article:hover {
        transform: translateY(-5px);
        border-color: rgba(224, 49, 49, 0.44);
        box-shadow: 0 18px 38px rgba(0, 0, 0, 0.22);
    }

    .demo-business--handwerk article:hover .demo-business-image-slot,
    .demo-business-praxis-team-grid article:hover .demo-business-praxis-image-slot,
    .demo-business-praxis-service-detail-list article:hover .demo-business-praxis-image-slot,
    .demo-business-kfz-team-grid article:hover .demo-business-kfz-image-slot,
    .demo-business-kfz-service-detail-list article:hover .demo-business-kfz-image-slot {
        transform: scale(1.018);
    }

    .demo-business-faq-list article:hover,
    .demo-business-praxis-faq-list article:hover,
    .demo-business-kfz-faq-list article:hover {
        border-color: rgba(228, 111, 42, 0.3);
    }

    .demo-business-praxis-faq-list article:hover {
        border-color: rgba(37, 107, 111, 0.22);
    }

    .demo-business-kfz-faq-list article:hover {
        border-color: rgba(224, 49, 49, 0.34);
    }
}

.demo-business a:focus-visible,
.demo-business button:focus-visible {
    outline: 3px solid currentColor;
    outline-offset: 4px;
}

.demo-business-faq-list article,
.demo-business-praxis-faq-list article,
.demo-business-kfz-faq-list article {
    overflow: hidden;
    transition: border-color 220ms ease, box-shadow 220ms ease, background-color 220ms ease;
}

.demo-business-faq-list button::after,
.demo-business-praxis-faq-list button::after,
.demo-business-kfz-faq-list button::after {
    transition: transform 220ms ease, background-color 220ms ease;
}

.demo-business-faq-list button[aria-expanded="true"]::after,
.demo-business-praxis-faq-list button[aria-expanded="true"]::after,
.demo-business-kfz-faq-list button[aria-expanded="true"]::after {
    transform: rotate(180deg);
}

.demo-business-faq-answer {
    overflow: hidden;
    max-height: 0;
    opacity: 0;
    transform: translateY(-4px);
    transition: max-height 260ms ease, opacity 200ms ease, transform 220ms ease;
}

.demo-business-faq-answer.is-demo-faq-open {
    opacity: 1;
    transform: translateY(0);
}

.demo-business--handwerk .demo-business-quality > div:first-child > span {
    color: #F4C46F;
}

.demo-business--handwerk .demo-business-quality h2 {
    color: #FFFFFF;
}

.demo-business--handwerk .demo-business-quality p,
.demo-business--handwerk .demo-business-quality li {
    color: rgba(255, 255, 255, 0.84);
}

.demo-business--handwerk .demo-business-quality ul {
    display: grid;
    gap: 12px;
    margin: 0;
    padding: 0;
    list-style: none;
}

.demo-business--handwerk .demo-business-quality li {
    padding: 13px 15px;
    background: rgba(255, 255, 255, 0.08);
    border-left: 4px solid var(--handwerk-orange);
    border-radius: 8px;
    font-weight: 760;
}

.demo-business-region {
    align-items: stretch;
}

.demo-business-region-layout {
    align-content: stretch;
    padding: 18px;
    background: #FFFFFF;
    border: 1px solid rgba(31, 37, 35, 0.12);
    border-radius: 12px;
}

.demo-business-region-panel {
    min-height: auto;
    justify-content: flex-start;
    padding: 0 0 14px;
    border: 0;
    background: transparent;
}

.demo-business-region-panel span {
    border-radius: 999px;
}

.demo-business--handwerk .demo-business-image-slot--region-map {
    min-height: 320px;
}

.demo-business-praxis-gallery {
    grid-template-columns: minmax(0, 1.05fr) minmax(0, 0.78fr) minmax(0, 0.78fr);
    grid-auto-rows: minmax(210px, auto);
    align-items: stretch;
}

.demo-business-praxis-gallery-main {
    grid-row: span 2;
}

.demo-business-praxis-gallery .demo-business-praxis-image-slot:nth-child(4) {
    grid-column: span 2;
}

.demo-business-praxis-gallery .demo-business-praxis-image-slot:nth-child(5) {
    min-height: 250px;
}

.demo-business-praxis-hours {
    align-items: stretch;
}

.demo-business-praxis-hours-copy {
    display: grid;
    gap: 18px;
}

.demo-business-praxis-contact-card {
    display: grid;
    gap: 12px;
    align-content: start;
    margin: 0;
    padding: 30px;
    color: var(--praxis-text);
    background: var(--praxis-blue);
    border: 1px solid rgba(37, 107, 111, 0.14);
    border-left: 5px solid var(--praxis-petrol);
    border-radius: 20px;
}

.demo-business-praxis-contact-card strong {
    color: var(--praxis-text);
    font-size: 1.2rem;
}

.demo-business-praxis-contact-card span,
.demo-business-praxis-contact-card a,
.demo-business-praxis-contact-card small,
.demo-business-praxis-contact-card li {
    color: var(--praxis-muted);
    font-style: normal;
    font-weight: 760;
}

.demo-business-praxis-contact-card a {
    color: var(--praxis-petrol);
}

.demo-business-praxis-contact-card ul {
    display: grid;
    gap: 8px;
    margin: 8px 0 0;
    padding: 0;
    list-style: none;
}

.demo-business-praxis-contact-card li {
    padding: 9px 0;
    border-top: 1px solid rgba(37, 107, 111, 0.12);
}

.demo-business-kfz-vehicle-check {
    color: var(--kfz-light);
    background:
        linear-gradient(135deg, var(--kfz-graphite) 0%, var(--kfz-dark) 68%, rgba(47, 111, 159, 0.42) 100%);
}

.demo-business-kfz-vehicle-check h2,
.demo-business-kfz-vehicle-check h3 {
    color: var(--kfz-white);
}

.demo-business-kfz-vehicle-check p {
    color: rgba(242, 244, 247, 0.78);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-kicker {
    color: var(--kfz-red);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-info-grid article {
    color: var(--kfz-light);
    background: rgba(242, 244, 247, 0.07);
    border-color: rgba(170, 178, 191, 0.18);
    border-left: 5px solid var(--kfz-red);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-info-grid article h3 {
    color: var(--kfz-white);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-info-grid article p {
    color: rgba(242, 244, 247, 0.76);
}

.demo-business-kfz-vehicle-check .demo-business-kfz-image-slot--vehicle-check {
    border-color: rgba(224, 49, 49, 0.24);
    background:
        linear-gradient(135deg, rgba(17, 24, 39, 0.92), rgba(47, 111, 159, 0.36)),
        repeating-linear-gradient(135deg, rgba(255, 255, 255, 0.08) 0 1px, transparent 1px 14px),
        var(--kfz-graphite);
}

@media (prefers-reduced-motion: reduce) {
    .demo-business [data-demo-smart-header],
    .demo-business-faq-answer,
    .demo-business-faq-list button::after,
    .demo-business-praxis-faq-list button::after,
    .demo-business-kfz-faq-list button::after,
    .demo-business--handwerk .demo-business-service-detail,
    .demo-business--handwerk .demo-business-project-grid article,
    .demo-business--handwerk .demo-business-process-grid article,
    .demo-business--handwerk .demo-business-team-list article,
    .demo-business--handwerk .demo-business-material-grid article,
    .demo-business-praxis-condition-grid article,
    .demo-business-praxis-service-detail-list article,
    .demo-business-praxis-timeline-list article,
    .demo-business-praxis-team-grid article,
    .demo-business-praxis-gallery .demo-business-praxis-image-slot,
    .demo-business-praxis-info-grid article,
    .demo-business-kfz-service-detail-list article,
    .demo-business-kfz-team-grid article,
    .demo-business-kfz-package-grid article,
    .demo-business-kfz-season-list span,
    .demo-business-kfz-info-grid article {
        transition: none;
    }
}

@media (max-width: 1180px) {
    .demo-business--handwerk .demo-business-header--stacked,
    .demo-business-praxis-header--stacked,
    .demo-business-kfz-header--stacked {
        grid-template-columns: 1fr;
    }

    .demo-business--handwerk .demo-business-header-info,
    .demo-business-praxis-header-info,
    .demo-business-kfz-header-info {
        justify-content: center;
    }

    .demo-business-kfz-package-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .demo-business-praxis-gallery {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-praxis-gallery .demo-business-praxis-image-slot:nth-child(4) {
        grid-column: auto;
    }
}

@media (max-width: 1023px) {
    .demo-business-material-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business--handwerk .demo-business-quality-layout,
    .demo-business-praxis-patient,
    .demo-business-kfz-vehicle-check,
    .demo-business-praxis-hours {
        grid-template-columns: 1fr;
    }

    .demo-business--handwerk .demo-business-process-grid--six,
    .demo-business-praxis-timeline-list--six,
    .demo-business-kfz-process-list,
    .demo-business-praxis-info-grid,
    .demo-business-kfz-info-grid,
    .demo-business-kfz-mobility .demo-business-kfz-info-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business--handwerk .demo-business-footer--expanded,
    .demo-business-praxis-footer--expanded,
    .demo-business-kfz-footer--expanded {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .demo-business-material-grid,
    .demo-business--handwerk .demo-business-reference-images,
    .demo-business--handwerk .demo-business-process-grid--six,
    .demo-business-praxis-timeline-list--six,
    .demo-business-kfz-process-list,
    .demo-business-praxis-info-grid,
    .demo-business-kfz-info-grid,
    .demo-business-kfz-package-grid,
    .demo-business-kfz-mobility .demo-business-kfz-info-grid,
    .demo-business--handwerk .demo-business-footer--expanded,
    .demo-business-praxis-footer--expanded,
    .demo-business-kfz-footer--expanded {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-patient,
    .demo-business-praxis-payment,
    .demo-business-kfz-vehicle-check,
    .demo-business-kfz-mobility {
        padding: 44px 22px;
    }

    .demo-business--handwerk .demo-business-header-info,
    .demo-business-praxis-header-info,
    .demo-business-kfz-header-info {
        justify-content: flex-start;
    }

    .demo-business-praxis-gallery {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-gallery-main,
    .demo-business-praxis-gallery .demo-business-praxis-image-slot:nth-child(4) {
        grid-column: auto;
        grid-row: auto;
    }

    .demo-business--handwerk .demo-business-facts li {
        display: grid;
        gap: 4px;
    }
}

/* Demo business interaction and mobile tightening */
.demo-business,
.demo-business * {
    box-sizing: border-box;
}

.demo-business-main,
.demo-business-praxis-main,
.demo-business-kfz-main {
    grid-template-columns: minmax(0, 1fr);
    min-width: 0;
}

.demo-business-main > *,
.demo-business-praxis-main > *,
.demo-business-kfz-main > * {
    min-width: 0;
}

.demo-business-footer-brand,
.demo-business-praxis-footer-brand,
.demo-business-kfz-footer-brand {
    color: #FFFFFF;
    font-size: 1.05rem;
    font-weight: 880;
    line-height: 1.2;
    text-decoration: none;
}

.demo-business-praxis-footer-brand,
.demo-business-kfz-footer-brand {
    font-size: 1.12rem;
}

.demo-business-footer-brand:hover,
.demo-business-footer-brand:focus-visible,
.demo-business-praxis-footer-brand:hover,
.demo-business-praxis-footer-brand:focus-visible,
.demo-business-kfz-footer-brand:hover,
.demo-business-kfz-footer-brand:focus-visible {
    color: var(--handwerk-sand);
}

.demo-business-praxis-footer-brand:hover,
.demo-business-praxis-footer-brand:focus-visible {
    color: var(--praxis-accent);
}

.demo-business-kfz-footer-brand:hover,
.demo-business-kfz-footer-brand:focus-visible {
    color: var(--kfz-white);
}

.demo-business-stats div,
.demo-business-hero-trust span,
.demo-business-praxis-trust span,
.demo-business-kfz-trust span,
.demo-business--handwerk .demo-business-quality li,
.demo-business-region-panel span,
.demo-business-inline-cta,
.demo-business-praxis-inline-cta,
.demo-business-kfz-inline-cta,
.demo-business-kfz-fast-list span,
.demo-business-kfz-process-list span {
    transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease, background-color 220ms ease, color 220ms ease;
}

@media (hover: hover) and (pointer: fine) {
    .demo-business-stats div:hover,
    .demo-business-hero-trust span:hover {
        transform: translateY(-5px);
        background: rgba(255, 255, 255, 0.13);
        box-shadow: 0 14px 30px rgba(17, 24, 22, 0.22);
    }

    .demo-business-praxis-trust span:hover {
        transform: translateY(-4px);
        border-color: rgba(37, 107, 111, 0.2);
        box-shadow: 0 14px 28px rgba(30, 51, 53, 0.1);
    }

    .demo-business-kfz-trust span:hover {
        transform: translateY(-4px);
        background: rgba(242, 244, 247, 0.12);
        border-left-color: var(--kfz-red-hover);
        box-shadow: 0 14px 28px rgba(0, 0, 0, 0.22);
    }

    .demo-business-history-layout:hover .demo-business-image-slot,
    .demo-business-praxis-philosophy:hover .demo-business-praxis-image-slot,
    .demo-business-praxis-patient:hover .demo-business-praxis-image-slot--patient,
    .demo-business-kfz-profile:hover .demo-business-kfz-image-slot,
    .demo-business-kfz-vehicle-check:hover .demo-business-kfz-image-slot--vehicle-check,
    .demo-business-kfz-diagnosis:hover .demo-business-kfz-image-slot--diagnosis {
        transform: scale(1.012);
        border-color: rgba(228, 111, 42, 0.3);
        box-shadow: 0 18px 38px rgba(17, 24, 22, 0.16);
    }

    .demo-business-praxis-philosophy:hover .demo-business-praxis-image-slot,
    .demo-business-praxis-patient:hover .demo-business-praxis-image-slot--patient {
        border-color: rgba(37, 107, 111, 0.22);
        box-shadow: 0 18px 38px rgba(30, 51, 53, 0.11);
    }

    .demo-business-kfz-profile:hover .demo-business-kfz-image-slot,
    .demo-business-kfz-vehicle-check:hover .demo-business-kfz-image-slot--vehicle-check,
    .demo-business-kfz-diagnosis:hover .demo-business-kfz-image-slot--diagnosis {
        border-color: rgba(224, 49, 49, 0.34);
        box-shadow: 0 18px 40px rgba(0, 0, 0, 0.24);
    }

    .demo-business-inline-cta:hover,
    .demo-business-praxis-inline-cta:hover,
    .demo-business-kfz-inline-cta:hover {
        transform: translateY(-4px);
        box-shadow: 0 18px 36px rgba(31, 37, 35, 0.12);
    }

    .demo-business-praxis-inline-cta:hover {
        border-color: rgba(37, 107, 111, 0.26);
        box-shadow: 0 18px 36px rgba(30, 51, 53, 0.1);
    }

    .demo-business-kfz-inline-cta:hover {
        border-color: rgba(224, 49, 49, 0.44);
        box-shadow: 0 18px 38px rgba(0, 0, 0, 0.22);
    }

    .demo-business--handwerk .demo-business-quality li:hover,
    .demo-business-region-panel span:hover {
        transform: translateY(-3px);
        border-color: rgba(228, 111, 42, 0.42);
        background: rgba(255, 255, 255, 0.14);
    }

    .demo-business-region-panel span:hover {
        color: var(--handwerk-ink);
        background: #F3C98B;
    }

    .demo-business-kfz-fast-list span:hover,
    .demo-business-kfz-process-list span:hover {
        transform: translateY(-4px);
        border-top-color: var(--kfz-red-hover);
        background: #20242B;
        box-shadow: inset 0 0 0 1px rgba(224, 49, 49, 0.22);
    }

    .demo-business-service-detail:hover > div:first-child > span,
    .demo-business-process-grid article:hover > span {
        color: #FFFFFF;
        background: var(--handwerk-orange);
        transform: scale(1.05);
    }

    .demo-business-praxis-timeline-list article:hover > span {
        color: var(--praxis-white);
        background: var(--praxis-petrol-dark);
        transform: scale(1.05);
    }

    .demo-business-kfz-process-list span:hover {
        color: #FFFFFF;
        border-color: rgba(224, 49, 49, 0.46);
    }

    .demo-business-faq-list button:hover,
    .demo-business-praxis-faq-list button:hover,
    .demo-business-kfz-faq-list button:hover {
        background: rgba(228, 111, 42, 0.08);
    }

    .demo-business-praxis-faq-list button:hover {
        background: rgba(37, 107, 111, 0.07);
    }

    .demo-business-kfz-faq-list button:hover {
        background: rgba(224, 49, 49, 0.1);
    }

    .demo-business-faq-list button:hover::after,
    .demo-business-praxis-faq-list button:hover::after,
    .demo-business-kfz-faq-list button:hover::after {
        transform: scale(1.08);
    }

    .demo-business-faq-list button[aria-expanded="true"]:hover::after,
    .demo-business-praxis-faq-list button[aria-expanded="true"]:hover::after,
    .demo-business-kfz-faq-list button[aria-expanded="true"]:hover::after {
        transform: rotate(180deg) scale(1.08);
    }
}

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

.demo-business-region-panel span {
    justify-content: center;
    text-align: center;
}

.demo-business-kfz-fast {
    border-bottom: 4px solid var(--kfz-red);
}

.demo-business-kfz-fast-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
}

@media (max-width: 1023px) {
    .demo-business-praxis-condition-grid,
    .demo-business-praxis-team-grid,
    .demo-business-kfz-team-grid,
    .demo-business-kfz-fast-list,
    .demo-business-kfz-process-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-kfz-fast {
        gap: 14px;
        background: var(--kfz-dark);
        border-bottom: 0;
    }

    .demo-business-kfz-fast-list {
        gap: 10px;
        background: transparent;
    }

    .demo-business-kfz-fast-list span {
        display: grid;
        min-height: 76px;
        align-content: center;
        border: 1px solid rgba(170, 178, 191, 0.16);
        border-left: 4px solid var(--kfz-red);
        border-top: 0;
        border-radius: 10px;
    }
}

@media (max-width: 767px) {
    .demo-business-praxis-condition-grid,
    .demo-business-praxis-service-detail-list,
    .demo-business-praxis-team-grid,
    .demo-business-praxis-info-grid,
    .demo-business-praxis-timeline-list,
    .demo-business-praxis-gallery,
    .demo-business-kfz-team-grid,
    .demo-business-kfz-service-detail-list,
    .demo-business-kfz-process-list,
    .demo-business-kfz-package-grid,
    .demo-business-kfz-mobility .demo-business-kfz-info-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-fast-list,
    .demo-business-kfz-season-list {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-kfz-fast {
        gap: 14px;
        background: var(--kfz-dark);
        border-bottom: 0;
    }

    .demo-business-kfz-fast-list {
        gap: 10px;
        background: transparent;
    }

    .demo-business-kfz-fast-list span {
        display: grid;
        min-height: 76px;
        align-content: center;
        border: 1px solid rgba(170, 178, 191, 0.16);
        border-left: 4px solid var(--kfz-red);
        border-top: 0;
        border-radius: 10px;
    }

    .demo-business-region-panel {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-inline-cta,
    .demo-business-praxis-inline-cta,
    .demo-business-kfz-inline-cta {
        align-items: stretch;
    }
}

@media (max-width: 520px) {
    .demo-business-praxis-condition-grid,
    .demo-business-praxis-team-grid,
    .demo-business-kfz-team-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-fast-list,
    .demo-business-kfz-season-list,
    .demo-business-region-panel {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }

    .demo-business-region-panel {
        gap: 8px;
    }

    .demo-business-region-panel span {
        padding: 9px 8px;
    }
}

/* Demo world layout repair v1 */
.demo-business--handwerk .demo-business-header--stacked,
.demo-business-praxis-header--stacked,
.demo-business-kfz-header--stacked {
    grid-template-columns: minmax(210px, 0.8fr) minmax(260px, 0.9fr) minmax(0, 1.4fr);
    gap: 20px;
    align-items: center;
}

.demo-business-menu {
    display: flex;
    min-width: 0;
    align-items: center;
    justify-content: flex-end;
    gap: 18px;
}

.demo-business-menu-toggle {
    display: none;
    width: 46px;
    height: 46px;
    align-items: center;
    justify-content: center;
    justify-self: end;
    padding: 0;
    color: #FFFFFF;
    border: 1px solid rgba(255, 255, 255, 0.32);
    border-radius: 8px;
    background: rgba(255, 255, 255, 0.08);
    cursor: pointer;
}

.demo-business-menu-toggle span {
    position: relative;
    width: 22px;
    height: 2px;
    overflow: visible;
    color: inherit;
    font-size: 0;
    background: currentColor;
}

.demo-business-menu-toggle span::before,
.demo-business-menu-toggle span::after {
    content: "";
    position: absolute;
    left: 0;
    width: 22px;
    height: 2px;
    background: currentColor;
}

.demo-business-menu-toggle span::before {
    top: -7px;
}

.demo-business-menu-toggle span::after {
    top: 7px;
}

.demo-business-menu-toggle--praxis {
    color: var(--praxis-petrol-dark);
    border-color: rgba(37, 107, 111, 0.24);
    background: rgba(37, 107, 111, 0.06);
}

.demo-business-menu-toggle--kfz {
    color: var(--kfz-white);
    border-color: rgba(170, 178, 191, 0.32);
    background: rgba(242, 244, 247, 0.06);
}

.demo-business--handwerk .demo-business-brand,
.demo-business-praxis-brand,
.demo-business-kfz-brand,
.demo-business-nav a,
.demo-business-praxis-nav a,
.demo-business-kfz-nav a,
.demo-business-footer a,
.demo-business-praxis-footer a,
.demo-business-kfz-footer a {
    transition: color 180ms ease, background-color 180ms ease, border-color 180ms ease, transform 180ms ease;
}

.demo-business--handwerk .demo-business-brand:hover,
.demo-business--handwerk .demo-business-brand:focus-visible {
    color: var(--handwerk-sand);
}

.demo-business-praxis-brand:hover,
.demo-business-praxis-brand:focus-visible,
.demo-business-praxis-nav a:hover,
.demo-business-praxis-nav a:focus-visible,
.demo-business-praxis-footer nav a:hover,
.demo-business-praxis-footer nav a:focus-visible,
.demo-business-praxis-footer address a:hover,
.demo-business-praxis-footer address a:focus-visible {
    color: var(--praxis-accent);
}

.demo-business-kfz-brand:hover,
.demo-business-kfz-brand:focus-visible,
.demo-business-kfz-nav a:hover,
.demo-business-kfz-nav a:focus-visible,
.demo-business-kfz-footer nav a:hover,
.demo-business-kfz-footer nav a:focus-visible,
.demo-business-kfz-footer address a:hover,
.demo-business-kfz-footer address a:focus-visible {
    color: var(--kfz-red);
}

.demo-business-footer-brand,
.demo-business-praxis-footer-brand,
.demo-business-kfz-footer-brand {
    font-size: clamp(1.25rem, 1.8vw, 1.55rem);
    font-weight: 940;
}

.demo-business-footer .demo-business-footer-brand,
.demo-business-praxis-footer .demo-business-praxis-footer-brand,
.demo-business-kfz-footer .demo-business-kfz-footer-brand {
    font-size: clamp(1.25rem, 1.8vw, 1.55rem);
    font-weight: 940;
    line-height: 1.18;
}

.demo-business-kfz-footer-brand:hover,
.demo-business-kfz-footer-brand:focus-visible {
    color: var(--kfz-red);
}

.demo-business--handwerk .demo-business-image-slot,
.demo-business-praxis-image-slot,
.demo-business-kfz-image-slot,
.demo-business-hero-media,
.demo-business-praxis-hero-visual,
.demo-business-kfz-hero-visual {
    border: 0;
    isolation: isolate;
}

.demo-business--handwerk .demo-business-image-slot::before,
.demo-business-praxis-image-slot::before,
.demo-business-kfz-image-slot::before,
.demo-business-kfz-hero-visual::before,
.demo-business-praxis-hero-visual figcaption,
.demo-business-kfz-hero-visual figcaption,
.demo-business--handwerk .demo-business-image-slot > span,
.demo-business-praxis-image-slot > span,
.demo-business-kfz-image-slot > span,
.demo-business-image-note {
    display: none;
}

.demo-business--handwerk .demo-business-image-slot,
.demo-business--handwerk .demo-business-image-slot--hero-roof,
.demo-business--handwerk .demo-business-image-slot--company-history,
.demo-business--handwerk .demo-business-image-slot--team-workshop,
.demo-business--handwerk .demo-business-image-slot--contact,
.demo-business--handwerk .demo-business-image-slot--service,
.demo-business--handwerk .demo-business-image-slot--project,
.demo-business--handwerk .demo-business-image-slot--region-map,
.demo-business--handwerk .demo-business-image-slot--quality {
    border-radius: 10px;
    box-shadow: 0 16px 34px rgba(31, 37, 35, 0.12);
}

.demo-business-praxis-image-slot,
.demo-business-praxis-image-slot--hero,
.demo-business-praxis-image-slot--philosophy,
.demo-business-praxis-image-slot--patient,
.demo-business-praxis-image-slot--contact,
.demo-business-praxis-image-slot--service,
.demo-business-praxis-image-slot--team,
.demo-business-praxis-gallery .demo-business-praxis-image-slot {
    border-radius: 18px;
    box-shadow: 0 16px 34px rgba(30, 51, 53, 0.09);
}

.demo-business-kfz-image-slot,
.demo-business-kfz-image-slot--hero,
.demo-business-kfz-image-slot--profile,
.demo-business-kfz-image-slot--diagnosis,
.demo-business-kfz-image-slot--tire,
.demo-business-kfz-image-slot--hours,
.demo-business-kfz-image-slot--contact,
.demo-business-kfz-image-slot--service,
.demo-business-kfz-image-slot--team {
    border-radius: 10px;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.18);
}

.demo-business-hero-visual-stack {
    display: grid;
    gap: 16px;
    min-width: 0;
}

.demo-business-hero-visual-stack .demo-business-hero-media {
    min-height: clamp(360px, 38vw, 520px);
    box-shadow: 14px 14px 0 rgba(17, 24, 22, 0.22);
}

.demo-business-hero-side-notes {
    display: grid;
    grid-template-columns: minmax(0, 1fr) minmax(180px, 0.72fr);
    gap: 12px;
}

.demo-business--handwerk .demo-business-project-badge,
.demo-business--handwerk .demo-business-info-card {
    position: static;
    max-width: none;
    min-height: 100%;
    box-shadow: none;
}

.demo-business--handwerk .demo-business-info-card {
    display: grid;
    align-items: center;
    justify-self: stretch;
    color: #FFFFFF;
    background: rgba(255, 255, 255, 0.1);
    border-left: 5px solid var(--handwerk-orange);
}

.demo-business-praxis-hero,
.demo-business-kfz-hero {
    align-items: center;
    padding-bottom: 52px;
}

.demo-business--praxis h1 {
    font-size: clamp(2.55rem, 5.05vw, 4.35rem);
}

.demo-business-praxis-hero-visual,
.demo-business-kfz-hero-visual {
    min-height: clamp(380px, 40vw, 520px);
}

.demo-business-praxis-trust,
.demo-business-kfz-trust {
    grid-column: 1 / -1;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    margin-top: 0;
}

.demo-business-kfz-microcopy,
.demo-business-praxis-microcopy {
    font-size: 1rem;
    line-height: 1.5;
}

.demo-business-praxis-patient,
.demo-business-kfz-vehicle-check {
    grid-template-columns: minmax(0, 0.95fr) minmax(320px, 1fr);
    align-items: center;
}

.demo-business-praxis-patient .demo-business-praxis-section-copy,
.demo-business-kfz-vehicle-check .demo-business-kfz-section-copy {
    grid-column: 1;
    grid-row: 1;
}

.demo-business-praxis-patient .demo-business-praxis-image-slot--patient,
.demo-business-kfz-vehicle-check .demo-business-kfz-image-slot--vehicle-check {
    grid-column: 2;
    grid-row: 1;
    min-height: 420px;
}

.demo-business-praxis-patient .demo-business-praxis-info-grid,
.demo-business-kfz-vehicle-check .demo-business-kfz-info-grid {
    grid-column: 1 / -1;
    grid-row: 2;
}

.demo-business-praxis-patient .demo-business-praxis-inline-cta,
.demo-business-kfz-vehicle-check .demo-business-kfz-inline-cta {
    grid-column: 1 / -1;
    grid-row: 3;
    width: 100%;
}

.demo-business-praxis-image-slot--patient > img,
.demo-business-praxis-image-slot--team > img,
.demo-business-kfz-image-slot--team > img {
    object-position: center top;
}

.demo-business-praxis-image-slot--team,
.demo-business-kfz-image-slot--team {
    aspect-ratio: 4 / 5;
    min-height: 0;
}

.demo-business-praxis-team-grid,
.demo-business-kfz-team-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

.demo-business-praxis-team-grid article,
.demo-business-kfz-team-grid article {
    grid-template-rows: auto 1fr;
}

.demo-business-kfz-fast {
    grid-template-columns: minmax(240px, 0.42fr) minmax(0, 1fr);
    gap: 1px;
    border-bottom: 0;
}

.demo-business-kfz-fast-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1px;
    background: rgba(170, 178, 191, 0.16);
}

.demo-business-kfz-fast-list span {
    display: grid;
    min-height: 92px;
    align-content: center;
    border: 0;
    border-top: 4px solid var(--kfz-red);
    border-radius: 0;
}

.demo-business-kfz-season {
    grid-template-columns: minmax(340px, 0.9fr) minmax(0, 1fr);
    align-items: stretch;
}

.demo-business-kfz-season .demo-business-kfz-section-copy {
    align-content: start;
}

.demo-business-kfz-image-slot--tire {
    min-height: 390px;
    margin-top: 24px;
}

.demo-business-kfz-season-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-content: center;
}

.demo-business-kfz-hours {
    grid-template-columns: minmax(280px, 0.74fr) minmax(220px, 0.52fr) minmax(360px, 1fr);
    align-items: stretch;
}

.demo-business-kfz-image-slot--hours {
    min-height: 430px;
}

.demo-business-kfz-image-slot--hours > img {
    object-position: center;
}

@media (max-width: 1180px) {
    .demo-business--handwerk .demo-business-header--stacked,
    .demo-business-praxis-header--stacked,
    .demo-business-kfz-header--stacked {
        grid-template-columns: minmax(0, 1fr) auto;
        gap: 12px 16px;
        align-items: center;
    }

    .demo-business--handwerk .demo-business-header-info,
    .demo-business-praxis-header-info,
    .demo-business-kfz-header-info {
        grid-column: 1 / -1;
        grid-row: 2;
        justify-content: center;
        text-align: center;
    }

    .demo-business-menu-toggle {
        display: inline-flex;
        grid-column: 2;
        grid-row: 1;
    }

    .demo-business-menu {
        display: none;
        grid-column: 1 / -1;
        grid-row: 3;
        width: 100%;
        align-items: stretch;
        justify-content: stretch;
        gap: 14px;
        padding-top: 12px;
        border-top: 1px solid rgba(255, 255, 255, 0.14);
    }

    .demo-business-praxis-header--stacked .demo-business-menu {
        border-top-color: rgba(37, 107, 111, 0.12);
    }

    .is-demo-menu-open .demo-business-menu {
        display: grid;
    }

    .demo-business-nav,
    .demo-business-praxis-nav,
    .demo-business-kfz-nav {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
        justify-content: stretch;
    }

    .demo-business-nav a,
    .demo-business-praxis-nav a,
    .demo-business-kfz-nav a {
        padding: 11px 12px;
        border-radius: 8px;
        background: rgba(255, 255, 255, 0.08);
    }

    .demo-business-praxis-nav a {
        background: rgba(37, 107, 111, 0.07);
    }

    .demo-business-kfz-nav a {
        background: rgba(242, 244, 247, 0.07);
    }

    .demo-business-menu > .demo-business-button,
    .demo-business-menu > .demo-business-praxis-button,
    .demo-business-menu > .demo-business-kfz-button {
        width: 100%;
    }

    .demo-business-praxis-trust,
    .demo-business-kfz-trust {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 1023px) {
    .demo-business-hero,
    .demo-business-praxis-hero,
    .demo-business-kfz-hero,
    .demo-business-praxis-patient,
    .demo-business-kfz-vehicle-check,
    .demo-business-kfz-season,
    .demo-business-kfz-hours {
        grid-template-columns: 1fr;
    }

    .demo-business-praxis-patient .demo-business-praxis-section-copy,
    .demo-business-kfz-vehicle-check .demo-business-kfz-section-copy,
    .demo-business-praxis-patient .demo-business-praxis-image-slot--patient,
    .demo-business-kfz-vehicle-check .demo-business-kfz-image-slot--vehicle-check,
    .demo-business-praxis-patient .demo-business-praxis-info-grid,
    .demo-business-kfz-vehicle-check .demo-business-kfz-info-grid,
    .demo-business-praxis-patient .demo-business-praxis-inline-cta,
    .demo-business-kfz-vehicle-check .demo-business-kfz-inline-cta {
        grid-column: 1;
        grid-row: auto;
    }

    .demo-business-kfz-hours > div:first-child {
        order: 1;
    }

    .demo-business-kfz-location {
        order: 2;
    }

    .demo-business-kfz-image-slot--hours {
        order: 3;
    }

    .demo-business-praxis-team-grid,
    .demo-business-kfz-team-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 767px) {
    .demo-business--handwerk .demo-business-header-info,
    .demo-business-praxis-header-info,
    .demo-business-kfz-header-info {
        justify-content: center;
        font-size: 0.8rem;
    }

    .demo-business--handwerk .demo-business-header-info span + span::before,
    .demo-business-praxis-header-info span + span::before,
    .demo-business-kfz-header-info span + span::before {
        margin: 0 6px;
    }

    .demo-business-nav,
    .demo-business-praxis-nav,
    .demo-business-kfz-nav,
    .demo-business-praxis-trust,
    .demo-business-kfz-trust,
    .demo-business-praxis-team-grid,
    .demo-business-kfz-team-grid {
        grid-template-columns: 1fr;
    }

    .demo-business-hero-side-notes,
    .demo-business-kfz-fast-list,
    .demo-business-kfz-season-list {
        grid-template-columns: 1fr;
    }

    .demo-business-kfz-fast {
        grid-template-columns: 1fr;
    }

    .demo-business-hero-visual-stack .demo-business-hero-media,
    .demo-business-praxis-hero-visual,
    .demo-business-kfz-hero-visual,
    .demo-business-praxis-patient .demo-business-praxis-image-slot--patient,
    .demo-business-kfz-vehicle-check .demo-business-kfz-image-slot--vehicle-check,
    .demo-business-kfz-image-slot--hours {
        min-height: 300px;
    }

    .demo-business-praxis-image-slot--team,
    .demo-business-kfz-image-slot--team {
        aspect-ratio: 4 / 5;
    }

    .demo-business-praxis-inline-cta,
    .demo-business-kfz-inline-cta {
        display: grid;
    }

    .demo-business-praxis-inline-cta .demo-business-praxis-button,
    .demo-business-kfz-inline-cta .demo-business-kfz-button {
        width: 100%;
    }
}

.demo-business--beauty-v2 .demo-business-menu-toggle--beauty {
    color: var(--beauty-v2-brown);
    border-color: rgba(58, 48, 44, 0.34);
    background: rgba(255, 253, 249, 0.9);
    box-shadow: 0 8px 20px rgba(58, 48, 44, 0.08);
}

.demo-business--beauty-v2 .demo-business-menu-toggle--beauty:hover,
.demo-business--beauty-v2 .demo-business-menu-toggle--beauty:focus-visible {
    color: #FFFFFF;
    border-color: var(--beauty-v2-accent-hover);
    background: var(--beauty-v2-accent-hover);
}

.demo-business--cleaning-v3 .demo-business-menu-toggle--cleaning {
    color: var(--cleaning-v3-deep);
    border-color: rgba(16, 61, 85, 0.28);
    background: rgba(234, 248, 251, 0.94);
}

.demo-business--cleaning-v3 .demo-business-menu-toggle--cleaning:hover,
.demo-business--cleaning-v3 .demo-business-menu-toggle--cleaning:focus-visible {
    color: #FFFFFF;
    border-color: var(--cleaning-v3-turquoise-dark);
    background: var(--cleaning-v3-turquoise-dark);
}

.demo-business--cleaning-v3 .demo-business-cleaning-footer .demo-business-cleaning-footer-brand {
    color: #FFFFFF;
    font-size: 1.72rem;
    font-weight: 920;
    line-height: 1.08;
}
