/* Dedicated mobile layout. Desktop .app is hidden on phones. */

.mobile-app {
  display: none;
}

@media (max-width: 767px) {
  html,
  body {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0;
    padding: 0;
    overflow-x: hidden;
    background: #0d1117;
  }

  body {
    min-height: 100svh;
    background:
      radial-gradient(circle at 50% -6%, rgba(59, 130, 246, .12), transparent 34%),
      linear-gradient(180deg, #070b12 0%, #0d1117 42%, #0f172a 100%);
  }

  .app {
    display: none !important;
  }

  .mobile-app {
    display: block;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    min-height: 100svh;
    padding: calc(8px + env(safe-area-inset-top)) 14px calc(150px + env(safe-area-inset-bottom));
    overflow-x: hidden;
    box-sizing: border-box;
  }

  .mobile-top {
    position: relative;
    min-height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    margin-bottom: 12px;
  }

  .mobile-brand {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 9px;
    max-width: calc(100% - 112px);
    color: #e5eefb;
    font-size: 23px;
    font-weight: 850;
    letter-spacing: .01em;
  }

  .mobile-brand img {
    width: 30px;
    height: 30px;
    flex: 0 0 auto;
  }

  .mobile-menu {
    position: absolute;
    left: 0;
    top: 0;
    z-index: 80;
  }

  .mobile-menu summary {
    width: 46px;
    height: 46px;
    display: grid;
    place-items: center;
    list-style: none;
    cursor: pointer;
    border: 1px solid rgba(126, 154, 197, .28);
    border-radius: 15px;
    background: rgba(27, 39, 56, .92);
    color: #dbeafe;
    box-shadow: 0 10px 26px rgba(0, 0, 0, .28);
    -webkit-tap-highlight-color: transparent;
  }

  .mobile-menu summary::-webkit-details-marker {
    display: none;
  }

  .mobile-menu-panel {
    position: absolute;
    left: 0;
    top: 56px;
    display: grid;
    gap: 8px;
    width: min(286px, calc(100vw - 28px));
    padding: 10px;
    border: 1px solid rgba(126, 154, 197, .24);
    border-radius: 16px;
    background: rgba(17, 24, 39, .98);
    box-shadow: 0 18px 44px rgba(0, 0, 0, .38);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  .mobile-menu-panel .button,
  .mobile-menu-panel button {
    width: 100%;
    min-height: 44px;
    justify-content: center;
  }

  .mobile-overview {
    width: 100%;
    box-sizing: border-box;
    margin: 0 0 16px;
    padding: 12px;
    border: 1px solid rgba(96, 130, 180, .18);
    border-radius: 18px;
    background: rgba(21, 31, 46, .72);
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .035);
  }

  .mobile-section-title {
    margin: 0 0 9px;
    color: #aeb8c7;
    font-size: 12px;
    font-weight: 750;
    letter-spacing: .03em;
  }

  .mobile-stats-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 9px;
  }

  .mobile-stats-grid .stat-card {
    min-height: 68px;
    padding: 10px;
    border-radius: 13px;
  }

  .mobile-stats-grid .stat-card span {
    font-size: 11px;
  }

  .mobile-stats-grid .stat-card strong {
    margin-top: 5px;
    font-size: 22px;
  }

  .mobile-hero {
    margin: 0 0 14px;
  }

  .mobile-hero h1 {
    margin: 0;
    color: #eef4ff;
    font-size: 28px;
    line-height: 1.18;
    font-weight: 850;
  }

  .mobile-hero p {
    margin: 8px 0 0;
    color: #9ca3af;
    font-size: 15px;
    line-height: 1.48;
  }

  .mobile-filter-card {
    width: 100%;
    box-sizing: border-box;
    display: grid;
    grid-template-columns: 1fr;
    gap: 12px;
    margin: 0 0 16px;
    padding: 13px;
    border: 1px solid rgba(96, 130, 180, .18);
    border-radius: 18px;
    background: rgba(15, 23, 42, .78);
    overflow: visible;
  }

  .mobile-filter-card label:not(.check) {
    display: block;
    margin-bottom: 7px;
    color: #aeb8c7;
    font-size: 12px;
    font-weight: 750;
  }

  .mobile-filter-card .custom-select,
  .mobile-filter-card .custom-select-button,
  .mobile-filter-card .filter-field,
  .mobile-filter-card select {
    width: 100%;
    max-width: 100%;
    min-width: 0;
  }

  .mobile-filter-card .custom-select-button {
    min-height: 45px;
    font-size: 16px;
  }

  .mobile-filter-card .custom-select-menu {
    max-height: 42vh;
  }

  .mobile-filter-card .switch-field {
    width: auto;
    min-height: 36px;
    padding: 2px 0 0;
    justify-content: flex-start;
  }

  .mobile-panel {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    margin: 0;
    border: 1px solid rgba(96, 130, 180, .2);
    border-radius: 18px;
    background: rgba(15, 23, 42, .76);
    overflow: hidden;
  }

  .mobile-panel-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    border-bottom: 1px solid rgba(96, 130, 180, .16);
  }

  .mobile-panel-head strong {
    color: #e5eefb;
    font-size: 20px;
  }

  .mobile-panel-head .muted {
    color: #aeb8c7;
    font-size: 17px;
  }

  #mobileItemsDedicated {
    display: grid;
    gap: 12px;
    width: 100%;
    max-width: 100%;
    min-width: 0;
    padding: 12px 12px calc(210px + env(safe-area-inset-bottom));
    box-sizing: border-box;
  }

  #mobileItemsDedicated .mobile-card {
    width: 100%;
    max-width: 100%;
    min-width: 0;
    box-sizing: border-box;
    padding: 14px;
    border-radius: 15px;
  }

  #mobileItemsDedicated .mobile-card h2 {
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  #mobileItemsDedicated .mobile-card-foot {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }
}

