/* AutoStore JP mobile app layer.
   Additive only: every rule is scoped to tablet/mobile breakpoints. */

@media (max-width: 1024px) {
  :root {
    --mobile-nav-h: 60px;
    --mobile-pad: clamp(16px, 4vw, 28px);
    --mobile-card: 12px;
  }

  html {
    -webkit-text-size-adjust: 100%;
    scroll-padding-top: calc(var(--mobile-nav-h) + 12px);
  }

  body {
    min-width: 0;
    overflow-x: hidden;
    -webkit-tap-highlight-color: transparent;
    touch-action: manipulation;
  }

  body.mobile-menu-open,
  body.filters-open {
    overflow: hidden;
  }

  .scroll-progress {
    height: 3px !important;
  }

  nav {
    height: var(--mobile-nav-h) !important;
    padding: 0 var(--mobile-pad) !important;
    background: rgba(0, 0, 0, .94) !important;
    border-bottom: 1px solid rgba(255, 90, 0, .18) !important;
    backdrop-filter: blur(14px);
  }

  .nav-links,
  .nav-cta {
    display: none !important;
  }

  .nav-logo {
    width: auto !important;
    min-width: 0 !important;
    max-width: calc(100vw - 92px) !important;
    height: 44px !important;
    gap: 9px !important;
  }

  .nav-logo-icon {
    width: 40px !important;
    height: 40px !important;
    flex: 0 0 40px !important;
  }

  .nav-logo-copy {
    min-width: 0 !important;
  }

  .nav-logo-wordmark {
    width: auto !important;
    max-width: min(188px, calc(100vw - 150px)) !important;
    height: auto !important;
    max-height: 30px !important;
    flex: 0 1 auto !important;
  }

  .nav-logo-tagline {
    max-width: min(188px, calc(100vw - 150px)) !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    font-size: 6px !important;
    letter-spacing: .26em !important;
  }

  .nav-hamburger {
    display: inline-flex !important;
    width: 44px !important;
    height: 44px !important;
    align-items: center !important;
    justify-content: center !important;
    border: 1px solid rgba(255, 255, 255, .12) !important;
    border-radius: 10px !important;
    background: rgba(255, 255, 255, .04) !important;
    flex: 0 0 44px !important;
  }

  .mobile-menu {
    display: flex !important;
    position: fixed !important;
    inset: var(--mobile-nav-h) 0 0 0 !important;
    z-index: 999 !important;
    padding: 18px var(--mobile-pad) calc(22px + env(safe-area-inset-bottom)) !important;
    align-items: stretch !important;
    justify-content: flex-start !important;
    gap: 8px !important;
    overflow-y: auto !important;
    background:
      linear-gradient(180deg, rgba(0, 0, 0, .98), rgba(12, 12, 12, .98)) !important;
    transform: translate3d(0, -10px, 0);
    opacity: 0;
    pointer-events: none;
    transition: opacity .22s ease, transform .22s ease;
  }

  .mobile-menu.open {
    opacity: 1;
    transform: translate3d(0, 0, 0);
    pointer-events: auto;
  }

  .mobile-menu a {
    width: 100%;
    min-height: 48px;
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    padding: 13px 4px !important;
    border-bottom: 1px solid rgba(255, 255, 255, .07);
    font-size: clamp(20px, 6vw, 28px) !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
    text-align: left !important;
  }

  .mobile-menu a::after {
    content: ">";
    color: var(--orange);
    font-family: var(--fb);
    font-size: 15px;
    font-weight: 700;
  }

  .mobile-menu .mobile-social {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px !important;
    margin-top: 12px;
  }

  .mobile-menu .mobile-social a {
    min-height: 44px !important;
    justify-content: center !important;
    gap: 7px !important;
    padding: 10px !important;
    border: 1px solid rgba(255, 90, 0, .24) !important;
    border-radius: 10px !important;
    font-family: var(--fb) !important;
    font-size: 10px !important;
    letter-spacing: .08em !important;
  }

  .mobile-menu .mobile-social a::after,
  .mobile-menu .mob-cta::after {
    display: none;
  }

  .mobile-menu .mob-cta {
    justify-content: center !important;
    margin-top: 14px !important;
    border: 0 !important;
    border-radius: 12px !important;
    min-height: 52px !important;
    font-family: var(--fb) !important;
    font-size: 13px !important;
    letter-spacing: .1em !important;
    clip-path: none !important;
  }

  .ticker-bar {
    margin-top: var(--mobile-nav-h) !important;
    height: 38px !important;
  }

  .ticker-item {
    padding-inline: 18px !important;
    font-size: 11px !important;
  }

  .page-hero,
  .jp-page-hero,
  .post-hero {
    margin-top: var(--mobile-nav-h) !important;
  }

  .hero-badge,
  .hero-title .line span,
  .hero-subtitle,
  .hero-actions,
  .hero-panel,
  .search-bar,
  .section-title,
  .section-link,
  .car-card,
  .trust-item,
  .sell-block,
  .sell-title,
  .sell-body,
  .sell-step,
  .sell-cta-row,
  #footer,
  .page-hero h1,
  .jp-page-hero h1,
  .featured-post,
  .post-card,
  .newsletter,
  .brand-card,
  .why-item,
  .detail-block,
  .insp-card,
  .timeline-item,
  .sim-card {
    opacity: 1 !important;
    transform: none !important;
  }

  input,
  select,
  textarea,
  .field-select,
  .field-input,
  .range-row input,
  .lead-form input,
  .lead-form select,
  .lead-form textarea,
  .modal-form input,
  .modal-form select,
  .modal-form textarea {
    min-height: 46px;
    font-size: 16px !important;
    border-radius: 10px !important;
  }

  .btn-cta,
  .btn-ghost,
  .btn-search,
  .modal-submit,
  .lead-form button,
  .newsletter-form button,
  .filters-clear,
  .card-cta {
    min-height: 46px;
    border-radius: 10px !important;
    clip-path: none !important;
  }

  .jp-section,
  .section-featured,
  .section-sell,
  .similar-section,
  .results,
  .post-body {
    padding-left: var(--mobile-pad) !important;
    padding-right: var(--mobile-pad) !important;
  }

  .jp-grid,
  .team-grid,
  .partner-row,
  .posts-grid,
  .similar-grid,
  .results-grid {
    gap: 12px !important;
  }
}

