/* ========================================
   TGVC MOBILE PRODUCT — EXACT COPY FROM EMBEDDED SECTIONS
   ======================================== */

.mob-product-content { display: none; }

@media screen and (max-width: 1024px) {
  .tgvc-grid { display: none !important; }
  .tgvc-product-title { display: none !important; }
  .tgvc-hero { display: none !important; }
  .vp-mob-overlay, .vp-mob-extra, .vp-mob-pricing-box,
  .vp-mob-quick-stats-bar, .vp-mob-compare-cta-wrap,
  .vp-mob-gallery-hint, .vp-mob-cta { display: none !important; }

  .mob-product-content {
    display: block !important;
    font-family: 'DM Sans', -apple-system, BlinkMacSystemFont, sans-serif;
    color: #1a1a2e;
    -webkit-font-smoothing: antialiased;
  }

  .hero-section { position: relative; overflow: hidden; }
  .hero-image { width: 100%; height: auto; display: block; }
  .hero-overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px 20px; background: linear-gradient(transparent, rgba(20,48,66,0.92)); }
  .hero-badge { display: inline-block; background: #fdca21; color: #143042; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; padding: 5px 12px; border-radius: 4px; margin-bottom: 10px; }
  .hero-title { font-family: 'DM Serif Display', Georgia, serif; color: #fff; font-size: 36px; margin-bottom: 6px; line-height: 1; }
  .hero-subtitle { color: rgba(255,255,255,0.9); font-size: 16px; font-weight: 400; }

  .product-desc { padding: 24px 20px; background: #fff; }
  .product-desc p { font-size: 15px; line-height: 1.7; color: #444; margin-bottom: 14px; }
  .product-desc p:last-child { margin-bottom: 0; }
  .product-desc strong { color: #143042; }

  .key-stats { display: flex; border-top: 1px solid #e9ecef; border-bottom: 1px solid #e9ecef; margin: 0 20px 24px; }
  .key-stat { flex: 1; text-align: center; padding: 18px 8px; border-right: 1px solid #e9ecef; }
  .key-stat:last-child { border-right: none; }
  .key-stat-value { font-family: 'DM Sans', sans-serif; font-weight: 700; font-size: 22px; color: #143042; line-height: 1.2; margin-bottom: 4px; }
  .key-stat-label { font-size: 11px; color: #6c757d; text-transform: uppercase; letter-spacing: 0.5px; font-weight: 600; }

  .pricing-section { background: #143042; padding: 28px 20px; margin: 0 20px 24px; border-radius: 4px; text-align: center; }
  .pricing-label { font-size: 12px; color: rgba(255,255,255,0.7); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 1.5px; font-weight: 600; }
  .pricing-amount { font-family: 'DM Serif Display', Georgia, serif; font-size: 44px; color: #fdca21; margin-bottom: 6px; }
  .pricing-note { font-size: 13px; color: rgba(255,255,255,0.6); margin-bottom: 18px; }
  .pricing-cta { background: #0074e0; color: white; padding: 14px 30px; border-radius: 4px; font-weight: 700; font-size: 15px; text-decoration: none; display: inline-block; transition: all 0.2s ease; }
  .pricing-cta:active { opacity: 0.9; }

  .cta-bar { display: flex; gap: 10px; padding: 0 20px 28px; }
  .cta-bar .cta-primary { flex: 1; display: flex; align-items: center; justify-content: center; padding: 14px 8px; background: #143042; color: #fff; font-weight: 700; font-size: 14px; border-radius: 4px; text-decoration: none; text-align: center; }
  .cta-bar .cta-secondary { flex: 1; display: flex; align-items: center; justify-content: center; padding: 14px 8px; border: 2px solid #143042; color: #143042; font-weight: 700; font-size: 14px; border-radius: 4px; text-decoration: none; text-align: center; }

  .gallery-section, .mob-gallery-section { padding: 28px 0; background: #fff; }
  .gallery-section-title, .mob-gallery-title { font-family: 'DM Serif Display', Georgia, serif; color: #143042; font-size: 22px; text-align: center; margin-bottom: 20px; padding: 0 20px; }
  .gallery-scroll, .mob-gallery-scroll { display: flex; gap: 10px; overflow-x: auto; scroll-snap-type: x mandatory; -webkit-overflow-scrolling: touch; padding: 0 20px; scrollbar-width: none; }
  .gallery-scroll::-webkit-scrollbar, .mob-gallery-scroll::-webkit-scrollbar { display: none; }
  .gallery-card, .mob-gallery-card { flex: 0 0 300px; scroll-snap-align: start; border-radius: 4px; overflow: hidden; position: relative; height: 225px; background: #e9ecef; }
  .gallery-card img, .mob-gallery-card img { width: 100%; height: 100%; object-fit: contain; display: block; background: #e9ecef; }
  .gallery-hint, .mob-gallery-hint { text-align: center; font-size: 12px; color: #6c757d; margin-top: 12px; }

  #mobile-spec-section { background-color: #143042; padding: 30px 20px; }
  .spec-section-toggle { display: flex; align-items: center; justify-content: space-between; cursor: pointer; -webkit-tap-highlight-color: transparent; padding: 16px 20px; margin: 0 -20px; position: sticky; top: 0; z-index: 60; background: #143042; transition: box-shadow 0.2s ease; }
  .spec-section-toggle.stuck { box-shadow: 0 2px 8px rgba(0,0,0,0.3); }
  .spec-section-toggle .mobile-spec-title { margin-bottom: 0; text-align: left; }
  .spec-toggle-chevron { color: #fdca21; font-size: 14px; font-weight: 700; letter-spacing: 1px; text-transform: uppercase; display: flex; align-items: center; gap: 6px; flex-shrink: 0; transition: opacity 0.3s ease; }
  .spec-toggle-chevron .chevron { display: inline-block; transition: transform 0.3s ease; }
  .spec-toggle-chevron.open .chevron { transform: rotate(180deg); }
  .spec-quick-stats { display: flex; gap: 0; margin-top: 20px; border-top: 1px solid rgba(255,255,255,0.1); border-bottom: 1px solid rgba(255,255,255,0.1); }
  .spec-quick-stat { flex: 1; text-align: center; padding: 8px 6px; border-right: 1px solid rgba(255,255,255,0.1); display: flex; flex-direction: column; justify-content: space-between; }
  .spec-quick-stat:last-child { border-right: none; }
  .spec-quick-stat-value { font-family: 'DM Sans', sans-serif; font-weight: 700; color: #fff; font-size: 20px; line-height: 1.2; margin-bottom: 4px; }
  .spec-quick-stat-label { color: #fdca21; font-size: 10px; text-transform: uppercase; letter-spacing: 0.5px; font-weight: 700; }
  .spec-collapsible-body { max-height: 0; overflow: hidden; transition: max-height 0.4s ease; }
  .spec-collapsible-body.open { max-height: 3000px; }
  .spec-body-inner { padding-top: 25px; }
  .mobile-spec-title { font-family: 'DM Sans', sans-serif; font-weight: 700; color: #fff; font-size: 22px; text-align: center; margin-bottom: 25px; }
  .mobile-spec-item { margin-bottom: 20px; padding-bottom: 20px; border-bottom: 1px solid rgba(255,255,255,0.1); }
  .mobile-spec-item:last-child { border-bottom: none; }
  .mobile-spec-label { color: #fdca21; font-size: 13px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 8px; display: block; }
  .mobile-spec-value { color: #e2e8f0; font-size: 15px; line-height: 1.6; }
  .mobile-color-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 10px; }
  .mobile-color-item { display: flex; align-items: center; gap: 10px; }
  .mobile-swatch { width: 28px; height: 28px; border-radius: 4px; border: 2px solid rgba(255,255,255,0.3); flex-shrink: 0; }
  .mobile-color-text { display: flex; flex-direction: column; font-size: 12px; }
  .mobile-color-name { color: #fff; font-weight: 600; }
  .mobile-ral-code { color: #94a3b8; font-size: 11px; }
  .mobile-bespoke { grid-column: 1/-1; text-align: center; color: #fdca21; font-weight: 600; font-size: 13px; margin-top: 5px; }
  .mobile-collapsible { background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.12); border-radius: 4px; overflow: hidden; margin-top: 10px; }
  .mobile-collapsible-header { background: rgba(255,255,255,0.08); color: #fff; padding: 12px 15px; font-weight: 600; font-size: 14px; cursor: pointer; display: flex; justify-content: space-between; align-items: center; user-select: none; -webkit-tap-highlight-color: transparent; }
  .mobile-collapsible-header:active { background: rgba(255,255,255,0.12); }
  .mobile-collapsible-icon { font-size: 14px; transition: transform 0.3s ease; color: #fdca21; }
  .mobile-collapsible-icon.open { transform: rotate(180deg); }
  .mobile-collapsible-content { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; padding: 0 15px; }
  .mobile-collapsible-content.open { max-height: 500px; padding: 15px; }
  .mobile-option-list { list-style: none; padding: 0; margin: 0; }
  .mobile-option-list li { color: #e2e8f0; font-size: 14px; padding: 6px 0 6px 16px; position: relative; }
  .mobile-option-list li::before { content: "\2013"; position: absolute; left: 0; color: #fdca21; }
  .mobile-flag-icon { display: inline-block; width: 24px; height: 16px; margin-left: 8px; vertical-align: middle; background-size: cover; border: 1px solid rgba(255,255,255,0.2); border-radius: 2px; }
  .mobile-combination-note { text-align: center; color: #fdca21; font-size: 12px; font-weight: 600; margin-top: 10px; font-style: italic; }
  .mobile-compare-btn { display: block; width: 100%; max-width: 280px; margin: 25px auto 0; padding: 14px 20px; background-color: #0074e0; color: #fff; font-size: 15px; font-weight: 700; text-align: center; text-decoration: none; border-radius: 4px; border: none; -webkit-tap-highlight-color: transparent; }
  .mobile-compare-btn:active { opacity: 0.9; }

  .lightbox-overlay { position: fixed; top: 0; left: 0; right: 0; bottom: 0; background: rgba(0,0,0,0.95); z-index: 2000; display: none; flex-direction: column; align-items: center; justify-content: center; -webkit-tap-highlight-color: transparent; }
  .lightbox-overlay.active { display: flex; }
  .lightbox-close { position: absolute; top: 12px; right: 16px; background: none; border: none; color: #fff; font-size: 32px; font-weight: 300; cursor: pointer; z-index: 2010; width: 44px; height: 44px; display: flex; align-items: center; justify-content: center; line-height: 1; }
  .lightbox-counter { position: absolute; top: 18px; left: 16px; color: rgba(255,255,255,0.6); font-size: 13px; font-weight: 600; z-index: 2010; }
  .lightbox-image-wrap { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; overflow: hidden; touch-action: pan-y; }
  .lightbox-image-wrap img { max-width: 100%; max-height: 80vh; object-fit: contain; border-radius: 4px; user-select: none; -webkit-user-drag: none; transition: opacity 0.2s ease; }
  .lightbox-nav { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(255,255,255,0.15); border: none; color: #fff; font-size: 24px; width: 44px; height: 44px; border-radius: 50%; cursor: pointer; display: flex; align-items: center; justify-content: center; z-index: 2010; backdrop-filter: blur(4px); -webkit-backdrop-filter: blur(4px); }
  .lightbox-nav:active { background: rgba(255,255,255,0.3); }
  .lightbox-prev { left: 10px; }
  .lightbox-next { right: 10px; }
  .lightbox-alt { position: absolute; bottom: 20px; left: 20px; right: 20px; text-align: center; color: rgba(255,255,255,0.5); font-size: 12px; }
}
