:root {
    --nwapp-bg: #25d366;
    --nwapp-text: #ffffff;
    --nwapp-hover-bg: #1ebe5d;
    --nwapp-online: #34c759;
    --nwapp-offline: #f59e0b;
    --nwapp-appointment-bg: #ffffff;
    --nwapp-appointment-icon: #111827;
    --nwapp-appointment-hover: #f3f4f6;
    --nwapp-radius: 999px;
    --nwapp-shadow: 0 10px 24px rgba(0, 0, 0, 0.16);
}

.nwapp-widget {
    position: fixed;
    bottom: 24px;
    z-index: 99999;
    display: flex;
    align-items: flex-start;
    gap: var(--nwapp-appointment-gap, 12px);
    width: auto;
    max-width: calc(100vw - 30px);
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.25s ease, transform 0.25s ease;
    font-family: "Segoe UI", "Helvetica Neue", sans-serif;
}

.nwapp-main {
    position: relative;
    width: var(--nwapp-width-d, 220px);
}

.nwapp-widget.nwapp-pos-right {
    right: 22px;
}

.nwapp-widget.nwapp-pos-left {
    left: 22px;
}

.nwapp-widget.nwapp-hidden {
    opacity: 0;
    transform: translateY(20px);
    pointer-events: none;
}

.nwapp-widget.nwapp-visible {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

.nwapp-widget .nwapp-link {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--nwapp-gap-d, 10px);
    width: 100%;
    min-height: var(--nwapp-height-d, 56px);
    padding: var(--nwapp-pad-y-d, 14px) var(--nwapp-pad-x-d, 18px);
    border-radius: var(--nwapp-radius, 999px);
    background: var(--nwapp-bg);
    color: var(--nwapp-text);
    box-shadow: var(--nwapp-shadow);
    text-decoration: none;
    font-size: var(--nwapp-font-d, 15px);
    font-weight: 600;
    line-height: 1.2;
    transition: background-color 0.2s ease, transform 0.2s ease, box-shadow 0.2s ease;
}

.nwapp-widget .nwapp-link:hover,
.nwapp-widget .nwapp-link:focus-visible {
    background: var(--nwapp-hover-bg);
    transform: translateY(-1px);
}

.nwapp-widget .nwapp-link:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--nwapp-bg), #ffffff 35%);
    outline-offset: 2px;
}

.nwapp-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--nwapp-icon-d, 22px);
    height: var(--nwapp-icon-d, 22px);
    flex: 0 0 auto;
}

.nwapp-icon svg {
    width: 100%;
    height: 100%;
}

.nwapp-icon-round {
    border-radius: 999px;
}

.nwapp-icon-square {
    border-radius: 8px;
}

.nwapp-icon-minimal {
    opacity: 0.92;
}