@media (min-width: 768px) and (max-width: 1024px) {
  .hero-content {
    grid-template-columns: 1fr !important;
    padding-inline: var(--mobile-pad) !important;
    gap: 30px !important;
  }

  .hero-panel {
    align-items: stretch !important;
    max-width: 620px;
  }

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

  .cars-grid,
  .results-grid,
  .jp-grid,
  .posts-grid,
  .similar-grid,
  .team-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

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

  .filters {
    width: min(420px, 92vw) !important;
  }
}

@media (max-width: 767px) {
  .hero-video-mobile {
    display: none !important;
  }

  .mobile-owner-section {
    display: block !important;
    padding: 0 var(--mobile-pad) 20px !important;
    background: #000 !important;
  }

  .mobile-owner-card {
    position: relative !important;
    overflow: hidden !important;
    border: 1px solid rgba(255, 90, 0, .24) !important;
    border-radius: 14px !important;
    background: #101010 !important;
    box-shadow: 0 18px 50px -32px rgba(255, 90, 0, .58) !important;
  }

  .mobile-owner-card img {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 4 / 3 !important;
    height: auto !important;
    object-fit: cover !important;
    object-position: center top !important;
  }

  .mobile-owner-card::after {
    content: "" !important;
    position: absolute !important;
    inset: auto 0 0 0 !important;
    height: 34% !important;
    background: linear-gradient(180deg, transparent, rgba(0, 0, 0, .78)) !important;
    pointer-events: none !important;
  }

  .mobile-owner-brand {
    position: absolute !important;
    left: 12px !important;
    right: 12px !important;
    bottom: 12px !important;
    z-index: 2 !important;
    min-height: 42px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 10px !important;
    padding: 8px 12px !important;
    border: 1px solid rgba(255, 255, 255, .12) !important;
    border-radius: 10px !important;
    background: rgba(0, 0, 0, .68) !important;
    backdrop-filter: blur(10px);
  }

  .mobile-owner-brand img {
    width: min(210px, 62vw) !important;
    height: auto !important;
    aspect-ratio: auto !important;
    object-fit: contain !important;
  }

  .mobile-owner-brand span {
    display: none !important;
  }

  .ticker-bar {
    display: none !important;
  }

  .hero {
    height: auto !important;
    min-height: 0 !important;
    display: block !important;
    padding: calc(var(--mobile-nav-h) + 26px) var(--mobile-pad) 34px !important;
    overflow: visible !important;
    background:
      radial-gradient(ellipse 90% 48% at 40% 0%, rgba(255, 90, 0, .14), transparent 62%),
      linear-gradient(180deg, #000 0%, #101010 58%, #000 100%);
  }

  .hero-media {
    inset: 0 !important;
    height: 100% !important;
    opacity: .38;
  }

  .hero-media img,
  .hero-media video {
    object-position: center top !important;
    filter: saturate(.86) contrast(1.08);
  }

  .hero-media-overlay {
    background:
      linear-gradient(180deg, rgba(0, 0, 0, .42), #000 82%),
      linear-gradient(90deg, rgba(0, 0, 0, .82), rgba(0, 0, 0, .35)) !important;
  }

  .hero-grid,
  .hero-scanline {
    display: none !important;
  }

  .hero-content {
    display: block !important;
    padding: 0 !important;
  }

  .hero-title {
    max-width: 12ch;
    font-size: clamp(42px, 13vw, 62px) !important;
    line-height: .94 !important;
    letter-spacing: 0 !important;
    margin-bottom: 18px;
  }

  .hero-title .line {
    overflow: visible !important;
  }

  .hero-subtitle {
    display: grid !important;
    gap: 8px !important;
    margin-top: 16px !important;
    letter-spacing: 0 !important;
  }

  .hero-subtitle span {
    display: flex;
    align-items: center;
    gap: 9px;
    font-size: 14px;
    line-height: 1.35;
    color: var(--white2);
  }

  .hero-subtitle span::before {
    content: "";
    width: 8px;
    height: 8px;
    margin: 0;
    border-radius: 999px;
    background: var(--orange);
    box-shadow: 0 0 0 5px rgba(255, 90, 0, .13);
    flex: 0 0 auto;
  }

  .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 9px !important;
    margin-top: 24px !important;
  }

  .hero-actions .btn-cta,
  .hero-actions .btn-ghost {
    width: 100% !important;
    justify-content: center !important;
    text-align: center !important;
    padding: 14px 16px !important;
  }

  .hero-actions .btn-ghost {
    background: rgba(255, 255, 255, .055) !important;
  }

  .hero-video-mobile {
    display: none !important;
  }

  .hero-panel {
    display: none !important;
  }

  .hero-stats-mobile {
    position: static !important;
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0;
    margin-top: 24px;
    border: 1px solid rgba(255, 255, 255, .08) !important;
    border-radius: 14px;
    overflow: hidden;
    background: rgba(0, 0, 0, .58) !important;
    backdrop-filter: blur(12px);
  }

  .hero-stats-mobile .hero-stat {
    padding: 14px 10px !important;
    text-align: left;
  }

  .hero-stats-mobile .hero-stat-num {
    font-size: 20px !important;
  }

  .hero-stats-mobile .hero-stat-label {
    font-size: 9px !important;
  }

  .search-section {
    padding: 22px var(--mobile-pad) 0 !important;
    background: #000 !important;
  }

  .search-bar {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    align-items: stretch !important;
    justify-items: stretch !important;
    gap: 14px !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 18px !important;
    border-radius: 16px;
    box-shadow: 0 18px 44px -28px rgba(255, 90, 0, .62);
  }

  .search-fields,
  .lead-form,
  .modal-row,
  .newsletter-form {
    grid-template-columns: 1fr !important;
    width: 100% !important;
    min-width: 0 !important;
    justify-self: stretch !important;
  }

  .field-group {
    width: 100% !important;
    min-width: 0 !important;
    gap: 7px !important;
  }

  .field-select,
  .field-input,
  .search-bar .budget-range,
  .btn-search {
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    justify-self: stretch !important;
  }

  .budget-range-values {
    width: 100% !important;
  }

  .budget-range-values span {
    min-width: 0 !important;
  }

  .quick-filters {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 8px !important;
    margin-inline: calc(var(--mobile-pad) * -1);
    padding: 14px var(--mobile-pad) 4px !important;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .quick-filters::-webkit-scrollbar {
    display: none;
  }

  .quick-label,
  .quick-chip {
    flex: 0 0 auto;
  }

  .quick-chip {
    min-height: 38px;
    display: inline-flex;
    align-items: center;
    border-radius: 999px !important;
  }

  .section-featured,
  .jp-section,
  .section-sell {
    padding-top: 52px !important;
    padding-bottom: 52px !important;
  }

  .section-header,
  .jp-section-head,
  .page-hero-inner,
  .results-toolbar {
    display: grid !important;
    grid-template-columns: 1fr !important;
    align-items: start !important;
    gap: 14px !important;
  }

  .section-title,
  .jp-section h2,
  .page-hero h1,
  .jp-page-hero h1,
  .post-hero h1 {
    font-size: clamp(34px, 11vw, 48px) !important;
    line-height: .96 !important;
    letter-spacing: 0 !important;
  }

  .cars-grid,
  .results-grid,
  .jp-grid,
  .posts-grid,
  .similar-grid,
  .team-grid,
  .partner-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .car-card,
  .car-card:first-child,
  .results-grid.list .car-card {
    display: block !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: hidden;
    border-radius: 14px;
    background: var(--black2) !important;
  }

  .car-card-img,
  .results-grid.list .car-card-img {
    position: relative !important;
    display: block !important;
    width: 100% !important;
    height: auto !important;
    aspect-ratio: 4 / 3;
    object-fit: cover;
    transform: none !important;
    filter: none !important;
    opacity: 1 !important;
  }

  .car-card-gradient {
    display: none !important;
  }

  .car-info,
  .results-grid.list .car-info {
    position: static !important;
    padding: 15px 15px 12px !important;
    background: var(--black2);
  }

  .car-name,
  .car-card:first-child .car-name {
    font-size: 24px !important;
    line-height: 1 !important;
  }

  .car-price,
  .car-card:first-child .car-price {
    font-size: 20px !important;
  }

  .card-hover-overlay {
    position: static !important;
    opacity: 1 !important;
    display: block !important;
    padding: 0 !important;
    background: transparent !important;
    backdrop-filter: none !important;
  }

  .card-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    max-width: none !important;
    padding: 0 15px 15px !important;
  }

  .card-cta,
  .card-cta.secondary,
  .card-cta.whatsapp {
    display: flex !important;
    width: 100%;
    transform: none !important;
  }

  .card-cta.secondary,
  .card-cta.whatsapp {
    display: none !important;
  }

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

  .trust-item {
    padding: 22px 14px !important;
  }

  .trust-num {
    font-size: 34px !important;
  }

  .sell-block {
    display: grid !important;
    grid-template-columns: 1fr !important;
    border-radius: 16px;
    overflow: hidden;
  }

  .sell-media {
    order: -1;
    min-height: 210px !important;
  }

  .sell-content {
    padding: 28px 20px !important;
  }

  .sell-cta-row,
  .contact-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .jp-page-hero,
  .page-hero,
  .post-hero {
    padding: calc(var(--mobile-nav-h) + 22px) var(--mobile-pad) 34px !important;
  }

  .jp-page-hero {
    grid-template-columns: 1fr !important;
    min-height: 0 !important;
  }

  .jp-hero-media {
    min-height: 220px !important;
    border-radius: 16px;
    overflow: hidden;
  }

  .map-embed,
  .map-embed iframe,
  .map-empty {
    min-height: 260px !important;
  }

  .map-empty {
    padding: 24px 18px !important;
  }

  .map-empty strong {
    font-size: 26px !important;
  }

  .lead-panel,
  .jp-tile,
  .newsletter,
  .featured-post,
  .post-card {
    border-radius: 14px;
  }

  .lead-panel {
    padding: 22px 18px !important;
  }

  .filters {
    position: fixed !important;
    top: var(--mobile-nav-h) !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    width: auto !important;
    height: auto !important;
    padding: 22px var(--mobile-pad) calc(24px + env(safe-area-inset-bottom)) !important;
    z-index: 1100 !important;
    overflow-y: auto !important;
    border-right: 0 !important;
    border-top: 1px solid rgba(255, 90, 0, .2) !important;
    transform: translateY(100%);
    transition: transform .28s cubic-bezier(.2, .8, .2, 1) !important;
  }

  .filters.open {
    left: 0 !important;
    transform: translateY(0);
  }

  .filter-toggle-mobile {
    position: sticky;
    top: calc(var(--mobile-nav-h) + 8px);
    z-index: 80;
    display: flex !important;
    width: 100%;
    min-height: 48px;
    border-radius: 12px;
    background: rgba(255, 90, 0, .11) !important;
    backdrop-filter: blur(10px);
  }

  .results-sort {
    width: 100%;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .results-sort select {
    width: 100%;
  }

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

  .breadcrumb {
    margin-top: var(--mobile-nav-h);
    overflow-x: auto;
    white-space: nowrap;
    scrollbar-width: none;
  }

  .breadcrumb::-webkit-scrollbar {
    display: none;
  }

  .gallery {
    grid-template-columns: 1fr !important;
    grid-template-rows: minmax(260px, 62vw) 92px !important;
    gap: 6px !important;
    height: auto !important;
  }

  .detail-layout {
    padding-inline: var(--mobile-pad) !important;
  }

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

  .post-body {
    font-size: 16px;
    line-height: 1.72;
  }

  .post-body h2 {
    font-size: 24px !important;
    line-height: 1.08 !important;
    overflow-wrap: anywhere;
  }

  .post-body h3 {
    font-size: 20px !important;
    overflow-wrap: anywhere;
  }

  footer {
    padding: 38px var(--mobile-pad) calc(88px + env(safe-area-inset-bottom)) !important;
  }

  .footer-top {
    grid-template-columns: 1fr !important;
    gap: 26px !important;
  }

  #footer .nav-logo {
    width: 220px !important;
    min-width: 0 !important;
    height: auto !important;
  }

  .footer-bottom {
    padding-right: 0 !important;
    align-items: flex-start !important;
  }

  .social-float,
  .social-float--alone {
    display: none !important;
  }

  .wa-float {
    right: 16px !important;
    bottom: calc(16px + env(safe-area-inset-bottom)) !important;
    width: 56px !important;
    height: 56px !important;
  }

  .modal-backdrop {
    align-items: flex-end !important;
    padding: 0 !important;
  }

  .modal {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 92svh !important;
    border-radius: 18px 18px 0 0 !important;
    padding: 28px 20px calc(24px + env(safe-area-inset-bottom)) !important;
  }
}

@media (min-width: 480px) and (max-width: 767px) {
  .posts-grid,
  .similar-grid,
  .partner-row {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .sim-card {
    min-height: 220px;
  }
}

@media (max-width: 359px) {
  :root {
    --mobile-pad: 12px;
  }

  .nav-logo-icon {
    width: 34px !important;
    height: 34px !important;
    flex-basis: 34px !important;
  }

  .nav-logo-wordmark {
    max-width: 132px !important;
    max-height: 24px !important;
  }

  .nav-logo-tagline {
    max-width: 132px !important;
    font-size: 5.5px !important;
    letter-spacing: .18em !important;
  }

  .nav-hamburger {
    width: 40px !important;
    height: 40px !important;
    flex-basis: 40px !important;
  }

  .hero-title {
    font-size: 38px !important;
  }

  .section-title,
  .jp-section h2,
  .page-hero h1,
  .jp-page-hero h1,
  .post-hero h1 {
    font-size: 31px !important;
  }

  .hero-stats-mobile .hero-stat {
    padding: 12px 8px !important;
  }
}

@media (max-width: 900px) and (orientation: landscape) and (max-height: 500px) {
  .ticker-bar {
    display: none !important;
  }

  .hero,
  .jp-page-hero,
  .page-hero,
  .post-hero {
    min-height: 0 !important;
    padding-top: calc(var(--mobile-nav-h) + 18px) !important;
    padding-bottom: 24px !important;
  }

  .hero-title {
    font-size: clamp(34px, 8vw, 48px) !important;
  }

  .hero-stats-mobile,
  .hero-video-mobile,
  .hero-panel,
  .jp-hero-media {
    display: none !important;
  }

  .mobile-menu {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 6px 18px !important;
  }

  .mobile-menu .mob-cta,
  .mobile-menu .mobile-social {
    grid-column: 1 / -1;
  }
}

@media (pointer: coarse) and (max-width: 1024px) {
  a,
  button,
  input,
  select,
  textarea,
  .quick-chip,
  .filter-check {
    touch-action: manipulation;
  }

  a:focus-visible,
  button:focus-visible,
  input:focus-visible,
  select:focus-visible,
  textarea:focus-visible {
    outline-width: 3px !important;
    outline-offset: 3px !important;
  }
}
