/**
 * iOS-only styles — active when document.body has .capacitor-native
 * (set by public/js/capacitor-native.js). No effect on normal web users.
 */

:root {
  --cap-safe-top: env(safe-area-inset-top, 0px);
  --cap-safe-right: env(safe-area-inset-right, 0px);
  --cap-safe-bottom: env(safe-area-inset-bottom, 0px);
  --cap-safe-left: env(safe-area-inset-left, 0px);
  /* Fallback when WKWebView reports 0 — clears clock, signal, battery */
  --cap-status-padding: max(var(--cap-safe-top), 47px);
  --cap-tab-bar-height: 3.5rem;
  --cap-header-height: 3.5rem;
  --cap-header-total: calc(var(--cap-status-padding) + var(--cap-header-height));
  --cap-brand: #3B7A6B;
  --cap-surface: #f9fafb;
  --cap-text: #111827;
  --cap-text-muted: #6b7280;
}

html.capacitor-native-boot {
  background-color: var(--cap-brand);
}

html.capacitor-native-root:not(.capacitor-native-boot) {
  background-color: var(--cap-surface);
}

html.capacitor-native-boot body {
  visibility: hidden;
}

html.capacitor-native-page-load {
  background-color: var(--cap-surface);
}

.cap-page-loader {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9998;
  align-items: center;
  justify-content: center;
  background: rgba(249, 250, 251, 0.96);
  opacity: 1;
  transition: opacity 0.15s ease;
  padding: var(--cap-safe-top) var(--cap-safe-right) var(--cap-safe-bottom) var(--cap-safe-left);
}

html.capacitor-native-page-load .cap-page-loader {
  display: flex;
}

.cap-page-loader.cap-page-loader--hiding {
  opacity: 0;
  pointer-events: none;
}

.cap-page-loader-spinner {
  width: 1.75rem;
  height: 1.75rem;
  border: 2px solid rgba(59, 122, 107, 0.2);
  border-top-color: var(--cap-brand);
  border-radius: 50%;
  animation: cap-spin 0.75s linear infinite;
}

.cap-boot-loader {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2147483646;
  align-items: center;
  justify-content: center;
  background: var(--cap-brand);
  color: #ffffff;
  padding: var(--cap-safe-top) var(--cap-safe-right) var(--cap-safe-bottom) var(--cap-safe-left);
  overflow: hidden;
}

html.capacitor-native-boot .cap-boot-loader {
  display: flex;
}

.cap-boot-loader-stage {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.cap-boot-logo {
  width: 3.75rem;
  height: 3.75rem;
  transform-origin: center center;
}

.cap-boot-logo img,
.cap-boot-logo svg {
  display: block;
  width: 100%;
  height: 100%;
}

.cap-boot-loader-title {
  margin: 0.25rem 0 0;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  font-size: 1.625rem;
  font-weight: 600;
  letter-spacing: -0.01em;
  line-height: 1.2;
  color: #ffffff;
}

.cap-boot-loader-title .cap-boot-domain {
  font-weight: 500;
  color: rgba(255, 255, 255, 0.92);
}

.cap-boot-loader-tagline {
  margin: 0.25rem 0 0;
  max-width: 18rem;
  font-family: -apple-system, BlinkMacSystemFont, 'Helvetica Neue', sans-serif;
  font-size: 0.9375rem;
  font-weight: 400;
  line-height: 1.35;
  color: rgba(255, 255, 255, 0.88);
}

.cap-boot-spinner {
  display: block;
  flex-shrink: 0;
  box-sizing: border-box;
  width: 2rem;
  height: 2rem;
  margin-top: 1.5rem;
  border: 3px solid rgba(255, 255, 255, 0.28);
  border-top-color: #ffffff;
  border-radius: 50%;
  animation: cap-spin 0.7s linear infinite;
  -webkit-animation: cap-spin 0.7s linear infinite;
}

.cap-boot-loader.cap-boot-exiting {
  animation: cap-splash-exit 0.8s forwards;
  pointer-events: none;
  will-change: transform;
}

html.capacitor-native-boot.cap-boot-revealing {
  background-color: var(--cap-surface);
}

html.capacitor-native-boot.cap-boot-revealing body {
  visibility: visible;
}

html.capacitor-native-boot #cap-native-tab-bar {
  visibility: hidden !important;
  pointer-events: none;
}