@supports (min-height: 100dvh) {
  @media (max-width: 767px) {
    body,
    .mobile-app {
      min-height: 100dvh;
    }
  }
}

/* Final mobile fit layer: force the standalone mobile UI to fill the visual viewport. */
@media (max-width: 767px) {
  :root {
    --mobile-edge: clamp(10px, 3.2vw, 14px);
  }

  *,
  *::before,
  *::after {
    box-sizing: border-box;
  }

  html,
  body {
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    overflow-x: hidden !important;
  }

  body {
    position: relative;
  }

  .mobile-app {
    width: 100vw !important;
    min-width: 100vw !important;
    max-width: 100vw !important;
    margin: 0 !important;
    padding-left: var(--mobile-edge) !important;
    padding-right: var(--mobile-edge) !important;
  }

  .mobile-top,
  .mobile-overview,
  .mobile-hero,
  .mobile-filter-card,
  .mobile-panel,
  #mobileItemsDedicated,
  #mobileItemsDedicated .mobile-card {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .mobile-top {
    min-height: 56px !important;
    margin-bottom: 12px !important;
  }

  .mobile-menu summary {
    width: 52px !important;
    height: 52px !important;
    min-width: 52px !important;
    min-height: 52px !important;
    border-radius: 18px !important;
    font-size: 22px !important;
    touch-action: manipulation;
  }

  .mobile-menu-panel {
    top: 62px !important;
    width: min(300px, calc(100vw - (var(--mobile-edge) * 2))) !important;
  }

  .mobile-brand {
    max-width: calc(100vw - 136px) !important;
    font-size: clamp(22px, 7vw, 27px) !important;
  }

  .mobile-brand img {
    width: 34px !important;
    height: 34px !important;
  }

  .mobile-overview,
  .mobile-filter-card,
  .mobile-panel {
    border-radius: 20px !important;
  }

  .mobile-overview,
  .mobile-filter-card {
    padding: 14px !important;
  }

  .mobile-stats-grid {
    gap: 10px !important;
  }

  .mobile-stats-grid .stat-card {
    min-width: 0 !important;
  }

  .mobile-filter-card .filter-field,
  .mobile-filter-card .custom-select,
  .mobile-filter-card .custom-select-button,
  .mobile-filter-card select {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  #mobileItemsDedicated {
    padding-left: 12px !important;
    padding-right: 12px !important;
  }
}

@supports (width: 100svw) {
  @media (max-width: 767px) {
    html,
    body,
    .mobile-app {
      width: 100svw !important;
      min-width: 100svw !important;
      max-width: 100svw !important;
    }
  }
}

@supports (overflow: clip) {
  @media (max-width: 767px) {
    html,
    body,
    .mobile-app {
      overflow-x: clip !important;
    }
  }
}

