/* ===== RESPONSIVE ===== */

/* Device-based hiding (platform detection, not viewport) */
.is-mobile-device body, .is-mobile-device a, .is-mobile-device button,
.is-mobile-device input, .is-mobile-device select, .is-mobile-device textarea { cursor: auto !important; }
.is-mobile-device .cursor { display: none !important; }
.is-mobile-device .section-dot, .is-mobile-device .section-ring, .is-mobile-device .section-cross { display: none !important; }

/* Tablet */
@media (max-width: 1024px) {
  .gyms-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
  .sports-grid { grid-template-columns: repeat(auto-fill, minmax(240px, 1fr)); }
  .contact-wrapper { grid-template-columns: 1fr; }
  .hero__stats { gap: 2rem; }
}

/* Mobile */
@media (max-width: 870px) {

  /* Catalog layout mobile */
  .catalog-layout { padding-left: 0; }
  .sidebar-track { display: block; }
  .filter-sidebar {
    position: fixed;
    top: 0;
    left: -320px;
    width: min(300px, 88vw);
    height: 100vh;
    z-index: 10000;
    border-radius: 0;
    border: none;
    border-right: 1px solid var(--border);
    max-height: 100vh;
    transition: left .3s ease;
  }
  .filter-sidebar.mobile-open { left: 0; }
  .filter-sidebar__header { padding: 1.25rem 1.25rem .75rem; }
  .filter-sidebar__close { display: flex; }
  .catalog-topbar__filter-btn { display: flex; }
  .catalog-topbar { flex-wrap: wrap; gap: .6rem; }
  .catalog-topbar__search { min-width: 0; width: 100%; flex: 0 0 100%; }
  .catalog-topbar__search svg {
    display: block;
    position: absolute;
    left: .85rem;
    color: var(--text-muted);
    opacity: .5;
    pointer-events: none;
  }
  .catalog-topbar__search input { padding-left: 2.6rem; }
  .catalog-topbar__search input,
  #sortSelect { height: 2.75rem; padding-top: 0; padding-bottom: 0; font-size: 16px; box-sizing: border-box; }
  .catalog-topbar__actions { flex: 1; }
  .catalog-topbar__filter-btn { height: 2.75rem; padding-top: 0; padding-bottom: 0; font-size: .85rem; box-sizing: border-box; flex: 1; justify-content: center; }
  #sortSelect { padding-left: .75rem; padding-right: 1.8rem; flex: 1; min-width: 0; }
  .wave-divider svg { height: 24px; }

  /* Reduce compositing overhead on mobile */
  .navbar::before,
  .navbar.scrolled::before { backdrop-filter: blur(12px); -webkit-backdrop-filter: blur(12px); clip-path: inset(0) !important; border-radius: 0; filter: none; background: rgba(0,0,0,.45); }
  .navbar::after { display: none; }
  [data-theme="dark"] .navbar::before,
  [data-theme="dark"] .navbar.scrolled::before { background: rgba(0,0,0,.6); }
  .trainer-card__specialty { backdrop-filter: none; -webkit-backdrop-filter: none; }
  .hero__badge { backdrop-filter: none; -webkit-backdrop-filter: none; }
  .page-hero__badge { backdrop-filter: none; -webkit-backdrop-filter: none; }

  /* Navbar */
  .navbar { padding: .75rem 1rem; justify-content: space-between; }
  .navbar.scrolled { padding: .6rem 1rem; }
  .navbar__logo { position: static; font-size: 1.25rem; z-index: 999; color: #ffffff !important; }
  .theme-toggle { display: none; }
  .menu-toggle { position: static; display: flex; z-index: 999; }
  .mobile-theme-toggle {
    display: flex; align-items: center; gap: .75rem;
    padding: .75rem 1.25rem;
    border-radius: 50px;
    font-size: .9rem; font-weight: 600;
    color: rgba(255,255,255,.7);
    border: 1px solid rgba(255,255,255,.15);
    background: rgba(255,255,255,.06);
    width: auto; margin-top: 1.5rem;
    font-family: inherit;
    transition: all .3s;
  }
  .mobile-theme-toggle:hover { background: rgba(255,255,255,.12); color: #ffffff; }
  .mobile-theme-toggle:active { transform: scale(.96); }
  .mobile-theme-toggle__icon {
    width: 32px; height: 32px;
    background: rgba(255,255,255,.12);
    color: #ffffff;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1rem;
    flex-shrink: 0;
  }
  .navbar__links {
    display: flex; flex-direction: column;
    position: fixed; top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(6,78,59,.98);
    padding: 6rem 2rem 2rem;
    gap: .25rem;
    opacity: 0; visibility: hidden; pointer-events: none;
    transform: translateY(0);
    z-index: 998;
    justify-content: center;
    align-items: center;
    overflow: hidden;
  }
  [data-theme="dark"] .navbar__links {
    background: rgba(10,15,18,.98);
  }
  .navbar__links::before {
    content: '';
    position: absolute;
    width: 300px; height: 300px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(52,211,153,.15) 0%, transparent 70%);
    top: -80px; right: -80px;
    pointer-events: none;
  }
  .navbar__links::after {
    content: '';
    position: absolute;
    width: 200px; height: 200px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(16,185,129,.1) 0%, transparent 70%);
    bottom: -40px; left: -40px;
    pointer-events: none;
  }
  .navbar__links.active {
    opacity: 1; visibility: visible; pointer-events: auto;
  }
  .navbar__links a {
    color: rgba(255,255,255,.85); font-size: 1.6rem; font-weight: 700;
    padding: .9rem 1.5rem;
    border-radius: 16px;
    transition: color .3s, background .3s;
    position: relative;
    letter-spacing: -.02em;
    white-space: nowrap;
  }
  .navbar__links a:not(.navbar__cta):not(.user-menu__item) { color: rgba(255,255,255,.85); }
  .navbar__links a:not(.navbar__cta):not(.user-menu__item):hover { color: #ffffff; }
  .navbar__links a::after { display: none; }
  .navbar__links a::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    transform: translateY(-50%) scaleX(0);
    width: 4px; height: 60%;
    background: var(--green-400);
    border-radius: 4px;
    transition: transform .3s ease;
    transform-origin: left center;
  }
  .navbar__links a:hover {
    color: #ffffff;
    background: rgba(255,255,255,.06);
  }
  .navbar__links a:hover::before {
    transform: translateY(-50%) scaleX(1);
  }
  .navbar__links a.navbar__cta {
    background: rgba(5,150,105,.08); color: var(--green-400);
    text-align: center; margin-top: 1rem; margin-left: 0;
    border-radius: 50px;
    font-size: .95rem;
    padding: .85rem 2rem;
    box-shadow: none;
    border: 1px solid rgba(52,211,153,.2);
    text-transform: uppercase; letter-spacing: .8px; font-weight: 700;
  }
  .navbar__links a.navbar__cta::before { display: none; }
  .navbar__links a.navbar__cta:hover { background: var(--green-500); color: #0f1419; border-color: var(--green-500); transform: translateY(-2px); }
  .menu-toggle.active { z-index: 999; }
  .menu-toggle.active span { background: #ffffff !important; }

  /* Scroll lock when menu is open */
  html.menu-open,
  html.menu-open body {
    overflow: hidden;
    height: 100%;
  }
  html.menu-open body {
    position: fixed;
    width: 100%;
  }

  /* Override ALL navbar states when menu is open */
  .navbar.menu-active,
  .navbar.menu-active.scrolled {
    background: transparent !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
  }
  .navbar.menu-active .navbar__logo,
  .navbar.menu-active.scrolled .navbar__logo {
    color: #ffffff !important;
  }

  .navbar.menu-active .logo-icon svg polygon,
  .navbar.menu-active.scrolled .logo-icon svg polygon {
    fill: var(--green-400) !important;
  }
  .navbar.menu-active .menu-toggle,
  .navbar.menu-active.scrolled .menu-toggle {
    background: none !important;
    border: none !important;
  }

  /* Modal — kill backdrop-filter on mobile (fullscreen modal, blur is invisible & expensive) */
  .modal-overlay {
    padding: 0;
    background: rgba(0,0,0,.7);
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  .modal-overlay.active {
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }
  [data-theme="dark"] .modal-overlay {
    background: rgba(0,0,0,.8);
  }
  .modal {
    max-width: 100%;
    max-height: 100vh;
    border-radius: 0;
    height: 100%;
    overflow-x: hidden;
    will-change: transform, opacity;
  }
  .modal__content { padding: 0 1.25rem 1.5rem; }
  .modal__close {
    top: .5rem;
    right: .5rem;
    backdrop-filter: none;
    -webkit-backdrop-filter: none;
  }

  /* Hero */
  .hero {
    padding: 5rem 1.25rem 3rem;
    min-height: 85vh;
    min-height: 85svh;
  }
  .hero__subtitle { font-size: 1rem; margin-bottom: 2rem; }
  .hero__actions { flex-direction: column; align-items: center; }
  .hero__stats { gap: 1.5rem; margin-top: 3rem; }
  .hero__stat-number { font-size: 1.8rem; }
  .hero__stat-label { font-size: .75rem; }

  /* Sections */
  .section { padding: 4rem 1.25rem; }
  .section__header { margin-bottom: 2.5rem; }
  .section__desc { font-size: .95rem; }

  /* Grids */
  .trainers-grid { grid-template-columns: 1fr 1fr; }
  .gyms-grid { grid-template-columns: 1fr 1fr; }
  .sports-grid { grid-template-columns: 1fr 1fr; }

  /* Smaller card images on tablets/mobile */
  .trainer-card__img { height: 220px; }
  .gym-card__img { height: 180px; }
  .sport-card__img { height: 160px; }
  .club-card__img { height: 180px; }
  .features-grid { grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 1.5rem; }

  /* Contact */
  .contact-wrapper { grid-template-columns: 1fr; gap: 2rem; }
  .contact-info { padding: 2rem 1.5rem; }
  .contact-info__title { font-size: 1.5rem; }
  .contact-form { padding: 2rem 1.5rem; }
  .form-row { grid-template-columns: 1fr; }

  /* Footer */
  .footer { padding: 2.5rem 1.25rem 1.25rem; }
  .footer__inner { flex-direction: column; text-align: center; gap: 1.25rem; }
  .footer__links { flex-wrap: wrap; justify-content: center; gap: 1rem; }

  /* ===== Submit form (prijava.html) ===== */
  /* Inputs ≥16px to stop iOS Safari from auto-zooming on focus. */
  .submit-form input,
  .submit-form select,
  .submit-form textarea,
  .map-picker__input,
  .chip-input__field { font-size: 16px; }

  /* Tighter padding inside the form so the long stack of fields fits */
  .submit-form { padding: 1.25rem 1rem; }
  .submit-form-header h2 { font-size: 1.15rem; }
  .form-section-title { font-size: .85rem; margin-top: 1.25rem; }

  /* File upload zones drop into a single column and shrink */
  .file-upload-zone { padding: .85rem; }
  .file-upload-zone__text { font-size: .85rem; }
  .file-upload-zone__preview img { max-width: 100px; max-height: 70px; }

  /* Map picker takes less vertical real estate on phones — the original
     280px height ate most of the viewport, making the rest of the form
     impossible to find without scrolling past the map */
  .map-picker__map { height: 160px; }
  .map-picker__cities { gap: .35rem; padding: .5rem; }
  .map-picker__city { font-size: .8rem; padding: .35rem .65rem; }

  /* Chip input dropdown shouldn't extend past the screen edge */
  .chip-input__dropdown { max-height: clamp(160px, 40vh, 280px); }

  /* Make submit/preview buttons full-width and stacked */
  .submit-form__actions { flex-direction: column; gap: .65rem; }
  .submit-form__actions .btn { width: 100%; }

  /* City autocomplete: cap height so it doesn't push the form */
  .city-autocomplete__list { max-height: clamp(150px, 38vh, 260px); }
}

/* Phone-sized form refinements */
@media (max-width: 480px) {
  .submit-form { padding: 1rem .85rem; border-radius: .85rem; }
  .map-picker__map { height: 130px; }
  .form-row { gap: .65rem; }
  .submit-type-grid { grid-template-columns: 1fr; }
}

/* Small phone */
@media (max-width: 570px) {
  .gyms-grid { grid-template-columns: 1fr; }
  .sports-grid { grid-template-columns: 1fr; }
}
@media (max-width: 480px) {
  .hero__title { font-size: 2rem; }
  .hero__badge { font-size: .75rem; padding: .4rem 1rem; }
  .hero__stats { flex-direction: column; gap: 1rem; align-items: center; }
  .hero__stat { display: flex; align-items: center; gap: .5rem; }
  .hero__stat-number { font-size: 1.5rem; }

  .trainers-grid { grid-template-columns: 1fr; }
  .features-grid { grid-template-columns: 1fr; }

  /* Smaller card images on phones */
  .trainer-card__img { height: 180px; }
  .gym-card__img { height: 160px; }
  .sport-card__img { height: 140px; }
  .club-card__img { height: 160px; }
  .explore-card { min-height: 280px; }
  .explore-card__content { min-height: 280px; }

  /* Tighter card body padding */
  .trainer-card__body,
  .gym-card__body,
  .sport-card__body,
  .club-card__body { padding: 1rem 1.25rem 1.25rem; }

  .feature-item { padding: 1.5rem 1rem; }

  .contact-info__item-value { font-size: .9rem; }

  .footer__links { flex-direction: column; gap: .75rem; }
}
