.pwa-banner {
    position: fixed;
    left: 50%;
    bottom: 1rem;
    transform: translateX(-50%);
    z-index: 9999;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.75rem;
    max-width: min(36rem, calc(100vw - 2rem));
    padding: 0.85rem 1rem;
    border-radius: 0.85rem;
    background: rgba(26, 15, 46, 0.96);
    border: 1px solid rgba(201, 162, 39, 0.45);
    color: #f3ecff;
    box-shadow: 0 0.75rem 2rem rgba(0, 0, 0, 0.35);
}

.pwa-banner[hidden] {
    display: none !important;
}

.pwa-banner__text {
    margin: 0;
    flex: 1 1 12rem;
    line-height: 1.4;
}

.pwa-banner__actions {
    display: flex;
    gap: 0.5rem;
    flex-wrap: wrap;
}

.pwa-banner__button {
    border: 0;
    border-radius: 999px;
    padding: 0.55rem 0.95rem;
    background: linear-gradient(180deg, #e0bc4a, #c9a227);
    color: #201106;
    font-weight: 700;
    cursor: pointer;
}

.pwa-banner__button--ghost {
    background: transparent;
    color: #d9c7ff;
    border: 1px solid rgba(217, 199, 255, 0.35);
}

#pwa-offline-banner {
    top: 0.75rem;
    bottom: auto;
    background: rgba(74, 20, 20, 0.95);
    border-color: rgba(255, 120, 120, 0.45);
}

.pwa-toast {
    position: fixed;
    left: 50%;
    bottom: 5.5rem;
    transform: translateX(-50%);
    z-index: 10000;
    padding: 0.75rem 1rem;
    border-radius: 999px;
    background: rgba(26, 15, 46, 0.98);
    border: 1px solid rgba(201, 162, 39, 0.45);
    color: #f3ecff;
}

body.is-offline main,
body.is-offline .events-container,
body.is-offline .quests-page {
    opacity: 0.92;
}

@media (display-mode: standalone) {
    body {
        padding-top: env(safe-area-inset-top);
        padding-bottom: env(safe-area-inset-bottom);
    }
}
