:root {
  color-scheme: dark light;
  --pwa-bg: #05152f;
  --pwa-cyan: #00e7f0;
  --pwa-white: #ffffff;
  --pwa-glass: rgba(255, 255, 255, 0.08);
}

html,
body {
  width: 100%;
  min-height: 100%;
  overscroll-behavior: none;
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

body {
  min-height: 100dvh;
  overflow: hidden;
  touch-action: pan-x pan-y;
}

.main {
  height: 100dvh;
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding-top: max(20px, env(safe-area-inset-top));
  padding-right: max(20px, env(safe-area-inset-right));
  padding-bottom: max(20px, env(safe-area-inset-bottom));
  padding-left: max(20px, env(safe-area-inset-left));
}

.sidebar {
  min-height: 100dvh;
  padding-top: max(18px, env(safe-area-inset-top));
  padding-left: max(16px, env(safe-area-inset-left));
  padding-bottom: max(18px, env(safe-area-inset-bottom));
}

input,
textarea,
select,
button,
a {
  font: inherit;
}

@media (display-mode: standalone) {
  body {
    background-color: var(--pwa-bg);
  }
}

.pwa-loader {
  position: fixed;
  inset: 0;
  z-index: 2147483647;
  display: grid;
  place-items: center;
  overflow: hidden;
  padding: max(24px, env(safe-area-inset-top)) max(24px, env(safe-area-inset-right)) max(24px, env(safe-area-inset-bottom)) max(24px, env(safe-area-inset-left));
  background:
    radial-gradient(circle at 50% 24%, rgba(0, 231, 240, 0.20), rgba(0, 231, 240, 0.00) 34%),
    linear-gradient(145deg, #05152f 0%, #061a3b 48%, #020a19 100%);
  color: var(--pwa-white);
  opacity: 1;
  visibility: visible;
  transition: opacity 480ms ease, visibility 480ms ease;
}

.pwa-loader__halo {
  position: absolute;
  width: min(72vw, 520px);
  aspect-ratio: 1;
  border-radius: 999px;
  border: 1px solid rgba(0, 231, 240, 0.20);
  box-shadow: 0 0 80px rgba(0, 231, 240, 0.16), inset 0 0 60px rgba(255, 255, 255, 0.04);
  animation: pwaHalo 5s cubic-bezier(.2,.8,.2,1) forwards;
}

.pwa-loader__panel {
  position: relative;
  display: flex;
  width: min(88vw, 380px);
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 34px 28px 30px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,0.10), rgba(255,255,255,0.04));
  box-shadow: 0 28px 80px rgba(0,0,0,0.38), inset 0 1px 0 rgba(255,255,255,0.12);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  animation: pwaPanel 620ms ease both;
}

.pwa-loader__logo {
  width: 148px;
  height: 148px;
  object-fit: contain;
  filter: drop-shadow(0 18px 30px rgba(0,0,0,0.35));
}

.pwa-loader__brand {
  margin-top: 4px;
  font-size: 1.25rem;
  font-weight: 800;
  letter-spacing: -0.025em;
}

.pwa-loader__title {
  font-size: 0.92rem;
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.78);
}

.pwa-loader__subtitle {
  font-size: 0.86rem;
  color: rgba(255, 255, 255, 0.62);
  text-align: center;
}

.pwa-loader__progress {
  position: relative;
  width: 100%;
  height: 5px;
  margin-top: 18px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
}