.nwapp-text {
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.nwapp-status {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 7px;
    padding: 0 5px;
    color: #193022;
    font-size: 12px;
    line-height: 1.2;
}

.nwapp-status-dot {
    width: 8px;
    height: 8px;
    border-radius: 999px;
    background: var(--nwapp-status-dot, var(--nwapp-online));
    flex: 0 0 auto;
}

.nwapp-tooltip {
    position: absolute;
    right: 0;
    bottom: calc(100% + 10px);
    display: inline-block;
    background: #1f2937;
    color: #ffffff;
    font-size: 12px;
    line-height: 1.3;
    padding: 6px 10px;
    border-radius: 8px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transform: translateY(6px);
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.nwapp-widget:hover .nwapp-tooltip,
.nwapp-widget:focus-within .nwapp-tooltip {
    opacity: 1;
    transform: translateY(0);
}

.nwapp-close {
    position: absolute;
    top: -10px;
    right: -10px;
    width: 24px;
    height: 24px;
    border: 0;
    border-radius: 999px;
    background: #ffffff;
    color: #334155;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
    cursor: pointer;
    font-size: 16px;
    line-height: 1;
    z-index: 2;
}

.nwapp-close:hover,
.nwapp-close:focus-visible {
    background: #f8fafc;
    outline: 2px solid #94a3b8;
}

.nwapp-widget.nwapp-icon-only .nwapp-main,
.nwapp-widget.nwapp-variant-1 .nwapp-main {
    width: var(--nwapp-height-d, 56px);
}

.nwapp-widget.nwapp-icon-only .nwapp-link {
    border-radius: 999px;
    padding: 0;
    width: var(--nwapp-height-d, 56px);
    height: var(--nwapp-height-d, 56px);
    min-height: var(--nwapp-height-d, 56px);
}

.nwapp-widget.nwapp-icon-only .nwapp-text {
    display: none;
}

.nwapp-widget.nwapp-variant-1 .nwapp-link {
    border-radius: 999px;
    padding: 0;
    min-height: var(--nwapp-height-d, 56px);
    width: var(--nwapp-height-d, 56px);
    height: var(--nwapp-height-d, 56px);
}

.nwapp-widget.nwapp-variant-1 .nwapp-text {
    display: none;
}

.nwapp-widget.nwapp-variant-2 .nwapp-link {
    border-radius: 999px;
}

.nwapp-widget.nwapp-variant-3 .nwapp-link {
    border-radius: 20px;
    box-shadow: 0 10px 20px rgba(18, 70, 42, 0.24);
}

.nwapp-widget.nwapp-variant-4 .nwapp-link {
    border-radius: 14px;
    min-height: calc(var(--nwapp-height-d, 56px) - 4px);
    box-shadow: 0 8px 18px rgba(18, 70, 42, 0.22);
}

.nwapp-widget.nwapp-variant-5 {
    max-width: calc(100vw - 30px);
}

.nwapp-widget.nwapp-variant-5 .nwapp-main {
    width: min(280px, calc(100vw - 30px));
}

.nwapp-widget.nwapp-variant-5 .nwapp-link {
    border-radius: 16px;
    justify-content: flex-start;
    box-shadow: 0 14px 28px rgba(18, 70, 42, 0.2);
}

.nwapp-widget.nwapp-variant-5 .nwapp-status {
    margin-top: 8px;
    padding-left: 3px;
}

.nwapp-widget.nwapp-disabled .nwapp-link {
    background: #94a3b8;
    cursor: not-allowed;
}

.nwapp-widget.nwapp-anim-none {
    animation: none;
}

.nwapp-widget.nwapp-anim-pulse {
    animation: nwappPulse 2.4s infinite;
}

.nwapp-widget.nwapp-anim-float {
    animation: nwappFloat 3.2s ease-in-out infinite;
}

.nwapp-widget.nwapp-anim-bounce {
    animation: nwappBounce 2.6s infinite;
}

.nwapp-widget.nwapp-anim-shake {
    animation: nwappShake 3.6s infinite;
}

.nwapp-widget.nwapp-intensity-low {
    animation-duration: 4s;
}

.nwapp-widget.nwapp-intensity-high {
    animation-duration: 1.8s;
}

.nwapp-widget.nwapp-is-preview {
    position: relative;
    right: auto;
    left: auto;
    bottom: auto;
    z-index: 1;
}

.nwapp-preview-mobile .nwapp-widget .nwapp-main {
    width: var(--nwapp-width-m, 190px);
}

.nwapp-preview-mobile .nwapp-widget .nwapp-link {
    min-height: var(--nwapp-height-m, 52px);
    padding: var(--nwapp-pad-y-m, 12px) var(--nwapp-pad-x-m, 16px);
    gap: var(--nwapp-gap-m, 8px);
    font-size: var(--nwapp-font-m, 14px);
}

.nwapp-preview-mobile .nwapp-widget .nwapp-icon {
    width: var(--nwapp-icon-m, 20px);
    height: var(--nwapp-icon-m, 20px);
}

.nwapp-preview-mobile .nwapp-appointment {
    width: var(--nwapp-appointment-size-m, 52px);
    height: var(--nwapp-appointment-size-m, 52px);
}

.nwapp-preview-mobile .nwapp-appointment-icon {
    width: var(--nwapp-appointment-icon-m, 20px);
    height: var(--nwapp-appointment-icon-m, 20px);
}

@media (max-width: 767px) {
    .nwapp-widget {
        bottom: 16px;
    }

    .nwapp-widget.nwapp-mobile-pos-right {
        right: 14px;
        left: auto;
    }

    .nwapp-widget.nwapp-mobile-pos-left {
        left: 14px;
        right: auto;
    }

    .nwapp-widget .nwapp-link {
        min-height: var(--nwapp-height-m, 52px);
        padding: var(--nwapp-pad-y-m, 12px) var(--nwapp-pad-x-m, 16px);
        gap: var(--nwapp-gap-m, 8px);
        font-size: var(--nwapp-font-m, 14px);
    }

    .nwapp-widget .nwapp-icon {
        width: var(--nwapp-icon-m, 20px);
        height: var(--nwapp-icon-m, 20px);
    }

    .nwapp-widget .nwapp-main {
        width: var(--nwapp-width-m, 190px);
    }

    .nwapp-widget.nwapp-variant-1 .nwapp-main,
    .nwapp-widget.nwapp-icon-only .nwapp-main {
        width: var(--nwapp-height-m, 52px);
    }

    .nwapp-widget.nwapp-variant-1 .nwapp-link {
        width: var(--nwapp-height-m, 52px);
        height: var(--nwapp-height-m, 52px);
        min-height: var(--nwapp-height-m, 52px);
    }

    .nwapp-widget.nwapp-icon-only .nwapp-link {
        width: var(--nwapp-height-m, 52px);
        height: var(--nwapp-height-m, 52px);
        min-height: var(--nwapp-height-m, 52px);
    }
}

.nwapp-appointment {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: var(--nwapp-appointment-size-d, 56px);
    height: var(--nwapp-appointment-size-d, 56px);
    border-radius: 999px;
    background: var(--nwapp-appointment-bg);
    color: var(--nwapp-appointment-icon);
    box-shadow: var(--nwapp-shadow);
    text-decoration: none;
    flex: 0 0 auto;
    transition: background-color 0.2s ease, transform 0.2s ease;
}

.nwapp-appointment:hover,
.nwapp-appointment:focus-visible {
    background: var(--nwapp-appointment-hover);
    transform: translateY(-1px);
}

.nwapp-appointment:focus-visible {
    outline: 3px solid color-mix(in srgb, var(--nwapp-appointment-bg), #2563eb 35%);
    outline-offset: 2px;
}

.nwapp-appointment-icon {
    width: var(--nwapp-appointment-icon-d, 22px);
    height: var(--nwapp-appointment-icon-d, 22px);
    display: inline-flex;
}

.nwapp-appointment-icon svg {
    width: 100%;
    height: 100%;
}

.nwapp-appointment-tooltip {
    position: absolute;
    left: 50%;
    bottom: calc(100% + 10px);
    transform: translate(-50%, 6px);
    display: inline-block;
    background: #111827;
    color: #ffffff;
    font-size: 12px;
    line-height: 1.3;
    padding: 6px 10px;
    border-radius: 8px;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.2s ease, transform 0.2s ease;
}

.nwapp-appointment:hover .nwapp-appointment-tooltip,
.nwapp-appointment:focus-within .nwapp-appointment-tooltip {
    opacity: 1;
    transform: translate(-50%, 0);
}

@media (max-width: 767px) {
    .nwapp-appointment {
        width: var(--nwapp-appointment-size-m, 52px);
        height: var(--nwapp-appointment-size-m, 52px);
    }

    .nwapp-appointment-icon {
        width: var(--nwapp-appointment-icon-m, 20px);
        height: var(--nwapp-appointment-icon-m, 20px);
    }
}

@media (max-width: 360px) {
    .nwapp-widget.nwapp-hide-small {
        display: none !important;
    }
}

@keyframes nwappPulse {
    0% { transform: scale(1); }
    50% { transform: scale(1.02); }
    100% { transform: scale(1); }
}

@keyframes nwappFloat {
    0% { transform: translateY(0); }
    50% { transform: translateY(-4px); }
    100% { transform: translateY(0); }
}

@keyframes nwappBounce {
    0%, 100% { transform: translateY(0); }
    50% { transform: translateY(-6px); }
}

@keyframes nwappShake {
    0%, 100% { transform: translateX(0); }
    25% { transform: translateX(-2px); }
    75% { transform: translateX(2px); }
}