@keyframes cap-spin {
  to {
    transform: rotate(360deg);
  }
}

@keyframes cap-splash-exit {
  0% {
    transform: translate3d(0, 0, 0);
  }
  18% {
    transform: translate3d(0, 28px, 0);
    animation-timing-function: cubic-bezier(0.34, 1.4, 0.64, 1);
  }
  30% {
    transform: translate3d(0, 10px, 0);
    animation-timing-function: cubic-bezier(0.55, 0.055, 0.675, 0.19);
  }
  100% {
    transform: translate3d(0, -100%, 0);
  }
}

/* iOS scroll container — keeps bottom tab bar pinned while content scrolls */
html.capacitor-native-root {
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: fixed;
}

html.capacitor-native-root body.capacitor-native {
  width: 100%;
  height: 100%;
  overflow-x: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}

body.capacitor-native {
  padding-top: var(--cap-header-total);
  padding-left: var(--cap-safe-left);
  padding-right: var(--cap-safe-right);
  padding-bottom: calc(var(--cap-safe-bottom) + var(--cap-tab-bar-height));
  background-color: var(--cap-surface);
  -webkit-tap-highlight-color: transparent;
  overscroll-behavior-y: none;
}

/* iOS zooms focused fields when font-size is below 16px */
html.capacitor-native input:not([type='checkbox']):not([type='radio']):not([type='range']):not([type='submit']):not([type='button']):not([type='reset']):not([type='hidden']):not([type='file']),
html.capacitor-native textarea,
html.capacitor-native select,
html.capacitor-native .ql-editor {
  font-size: 16px;
}

/* Header is mounted on <html> — must not use body ancestor selector */
html.capacitor-native #cap-native-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 9991;
  box-sizing: border-box;
  margin: 0;
  min-height: var(--cap-header-total);
  padding-top: var(--cap-status-padding);
  padding-left: var(--cap-safe-left);
  padding-right: var(--cap-safe-right);
  background: var(--cap-brand) !important;
  background-color: var(--cap-brand) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14) !important;
  box-shadow: none !important;
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  isolation: isolate;
}

html.capacitor-native #cap-native-header::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--cap-brand);
  z-index: -1;
}

html.capacitor-native #cap-native-header > div,
html.capacitor-native #cap-native-header .flex.items-center.justify-between,
html.capacitor-native #cap-native-header a.flex.items-center {
  background: transparent !important;
  background-color: transparent !important;
}

html.capacitor-native #cap-native-header .flex.items-center.justify-between {
  height: var(--cap-header-height);
}

html.capacitor-native #cap-native-header .hidden.sm\:flex,
html.capacitor-native #cap-native-header .sm\:hidden.flex,
html.capacitor-native #cap-native-header .sm\:hidden:not(.cap-native-menu-btn),
html.capacitor-native #cap-native-header .cap-header-web-actions {
  display: none !important;
}

html.capacitor-native #cap-native-header .cap-native-case-crumb {
  display: none !important;
}

html.capacitor-native .cap-native-header-actions {
  display: flex !important;
  align-items: center;
  margin-left: auto;
  flex-shrink: 0;
  position: relative;
  z-index: 2;
}

html.capacitor-native .cap-native-menu-btn {
  display: flex !important;
  align-items: center;
  justify-content: center;
  min-width: 2.75rem;
  min-height: 2.75rem;
  border: 0;
  background: transparent;
  color: #fff;
  cursor: pointer;
  pointer-events: auto;
  touch-action: manipulation;
  -webkit-tap-highlight-color: transparent;
}