.pwa-loader__progress span {
  position: absolute;
  inset: 0 auto 0 0;
  width: 100%;
  transform-origin: left center;
  transform: scaleX(0);
  border-radius: inherit;
  background: linear-gradient(90deg, #ffffff, #39fbff);
  box-shadow: 0 0 22px rgba(57, 251, 255, 0.55);
  animation: pwaProgress 5s linear forwards;
}

body:not(.pwa-loading) .pwa-loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

@keyframes pwaProgress {
  to { transform: scaleX(1); }
}

@keyframes pwaPanel {
  from { opacity: 0; transform: translateY(18px) scale(0.98); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

@keyframes pwaHalo {
  0% { transform: scale(0.92); opacity: 0.28; }
  45% { opacity: 0.75; }
  100% { transform: scale(1.06); opacity: 0.18; }
}

@media (prefers-reduced-motion: reduce) {
  .pwa-loader,
  .pwa-loader__halo,
  .pwa-loader__panel,
  .pwa-loader__progress span {
    animation-duration: 1ms;
    transition-duration: 1ms;
  }
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  body {
    min-height: 100svh;
  }

  .main,
  .sidebar {
    height: 100svh;
  }

  .pwa-loader__panel {
    border-radius: 24px;
    padding: 30px 24px 26px;
  }

  .pwa-loader__logo {
    width: 132px;
    height: 132px;
  }
}


/* === HelpRate AI mobile responsive fixes - universal Android/iOS build === */
/* Previous brand-loader requirement: logo only, no text/progress, light panel, slow pulse. */
.pwa-loader {
  background: #05152f !important;
}
.pwa-loader__halo,
.pwa-loader__brand,
.pwa-loader__title,
.pwa-loader__subtitle,
.pwa-loader__progress {
  display: none !important;
}
.pwa-loader__panel {
  width: auto !important;
  padding: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  animation: none !important;
}
.pwa-loader__logo {
  width: min(48vw, 230px) !important;
  height: auto !important;
  aspect-ratio: 1 / 1 !important;
  object-fit: contain !important;
  display: block !important;
  transform: translateZ(0) scale(1);
  transform-origin: center center;
  animation: helpcoreLogoHeartbeat 3s ease-in-out infinite !important;
  will-change: transform, opacity;
  box-shadow: none !important;
  filter: none !important;
  border: 0 !important;
  background: transparent !important;
}
@keyframes helpcoreLogoHeartbeat {
  0% { transform: translateZ(0) scale(1); opacity: 0.94; }
  18% { transform: translateZ(0) scale(1.055); opacity: 1; }
  32% { transform: translateZ(0) scale(1); opacity: 0.96; }
  46% { transform: translateZ(0) scale(1.035); opacity: 1; }
  64%, 100% { transform: translateZ(0) scale(1); opacity: 0.94; }
}
@media (prefers-reduced-motion: reduce) {
  .pwa-loader__logo {
    animation: none !important;
  }
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    overscroll-behavior: none !important;
    -webkit-text-size-adjust: 100% !important;
  }

  body {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100svh !important;
    overflow: hidden !important;
    touch-action: pan-x pan-y !important;
  }

  .sidebar {
    position: relative !important;
    z-index: 1000 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: min(76svh, 640px) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    padding: max(12px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 14px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22) !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 10px !important;
  }

  .sidebar .brand {
    width: 100% !important;
    min-height: var(--hamburger-size) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name {
    min-width: 0 !important;
    white-space: normal !important;
  }

  .sidebar-toggle-btn {
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
  }

  .nav,
  .nav-bottom {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin-top: 8px !important;
    padding-top: 0 !important;
    border-top: 0 !important;
  }

  .nav-link,
  .nav-sublink {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
    font-size: 0.94rem !important;
    line-height: 1.22 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    text-align: left !important;
    -webkit-user-select: none !important;
    user-select: none !important;
  }

  .nav-link span,
  .nav-text,
  .hf-io-btn span {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    opacity: 1 !important;
    overflow: visible !important;
  }

  .submenu-toggle {
    display: none !important;
  }

  .submenu,
  .submenu.open {
    display: flex !important;
    width: 100% !important;
    flex-direction: column !important;
    gap: 8px !important;
    margin: 0 !important;
    padding-left: 10px !important;
  }

  .hf-io-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 2px 0 0 0 !important;
  }

  .hf-io-btn {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 44px !important;
    justify-content: center !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
    font-size: 0.86rem !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: auto !important;
    bottom: auto !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: none !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: max(10px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) 0 0 !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    pointer-events: none !important;
  }

  body.sidebar-collapsed .sidebar .brand {
    width: auto !important;
    min-height: 0 !important;
    justify-content: flex-end !important;
    pointer-events: none !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    pointer-events: auto !important;
    margin: 0 !important;
    box-shadow: 0 10px 24px rgba(0, 114, 255, 0.38), inset 0 1px 0 rgba(255,255,255,0.34) !important;
  }

  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .nav-bottom,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
  }

  .main {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
    height: auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 14px max(14px, env(safe-area-inset-right)) max(18px, env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left)) !important;
  }

  body.sidebar-collapsed .main {
    height: 100svh !important;
    padding-top: max(70px, calc(env(safe-area-inset-top) + 62px)) !important;
  }

  .main-header,
  .guide-hero {
    width: 100% !important;
    min-width: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 12px !important;
    margin-bottom: 18px !important;
  }

  .main-header .title-block,
  .title-block,
  .guide-hero-left {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    flex: 0 1 auto !important;
  }

  .title-block h1,
  .title-block h1.dashboard-hero-title,
  .guide-hero h1,
  .guide-hero-left h1 {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 0 7px 0 !important;
    font-size: clamp(1.12rem, 5.2vw, 1.42rem) !important;
    line-height: 1.18 !important;
    letter-spacing: -0.025em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    hyphens: auto !important;
    text-wrap: pretty;
  }

  .title-block p,
  .guide-hero p,
  .guide-hero-left p {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    margin: 0 !important;
    font-size: clamp(0.88rem, 3.8vw, 1rem) !important;
    line-height: 1.42 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    hyphens: auto !important;
  }

  .header-actions,
  #globalHeaderActions {
    width: 100% !important;
    min-width: 0 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    align-items: stretch !important;
    justify-content: stretch !important;
  }

  .header-actions .btn-primary,
  #globalHeaderActions .btn-primary,
  .btn-save-main,
  .btn-delete-main {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 42px !important;
    padding: 10px 8px !important;
    font-size: 0.72rem !important;
    line-height: 1.15 !important;
    white-space: normal !important;
  }

  .dashboard-grid,
  .dashboard-layout,
  .loan-form-grid {
    width: 100% !important;
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .card,
  .loans-stack,
  .page,
  table {
    max-width: 100% !important;
  }
}


