.demo-button {
    position: relative;
    overflow: hidden;
}

.demo-button--docked-closed {
    position: fixed;
    top: var(--btn-top);
    left: var(--btn-left);
    width: var(--btn-width);
    height: var(--btn-height);
    border-radius: var(--btn-radius, 999px);
    z-index: 1101;
    margin: 0;
    padding: 3px 12px 3px 8px;
    border: none;
    background-color: var(--colorBlue);
    color: var(--colorWhite);
    display: grid;
    grid-template-columns: min-content min-content;
    grid-template-rows: min-content;
    column-gap: 5px;
    font: inherit;
    cursor: pointer;
    box-sizing: border-box;
    transition: none !important;
}

.demo-button--docked-closed.demo-button--dock-bottom {
    top: auto;
    left: 50%;
    bottom: calc(12px + env(safe-area-inset-bottom, 0px));
    transform: translateX(-50%);
    width: var(--btn-width);
    height: var(--btn-height);
}

.demo-button--docked-closed .icon {
    width: 15px;
    height: 15px;
    margin: auto;
}

.demo-button--docked-closed p {
    margin: auto;
    white-space: nowrap;
}

.demo-button--docked-closed .demo-button__calendly-host {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    top: 0;
    background: none;
}

.demo-button-placeholder {
    flex-shrink: 0;
}

.demo-button__calendly-host {
    position: absolute;
    inset: 0;
    opacity: 0;
    overflow: hidden;
    pointer-events: none;
    z-index: 0;
}

.demo-button__close {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 32px;
    height: 32px;
    border: none;
    border-radius: 999px;
    background: rgba(0, 0, 0, 0.06);
    color: rgba(0, 0, 0, 0.65);
    font-size: 1.35rem;
    line-height: 1;
    display: grid;
    place-items: center;
    padding: 0;
    cursor: pointer;
    opacity: 0;
    pointer-events: none;
    z-index: 3;
}

.demo-button--expanded,
.menu .demo-button.demo-button--expanded,
.mobile-dynamic-island-bar .demo-button.demo-button--expanded {
    --demo-morph-duration: 0.5s;
    position: fixed;
    top: var(--btn-top);
    left: var(--btn-left);
    width: var(--btn-width);
    height: var(--btn-height);
    border-radius: var(--btn-radius);
    z-index: 2100;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    align-items: stretch;
    grid-template-columns: unset;
    grid-template-rows: unset;
    column-gap: 0;
    box-sizing: border-box;
    background-color: var(--colorBlue);
    color: var(--colorWhite);
    box-shadow: 0 12px 48px rgba(0, 0, 0, 0.22);
    transform: none;
    bottom: auto;
}

.demo-button--expanded.demo-button--morphing,
.menu .demo-button.demo-button--expanded.demo-button--morphing,
.mobile-dynamic-island-bar .demo-button.demo-button--expanded.demo-button--morphing {
    transition:
        top var(--demo-morph-duration) var(--easing),
        left var(--demo-morph-duration) var(--easing),
        width var(--demo-morph-duration) var(--easing),
        height var(--demo-morph-duration) var(--easing),
        border-radius var(--demo-morph-duration) var(--easing),
        background-color var(--demo-morph-duration) var(--easing),
        color var(--demo-morph-duration) var(--easing);
}

