/* ═══════════════════════════════════════════════════════════════════
   POKECA — MOBILE RESPONSIVE STYLESHEET
   Targets: ≤768px (tablet), ≤480px (phone), ≤360px (small phone)
   ═══════════════════════════════════════════════════════════════════ */

/* ── GLOBAL TOUCH IMPROVEMENTS ─────────────────────────────────── */
@media (max-width: 768px) {
  /* Reduce container padding on mobile */
  .container { padding: 0 var(--sp-4); }

  /* Better touch scroll */
  * { -webkit-tap-highlight-color: rgba(30,58,95,0.10); }

  /* Prevent layout overflow */
  body { overflow-x: hidden; }
}

/* ── ANNOUNCEMENT BAR ───────────────────────────────────────────── */
@media (max-width: 768px) {
  .ann-bar {
    font-size: 11px;
    padding: 8px var(--sp-4);
    white-space: nowrap;
    overflow-x: auto;
    text-overflow: ellipsis;
    scrollbar-width: none;
  }
  .ann-bar::-webkit-scrollbar { display: none; }
}

/* ── HEADER ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .site-header { position: sticky; top: 0; z-index: 900; }

  .header-inner {
    height: 56px;
    padding: 0 var(--sp-4);
    gap: var(--sp-3);
  }

  /* Logo first, hamburger second (order via flex order) */
  .header-logo { order: 1; flex: 1; }
  .header-logo img { height: 36px; }

  /* Nav moves below header on mobile */
  .header-nav {
    order: 4;
    top: 56px;
    padding: var(--sp-2) var(--sp-3) var(--sp-4);
    gap: 2px;
    box-shadow: 0 8px 24px rgba(15,23,42,0.12);
  }
  .header-nav .nav-link {
    padding: 13px 16px;
    font-size: 15px;
    border-radius: var(--r-md);
    width: 100%;
    text-align: left;
  }

  /* Hamburger visible, ordered after logo */
  .hamburger {
    order: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    flex-shrink: 0;
  }

  /* Header right — only show cart on mobile */
  .header-right {
    order: 3;
    gap: var(--sp-2);
    flex-shrink: 0;
  }

  /* Hide language label, show only icon */
  .lang-btn span#currentLang { display: none; }
  .lang-btn svg:last-child { display: none; }
  .lang-btn { padding: 8px; border-radius: var(--r-md); min-width: 36px; justify-content: center; }

  /* Cart button: icon only on very small screens */
  .order-sidebar-btn {
    padding: 8px 12px;
    font-size: 13px;
    gap: var(--sp-1);
  }
}

@media (max-width: 400px) {
  /* Shrink cart text on tiny screens */
  .order-sidebar-btn { font-size: 0; width: 40px; height: 40px; padding: 0; justify-content: center; gap: 0; }
  .order-sidebar-btn svg { display: block; }
  .order-count-badge { position: absolute; top: -4px; right: -4px; min-width: 18px; height: 18px; font-size: 10px; }
  .order-sidebar-btn { position: relative; }
}

/* ── ORDER SIDEBAR ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .order-sidebar { width: 100vw; max-width: 100vw; }
  .osb-header { padding: var(--sp-4) var(--sp-4); }
  .osb-body { padding: var(--sp-3); }
  .osb-footer { padding: var(--sp-4) var(--sp-4); }
}

/* ── HERO SECTION ───────────────────────────────────────────────── */
@media (max-width: 768px) {
  .hero { min-height: auto; }

  .hero-inner {
    padding: 36px var(--sp-4) 40px;
    grid-template-columns: 1fr;
    gap: var(--sp-6);
  }

  .hero-mosaic { display: none; }

  .hero-h1 {
    font-size: clamp(1.6rem, 7vw, 2.4rem);
    margin-bottom: var(--sp-4);
  }

  .hero-sub {
    font-size: 14px;
    margin-bottom: var(--sp-5);
  }

  .hero-badge {
    font-size: 11px;
    padding: 4px 10px;
    margin-bottom: var(--sp-4);
  }

  .hero-trust-pills {
    gap: var(--sp-1);
    margin-bottom: var(--sp-5);
  }
  .trust-pill {
    font-size: 11px;
    padding: 5px 10px;
  }

  .hero-ctas {
    flex-direction: column;
    gap: var(--sp-2);
  }
  .hero-ctas .btn {
    width: 100%;
    justify-content: center;
    padding: 14px 20px;
    font-size: 14px;
  }
}