.cap-native-menu-btn {
  display: none;
}

.cap-native-header-actions {
  display: none;
}

/* Slide-out drawer */
.cap-native-drawer {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9992;
  pointer-events: none;
}

html.capacitor-native .cap-native-drawer.cap-native-drawer--visible {
  display: block !important;
  pointer-events: auto;
  z-index: 9995;
}

html.capacitor-native.cap-drawer-open {
  overflow: hidden;
}

html.capacitor-native.cap-drawer-open body.capacitor-native {
  overflow: hidden;
}

.cap-native-drawer-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 24, 39, 0.45);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.cap-native-drawer.cap-native-drawer--open .cap-native-drawer-backdrop {
  opacity: 1;
}

.cap-native-drawer-panel {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  width: min(20rem, 88vw);
  background: #fff;
  box-shadow: -4px 0 24px rgba(0, 0, 0, 0.12);
  display: flex;
  flex-direction: column;
  transform: translate3d(100%, 0, 0);
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
  will-change: transform;
  overflow: hidden;
  padding-right: var(--cap-safe-right);
  padding-bottom: var(--cap-safe-bottom);
  box-sizing: border-box;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.cap-native-drawer.cap-native-drawer--open .cap-native-drawer-panel {
  transform: translate3d(0, 0, 0);
}

.cap-native-drawer-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  min-height: var(--cap-header-total);
  padding: var(--cap-status-padding) 1rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.14);
  background: var(--cap-brand);
  color: #fff;
  flex-shrink: 0;
  box-sizing: border-box;
}

.cap-native-drawer-title {
  margin: 0;
  font-size: 1rem;
  font-weight: 600;
}

.cap-native-drawer-close {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  color: #fff;
  padding: 0.25rem;
  cursor: pointer;
}

.cap-native-drawer-nav {
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0.5rem 0 1rem;
}

.cap-native-drawer-section {
  margin: 0;
  padding: 0.75rem 1rem 0.35rem;
  font-size: 0.6875rem;
  font-weight: 600;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: #6b7280;
}

.cap-native-drawer-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 0.8rem 1rem;
  font-size: 0.9375rem;
  color: #374151 !important;
  text-decoration: none;
  border: 0;
  background: transparent;
  text-align: left;
  cursor: pointer;
}

.cap-native-drawer-link.active {
  color: var(--cap-brand) !important;
  font-weight: 600;
  background: #f0f7f4;
}

.cap-native-drawer-button {
  font-family: inherit;
}

.cap-native-drawer-divider {
  height: 1px;
  margin: 0.5rem 1rem;
  background: #e5e7eb;
}

.cap-native-drawer-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.25rem;
  height: 1.25rem;
  padding: 0 0.35rem;
  border-radius: 9999px;
  background: #ef4444;
  color: #fff;
  font-size: 0.6875rem;
  font-weight: 700;
}

html.capacitor-native #cap-native-header a,
html.capacitor-native #cap-native-header button,
html.capacitor-native #cap-native-header span {
  color: #fff !important;
}

html.capacitor-native #cap-native-header svg circle,
html.capacitor-native #cap-native-header svg path {
  stroke: #fff !important;
}

html.capacitor-native #cap-native-header .text-gray-400 {
  color: rgba(255, 255, 255, 0.65) !important;
}

html.capacitor-native #cap-native-header.bg-white {
  background-color: var(--cap-brand) !important;
}

html.capacitor-native #mobile-menu,
html.capacitor-native .cap-native-web-only {
  display: none !important;
}

.cap-native-only {
  display: none !important;
}

html.capacitor-native .cap-native-only.cap-native-drawer-link {
  display: flex !important;
}

html.capacitor-native .cap-native-only.cap-welcome-create-btn {
  display: block !important;
}

html.capacitor-native .cap-native-only.cap-dashboard-new-btn {
  display: inline-block !important;
}