/* === HelpRate AI - smartphone sidebar/mobile menu patch v1.0.3 === */
@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  /* Mobile-only navigation order: Import/Export must stay above Dashboard. */
  .nav {
    display: flex !important;
    flex-direction: column !important;
  }

  .nav > .hf-io-row {
    order: -30 !important;
    margin: 0 0 8px 0 !important;
  }

  .nav > .nav-link[data-page="dashboard"] {
    order: -20 !important;
  }

  .nav > #navPlanning,
  .nav > .nav-parent[data-page="planning"] {
    order: -10 !important;
  }

  .nav > #submenuPlanning,
  .nav > .submenu[data-parent="planning"] {
    order: -9 !important;
  }

  /* Restore the same Planning submenu logic as desktop on smartphone. */
  .submenu-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 32px !important;
    min-height: 32px !important;
    margin-left: auto !important;
    padding: 0 !important;
    border-radius: 10px !important;
    background: transparent !important;
  }

  #submenuPlanning,
  .submenu[data-parent="planning"] {
    display: none !important;
    width: 100% !important;
    flex-direction: column !important;
    gap: 7px !important;
    margin: -2px 0 2px 0 !important;
    padding: 0 0 0 14px !important;
    border-left: 1px solid rgba(255, 255, 255, 0.13) !important;
  }

  #submenuPlanning.open,
  .submenu[data-parent="planning"].open {
    display: flex !important;
  }

  #submenuPlanning .nav-sublink,
  .submenu[data-parent="planning"] .nav-sublink {
    padding-left: 14px !important;
    font-size: 0.9rem !important;
    border-radius: 12px !important;
  }

  /* Collapsed mobile sidebar must keep the title row visible; hide only menu/content. */
  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    z-index: 1000 !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    overflow: visible !important;
    padding: max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: none !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .nav-bottom,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
  }

  body.sidebar-collapsed .main {
    height: 100svh !important;
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
  }

  /* Remove the highlighted/focus/press effect on hamburger after auto-closing the menu. */
  .sidebar-toggle-btn,
  .sidebar-toggle-btn:hover,
  .sidebar-toggle-btn:active,
  .sidebar-toggle-btn:focus,
  .sidebar-toggle-btn:focus-visible,
  body.sidebar-collapsed .sidebar-toggle-btn,
  body.sidebar-collapsed .sidebar-toggle-btn:hover,
  body.sidebar-collapsed .sidebar-toggle-btn:active,
  body.sidebar-collapsed .sidebar-toggle-btn:focus,
  body.sidebar-collapsed .sidebar-toggle-btn:focus-visible {
    transform: none !important;
    outline: none !important;
    filter: none !important;
    box-shadow: none !important;
    -webkit-tap-highlight-color: transparent !important;
  }
}

/* === HelpRate AI responsive smartphone requested changes v1.0.4 === */
@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  /* Dashboard > Riepilogo Flussi Mensili: equal, larger spacing between the three internal cards. */
  #page-dashboard .dashboard-flows {
    display: flex !important;
    flex-direction: column !important;
  }

  #page-dashboard .dashboard-flows .quick-main {
    margin-top: 0 !important;
  }

  #page-dashboard .dashboard-flows .quick-main + .quick-main,
  #page-dashboard .dashboard-flows .dash-capacity-box {
    margin-top: 32px !important;
  }

  /* Pianificazione > DTI stimato: more space before the capacity card. */
  #page-planning .dti-card .capacity-box {
    margin-top: 48px !important;
  }

  /* Smartphone tables: keep page width fixed and enable horizontal table scroll. */
  #page-rentals .card > div[style*="overflow-x:auto"],
  #page-recurring .card > div[style*="overflow-x:auto"],
  #page-loans .card > div[style*="overflow-x:auto"],
  #page-ai .card > div[style*="overflow-x:auto"] {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    touch-action: pan-x pan-y !important;
  }

  #page-rentals table,
  #page-recurring table,
  #page-loans table,
  #page-ai table {
    width: max-content !important;
    min-width: max-content !important;
    max-width: none !important;
    table-layout: auto !important;
  }

  /* Reddito Locazioni: +70% columns, +100% only Start/End. */
  #page-rentals table th,
  #page-rentals table td,
  #page-recurring table th,
  #page-recurring table td,
  #page-loans table th,
  #page-loans table td {
    min-width: 170px !important;
    white-space: nowrap !important;
  }

  #page-rentals table th:nth-child(4),
  #page-rentals table td:nth-child(4),
  #page-rentals table th:nth-child(5),
  #page-rentals table td:nth-child(5),
  #page-recurring table th:nth-child(4),
  #page-recurring table td:nth-child(4),
  #page-recurring table th:nth-child(5),
  #page-recurring table td:nth-child(5),
  #page-loans table th:nth-child(8),
  #page-loans table td:nth-child(8),
  #page-loans table th:nth-child(9),
  #page-loans table td:nth-child(9) {
    min-width: 200px !important;
  }

  /* Consigli Intelligenti AI: +70% all columns except PRIORITÀ. */
  #page-ai table th,
  #page-ai table td {
    white-space: nowrap !important;
  }

  #page-ai table th:first-child,
  #page-ai table td:first-child {
    min-width: 86px !important;
    width: 86px !important;
  }

  #page-ai table th:not(:first-child),
  #page-ai table td:not(:first-child) {
    min-width: 170px !important;
  }
}