/* Browser-measured mobile width override for stubborn iOS/Android webviews. */
@media (max-width: 767px) {
  html,
  body {
    inline-size: var(--real-mobile-vw, 100%) !important;
    min-inline-size: var(--real-mobile-vw, 100%) !important;
    max-inline-size: none !important;
    background:
      radial-gradient(circle at 50% -6%, rgba(59, 130, 246, .12), transparent 34%),
      linear-gradient(180deg, #070b12 0%, #0d1117 42%, #0f172a 100%) !important;
  }

  .mobile-app {
    inline-size: var(--real-mobile-vw, 100%) !important;
    min-inline-size: var(--real-mobile-vw, 100%) !important;
    max-inline-size: none !important;
    padding-left: max(var(--mobile-edge), env(safe-area-inset-left)) !important;
    padding-right: max(var(--mobile-edge), env(safe-area-inset-right)) !important;
  }

  .mobile-top,
  .mobile-overview,
  .mobile-hero,
  .mobile-filter-card,
  .mobile-panel,
  .mobile-panel-head,
  #mobileItemsDedicated,
  #mobileItemsDedicated .mobile-card {
    inline-size: 100% !important;
    max-inline-size: 100% !important;
  }

  .mobile-overview,
  .mobile-filter-card,
  .mobile-panel {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .mobile-menu-panel {
    inline-size: min(300px, calc(var(--real-mobile-vw, 100vw) - (var(--mobile-edge) * 2))) !important;
  }
}

/* iOS-like touch and motion polish. */
@media (max-width: 767px) {
  html {
    -webkit-text-size-adjust: 100%;
    scroll-behavior: smooth;
  }

  body {
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    overscroll-behavior-x: none;
  }

  .mobile-app {
    -webkit-overflow-scrolling: touch;
    isolation: isolate;
  }

  .mobile-top {
    position: sticky !important;
    top: 0;
    z-index: 90;
    margin: calc(-8px - env(safe-area-inset-top)) calc(-1 * var(--mobile-edge)) 12px !important;
    padding: calc(8px + env(safe-area-inset-top)) var(--mobile-edge) 10px;
    background: linear-gradient(180deg, rgba(7, 11, 18, .92), rgba(7, 11, 18, .7) 72%, rgba(7, 11, 18, 0));
    backdrop-filter: blur(22px) saturate(1.22);
    -webkit-backdrop-filter: blur(22px) saturate(1.22);
  }

  .mobile-menu {
    left: var(--mobile-edge) !important;
    top: calc(8px + env(safe-area-inset-top)) !important;
  }

  .mobile-menu summary,
  .mobile-menu-panel,
  .mobile-overview,
  .mobile-filter-card,
  .mobile-panel,
  #mobileItemsDedicated .mobile-card,
  .mobile-stats-grid .stat-card {
    backdrop-filter: blur(18px) saturate(1.12);
    -webkit-backdrop-filter: blur(18px) saturate(1.12);
  }

  .mobile-overview,
  .mobile-filter-card,
  .mobile-panel,
  #mobileItemsDedicated .mobile-card {
    border-color: rgba(126, 154, 197, .2) !important;
    background: linear-gradient(180deg, rgba(22, 33, 50, .82), rgba(13, 20, 33, .76)) !important;
    box-shadow:
      0 14px 36px rgba(0, 0, 0, .22),
      inset 0 1px 0 rgba(255, 255, 255, .045) !important;
  }

  .mobile-stats-grid .stat-card {
    background: linear-gradient(180deg, rgba(17, 25, 41, .84), rgba(9, 15, 25, .78)) !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, .035);
  }

  .mobile-filter-card .custom-select-button,
  .mobile-filter-card select,
  .mobile-menu summary,
  .mobile-menu-panel .button,
  .mobile-menu-panel button,
  #mobileItemsDedicated .source-button {
    min-height: 50px !important;
    border-radius: 16px !important;
    touch-action: manipulation;
    -webkit-tap-highlight-color: transparent;
  }

  .mobile-menu summary,
  .mobile-menu-panel .button,
  .mobile-menu-panel button,
  .mobile-filter-card .custom-select-button,
  #mobileItemsDedicated .mobile-card,
  #mobileItemsDedicated .source-button {
    transition:
      transform .16s cubic-bezier(.2, .8, .2, 1),
      border-color .16s ease,
      background-color .16s ease,
      box-shadow .16s ease,
      opacity .16s ease;
  }

  .mobile-menu summary:active,
  .mobile-menu-panel .button:active,
  .mobile-menu-panel button:active,
  .mobile-filter-card .custom-select-button:active,
  #mobileItemsDedicated .mobile-card:active,
  #mobileItemsDedicated .source-button:active {
    transform: scale(.985);
  }

  .mobile-filter-card .custom-select.open .custom-select-button,
  .mobile-filter-card .custom-select-button:focus-visible,
  .mobile-menu summary:focus-visible,
  #mobileItemsDedicated .source-button:focus-visible {
    outline: 0;
    border-color: rgba(96, 165, 250, .76) !important;
    box-shadow:
      0 0 0 4px rgba(59, 130, 246, .16),
      inset 0 1px 0 rgba(255, 255, 255, .045) !important;
  }

  .mobile-menu-panel {
    transform-origin: top left;
    animation: mobileMenuIn .18s cubic-bezier(.2, .8, .2, 1) both;
  }

  .mobile-panel-head {
    background: rgba(10, 17, 29, .38);
  }

  #mobileItemsDedicated {
    gap: 11px !important;
  }

  #mobileItemsDedicated .mobile-card {
    content-visibility: auto;
    contain-intrinsic-size: 176px;
  }
}

@keyframes mobileMenuIn {
  from {
    opacity: 0;
    transform: translateY(-6px) scale(.98);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

@media (max-width: 767px) and (prefers-reduced-motion: reduce) {
  html {
    scroll-behavior: auto;
  }

  .mobile-menu-panel,
  .mobile-menu summary,
  .mobile-menu-panel .button,
  .mobile-menu-panel button,
  .mobile-filter-card .custom-select-button,
  #mobileItemsDedicated .mobile-card,
  #mobileItemsDedicated .source-button {
    animation: none !important;
    transition: none !important;
  }
}