html.capacitor-native .cap-native-new-case-type-card {
  min-height: 3.25rem;
}

html.capacitor-native .cap-native-new-case-type-card:active {
  transform: scale(0.99);
}

html.capacitor-native .cap-agreement-type .grid {
  gap: 1rem;
}

html.capacitor-native .cap-agreement-type button[type='submit'] {
  min-height: 3.25rem;
}

html.capacitor-native .cap-agreement-type .cap-agreement-card {
  border-radius: 1rem;
}

html.capacitor-native main.max-w-6xl:has(.cap-agreement-type),
html.capacitor-native main.max-w-6xl:has(.cap-create-case) {
  padding-top: 0.5rem;
}

.cap-native-cases-title {
  display: none;
}

html.capacitor-native .cap-native-cases-title {
  display: inline;
}

body.capacitor-native .cap-native-iap-placeholder {
  display: block !important;
}

body.capacitor-native footer.border-t.border-gray-200,
body.capacitor-native .site-footer {
  display: none !important;
}

.cap-native-tab-bar {
  display: none;
  position: fixed;
  inset: auto 0 0 0;
  width: 100%;
  z-index: 9990;
  box-sizing: border-box;
  margin: 0;
  padding: 0 0 var(--cap-safe-bottom);
  background: rgba(255, 255, 255, 0.98);
  border-top: 1px solid #e5e7eb;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  transform: translate3d(0, 0, 0);
  -webkit-transform: translate3d(0, 0, 0);
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
}

body.capacitor-native .cap-native-tab-bar,
html.capacitor-native .cap-native-tab-bar {
  display: block;
}

.cap-native-tab-bar-inner {
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  align-items: stretch;
  width: 100%;
  height: var(--cap-tab-bar-height);
  max-height: var(--cap-tab-bar-height);
  padding-left: var(--cap-safe-left);
  padding-right: var(--cap-safe-right);
  box-sizing: border-box;
  overflow: hidden;
}

.cap-native-tab-bar a[hidden],
.cap-native-tab-bar button[hidden] {
  display: none !important;
}

.cap-native-tab-bar a,
.cap-native-tab-bar button {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 0.1rem;
  flex: 1 1 0%;
  min-width: 0;
  max-width: 100%;
  font-size: 0.625rem;
  font-weight: 500;
  color: #6b7280;
  text-decoration: none;
  border: 0;
  background: transparent;
  padding: 0.25rem 0.125rem 0.15rem;
  min-height: var(--cap-tab-bar-height);
  overflow: hidden;
}

.cap-native-tab-bar a span,
.cap-native-tab-bar button span {
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.1;
}

.cap-native-tab-bar a.active,
.cap-native-tab-bar button.active {
  color: var(--cap-brand);
}

.cap-native-tab-bar svg {
  width: 1.35rem;
  height: 1.35rem;
}

.cap-native-iap-placeholder {
  display: none;
  border: 1px solid #c4d9d3;
  background: #f0f7f4;
  border-radius: 0.75rem;
  padding: 1rem;
}

.cap-native-iap-placeholder h3 {
  font-size: 0.95rem;
  font-weight: 600;
  color: #1f2937;
  margin: 0 0 0.35rem;
}

.cap-native-iap-placeholder p {
  font-size: 0.75rem;
  color: #4b5563;
  margin: 0 0 0.75rem;
  line-height: 1.45;
}

.cap-native-iap-placeholder button {
  width: 100%;
  border: 0;
  border-radius: 0.5rem;
  background: var(--cap-brand);
  color: #fff;
  font-size: 0.875rem;
  font-weight: 600;
  padding: 0.65rem 1rem;
}

.cap-native-iap-placeholder button:disabled {
  opacity: 0.55;
}

body.capacitor-native .cap-case-subnav {
  display: none !important;
}

body.capacitor-native main.max-w-6xl {
  padding-bottom: 1rem;
}

/* Children list — cards on iOS instead of wide table */
.cap-children-cards {
  display: none;
}

