/* Debit Base final hardening layer: routing, narrow right menu, safe-area, compact work pages. */
:root {
  --db-final-right-menu-width: clamp(228px, 25vw, 262px);
  --db-final-safe-bottom: max(1rem, calc(env(safe-area-inset-bottom, 0px) + 1rem));
}

html.db-route-work .personal-greeting.surface,
html.db-route-work .personal-greeting {
  min-height: clamp(8.5rem, 18vw, 15rem) !important;
  padding-block: clamp(1rem, 2vw, 1.5rem) !important;
  background-size: auto 100% !important;
  background-position: center center !important;
}

html.db-route-work .personal-greeting h1 {
  font-size: clamp(1.45rem, 3vw, 2.25rem) !important;
}

html.db-route-work .brand-hero,
html.db-route-work .hero-image,
html.db-route-work [class*="brand-header"] {
  max-height: clamp(8.5rem, 20vw, 16rem) !important;
  object-fit: contain !important;
}

.period-drawer,
.period-drawer-backdrop {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.period-drawer-backdrop {
  background: rgba(7, 22, 48, 0.18) !important;
}

.period-drawer-panel,
.period-drawer-panel.db-final-right-menu-panel {
  left: auto !important;
  right: 0 !important;
  width: var(--db-final-right-menu-width) !important;
  max-width: calc(100vw - 32px) !important;
  min-width: 224px !important;
  transform-origin: right center !important;
  overflow: hidden !important;
}

.period-drawer-body.db-final-right-menu,
.period-drawer-body.debitbase-right-menu-refined {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.45rem !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  overscroll-behavior: contain !important;
  padding-bottom: max(5.4rem, calc(env(safe-area-inset-bottom, 0px) + 4.8rem)) !important;
}

.db-menu-account-card,
.db-period-chooser.db-final-period-chooser,
.db-period-chooser.db-menu-period-feature {
  flex: 0 0 auto !important;
  min-height: 44px !important;
}

.db-period-chooser.db-final-period-chooser,
.debitbase-right-menu-refined .db-period-chooser {
  contain: layout paint !important;
  transition: none !important;
  animation: none !important;
}

.db-period-chooser-head {
  min-height: 42px !important;
  padding: 0.52rem 0.5rem !important;
  align-items: center !important;
}

.db-period-chooser-title,
.db-period-chooser-hint,
.drawer-menu-item strong,
.drawer-menu-item span {
  animation: none !important;
  transition: none !important;
  transform: none !important;
  will-change: auto !important;
}

.db-period-chooser-toggle {
  width: 32px !important;
  height: 32px !important;
  min-width: 32px !important;
  min-height: 32px !important;
  flex: 0 0 32px !important;
}

.db-period-chooser-content:not([hidden]),
.db-final-period-content:not([hidden]) {
  display: flex !important;
  flex-direction: column !important;
  gap: 0.45rem !important;
  max-height: min(66vh, 560px) !important;
  min-height: min(42vh, 330px) !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  -webkit-overflow-scrolling: touch !important;
  overscroll-behavior: contain !important;
  padding: 0.45rem !important;
  pointer-events: auto !important;
}

.db-period-chooser-content[hidden] {
  display: none !important;
}

.db-period-chooser-content button,
.db-period-chooser-content select,
.db-period-chooser-content input {
  min-height: 40px !important;
  touch-action: manipulation !important;
}

.period-drawer .drawer-menu-item {
  min-height: 44px !important;
  padding-block: 0.42rem !important;
  padding-inline: 0.5rem !important;
}

.period-drawer .drawer-menu-item .menu-action,
.period-drawer .drawer-menu-item-removed,
.period-drawer .db-menu-my-area-lower-removed {
  display: none !important;
}

.period-drawer .db-menu-account-card {
  order: -30 !important;
}

.period-drawer .db-period-chooser {
  order: -20 !important;
}

.fab,
button.fab,
.floating-action-button {
  right: max(0.85rem, env(safe-area-inset-right, 0px)) !important;
  bottom: max(1rem, calc(env(safe-area-inset-bottom, 0px) + 1rem)) !important;
  z-index: 740 !important;
}

.fab-menu,
.quick-action-menu {
  right: max(0.85rem, env(safe-area-inset-right, 0px)) !important;
  bottom: max(5.9rem, calc(env(safe-area-inset-bottom, 0px) + 5.9rem)) !important;
  max-height: min(58vh, calc(100vh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 8rem)) !important;
  overflow-y: auto !important;
}

.fab-menu button:has(span),
.quick-action-menu button:has(span) {
  min-height: 44px !important;
}

.modal-backdrop .surface,
.modal-backdrop form,
.modal-backdrop [role="dialog"] {
  max-height: min(88vh, calc(100vh - env(safe-area-inset-top, 0px) - env(safe-area-inset-bottom, 0px) - 2rem)) !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

.modal-backdrop .button-row,
.modal-backdrop form > .button-row,
.modal-backdrop [class*="modal"] .button-row {
  position: sticky !important;
  bottom: 0 !important;
  z-index: 5 !important;
  background: linear-gradient(180deg, rgba(245,250,255,0.86), rgba(245,250,255,0.98)) !important;
  padding-block: 0.75rem !important;
  margin-bottom: calc(env(safe-area-inset-bottom, 0px) * 0.5) !important;
}

.db-date-input-stable::-webkit-calendar-picker-indicator {
  opacity: 0.85 !important;
  cursor: pointer !important;
}

.db-my-area-page .db-my-info-section,
.db-my-area-page .db-my-link-card em {
  display: none !important;
}

.db-my-area-page .db-my-hero-copy p:not(.eyebrow),
.db-my-section-head > p:not(.eyebrow) {
  max-width: 56rem !important;
}

.db-import-export-ready .db-final-tool-button {
  text-align: left !important;
  cursor: pointer !important;
}

.db-import-export-ready .db-final-tool-button:hover,
.db-import-export-ready .db-final-tool-button:focus-visible {
  transform: translateY(-1px) !important;
  border-color: rgba(10, 102, 255, 0.45) !important;
}

.db-final-toast {
  position: fixed;
  left: 50%;
  bottom: max(1rem, calc(env(safe-area-inset-bottom, 0px) + 1rem));
  transform: translate(-50%, 120%);
  z-index: 2000;
  max-width: min(92vw, 32rem);
  padding: 0.8rem 1rem;
  border-radius: 999px;
  background: #123d7c;
  color: #fff;
  box-shadow: 0 18px 38px rgba(16, 49, 96, 0.28);
  font-weight: 700;
  opacity: 0;
  pointer-events: none;
  transition: transform 0.18s ease, opacity 0.18s ease;
}

.db-final-toast.is-visible {
  opacity: 1;
  transform: translate(-50%, 0);
}

section:empty,
article:empty,
.surface:empty {
  display: none !important;
}

@media (max-width: 700px) {
  :root { --db-final-right-menu-width: min(280px, calc(100vw - 44px)); }

  html.db-route-work .personal-greeting.surface,
  html.db-route-work .personal-greeting {
    min-height: clamp(6.75rem, 24vw, 10rem) !important;
    background-size: auto 100% !important;
  }

  .period-drawer-panel,
  .period-drawer-panel.db-final-right-menu-panel {
    width: min(280px, calc(100vw - 44px)) !important;
    max-width: calc(100vw - 44px) !important;
  }

  .db-period-chooser-content:not([hidden]),
  .db-final-period-content:not([hidden]) {
    max-height: min(62vh, 520px) !important;
    min-height: min(44vh, 360px) !important;
  }

  .fab,
  button.fab,
  .floating-action-button {
    bottom: max(4.4rem, calc(env(safe-area-inset-bottom, 0px) + 4.2rem)) !important;
  }

  .fab-menu,
  .quick-action-menu {
    bottom: max(9rem, calc(env(safe-area-inset-bottom, 0px) + 8.8rem)) !important;
  }
}

/* Debit Base Agent-Final: exact narrow right menu, no active marker, no quick categories. */
.period-drawer .drawer-menu-item.active,
.period-drawer .drawer-menu-item.active:hover,
.period-drawer .drawer-menu-item[aria-current="page"],
.period-drawer .drawer-menu-item[aria-selected="true"] {
  background: rgba(255,255,255,0.72) !important;
  color: inherit !important;
  box-shadow: none !important;
  border-color: rgba(132, 180, 236, 0.42) !important;
}
.period-drawer .drawer-menu-item.active .drawer-menu-icon,
.period-drawer .drawer-menu-item.active .drawer-menu-item-main strong,
.period-drawer .drawer-menu-item.active .menu-label > span {
  color: inherit !important;
  filter: none !important;
}
.period-drawer .drawer-menu-item-removed,
.period-drawer .db-menu-my-area-lower-removed,
.period-drawer button.drawer-menu-item[aria-hidden="true"] {
  display: none !important;
}
.period-drawer-panel.db-final-right-menu-panel,
.period-drawer-panel {
  right: 0 !important;
  left: auto !important;
  max-height: calc(100dvh - env(safe-area-inset-top, 0px)) !important;
}
.period-drawer-body.db-final-right-menu,
.period-drawer-body.debitbase-right-menu-refined {
  padding-bottom: calc(env(safe-area-inset-bottom, 0px) + 5.8rem) !important;
}
.db-period-chooser-content:not([hidden]),
.db-final-period-content:not([hidden]) {
  max-height: min(68dvh, 590px) !important;
}
.quick-action-menu button,
.fab-menu button {
  scroll-margin-bottom: calc(env(safe-area-inset-bottom, 0px) + 7rem) !important;
}
.quick-action-menu button:is([aria-label*="Kategorie" i]),
.quick-action-menu a:is([aria-label*="Kategorie" i]),
.fab-menu button:is([aria-label*="Kategorie" i]),
.fab-menu a:is([aria-label*="Kategorie" i]) {
  display: none !important;
}
/* Keep functional pages compact without modifying bear artwork. */
html.db-route-work .brand-header,
html.db-route-work img[src*="brand-header"],
html.db-route-work .personal-greeting img,
html.db-route-work .hero img {
  object-fit: contain !important;
}