/* === HelpRate AI - universal Android/iOS smartphone date field separation patch v2.0.0 === */
@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  /* Keep the INIZIO/FINE input columns physically separated on every mobile browser. */
  #page-rentals table th:nth-child(4),
  #page-rentals table td:nth-child(4),
  #page-rentals table th:nth-child(5),
  #page-rentals table td:nth-child(5),
  #page-recurring table th:nth-child(4),
  #page-recurring table td:nth-child(4),
  #page-recurring table th:nth-child(5),
  #page-recurring table td:nth-child(5),
  #page-loans table th:nth-child(8),
  #page-loans table td:nth-child(8),
  #page-loans table th:nth-child(9),
  #page-loans table td:nth-child(9) {
    min-width: 242px !important;
    width: 242px !important;
    box-sizing: border-box !important;
    overflow: hidden !important;
  }

  #page-rentals #rentalInputRow td:nth-child(4),
  #page-recurring #recurringInputRow td:nth-child(4),
  #page-loans #loanInputRow td:nth-child(8) {
    padding-left: 16px !important;
    padding-right: 24px !important;
  }

  #page-rentals #rentalInputRow td:nth-child(5),
  #page-recurring #recurringInputRow td:nth-child(5),
  #page-loans #loanInputRow td:nth-child(9) {
    padding-left: 24px !important;
    padding-right: 16px !important;
  }

  #page-rentals #rentalInputRow td:nth-child(4) .table-input,
  #page-rentals #rentalInputRow td:nth-child(5) .table-input,
  #page-recurring #recurringInputRow td:nth-child(4) .table-input,
  #page-recurring #recurringInputRow td:nth-child(5) .table-input,
  #page-loans #loanInputRow td:nth-child(8) .table-input,
  #page-loans #loanInputRow td:nth-child(9) .table-input {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box !important;
    -webkit-appearance: none !important;
    appearance: none !important;
  }
}

/* === HelpRate AI - mobile AI debt strategy badge hide patch v1.0.6 === */
@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  /* Smartphone Android/iOS: hide only the Avalanche / Snowball badge in the AI debt optimization card. */
  #page-ai .card-title-row > .pill[data-i18n="k085"] {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
    flex: 0 0 0 !important;
  }
}

@supports (-webkit-touch-callout: none) {
  @media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
    #page-ai .card-title-row > .pill[data-i18n="k085"] {
      display: none !important;
    }
  }
}