@media (max-width: 768px) {
  .cap-children-cards {
    display: block;
  }

  .cap-children-table-wrap {
    display: none !important;
  }

  .cap-children-header {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .cap-children-add-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.75rem;
    text-align: center;
  }

  .cap-children-card-meta {
    grid-template-columns: 1fr;
  }
}

html.capacitor-native .cap-children-cards {
  display: block;
}

html.capacitor-native .cap-children-table-wrap {
  display: none !important;
}

html.capacitor-native .cap-children-header {
  flex-direction: column;
  align-items: stretch;
  gap: 0.75rem;
}

html.capacitor-native .cap-children-add-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 2.75rem;
  text-align: center;
}

html.capacitor-native .cap-children-card {
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.04);
}

html.capacitor-native .cap-children-card-actions a,
html.capacitor-native .cap-children-card-actions button {
  min-height: 2.75rem;
  padding: 0.5rem 0.25rem;
}

html.capacitor-native .cap-children-card-meta {
  grid-template-columns: 1fr;
}

html.capacitor-native .cap-section-children-list li {
  flex-direction: column;
  align-items: flex-start !important;
  gap: 0.35rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid #f3f4f6;
}

html.capacitor-native .cap-section-children-list li:last-child {
  border-bottom: 0;
}

html.capacitor-native .cap-section-children-list span:last-child {
  text-align: left;
  line-height: 1.4;
}

/* Dashboard / cases list — touching rows, full-row tap targets */
@media (max-width: 768px) {
  .cap-dashboard-header {
    flex-direction: column;
    align-items: stretch;
    gap: 0.75rem;
  }

  .cap-dashboard-new-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    min-height: 2.75rem;
    text-align: center;
  }

  .cap-case-list {
    display: flex;
    flex-direction: column;
    gap: 0 !important;
    border: 1px solid #e5e7eb;
    border-radius: 0.75rem;
    overflow: hidden;
    background: #fff;
  }

  .cap-case-list-item {
    border: 0 !important;
    border-radius: 0 !important;
    border-bottom: 1px solid #e5e7eb !important;
    margin: 0;
    min-height: 4.5rem;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  .cap-case-list-item:last-child {
    border-bottom: 0 !important;
  }

  .cap-case-list-item:active {
    background: #f9fafb;
  }
}

html.capacitor-native .cap-dashboard-header {
  flex-direction: column;
  align-items: stretch;
  gap: 0.75rem;
}

html.capacitor-native .cap-dashboard-new-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 2.75rem;
  text-align: center;
}

html.capacitor-native .cap-case-list {
  display: flex;
  flex-direction: column;
  gap: 0 !important;
  border: 1px solid #e5e7eb;
  border-radius: 0.75rem;
  overflow: hidden;
  background: #fff;
}

