/* Adaptive layout fixes for fixed desktop sidebar and mobile viewport fit. */

@media (min-width: 768px) {
  .app {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-height: 100vh;
    padding: 0 !important;
    overflow-x: hidden !important;
  }

  .sidebar {
    position: fixed !important;
    left: 18px;
    top: 18px;
    bottom: 18px;
    z-index: 30;
    width: 300px;
    height: auto !important;
    max-height: calc(100dvh - 36px);
    overflow-y: auto;
    padding: 18px;
    border: 1px solid rgba(126, 154, 197, .22);
    border-radius: 22px;
    background: linear-gradient(180deg, rgba(17, 24, 39, .72), rgba(10, 17, 29, .62));
    box-shadow: 0 24px 70px rgba(0, 0, 0, .32), inset 0 1px 0 rgba(255, 255, 255, .04);
    backdrop-filter: blur(22px) saturate(1.2);
    -webkit-backdrop-filter: blur(22px) saturate(1.2);
  }

  .sidebar::-webkit-scrollbar {
    width: 0;
    height: 0;
  }

  .side-nav {
    display: none !important;
  }

  .overview-card {
    margin-top: 20px !important;
  }

  .settings-menu {
    order: unset !important;
    margin-top: 18px !important;
  }

  .settings-summary {
    min-height: 44px;
  }

  .settings-actions {
    display: grid;
  }

  .main {
    width: min(1180px, calc(100vw - 384px)) !important;
    max-width: calc(100vw - 384px) !important;
    min-width: 0;
    margin-left: 360px !important;
    margin-right: auto !important;
    padding: 36px 28px 56px !important;
  }

  .filter-card {
    width: 100%;
    max-width: 100%;
    grid-template-columns: minmax(120px, 1fr) minmax(120px, 1fr) minmax(180px, 1.35fr) minmax(120px, 1fr) minmax(150px, auto) !important;
    gap: 12px;
    overflow: visible !important;
  }

  .switch-field {
    white-space: nowrap;
  }
}

@media (min-width: 768px) and (max-width: 1240px) {
  .sidebar {
    width: 280px;
  }

  .main {
    width: calc(100vw - 340px) !important;
    max-width: calc(100vw - 340px) !important;
    margin-left: 322px !important;
    padding-right: 18px !important;
  }

  .filter-card {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .switch-field {
    grid-column: 1 / -1;
  }
}

@media (max-width: 767px) {
  html,
  body {
    width: 100% !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  body {
    padding-bottom: calc(96px + env(safe-area-inset-bottom)) !important;
  }

  .app {
    display: block !important;
    width: 100vw !important;
    max-width: 100vw !important;
    min-height: 100vh;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: hidden !important;
  }

  .sidebar {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    bottom: auto !important;
    width: 100vw !important;
    max-width: 100vw !important;
    height: auto !important;
    max-height: none !important;
    padding: calc(18px + env(safe-area-inset-top)) 14px 18px !important;
    border: 0 !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(126, 154, 197, .18) !important;
    border-radius: 0 !important;
    outline: 0 !important;
    box-shadow: none !important;
    background: rgba(13, 17, 23, .9) !important;
    overflow: visible !important;
  }

  .sidebar-head {
    display: flex;
    min-height: 56px;
    align-items: center;
    justify-content: center;
  }

  .brand {
    justify-content: center;
  }

  .settings-menu {
    position: absolute !important;
    left: 14px;
    top: calc(18px + env(safe-area-inset-top));
    z-index: 60;
    margin: 0 !important;
    border: 0 !important;
    background: transparent !important;
  }

  .settings-summary {
    width: 48px !important;
    height: 48px !important;
    min-height: 48px !important;
    padding: 0 !important;
    justify-content: center;
    border: 1px solid rgba(126, 154, 197, .28);
    border-radius: 16px;
    background: rgba(27, 39, 56, .96);
    box-shadow: 0 10px 26px rgba(0, 0, 0, .28);
  }

  .summary-icon {
    font-size: 22px;
    color: #dbeafe;
  }

  .summary-label {
    display: none;
  }

  .settings-actions {
    display: none;
    position: absolute;
    left: 0;
    top: 58px;
    width: min(286px, calc(100vw - 28px));
    padding: 10px;
    border: 1px solid rgba(126, 154, 197, .22);
    border-radius: 16px;
    background: rgba(17, 24, 39, .97);
    box-shadow: 0 18px 44px rgba(0, 0, 0, .38);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .settings-menu[open] .settings-actions {
    display: grid !important;
  }

  .settings-actions .button,
  .settings-actions button {
    width: 100%;
    min-height: 44px;
  }

  .overview-card {
    width: 100%;
    max-width: 100%;
    margin-top: 18px !important;
    padding: 14px !important;
    border-radius: 18px;
  }

  .main {
    width: 100vw !important;
    max-width: 100vw !important;
    min-width: 0;
    margin: 0 !important;
    padding: 20px 14px 0 !important;
    overflow-x: hidden !important;
  }

  .topbar {
    margin-bottom: 18px;
  }

  h1 {
    font-size: 26px !important;
    line-height: 1.18;
  }

  .filter-card {
    width: 100% !important;
    max-width: 100% !important;
    grid-template-columns: 1fr !important;
    gap: 12px !important;
    margin-bottom: 18px !important;
    padding: 14px !important;
    border-radius: 18px !important;
    overflow: hidden !important;
  }

  input,
  select,
  button,
  .button {
    min-height: 44px;
    font-size: 16px;
  }

  .panel {
    width: 100% !important;
    max-width: 100% !important;
    overflow: hidden !important;
  }

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

  .mobile-list {
    display: grid !important;
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
  }

  .mobile-card {
    width: 100%;
    max-width: 100%;
  }
}