/* === HelpRate AI - universal Android/iOS landscape viewport parity patch v2.0.0 === */
@media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100% !important;
    height: auto !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: auto !important;
    -webkit-text-size-adjust: 100% !important;
  }

  body {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100vh !important;
    min-height: 100svh !important;
    height: auto !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
    padding: 0 !important;
    margin: 0 !important;
    touch-action: pan-x pan-y !important;
  }

  .sidebar,
  body.sidebar-collapsed .sidebar {
    display: none !important;
    visibility: hidden !important;
    position: absolute !important;
    inset: 0 auto auto 0 !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    flex: 0 0 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    box-shadow: none !important;
    overflow: hidden !important;
    pointer-events: none !important;
    transform: translateX(-120%) !important;
  }

  .main,
  body.sidebar-collapsed .main {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 100vh !important;
    min-height: 100svh !important;
    height: auto !important;
    max-height: none !important;
    margin: 0 !important;
    margin-left: 0 !important;
    padding-top: max(14px, env(safe-area-inset-top)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .main-header,
  .guide-hero {
    gap: 12px !important;
  }

  .card {
    padding: clamp(16px, 4vw, 20px) !important;
  }

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

@supports (-webkit-touch-callout: none) {
  @media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
    html,
    body {
      min-height: -webkit-fill-available !important;
    }

    body {
      min-height: 100svh !important;
    }

    .main,
    body.sidebar-collapsed .main {
      min-height: 100svh !important;
      padding-top: max(14px, env(safe-area-inset-top)) !important;
      padding-right: max(14px, env(safe-area-inset-right)) !important;
      padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
      padding-left: max(14px, env(safe-area-inset-left)) !important;
    }
  }
}

/* === HelpRate AI - universal Android/iOS landscape sidebar parity patch v2.0.0 === */
@media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    -webkit-text-size-adjust: 100% !important;
  }

  body {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100svh !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    touch-action: pan-x pan-y !important;
  }

  .sidebar {
    position: relative !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    flex: 0 0 auto !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: min(76svh, 640px) !important;
    margin: 0 !important;
    padding: max(12px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 14px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    pointer-events: auto !important;
  }

  .nav,
  .nav-bottom {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin-top: 8px !important;
    padding-top: 0 !important;
    border-top: 0 !important;
  }

  .hf-io-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 2px 0 0 0 !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: none !important;
    overflow: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .nav-bottom,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  .main,
  body.sidebar-collapsed .main {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 100svh !important;
    height: 100svh !important;
    max-height: none !important;
    margin: 0 !important;
    margin-left: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .main {
    padding-top: max(14px, env(safe-area-inset-top)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
  }

  body.sidebar-collapsed .main {
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
  }
}

@supports (-webkit-touch-callout: none) {
  @media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
    body.sidebar-collapsed .main {
      padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
    }
  }
}

/* === HelpRate AI - universal Android/iOS tablet sidebar/menu parity with smartphone v2.0.0 === */
@media (hover: none) and (pointer: coarse) and (min-width: 769px) and (max-width: 1366px) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    overscroll-behavior: none !important;
    -webkit-text-size-adjust: 100% !important;
  }

  body {
    display: flex !important;
    flex-direction: column !important;
    min-height: 100svh !important;
    height: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    touch-action: pan-x pan-y !important;
  }

  .sidebar {
    position: relative !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    flex: 0 0 auto !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: min(76svh, 640px) !important;
    margin: 0 !important;
    padding: max(12px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 14px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: 0 16px 34px rgba(0, 0, 0, 0.22) !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior: contain !important;
    -webkit-overflow-scrolling: touch !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  .sidebar .brand-copy,
  .sidebar .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    min-width: 46px !important;
    min-height: 46px !important;
    width: 46px !important;
    height: 46px !important;
    margin-left: auto !important;
    flex: 0 0 46px !important;
    pointer-events: auto !important;
  }

  .nav,
  .nav-bottom {
    width: 100% !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    margin-top: 8px !important;
    padding-top: 0 !important;
    border-top: 0 !important;
  }

  .nav-link,
  .nav-sublink {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
    font-size: 0.94rem !important;
    line-height: 1.22 !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: break-word !important;
    text-align: left !important;
    -webkit-user-select: none !important;
    user-select: none !important;
  }

  .nav-link span,
  .nav-text,
  .hf-io-btn span {
    display: inline !important;
    width: auto !important;
    max-width: none !important;
    opacity: 1 !important;
    overflow: visible !important;
  }

  .nav {
    display: flex !important;
    flex-direction: column !important;
  }

  .nav > .hf-io-row {
    order: -30 !important;
    margin: 0 0 8px 0 !important;
  }

  .nav > .nav-link[data-page="dashboard"] {
    order: -20 !important;
  }

  .nav > #navPlanning,
  .nav > .nav-parent[data-page="planning"] {
    order: -10 !important;
  }

  .nav > #submenuPlanning,
  .nav > .submenu[data-parent="planning"] {
    order: -9 !important;
  }

  .submenu-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 32px !important;
    min-height: 32px !important;
    margin-left: auto !important;
    padding: 0 !important;
    border-radius: 10px !important;
    background: transparent !important;
  }

  #submenuPlanning,
  .submenu[data-parent="planning"] {
    display: none !important;
    width: 100% !important;
    flex-direction: column !important;
    gap: 7px !important;
    margin: -2px 0 2px 0 !important;
    padding: 0 0 0 14px !important;
    border-left: 1px solid rgba(255, 255, 255, 0.13) !important;
  }

  #submenuPlanning.open,
  .submenu[data-parent="planning"].open {
    display: flex !important;
  }

  #submenuPlanning .nav-sublink,
  .submenu[data-parent="planning"] .nav-sublink {
    padding-left: 14px !important;
    font-size: 0.9rem !important;
    border-radius: 12px !important;
  }

  .hf-io-row {
    width: 100% !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
    margin: 2px 0 0 0 !important;
  }

  .hf-io-btn {
    width: 100% !important;
    min-width: 0 !important;
    min-height: 44px !important;
    justify-content: center !important;
    padding: 10px 12px !important;
    border-radius: 14px !important;
    font-size: 0.86rem !important;
  }

  body.sidebar-collapsed .sidebar {
    position: fixed !important;
    top: 0 !important;
    right: 0 !important;
    left: 0 !important;
    bottom: auto !important;
    z-index: 1000 !important;
    display: flex !important;
    visibility: visible !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    height: auto !important;
    min-height: 0 !important;
    max-height: none !important;
    flex: 0 0 auto !important;
    margin: 0 !important;
    padding: max(10px, env(safe-area-inset-top)) max(14px, env(safe-area-inset-right)) 10px max(14px, env(safe-area-inset-left)) !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;
    background: rgba(5, 7, 15, 0.98) !important;
    box-shadow: none !important;
    overflow: visible !important;
    pointer-events: auto !important;
    transform: none !important;
  }

  body.sidebar-collapsed .sidebar .brand {
    width: 100% !important;
    min-height: 46px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 12px !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .brand-copy,
  body.sidebar-collapsed .brand-name {
    display: block !important;
    opacity: 1 !important;
    width: auto !important;
    max-width: calc(100vw - 92px) !important;
    min-width: 0 !important;
    overflow: hidden !important;
    white-space: nowrap !important;
    text-overflow: ellipsis !important;
    pointer-events: auto !important;
  }

  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
    margin: 0 !important;
  }

  body.sidebar-collapsed .nav,
  body.sidebar-collapsed .nav-bottom,
  body.sidebar-collapsed .hf-io-row,
  body.sidebar-collapsed .sidebar-footer {
    display: none !important;
    visibility: hidden !important;
  }

  .main,
  body.sidebar-collapsed .main {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    min-height: 100svh !important;
    height: 100svh !important;
    max-height: none !important;
    margin: 0 !important;
    margin-left: 0 !important;
    overflow-x: hidden !important;
    overflow-y: auto !important;
    overscroll-behavior-y: contain !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .main {
    padding-top: max(14px, env(safe-area-inset-top)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
  }

  body.sidebar-collapsed .main {
    padding-top: max(82px, calc(env(safe-area-inset-top) + 72px)) !important;
    padding-right: max(14px, env(safe-area-inset-right)) !important;
    padding-bottom: max(18px, env(safe-area-inset-bottom)) !important;
    padding-left: max(14px, env(safe-area-inset-left)) !important;
  }

  .sidebar-toggle-btn,
  .sidebar-toggle-btn:hover,
  .sidebar-toggle-btn:active,
  .sidebar-toggle-btn:focus,
  .sidebar-toggle-btn:focus-visible,
  body.sidebar-collapsed .sidebar-toggle-btn,
  body.sidebar-collapsed .sidebar-toggle-btn:hover,
  body.sidebar-collapsed .sidebar-toggle-btn:active,
  body.sidebar-collapsed .sidebar-toggle-btn:focus,
  body.sidebar-collapsed .sidebar-toggle-btn:focus-visible {
    transform: none !important;
    outline: none !important;
    filter: none !important;
    box-shadow: none !important;
    -webkit-tap-highlight-color: transparent !important;
  }
}

@supports (-webkit-touch-callout: none) {
  @media (hover: none) and (pointer: coarse) and (min-width: 769px) and (max-width: 1366px) {
    html,
    body {
      min-height: -webkit-fill-available !important;
    }

    body {
      min-height: 100svh !important;
    }

    .main,
    body.sidebar-collapsed .main {
      min-height: 100svh !important;
    }
  }
}


/* === HelpRate AI - universal Android/iOS parity enforcement 2.0.1-universal-android-ios-no-doubletap-light-overlay-20260611 === */
:root {
  --hr-universal-mobile-topbar: 72px;
}

@media (max-width: 768px), (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    text-size-adjust: 100% !important;
    -webkit-text-size-adjust: 100% !important;
  }

  body {
    touch-action: pan-x pan-y !important;
    overscroll-behavior: none !important;
  }

  .sidebar,
  body.sidebar-collapsed .sidebar {
    left: 0 !important;
    right: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
  }

  .sidebar-toggle-btn,
  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
  }

  .nav,
  .nav-bottom,
  .hf-io-row {
    width: 100% !important;
  }

  .main,
  body.sidebar-collapsed .main {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }

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

  input[type="date"],
  input[type="number"],
  input[type="text"] {
    max-width: 100% !important;
    box-sizing: border-box !important;
    appearance: none !important;
    -webkit-appearance: none !important;
  }

  #page-rentals .table-scroll,
  #page-recurring .table-scroll,
  #page-loans .table-scroll,
  #page-ai .table-scroll {
    overflow-x: auto !important;
    overflow-y: visible !important;
    -webkit-overflow-scrolling: touch !important;
    overscroll-behavior-x: contain !important;
  }
}