html.capacitor-native .cap-case-list-item {
  border: 0 !important;
  border-radius: 0 !important;
  border-bottom: 1px solid #e5e7eb !important;
  margin: 0;
  min-height: 4.5rem;
  color: inherit;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

html.capacitor-native .cap-case-list-item:last-child {
  border-bottom: 0 !important;
}

html.capacitor-native .cap-case-list-item:active {
  background: #f9fafb;
}

html.capacitor-native .cap-case-list-chevron {
  color: #9ca3af;
}

/* First-login welcome page */
.cap-welcome {
  padding: 1.5rem 0 2rem;
}

.cap-welcome-primary-btn {
  min-height: 2.75rem;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
}

.cap-welcome-modal {
  max-height: calc(100dvh - 1rem);
  overflow-y: auto;
  padding-bottom: env(safe-area-inset-bottom, 0);
}

@media (max-width: 768px) {
  .cap-welcome {
    padding-top: 1rem;
    min-height: calc(100dvh - 8rem);
    display: flex;
    flex-direction: column;
    justify-content: center;
  }

  .cap-welcome-modal {
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
  }
}

html.capacitor-native main.max-w-6xl:has(.cap-welcome) {
  padding-top: 1rem;
  padding-bottom: 1.5rem;
}

html.capacitor-native .cap-welcome {
  padding-top: 0.75rem;
  padding-bottom: 2rem;
  min-height: auto;
  display: block;
}

html.capacitor-native .cap-welcome-modal {
  padding-bottom: calc(env(safe-area-inset-bottom, 0) + 0.5rem);
  will-change: transform;
}

html.capacitor-native .cap-welcome-modal-shell {
  z-index: 9993;
  align-items: flex-end;
}

.cap-welcome-modal-enter,
.cap-welcome-modal-leave {
  transition-property: transform, opacity;
  transition-timing-function: cubic-bezier(0.32, 0.72, 0, 1);
}

.cap-welcome-modal-enter,
.cap-welcome-modal-leave {
  transition-duration: 320ms;
}

.cap-welcome-modal-enter-start,
.cap-welcome-modal-leave-end {
  transform: translate3d(0, 100%, 0);
  opacity: 1;
}

.cap-welcome-modal-enter-end,
.cap-welcome-modal-leave-start {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}

@media (min-width: 640px) {
  .cap-welcome-modal-enter-start,
  .cap-welcome-modal-leave-end {
    transform: translate3d(0, 1rem, 0);
    opacity: 0;
  }

  .cap-welcome-modal-enter-end,
  .cap-welcome-modal-leave-start {
    transform: translate3d(0, 0, 0);
    opacity: 1;
  }
}

html.capacitor-native .cap-welcome-modal-enter-start,
html.capacitor-native .cap-welcome-modal-leave-end {
  transform: translate3d(0, 100%, 0);
  opacity: 1;
}

html.capacitor-native .cap-welcome-modal-enter-end,
html.capacitor-native .cap-welcome-modal-leave-start {
  transform: translate3d(0, 0, 0);
  opacity: 1;
}

/* Native slide-up sheets (Support, Change Password) */
.cap-native-sheet {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 9994;
  pointer-events: none;
}

html.capacitor-native .cap-native-sheet.cap-native-sheet--visible {
  display: block;
  pointer-events: auto;
}

html.capacitor-native.cap-sheet-open {
  overflow: hidden;
}

html.capacitor-native.cap-sheet-open body.capacitor-native {
  overflow: hidden;
}

.cap-native-sheet-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(17, 24, 39, 0.45);
  opacity: 0;
  transition: opacity 0.3s ease;
}

.cap-native-sheet.cap-native-sheet--open .cap-native-sheet-backdrop {
  opacity: 1;
}

.cap-native-sheet-panel {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  max-height: min(92dvh, 44rem);
  background: #fff;
  border-top-left-radius: 1rem;
  border-top-right-radius: 1rem;
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.12);
  display: flex;
  flex-direction: column;
  transform: translate3d(0, 100%, 0);
  transition: transform 0.32s cubic-bezier(0.32, 0.72, 0, 1);
  padding-bottom: calc(var(--cap-safe-bottom) + 0.5rem);
  box-sizing: border-box;
}

.cap-native-sheet.cap-native-sheet--open .cap-native-sheet-panel {
  transform: translate3d(0, 0, 0);
}

.cap-native-sheet-handle {
  width: 2.5rem;
  height: 0.25rem;
  margin: 0.5rem auto 0;
  border-radius: 9999px;
  background: #d1d5db;
  flex-shrink: 0;
}

.cap-native-sheet-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 0.75rem 1rem 0.5rem;
  flex-shrink: 0;
}

.cap-native-sheet-title {
  margin: 0;
  font-size: 1.0625rem;
  font-weight: 600;
  color: #111827;
}

.cap-native-sheet-close {
  display: flex;
  align-items: center;
  justify-content: center;
  border: 0;
  background: transparent;
  color: #6b7280;
  padding: 0.25rem;
  cursor: pointer;
  min-width: 2.25rem;
  min-height: 2.25rem;
}

