:root {
  --pwa-theme-color: #2c5282;
  --pwa-update-color: #166534;
  --pwa-offline-color: #7c2d12;
}

html {
  min-height: 100%;
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  scroll-behavior: smooth;
}

body {
  min-height: 100%;
  overscroll-behavior-y: contain;
  touch-action: manipulation;
}

img,
svg,
video,
canvas {
  max-width: 100%;
  height: auto;
}

button,
[type="button"],
[type="submit"],
[type="reset"],
.btn,
.nav-link,
.dropdown-item,
.v3-bottom-nav-item {
  min-height: 44px;
}

input,
select,
textarea {
  font-size: max(16px, 1rem);
}

@media (display-mode: standalone) {
  body {
    user-select: none;
    -webkit-user-select: none;
  }

  input,
  textarea,
  [contenteditable="true"] {
    user-select: text;
    -webkit-user-select: text;
  }
}

.v3-body {
  padding-top: max(86px, calc(86px + env(safe-area-inset-top)));
}

.v3-navbar.fixed-top {
  padding-top: env(safe-area-inset-top);
}

.v3-bottom-nav {
  height: calc(60px + env(safe-area-inset-bottom));
  padding-bottom: env(safe-area-inset-bottom);
}

@media (max-width: 991px) {
  .v3-body {
    padding-bottom: calc(78px + env(safe-area-inset-bottom));
  }

  .pwa-status-banner {
    bottom: max(76px, calc(76px + env(safe-area-inset-bottom)));
  }
}

@media (min-width: 992px) {
  .v3-body {
    padding-top: max(48px, calc(48px + env(safe-area-inset-top)));
  }
}

.pwa-status-banner {
  position: fixed;
  left: max(12px, env(safe-area-inset-left));
  right: max(12px, env(safe-area-inset-right));
  bottom: max(12px, calc(12px + env(safe-area-inset-bottom)));
  z-index: 2000;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 8px;
  color: #ffffff;
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.24);
  font-size: 0.95rem;
  line-height: 1.3;
}

.pwa-status-banner button {
  min-height: 40px;
  border: 0;
  border-radius: 8px;
  padding: 0 14px;
  color: #111827;
  background: #ffffff;
  font: inherit;
  font-weight: 700;
  white-space: nowrap;
}

.pwa-status-banner-offline {
  background: var(--pwa-offline-color);
}

.pwa-status-banner-update {
  background: var(--pwa-update-color);
}

@media (min-width: 640px) {
  .pwa-status-banner {
    left: auto;
    width: min(440px, calc(100vw - 24px));
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 0.001ms !important;
  }
}