@media (orientation: landscape) and (max-height: 500px) and (hover: none) and (pointer: coarse) {
  html,
  body {
    min-height: 100svh !important;
  }

  body.sidebar-collapsed .main {
    padding-top: max(82px, calc(env(safe-area-inset-top) + var(--hr-universal-mobile-topbar))) !important;
  }
}

@media (hover: none) and (pointer: coarse) and (min-width: 769px) and (max-width: 1366px) {
  html,
  body {
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100svh !important;
    overflow-x: hidden !important;
    text-size-adjust: 100% !important;
    -webkit-text-size-adjust: 100% !important;
  }

  .sidebar-toggle-btn,
  body.sidebar-collapsed .sidebar-toggle-btn {
    display: inline-flex !important;
    visibility: visible !important;
    pointer-events: auto !important;
    touch-action: manipulation !important;
  }

  .main,
  body.sidebar-collapsed .main {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
    -webkit-overflow-scrolling: touch !important;
  }
}


/* === HelpRate AI - universal double-tap lock prevention + light language/currency selectors 2.0.1 === */
html,
body,
.main,
.sidebar,
.nav-link,
.submenu-toggle,
.sidebar-toggle-btn,
button,
a,
input,
textarea,
select,
[role="button"] {
  touch-action: manipulation !important;
  -ms-touch-action: manipulation !important;
  -webkit-tap-highlight-color: transparent !important;
}