.cap-native-sheet-body {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  padding: 0.5rem 1rem 1rem;
  min-width: 0;
}

html.capacitor-native .cap-native-sheet-form {
  min-width: 0;
  max-width: 100%;
}

html.capacitor-native .cap-native-sheet-form > div {
  min-width: 0;
  max-width: 100%;
}

html.capacitor-native .cap-native-sheet-form input[type='date'],
html.capacitor-native .cap-native-sheet-form select {
  display: block;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

html.capacitor-native .cap-native-sheet-form input[type='date'] {
  -webkit-appearance: none;
  appearance: none;
}

html.capacitor-native .cap-native-sheet-form input[type='date']::-webkit-date-and-time-value {
  min-width: 0;
  width: 100%;
  text-align: left;
}

html.capacitor-native .cap-create-case input[type='date'],
html.capacitor-native .cap-create-case select {
  display: block;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  box-sizing: border-box;
}

html.capacitor-native .cap-create-case input[type='date'] {
  -webkit-appearance: none;
  appearance: none;
}

html.capacitor-native .cap-create-case input[type='date']::-webkit-date-and-time-value {
  min-width: 0;
  width: 100%;
  text-align: left;
}

.cap-native-sheet-form-message.cap-native-sheet-form-message--success {
  display: block;
  background: #ecfdf5;
  color: #047857;
}

.cap-native-sheet-form-message.cap-native-sheet-form-message--error {
  display: block;
  background: #fef2f2;
  color: #b91c1c;
}

.cap-native-sheet-field-error:not(.hidden) {
  display: block;
}

/* Full-screen PDF / image viewer */
.cap-native-file-viewer {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2147483646;
  flex-direction: column;
  background: #111827;
}

.cap-native-file-viewer.cap-native-file-viewer--open {
  display: flex !important;
}

html.capacitor-native.cap-native-file-view-open #cap-native-tab-bar,
html.capacitor-native.cap-native-file-view-open #cap-native-header {
  visibility: hidden;
}

.cap-native-file-viewer-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2147483647;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  min-height: var(--cap-header-height);
  padding: calc(var(--cap-safe-top) + 0.25rem) calc(var(--cap-safe-right) + 0.5rem) 0.25rem calc(var(--cap-safe-left) + 0.5rem);
  background: var(--cap-brand);
  color: #ffffff;
  flex-shrink: 0;
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.12);
}

.cap-native-file-viewer-title {
  flex: 1;
  min-width: 0;
  font-size: 0.875rem;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  text-align: center;
}

.cap-native-file-viewer-close,
.cap-native-file-viewer-action {
  appearance: none;
  border: none;
  background: transparent;
  color: #ffffff;
  font-size: 1rem;
  font-weight: 600;
  padding: 0.625rem 0.5rem;
  flex-shrink: 0;
  min-width: 3.25rem;
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
}

.cap-native-file-viewer-action {
  justify-content: flex-end;
}

.cap-native-file-viewer-body {
  position: fixed;
  top: calc(var(--cap-safe-top) + var(--cap-header-height));
  left: var(--cap-safe-left);
  right: var(--cap-safe-right);
  bottom: var(--cap-safe-bottom);
  display: flex;
  align-items: center;
  justify-content: center;
  background: #111827;
}

.cap-native-file-viewer-image {
  display: block;
  max-width: 100%;
  max-height: 100%;
  object-fit: contain;
}

.cap-native-file-viewer-frame {
  display: block;
  width: 100%;
  height: 100%;
  border: none;
  background: #ffffff;
}

.cap-native-file-viewer-loading {
  position: absolute;
  color: rgba(255, 255, 255, 0.88);
  font-size: 0.9375rem;
}

.cap-native-file-viewer-image[hidden],
.cap-native-file-viewer-frame[hidden],
.cap-native-file-viewer-loading[hidden] {
  display: none !important;
}