/* ── QUICK ORDER SECTION ────────────────────────────────────────── */
@media (max-width: 768px) {
  .quick-order { padding: var(--sp-8) 0; }
  .quick-order-inner { padding: 0 var(--sp-4); }

  .qo-header { margin-bottom: var(--sp-4); }
  .qo-title { font-size: 22px; }

  /* Horizontally scrollable tabs */
  .qo-tabs {
    overflow-x: auto;
    scrollbar-width: none;
    -webkit-overflow-scrolling: touch;
    gap: 0;
    flex-wrap: nowrap;
  }
  .qo-tabs::-webkit-scrollbar { display: none; }
  .qo-tab {
    padding: 10px 16px;
    font-size: 13px;
    white-space: nowrap;
    flex-shrink: 0;
  }

  /* Filter bar: stack vertically */
  .qo-filter-bar {
    flex-direction: column;
    align-items: stretch;
    gap: var(--sp-3);
    margin-bottom: var(--sp-4);
  }

  .qo-count { font-size: 13px; color: var(--text-400); }

  .qo-filters {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-2);
    width: 100%;
  }

  /* Stock toggle gets its own row */
  .stock-toggle {
    grid-column: 1 / -1;
    padding: 8px 0;
    font-size: 14px;
  }
  .stock-toggle-track { width: 38px; height: 20px; }
  .stock-toggle-track::after { width: 16px; height: 16px; }
  .stock-toggle input:checked + .stock-toggle-track::after { transform: translateX(18px); }

  /* Search: full width, own row */
  .qo-search-wrap { grid-column: 1 / -1; }
  .qo-search { width: 100%; font-size: 14px; padding: 10px 12px 10px 34px; }
  .qo-search:focus { width: 100%; }

  /* Selects: half width each */
  .qo-select {
    width: 100%;
    font-size: 13px;
    padding: 9px 10px;
  }

  /* View toggle: own row, right aligned */
  .view-toggle { grid-column: 1 / -1; align-self: flex-end; width: fit-content; }
  .view-btn { padding: 9px 14px; font-size: 13px; }
}

@media (max-width: 480px) {
  .qo-filters { grid-template-columns: 1fr; }
  .qo-select { font-size: 14px; padding: 11px 12px; }
  .view-toggle { width: 100%; }
  .view-btn { flex: 1; justify-content: center; }
}

/* ── PRODUCT IMAGE GRID ─────────────────────────────────────────── */
@media (max-width: 768px) {
  .product-image-grid {
    grid-template-columns: repeat(auto-fill, minmax(155px, 1fr));
    gap: var(--sp-3);
  }
}

@media (max-width: 480px) {
  .product-image-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: var(--sp-2);
  }
}

/* ── PRODUCT IMAGE CARD (pimg-card) ─────────────────────────────── */
@media (max-width: 768px) {
  /* On mobile, hover overlay is not usable — hide it */
  .pimg-hover-overlay { display: none; }

  .pimg-card-body {
    padding: var(--sp-2) var(--sp-3) var(--sp-3);
    gap: 3px;
  }

  .pimg-name { font-size: 11px; }
  .pimg-sku  { font-size: 10px; }

  .pimg-stock-row { margin-top: 2px; }
  .pimg-total-stock { font-size: 10px; }

  .pimg-variants { gap: 4px; margin-top: var(--sp-1); }

  .pimg-variant-top { gap: 4px; }
  .pv-type  { font-size: 9px; }
  .pv-price { font-size: 12px; }
  .pv-stock { font-size: 9px; }

  /* Larger touch targets for qty buttons */
  .qty-btn {
    width: 28px;
    height: 28px;
    font-size: 16px;
    border-radius: 6px;
  }
  .qty-val { font-size: 12px; min-width: 22px; }
}

@media (max-width: 360px) {
  .product-image-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 8px;
  }
  .pimg-card-body { padding: 6px 8px 8px; }
  .pimg-name { font-size: 10px; }
  .pv-price { font-size: 11px; }
  /* Stack variant rows on very small screens */
  .pimg-variant-bottom { flex-direction: column; align-items: flex-start; gap: 4px; }
}