#overlayLangCurrency .hr-lc-light-container,
#overlayLangCurrency .hr-lc-light-container label,
#overlayLangCurrency #selectLanguage,
#overlayLangCurrency #selectCurrency,
#overlayLangCurrency #selectLanguage option,
#overlayLangCurrency #selectCurrency option {
  color-scheme: light !important;
}

#overlayLangCurrency .hr-lc-light-container {
  color: #141824 !important;
}

#overlayLangCurrency .hr-lc-light-container label {
  color: #141824 !important;
}

#overlayLangCurrency #selectLanguage,
#overlayLangCurrency #selectCurrency {
  appearance: auto !important;
  -webkit-appearance: menulist !important;
  background-color: #ffffff !important;
  color: #141824 !important;
  border-color: #d0d7f2 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.65) !important;
}

#overlayLangCurrency #selectLanguage option,
#overlayLangCurrency #selectCurrency option {
  background-color: #ffffff !important;
  color: #141824 !important;
}


/* === Accesso riservato PWA headless === */
body.auth-pending,
body.auth-locked {
  overflow: hidden;
}

body.auth-pending .sidebar,
body.auth-pending .main,
body.auth-locked .sidebar,
body.auth-locked .main {
  display: none !important;
}

body:not(.auth-ready) #overlayLangCurrency,
body:not(.auth-ready) #subentryModal,
body:not(.auth-ready) #appDialogOverlay {
  display: none !important;
}