.demo-button--expanded.demo-button--open {
    background-color: var(--colorWhite);
    color: var(--colorBlack, #000);
}

.demo-button--expanded > .icon,
.demo-button--expanded > p {
    position: absolute;
    top: 10px;
    margin: 0;
    z-index: 2;
    pointer-events: none;
}

.demo-button--expanded.demo-button--morphing > .icon,
.demo-button--expanded.demo-button--morphing > p {
    transition: opacity 0.25s var(--easing), visibility 0s linear 0.25s;
}

.demo-button--expanded > .icon {
    left: 8px;
    width: 15px;
    height: 15px;
    transform: none;
}

.demo-button--expanded > p {
    left: 16px;
    line-height: 1.3;
    white-space: nowrap;
    transform: none;
}

.demo-button--expanded.demo-button--open > .icon,
.demo-button--expanded.demo-button--loading > .icon,
.demo-button--expanded.demo-button--ready > .icon {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
}

.demo-button--expanded.demo-button--open > p,
.demo-button--expanded.demo-button--loading > p,
.demo-button--expanded.demo-button--ready > p {
    opacity: 1;
    visibility: visible;
    color: var(--colorBlue);
    left: 16px;
    right: auto;
    text-align: left;
    font-weight: 600;
}

.demo-button--expanded.demo-button--morphing.demo-button--open > .icon,
.demo-button--expanded.demo-button--morphing.demo-button--loading > .icon,
.demo-button--expanded.demo-button--morphing.demo-button--ready > .icon {
    transition: opacity 0.25s var(--easing), visibility 0s linear 0.25s;
}

.demo-button--expanded.demo-button--morphing.demo-button--open > p,
.demo-button--expanded.demo-button--morphing.demo-button--loading > p,
.demo-button--expanded.demo-button--morphing.demo-button--ready > p {
    transition: opacity 0.25s var(--easing), color 0.25s var(--easing), visibility 0s linear 0s;
}

.demo-button--expanded .demo-button__calendly-host {
    position: absolute;
    top: 44px;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    background: none;
}

.demo-button--expanded.demo-button--morphing .demo-button__calendly-host {
    transition:
        opacity var(--demo-morph-duration) var(--easing),
        visibility 0s linear var(--demo-morph-duration);
}

.demo-button--expanded.demo-button--morphing.demo-button--open:not(.demo-button--closing) .demo-button__calendly-host {
    transition:
        opacity var(--demo-morph-duration) var(--easing),
        visibility 0s linear 0s;
}

.demo-button--expanded.demo-button--morphing.demo-button--closing .demo-button__calendly-host {
    transition:
        opacity var(--demo-morph-duration) var(--easing),
        visibility 0s linear var(--demo-morph-duration);
}

.demo-button--expanded.demo-button--open:not(.demo-button--closing) .demo-button__calendly-host {
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    overflow: hidden;
    touch-action: pan-y;
}

.demo-button--expanded.demo-button--closing .demo-button__calendly-host {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    background: none;
}

.demo-button--expanded.demo-button--loading.demo-button--open:not(.demo-button--closing) .demo-button__calendly-host {
    background: var(--colorWhite)
        url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='10' stroke='%232A3EF6' stroke-width='2' fill='none' stroke-dasharray='32' stroke-linecap='round'%3E%3CanimateTransform attributeName='transform' type='rotate' from='0 12 12' to='360 12 12' dur='0.8s' repeatCount='indefinite'/%3E%3C/circle%3E%3C/svg%3E")
        center 40% / 28px no-repeat;
}

.demo-button--expanded.demo-button--open:not(.demo-button--closing) .demo-button__close {
    opacity: 1;
    pointer-events: auto;
}

.demo-button--expanded.demo-button--closing .demo-button__close {
    opacity: 0;
    pointer-events: none;
}

.demo-button--expanded.demo-button--morphing.demo-button--open:not(.demo-button--closing) .demo-button__close,
.demo-button--expanded.demo-button--morphing.demo-button--closing .demo-button__close {
    transition: opacity var(--demo-morph-duration) var(--easing);
}

.demo-button .calendly-inline-widget {
    width: 100%;
    height: 100%;
    min-width: 0;
    min-height: 0;
}

.demo-button .calendly-inline-widget iframe {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    color-scheme: light;
}

body.demo-booking-open {
    overflow: hidden;
}

.demo-booking-backdrop {
    position: fixed;
    inset: 0;
    z-index: 2050;
    border: none;
    padding: 0;
    margin: 0;
    background: rgba(0, 0, 0, 0.45);
    opacity: 0;
    pointer-events: none;
    cursor: pointer;
    transition: opacity 0.6s var(--easing);
}

.demo-booking-backdrop--visible {
    opacity: 1;
    pointer-events: auto;
}

body.demo-booking-open .demo-button:not(.demo-button--expanded) {
    visibility: hidden;
}

@media (prefers-reduced-motion: reduce) {
    .demo-button--expanded {
        --demo-morph-duration: 0.01ms;
    }

    .demo-button--expanded.demo-button--morphing,
    .demo-booking-backdrop,
    .demo-button--expanded.demo-button--morphing > .icon,
    .demo-button--expanded.demo-button--morphing > p,
    .demo-button--expanded.demo-button--morphing .demo-button__calendly-host,
    .demo-button--expanded.demo-button--morphing .demo-button__close {
        transition-duration: 0.01ms !important;
        transition-delay: 0s !important;
    }
}

@media (max-width: 768px) {
    .demo-button--docked-closed {
        height: 40px;
        padding: 0 24px 0 16px;
        display: inline-flex;
        align-items: center;
        justify-content: center;
        gap: 8px;
        column-gap: 8px;
    }

    .demo-button--docked-closed .icon {
        margin: 0;
        flex-shrink: 0;
    }

    .demo-button--docked-closed p {
        margin: 0;
        line-height: 1;
    }

    .demo-button--expanded.demo-button--open > p,
    .demo-button--expanded.demo-button--loading > p,
    .demo-button--expanded.demo-button--ready > p {
        left: 20px;
        top: 12px;
    }
}