/* ── PRODUCT LIST VIEW ──────────────────────────────────────────── */
@media (max-width: 768px) {
  .plist-card { flex-direction: row; align-items: stretch; }

  .plist-img-col { width: 72px; min-height: 72px; flex-shrink: 0; }

  .plist-body {
    flex-direction: column;
    padding: var(--sp-2) var(--sp-3);
    gap: var(--sp-2);
    align-items: stretch;
  }

  .plist-top { min-width: unset; }
  .plist-name { font-size: 13px; }
  .plist-sku { font-size: 10px; }

  .plist-variants {
    flex-direction: row;
    flex-wrap: wrap;
    gap: var(--sp-2);
  }

  .plist-variant {
    flex: 1;
    min-width: 120px;
    flex-direction: column;
    align-items: flex-start;
    gap: 3px;
    background: var(--bg-elevated);
    border: 1px solid var(--border-100);
    border-radius: var(--r-sm);
    padding: var(--sp-2);
  }

  .pv-price-big { font-size: 14px; }

  .plist-variant .pimg-qty-ctrl {
    margin-top: 2px;
  }
}

@media (max-width: 480px) {
  .plist-variants { flex-direction: column; gap: var(--sp-2); }
  .plist-variant { min-width: unset; flex-direction: row; align-items: center; justify-content: space-between; flex-wrap: wrap; }
}

/* ── PRODUCT DETAIL MODAL (bottom sheet) — mobile improvements ── */
@media (max-width: 480px) {
  .pdm-sheet { border-radius: 16px 16px 0 0; }
  .pdm-scroll { padding: 12px 16px 32px; gap: 14px; }
  .pdm-img-wrap { height: 200px; }
  .pdm-name { font-size: 16px; }
  .pdm-variant-price { font-size: 19px; }
  .pdm-qty-btn { width: 44px; height: 48px; font-size: 22px; }
  .pdm-done-btn { padding: 18px; font-size: 15px; border-radius: 14px; }
}

/* ── SHIPPING STRIP ─────────────────────────────────────────────── */
@media (max-width: 768px) {
  .ship-strip { padding: var(--sp-4) 0; }
  .ship-strip-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-4);
    padding: 0 var(--sp-4);
    justify-items: start;
  }
  .ship-item {
    font-size: 12px;
    gap: var(--sp-2);
  }
  .ship-item svg { width: 22px; height: 22px; }
  .ship-item strong { font-size: 13px; }
}

@media (max-width: 480px) {
  .ship-strip-inner { grid-template-columns: 1fr; gap: var(--sp-3); }
}

/* ── FOOTER ─────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .site-footer { padding-top: var(--sp-10); margin-top: var(--sp-10); }

  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--sp-6);
    padding: 0 var(--sp-4) var(--sp-8);
  }
  .footer-brand { grid-column: 1 / -1; }
  .footer-brand p { font-size: 13px; }

  .site-footer h4 { font-size: 10px; margin-bottom: var(--sp-3); }
  .site-footer a { font-size: 13px; margin-bottom: var(--sp-1); }

  .social-btn { font-size: 12px; padding: 8px 12px; }

  .footer-bottom {
    flex-direction: column;
    align-items: center;
    text-align: center;
    padding: var(--sp-4);
    gap: var(--sp-3);
  }
  .footer-links { justify-content: center; gap: var(--sp-3); flex-wrap: wrap; }
  .footer-links a { font-size: 12px; }
  .footer-bottom p { font-size: 12px; }

  .footer-rating { font-size: 2rem; }
  .footer-stars { font-size: 16px; }
}

@media (max-width: 480px) {
  .footer-grid { grid-template-columns: 1fr; gap: var(--sp-5); }
}

/* ── FLOAT BUTTONS ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .wa-float-btn {
    bottom: 80px;
    right: 16px;
    width: 50px;
    height: 50px;
  }
  .tg-float-btn {
    bottom: 20px;
    right: 16px;
    width: 50px;
    height: 50px;
  }
  /* Hide tooltips on mobile (no hover) */
  .wa-float-btn .wa-tooltip,
  .tg-float-btn .tg-tooltip { display: none; }
}

/* ── MODAL (general) ────────────────────────────────────────────── */
@media (max-width: 768px) {
  .modal-overlay {
    padding: 0;
    align-items: flex-end;
  }
  .modal {
    border-radius: var(--r-xl) var(--r-xl) 0 0;
    max-height: 92vh;
    max-width: 100%;
  }
  .modal-header { padding: var(--sp-4) var(--sp-4); }
  .modal-body { padding: var(--sp-4); }
  .modal-title { font-size: 15px; }
}