.auth-gate {
  position: fixed;
  inset: 0;
  z-index: 2147482500;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: clamp(12px, 2.2vw, 28px);
  background:
    radial-gradient(circle at 16% 18%, rgba(76,111,255,0.42), transparent 30%),
    radial-gradient(circle at 82% 8%, rgba(18,198,167,0.28), transparent 29%),
    linear-gradient(135deg, #05152f 0%, #0B1020 52%, #101a3b 100%);
  color: #fff;
  overflow: hidden;
}

body.auth-ready .auth-gate {
  display: none !important;
}

.auth-shell {
  width: min(468px, 100%);
  max-height: calc(100dvh - clamp(24px, 4vw, 56px));
  display: flex;
  align-items: center;
  justify-content: center;
}

.auth-card {
  position: relative;
  width: 100%;
  align-self: center;
  overflow: hidden;
  padding: clamp(20px, 2.7vw, 34px);
  border: 1px solid rgba(255,255,255,0.14);
  border-radius: clamp(20px, 2vw, 28px);
  background: rgba(245,247,251,0.97);
  color: var(--color-text-main);
  text-align: center;
  box-shadow: 0 24px 70px rgba(0,0,0,0.36);
  backdrop-filter: blur(22px);
}

.auth-logo-row {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  margin-bottom: clamp(14px, 2vh, 24px);
}

.auth-logo {
  width: 58px;
  height: 58px;
  object-fit: contain;
  border-radius: 18px;
  box-shadow: 0 14px 28px rgba(76,111,255,0.18);
  background: #fff;
}

.auth-product {
  font-weight: 900;
  font-size: clamp(1rem, 0.4vw + 0.95rem, 1.2rem);
  letter-spacing: -0.04em;
}

.auth-kicker {
  margin-top: 2px;
  color: var(--color-primary);
  font-size: 0.74rem;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.auth-card h1 {
  font-size: clamp(1.45rem, 1.4vw + 1.1rem, 2.25rem);
  line-height: 1.03;
  letter-spacing: -0.055em;
  margin-bottom: 8px;
  text-wrap: balance;
}

.auth-lead {
  color: #60708f;
  font-size: clamp(0.88rem, 0.25vw + 0.82rem, 1rem);
  line-height: 1.45;
  margin-bottom: clamp(14px, 2vh, 22px);
}

.auth-lead:empty {
  display: none;
}

.auth-form {
  display: grid;
  gap: 11px;
}

.auth-field {
  display: grid;
  gap: 6px;
  text-align: left;
}

.auth-field[hidden] {
  display: none !important;
}

.auth-field label {
  color: #455371;
  font-size: 0.78rem;
  font-weight: 800;
}

.auth-field input {
  width: 100%;
  min-height: 46px;
  padding: 10px 13px;
  border: 1px solid #d3dcf3;
  border-radius: 14px;
  background: #fff;
  color: var(--color-text-main);
  font-size: 0.96rem;
  outline: none;
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}

.auth-field input:focus {
  border-color: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(76,111,255,0.13);
}

.auth-submit {
  min-height: 48px;
  margin-top: 2px;
  border: 0;
  border-radius: 16px;
  background: linear-gradient(135deg, var(--color-primary), #6C8CFF);
  color: #fff;
  font-weight: 900;
  font-size: 0.95rem;
  cursor: pointer;
  box-shadow: 0 14px 26px rgba(76,111,255,0.28);
  transition: transform 140ms ease, box-shadow 140ms ease, opacity 140ms ease;
}

.auth-submit:hover:not(:disabled) {
  transform: translateY(-1px);
  box-shadow: 0 18px 32px rgba(76,111,255,0.35);
}

.auth-submit:disabled,
.auth-link-button:disabled,
.auth-logout-btn:disabled {
  cursor: wait;
  opacity: 0.7;
}

.auth-actions {
  display: flex;
  justify-content: center;
  margin-top: 12px;
}

.auth-link-button {
  border: 0;
  background: transparent;
  color: var(--color-primary);
  font-size: 0.82rem;
  font-weight: 850;
  cursor: pointer;
  text-decoration: none;
}

.auth-link-button:hover:not(:disabled) {
  text-decoration: underline;
}

.auth-link-button[hidden] {
  display: none !important;
}

.auth-status {
  min-height: 20px;
  margin-top: 12px;
  color: #60708f;
  font-size: 0.82rem;
  line-height: 1.35;
  text-align: center;
}

.auth-status[data-type="success"] {
  color: #0B9E84;
  font-weight: 750;
}

.auth-status[data-type="error"] {
  color: #D83B5B;
  font-weight: 750;
}

.auth-logout-btn {
  width: 100%;
  margin: 0 0 13px;
  padding: 10px 11px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(76,111,255,0.24), rgba(18,198,167,0.14));
  color: #fff;
  cursor: pointer;
  box-shadow: 0 10px 22px rgba(0,0,0,0.18);
  transition: transform 140ms ease, background 140ms ease, border-color 140ms ease;
}

.auth-logout-btn:hover:not(:disabled) {
  transform: translateY(-1px);
  background: linear-gradient(135deg, rgba(76,111,255,0.34), rgba(18,198,167,0.2));
  border-color: rgba(255,255,255,0.22);
}

.auth-logout-icon {
  width: 30px;
  height: 30px;
  display: inline-grid;
  place-items: center;
  border-radius: 11px;
  background: rgba(255,255,255,0.1);
  font-weight: 900;
  flex: 0 0 auto;
}

.auth-logout-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  line-height: 1.18;
}

.auth-logout-user {
  max-width: 155px;
  color: #dbe5ff;
  font-size: 0.69rem;
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.auth-logout-label {
  color: #fff;
  font-size: 0.84rem;
  font-weight: 900;
}

html[dir="rtl"] .auth-logo-row,
html[dir="rtl"] .auth-logout-btn {
  flex-direction: row-reverse;
}

html[dir="rtl"] .auth-logout-copy {
  align-items: flex-end;
}

html[dir="rtl"] .auth-field {
  text-align: right;
}

@media (max-width: 820px) {
  .auth-shell {
    width: min(500px, 100%);
    max-height: calc(100dvh - 20px);
  }

  .auth-card {
    padding: clamp(18px, 5vw, 28px);
  }
}

@media (max-height: 690px) and (min-width: 821px) {
  .auth-card {
    padding: 22px;
  }

  .auth-logo-row,
  .auth-lead {
    margin-bottom: 12px;
  }
}

@media (max-width: 420px), (max-height: 560px) {
  .auth-gate {
    padding: 10px;
  }

  .auth-card {
    border-radius: 20px;
  }

  .auth-logo {
    width: 48px;
    height: 48px;
    border-radius: 15px;
  }

  .auth-field input,
  .auth-submit {
    min-height: 44px;
  }
}