/* ── PAGINATION ─────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .page-btn {
    width: 36px;
    height: 36px;
    font-size: 13px;
  }
}

/* ── CATEGORY PAGE ──────────────────────────────────────────────── */
@media (max-width: 768px) {
  .category-page-inner { padding: 0 var(--sp-4); }
  .category-page-header { padding: 40px var(--sp-4) 30px; }
  .category-hero { padding: var(--sp-6) var(--sp-4); margin-bottom: var(--sp-5); }
  .category-hero-title { font-size: 1.6rem; }
  .category-hero-sub { font-size: 14px; }
  .category-hero-badge { display: none; }

  .filter-tabs { gap: var(--sp-1); overflow-x: auto; flex-wrap: nowrap; padding-bottom: 4px; }
  .filter-tab { white-space: nowrap; flex-shrink: 0; }
}

/* ── ABOUT PAGE ─────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .about-hero-fullbleed { padding: 48px var(--sp-4) 40px; }
  .about-content-wrap { padding: var(--sp-6) var(--sp-4); }
  .about-features { grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
  .about-feature { padding: var(--sp-5) var(--sp-4); }
  .about-table { font-size: 13px; }
  .about-table td { padding: 10px 14px; }
  .about-table td:first-child { width: 120px; font-size: 11px; }
}

@media (max-width: 480px) {
  .about-features { grid-template-columns: 1fr; }
  .about-table { display: block; overflow-x: auto; }
}

/* ── NEWS PAGE ──────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .news-page-inner { padding: 0 var(--sp-4); }
  .news-grid { grid-template-columns: 1fr; gap: var(--sp-4); }
}

/* ── CONTACT PAGE ───────────────────────────────────────────────── */
@media (max-width: 768px) {
  .contact-page { padding: var(--sp-6) var(--sp-4); }
  .contact-info-panel,
  .contact-form-panel { padding: var(--sp-5); }
  .contact-page-title { font-size: 1.5rem; }
}

/* ── CARD LIST PAGE ─────────────────────────────────────────────── */
@media (max-width: 768px) {
  .cardlist-hero { padding: 48px var(--sp-4) 36px; }
  .cardlist-content { padding: var(--sp-6) var(--sp-4); }
  .cardlist-grid { grid-template-columns: 1fr; gap: var(--sp-4); }
  .cardlist-card { padding: var(--sp-6) var(--sp-5); }
}

/* ── LANGUAGE BANNER ────────────────────────────────────────────── */
@media (max-width: 768px) {
  .lang-banner-inner { flex-direction: column; align-items: flex-start; gap: var(--sp-2); }
  #lang-banner { padding: var(--sp-3) var(--sp-4); font-size: 13px; }
}

/* ── LANG DROPDOWN ──────────────────────────────────────────────── */
@media (max-width: 480px) {
  .lang-dropdown { right: -8px; min-width: 140px; }
}

/* ── TOAST ──────────────────────────────────────────────────────── */
@media (max-width: 480px) {
  .toast {
    left: var(--sp-4);
    right: var(--sp-4);
    transform: translateY(20px);
    width: auto;
    white-space: normal;
    text-align: center;
  }
  .toast.show {
    transform: translateY(0);
  }
}

/* ── CHECKOUT MODAL ─────────────────────────────────────────────── */
@media (max-width: 768px) {
  .checkout-modal { max-width: 100%; }
  .payment-methods-grid { grid-template-columns: repeat(3, 1fr); }
  .checkout-item-name { font-size: 13px; }
  .checkout-total-val { font-size: 18px; }
}

/* ── LEGAL PAGES ────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .legal-page-wrap { padding: var(--sp-6) var(--sp-4); }
  .legal-section-title { font-size: 0.95rem; }
  .legal-section-body { font-size: 13px; }
}

/* ── SOCIAL PROOF POPUP ─────────────────────────────────────────── */
@media (max-width: 480px) {
  #social-proof-container {
    left: 8px;
    right: 8px;
    bottom: 76px;
  }
}

/* ── CONTACT POPUP (checkout contact) ──────────────────────────── */
@media (max-width: 480px) {
  .contact-popup { padding: var(--sp-5); margin: var(--sp-4); }
  .contact-popup-icon { font-size: 44px; }
  .contact-popup-title { font-size: 18px; }
  .contact-popup-text { font-size: 14px; }
  .contact-popup-btn { font-size: 14px; padding: 12px 18px; }
}

/* ── IMPROVED PIMG CARD ON MOBILE — show tap hint ──────────────── */
@media (max-width: 768px) {
  /* Subtle tap indicator on mobile to invite interaction */
  .pimg-card::after {
    content: '↗';
    position: absolute;
    top: 8px;
    right: 8px;
    width: 24px;
    height: 24px;
    background: rgba(30,58,95,0.75);
    color: white;
    font-size: 12px;
    font-weight: 700;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    z-index: 3;
    pointer-events: none;
    line-height: 24px;
    text-align: center;
  }
}

/* ── SECTION SPACING ────────────────────────────────────────────── */
@media (max-width: 768px) {
  .quick-order { padding: var(--sp-6) 0; }
  .site-footer { margin-top: var(--sp-8); }
}

/* ── DISABLE HOVER ANIMATIONS ON TOUCH ─────────────────────────── */
@media (hover: none) {
  .pimg-card:hover { transform: none; box-shadow: none; }
  .plist-card:hover { transform: none; }
  .mosaic-card:hover { transform: rotate(0deg) scale(1); }
  .value-card:hover { transform: none; }
  .btn:hover { transform: none; }
  .btn-primary:hover { transform: none; }
  .btn-brown:hover { transform: none; }
  .social-btn:hover { transform: none; }
}

/* ── FIX: background-attachment:fixed broken on iOS ────────────── */
@media (max-width: 768px) {
  .about-page,
  .about-page::before,
  .news-page,
  .news-grid-wrap,
  .contact-page,
  .legal-page-wrap {
    background-attachment: scroll !important;
  }

  body::after {
    position: absolute !important;
    background-attachment: scroll !important;
  }
}

/* ── FIX: pimg-card::after tap indicator (needs display:flex fix) ─ */
@media (max-width: 768px) {
  .pimg-card { position: relative; }
  .pimg-card::after {
    content: '↗';
    position: absolute;
    top: 8px;
    right: 8px;
    width: 22px;
    height: 22px;
    background: rgba(30,58,95,0.80);
    color: white;
    font-size: 11px;
    border-radius: 50%;
    display: block;
    line-height: 22px;
    text-align: center;
    z-index: 3;
    pointer-events: none;
  }
}

/* ── FIX: social-proof container positioning on mobile ──────────── */
@media (max-width: 480px) {
  #social-proof-container {
    left: 8px !important;
    right: 8px !important;
    bottom: 76px !important;
    pointer-events: none;
  }
}

/* ── FIX: qo-filters — proper wrapping even in column mode ─────── */
@media (max-width: 768px) {
  /* The whole filter section should not horizontally overflow */
  .qo-filter-bar { overflow: visible; }
  .qo-filters { overflow: visible; }

  /* Select elements: full-width and properly sized */
  select.qo-select {
    -webkit-appearance: none;
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 10px center;
    padding-right: 28px;
  }
}

/* ── FIX: plist-card on very small screens ──────────────────────── */
@media (max-width: 360px) {
  .plist-img-col { width: 60px; }
  .plist-name { font-size: 12px; }
  .plist-variant { flex-direction: column; align-items: flex-start; }
}

/* ── FIX: header-right on mobile — prevent overflow ─────────────── */
@media (max-width: 768px) {
  .header-right { flex-shrink: 0; }
  .lang-switcher { flex-shrink: 0; }

  /* Keep the lang dropdown from going off screen */
  .lang-dropdown { right: 0; }
}

/* ── EXTRA: Grid pagination touch targets ───────────────────────── */
@media (max-width: 768px) {
  #gridPagination { margin-top: var(--sp-6); }
  .page-btn {
    min-width: 40px;
    height: 40px;
    font-size: 14px;
    border-radius: var(--r-md);
  }
}

/* ── EXTRA: Improve hero CTA button text on very small screens ──── */
@media (max-width: 360px) {
  .hero-ctas .btn { font-size: 13px; padding: 13px 16px; }
  .hero-h1 { font-size: 1.4rem; }
  .qo-title { font-size: 19px; }
}
