/*
 * mobile-responsive.css — Global mobile-first responsive polish.
 * Loaded on ALL pages. Covers: phones (360–480px), tablets (768–1024px),
 * and fills gaps in every page-specific stylesheet.
 *
 * Breakpoints used:
 *   ≤1024px  — large tablet / small laptop
 *   ≤767px   — tablet / large phone (hamburger already active)
 *   ≤480px   — standard phone
 *   ≤360px   — small phone (iPhone SE, Galaxy A series)
 */

/* ─────────────────────────────────────────────────────────────
   1. UNIVERSAL BASE — overflow, image, and touch safety
   ───────────────────────────────────────────────────────────── */

html, body { max-width: 100%; }

img, video, iframe, svg { max-width: 100%; }

/* iOS Safari: prevent font zoom on input focus (requires ≥16px) */
@media (max-width: 767px) {
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="number"],
  input[type="search"],
  input[type="url"],
  input[type="password"],
  select,
  textarea {
    font-size: 16px !important;
  }
}

/* Touch target minimum — all interactive controls at ≥44px */
@media (max-width: 959px) {
  .btn-accent, .btn-ghost, .btn-primary, .btn-outline,
  .hero-cta, .hero-cta-secondary,
  .cta-btn-accent, .cta-btn-outline,
  .form-submit, .btn-submit, .rfq-submit,
  .tab-btn { min-height: 44px; }
}

/* ─────────────────────────────────────────────────────────────
   2. HEADER / NAV
   ───────────────────────────────────────────────────────────── */

/* Very small phones: shrink or hide search to prevent overflow */
@media (max-width: 400px) {
  .site-search { max-width: 140px; }
  .site-search input { padding: 5px 8px 5px 26px; font-size: 11px; }
}

@media (max-width: 340px) {
  .site-search { display: none; }
}

/* ─────────────────────────────────────────────────────────────
   3. HOMEPAGE
   ───────────────────────────────────────────────────────────── */

/* --- Tablet (≤1024px) --- */
@media (max-width: 1024px) {
  .ind-grid  { grid-template-columns: repeat(2, 1fr); }
  .fam-grid  { grid-template-columns: repeat(3, 1fr); }
  .value-inner { grid-template-columns: 1fr; gap: 36px; padding: 56px 32px; }
  .services-inner { grid-template-columns: repeat(2, 1fr); gap: 14px; padding: 40px 32px; }
  .cta-inner { flex-direction: column; align-items: flex-start; text-align: left; padding: 48px 32px; gap: 28px; }
  .cta-form  { flex-direction: column; width: 100%; gap: 10px; }
  .cta-form input { min-width: unset; width: 100%; }
  .cta-form button { width: 100%; }
}

/* --- Mobile (≤767px) --- */
@media (max-width: 767px) {
  .hero { padding: 52px 0 0; }
  .hero-inner { padding: 0 20px; }
  .hero-headline { font-size: 36px; letter-spacing: -1px; line-height: 1.12; }
  .hero-sub { font-size: 14px; }
  .hero-search { margin-bottom: 28px; }
  .stat-strip { flex-wrap: wrap; }
  .stat-item { flex: 1 1 50%; padding: 20px; border-right: none; border-bottom: 1px solid rgba(255,255,255,0.05); }
  .stat-item:nth-child(odd) { border-right: 1px solid rgba(255,255,255,0.05); }
  .stat-item:last-child, .stat-item:nth-last-child(2):nth-child(odd) { border-bottom: none; }
  .doors { padding: 36px 20px; }
  .doors-header { flex-direction: column; align-items: flex-start; gap: 8px; margin-bottom: 24px; }
  .doors-header p { text-align: left; max-width: 100%; }
  .ind-grid { grid-template-columns: 1fr; gap: 10px; }
  .fam-grid { grid-template-columns: repeat(2, 1fr); gap: 8px; }
  .value-inner { padding: 48px 20px; gap: 28px; }
  .value-cards { grid-template-columns: 1fr; gap: 12px; }
  .featured { padding: 36px 20px; }
  .services-inner { grid-template-columns: 1fr; padding: 36px 20px; }
  .cta-inner { padding: 40px 20px; text-align: center; align-items: center; }
  .cta-text { text-align: center; }
  .cta-form input { min-width: unset; width: 100%; }
  .footer { padding: 40px 20px 28px; }
  .footer-inner-grid { grid-template-columns: 1fr; }
  .footer-links { grid-template-columns: repeat(2, 1fr); gap: 24px; }
  .footer-bottom { flex-direction: column; text-align: center; gap: 12px; }
  .footer-badges { justify-content: center; }
}

/* --- Small phone (≤480px) --- */
@media (max-width: 480px) {
  .hero { padding: 40px 0 0; }
  .hero-inner { padding: 0 16px; }
  .hero-headline { font-size: 28px; line-height: 1.15; }
  .hero-sub { font-size: 13px; margin-bottom: 28px; }
  .hero-search input { padding: 14px 16px 14px 40px; }
  .hero-eyebrow { margin-bottom: 18px; }
  .stat-strip { flex-direction: column; }
  .stat-item { flex: none; width: 100%; border-right: none !important; border-bottom: 1px solid rgba(255,255,255,0.05) !important; padding: 16px; }
  .stat-item:last-child { border-bottom: none !important; }
  .stat-num { font-size: 24px; }
  .doors { padding: 24px 16px 20px; }
  .doors-header h2 { font-size: 20px; }
  .doors-tabs { width: 100%; }
  .doors-tabs button { flex: 1; padding: 9px 10px; font-size: 11px; }
  .ind-card-name { font-size: 14px; }
  .ind-card-desc { font-size: 11px; }
  .fam-card-name { font-size: 12px; }
  .fam-grid { grid-template-columns: 1fr; }
  .value-inner { padding: 32px 16px; }
  .value-heading { font-size: 26px; }
  .value-card { padding: 20px 18px; }
  .featured { padding: 24px 16px; }
  .featured-header { flex-direction: column; align-items: flex-start; gap: 8px; }
  .featured-header h2 { font-size: 18px; }
  .services-inner { padding: 24px 16px; }
  .svc-card { padding: 24px 20px; }
  .cta-inner { padding: 32px 16px; }
  .cta-text h2 { font-size: 20px; }
  .footer { padding: 32px 16px 24px; }
  .footer-links { grid-template-columns: 1fr 1fr; gap: 18px; }
}

/* --- Smallest phones (≤360px) --- */
@media (max-width: 360px) {
  .hero-headline { font-size: 22px; }
  .hero-sub { font-size: 12px; }
  .stat-num { font-size: 20px; }
  .doors { padding: 20px 12px; }
  .value-inner { padding: 28px 12px; }
  .featured { padding: 20px 12px; }
  .services-inner { padding: 20px 12px; }
  .cta-inner { padding: 24px 12px; }
  .footer { padding: 24px 12px 20px; }
  .footer-links { grid-template-columns: 1fr; gap: 14px; }
}

/* ─────────────────────────────────────────────────────────────
   4. CONTACT PAGE
   ───────────────────────────────────────────────────────────── */

/* Hero: fixed 480px height collapses properly at all mobile sizes */
@media (max-width: 767px) {
  .page-template-contact .hero,
  .contact-section ~ .hero { height: auto; min-height: auto; }
}

/* --- Small phone (≤480px) --- */
@media (max-width: 480px) {
  /* Hero */
  .hero-text h1 { font-size: 22px !important; }
  .hero-text .tagline { font-size: 13px !important; }
  /* Quick strip */
  .quick-strip { padding: 16px; }
  .quick-strip-inner { flex-direction: column; align-items: flex-start; gap: 12px; }
  .quick-contacts { flex-direction: column; gap: 10px; width: 100%; }
  .qc-item { width: 100%; }
  /* Contact section */
  .contact-section { padding: 24px 16px; }
  .contact-grid { gap: 24px; }
  .contact-info h2 { font-size: 20px; }
  .contact-info .intro { font-size: 13px; margin-bottom: 24px; }
  .contact-cards { gap: 8px; margin-bottom: 20px; }
  .contact-card { padding: 14px 16px; gap: 12px; }
  .cc-icon { width: 36px; height: 36px; }
  .cc-value { font-size: 13px; }
  .hours-note { padding: 12px 14px; }
  .hours-note p { font-size: 12px; }
  /* Form */
  .form-head { padding: 16px 18px; }
  .form-head h3 { font-size: 15px; }
  .form-body { padding: 18px 16px; }
  .form-group { margin-bottom: 12px; }
  .form-group input,
  .form-group select,
  .form-group textarea { padding: 10px 12px; }
  .form-submit { min-height: 48px; font-size: 14px; }
  .bottom-cta-inner { padding: 24px 16px; }
}

@media (max-width: 360px) {
  .contact-section { padding: 20px 12px; }
  .form-body { padding: 14px 12px; }
  .quick-strip { padding: 12px; }
}

/* ─────────────────────────────────────────────────────────────
   5. PRODUCT PAGES
   ───────────────────────────────────────────────────────────── */

/* Prevent CAS / formula strings overflowing hero on narrow screens */
.product-ids { flex-wrap: wrap; word-break: break-all; gap: 2px 6px; }

/* --- Tablet (≤960px already in product.css, add small-phone fixes) --- */
@media (max-width: 480px) {
  .product-hero { padding: 28px 16px 24px; }
  h1.product-name { font-size: 22px; letter-spacing: -0.5px; }
  .product-abbrev { font-size: 12px; }
  .hero-desc { font-size: 13px; line-height: 1.7; margin-bottom: 20px; }
  .hero-actions { flex-direction: column; }
  .hero-actions .btn-accent,
  .hero-actions .btn-ghost { width: 100%; justify-content: center; min-height: 48px; }
  .product-body { padding: 20px 14px 48px; }
  /* Cards */
  .card-head { padding: 12px 16px; }
  .card-body { padding: 14px 16px; }
  /* RFQ form sidebar */
  .rfq-head { padding: 18px 18px; }
  .rfq-head h3 { font-size: 16px; }
  .rfq-body { padding: 16px 18px; }
  .btn-submit { min-height: 48px; font-size: 14px; }
  .rfq-note { font-size: 11px; }
  /* Packaging & related */
  .pkg { padding: 16px; }
  .pkg-item { padding: 10px 12px; }
  .related { padding: 16px; }
  /* Chemical identity table */
  .chem-identity td:first-child { width: 100px; font-size: 9px; }
  .chem-identity td:last-child { font-size: 11px; }
}

@media (max-width: 360px) {
  .product-hero { padding: 20px 12px 20px; }
  h1.product-name { font-size: 19px; }
  .product-body { padding: 16px 12px 40px; }
  .fg-row { grid-template-columns: 1fr; }
  .card-head { padding: 10px 12px; }
  .card-body { padding: 12px; }
}

/* ─────────────────────────────────────────────────────────────
   6. INDUSTRY / INDUSTRIES / SERVICES — shared layout + RFQ
   ───────────────────────────────────────────────────────────── */

/* --- Hero on all shared-layout pages --- */
@media (max-width: 480px) {
  .hero-text-col { padding: 24px 16px !important; }
  .hero-text h1 { font-size: 22px !important; line-height: 1.2; margin-bottom: 10px; }
  .hero-text .tagline { font-size: 12px !important; margin-bottom: 14px; }
  .hero-chips { gap: 5px; margin-bottom: 14px; }
  .hero-chip { padding: 5px 9px; font-size: 9px; }
  .hero-ctas { gap: 8px; flex-direction: column; }
  .hero-cta, .hero-cta-secondary { width: 100%; justify-content: center; }
}

@media (max-width: 360px) {
  .hero-text-col { padding: 20px 12px !important; }
  .hero-text h1 { font-size: 19px !important; }
}

/* --- Tab bar --- */
@media (max-width: 480px) {
  .tab-bar-inner { padding: 0 12px; }
  .tab-btn { padding: 8px 10px; font-size: 10px; gap: 3px; }
}

@media (max-width: 360px) {
  .tab-btn { padding: 7px 8px; font-size: 9px; }
}

/* --- Tab panel inner content --- */
@media (max-width: 480px) {
  .panel-inner { padding: 20px 16px 36px; }
  .section-eyebrow { font-size: 9px; }
  .section-title { font-size: 18px; }
  .section-desc { font-size: 12px; margin-bottom: 18px; }
}

@media (max-width: 360px) {
  .panel-inner { padding: 16px 12px 28px; }
  .section-title { font-size: 16px; }
}

/* --- Overview grid --- */
@media (max-width: 480px) {
  .overview-grid { grid-template-columns: 1fr; gap: 16px; margin-bottom: 24px; }
  .overview-text h2 { font-size: 18px; }
  .overview-text p { font-size: 12px; margin-bottom: 12px; }
  .supply-categories { margin-top: 20px; }
  .supply-categories h3 { font-size: 14px; margin-bottom: 10px; }
  .cat-pill { padding: 7px 12px; font-size: 11px; }
  .overview-cta-row { flex-direction: column; gap: 8px; padding-top: 20px; margin-top: 20px; }
  .btn-primary, .btn-ghost { width: 100%; justify-content: center; }
}

/* --- Tile / Family / Proc grids --- */
@media (max-width: 480px) {
  .tile-grid { grid-template-columns: 1fr; gap: 8px; }
  .families-grid { grid-template-columns: 1fr; gap: 8px; }
  .tile-card, .family-card { padding: 14px; }
  .tile-card .t-title, .family-card .f-name { font-size: 13px; }
  .tile-card .t-desc, .family-card .f-purpose { font-size: 11px; }
  .proc-grid { grid-template-columns: 1fr; gap: 8px; }
  .proc-card { padding: 20px 16px; }
  .proc-icon-wrap { width: 44px; height: 44px; }
  /* Industries card grid */
  .industries-grid { grid-template-columns: 1fr; gap: 8px; }
  .assoc-grid { grid-template-columns: 1fr; gap: 8px; }
  /* Services */
  .services-grid { grid-template-columns: 1fr; gap: 8px; }
  .service-card { padding: 20px 16px; }
  .benefits-grid { grid-template-columns: 1fr; gap: 8px; }
  .benefit-card { padding: 20px 16px; }
}

@media (max-width: 360px) {
  .tile-card, .family-card, .proc-card { padding: 12px; }
  .tile-card .t-title, .family-card .f-name { font-size: 12px; }
  .proc-card h4 { font-size: 13px; }
}

/* --- Segment toggle --- */
@media (max-width: 480px) {
  .segment-toggle { width: 100%; flex-wrap: wrap; }
  .seg-btn { flex: 1 1 calc(50% - 4px); text-align: center; padding: 7px 8px; font-size: 10px; }
}

@media (max-width: 360px) {
  .seg-btn { font-size: 9px; padding: 6px 6px; }
}

/* ─────────────────────────────────────────────────────────────
   7. FLOATING RFQ PANEL — bottom sheet on mobile
   ───────────────────────────────────────────────────────────── */

/*
 * On tablets (768–1199px) the rfq-float is already display:none.
 * On phones (≤767px) we convert it to a full-width bottom sheet.
 * It remains hidden until the user taps "Request Bulk Quote" or
 * any CTA that runs: document.getElementById('rfqPanel').classList.remove('collapsed')
 */

@media (max-width: 767px) {
  /* Collapsed (default): hidden off-screen below */
  .rfq-float {
    display: block !important;
    position: fixed !important;
    bottom: 0 !important;
    left: 0 !important;
    right: 0 !important;
    top: auto !important;
    width: 100% !important;
    max-width: 100% !important;
    max-height: 88vh;
    overflow-y: auto;
    overflow-x: hidden;
    border-radius: 20px 20px 0 0;
    z-index: 9995;
    transform: translateY(100%) !important;
    transition: transform 0.38s cubic-bezier(0.22, 0.61, 0.36, 1) !important;
    box-shadow: 0 -6px 40px rgba(0, 0, 0, 0.28) !important;
  }

  /* Open: slide up into view */
  .rfq-float:not(.collapsed) {
    transform: translateY(0) !important;
  }

  /* Drag handle on header */
  .rfq-head {
    border-radius: 20px 20px 0 0;
    padding: 10px 18px 14px !important;
    cursor: pointer;
  }

  .rfq-head::before {
    content: '';
    display: block;
    width: 40px;
    height: 4px;
    background: rgba(255, 255, 255, 0.28);
    border-radius: 2px;
    margin: 0 auto 12px;
  }

  /* Side-rail toggle: hidden on mobile (no space, panel uses CTAs to open) */
  .rfq-toggle { display: none !important; }

  /* Body scroll lock hint — handled by JS but won't break without it */
  .rfq-body { padding: 14px 18px 24px; max-height: calc(88vh - 80px); overflow-y: auto; }

  /* Full-width submit button */
  .rfq-submit { min-height: 48px; font-size: 14px; }
}

@media (max-width: 480px) {
  .rfq-float { max-height: 92vh; }
  .rfq-head { padding: 10px 14px 12px !important; }
  .rfq-body { padding: 12px 14px 20px; }
  .rfq-row { grid-template-columns: 1fr 1fr; }
  .rfq-field { margin-bottom: 10px; }
  .rfq-field input,
  .rfq-field select,
  .rfq-field textarea { padding: 8px 10px; }
  .rfq-badge { font-size: 9px; padding: 2px 7px; }
  .rfq-note { font-size: 10px; }
}

@media (max-width: 360px) {
  .rfq-row { grid-template-columns: 1fr; gap: 0; }
  .rfq-body { padding: 10px 12px 18px; }
  .rfq-field input,
  .rfq-field select,
  .rfq-field textarea { padding: 7px 9px; font-size: 14px; }
  .rfq-submit { font-size: 13px; }
}

/* ─────────────────────────────────────────────────────────────
   8. ARCHIVE / CATALOG
   ───────────────────────────────────────────────────────────── */

@media (max-width: 960px) {
  .archive-header { padding: 28px 20px; }
  .archive-layout { padding: 20px 20px 48px; gap: 20px; }
  .filter-sidebar { margin-bottom: 8px; }
}

@media (max-width: 480px) {
  .archive-header { padding: 20px 16px; }
  .archive-header h1 { font-size: 22px; }
  .archive-header p { font-size: 12px; }
  .archive-layout { padding: 16px 14px 40px; gap: 16px; }
  .product-grid { grid-template-columns: 1fr; gap: 10px; }
  .product-grid-toolbar { flex-direction: column; align-items: flex-start; gap: 8px; }
  .product-card { padding: 16px; }
  .product-card-name { font-size: 13px; }
  .product-card-desc { font-size: 11px; }
  .filter-panel-head { padding: 12px 14px; }
  .filter-group-head { padding: 10px 14px; }
  .filter-group-body { padding: 6px 14px 10px; }
  .filter-search-wrap { padding: 12px 14px; }
  .filter-apply { width: calc(100% - 28px); margin: 12px 14px; }
  .active-filters { gap: 5px; }
  .active-filter-tag { font-size: 10px; padding: 4px 9px; }
  .archive-pagination { margin-top: 24px; }
  .page-numbers li a,
  .page-numbers li span { width: 32px; height: 32px; font-size: 12px; }
}

@media (max-width: 360px) {
  .archive-header { padding: 16px 12px; }
  .archive-layout { padding: 12px 12px 32px; }
  .product-card { padding: 14px 12px; }
  .filter-panel-head { padding: 10px 12px; }
  .filter-group-head { padding: 8px 12px; }
  .filter-group-body { padding: 4px 12px 8px; }
  .filter-apply { width: calc(100% - 24px); margin: 10px 12px; }
}

/* ─────────────────────────────────────────────────────────────
   9. PROCUREMENT PAGE
   ───────────────────────────────────────────────────────────── */

@media (max-width: 767px) {
  .proc-hero { padding: 40px 20px; }
  .proc-hero h1 { font-size: 26px; }
  .proc-body { padding: 36px 20px; }
  .proc-services-grid { gap: 14px; }
}

@media (max-width: 480px) {
  .proc-hero { padding: 28px 16px; }
  .proc-hero h1 { font-size: 22px; }
  .proc-hero-desc { font-size: 13px; margin-bottom: 20px; }
  .proc-body { padding: 24px 16px; }
  .proc-intro { font-size: 13px; margin-bottom: 28px; }
  .proc-services-grid { gap: 10px; }
  .proc-service-card { padding: 20px 16px; }
  .proc-service-name { font-size: 14px; }
  .proc-service-desc { font-size: 12px; }
}

@media (max-width: 360px) {
  .proc-hero { padding: 24px 12px; }
  .proc-body { padding: 20px 12px; }
  .proc-service-card { padding: 16px 12px; }
}

/* ─────────────────────────────────────────────────────────────
   10. GLOBAL COMPONENTS
   ───────────────────────────────────────────────────────────── */

/* Footer CTA bar */
@media (max-width: 767px) {
  .footer-cta-bar { padding: 44px 20px; }
  .footer-cta-bar h2 { font-size: 22px; }
  .footer-cta-bar p { font-size: 13px; margin-bottom: 22px; }
}

@media (max-width: 480px) {
  .footer-cta-bar { padding: 36px 16px; }
  .footer-cta-bar h2 { font-size: 20px; letter-spacing: -0.3px; }
  .footer-cta-bar p { font-size: 12px; margin-bottom: 18px; }
  .footer-cta-bar .btn-accent { width: 100%; justify-content: center; }
}

@media (max-width: 360px) {
  .footer-cta-bar { padding: 28px 12px; }
  .footer-cta-bar h2 { font-size: 18px; }
}

/* Bottom CTA bar (shared across pages) */
@media (max-width: 480px) {
  .bottom-cta-inner { padding: 24px 16px !important; gap: 16px; }
  .bottom-cta h2 { font-size: 18px !important; }
  .bottom-cta p { font-size: 12px !important; }
  .cta-buttons { flex-direction: column; width: 100%; }
  .cta-btn-accent, .cta-btn-outline { width: 100%; justify-content: center; text-align: center; min-height: 44px; }
}

@media (max-width: 360px) {
  .bottom-cta-inner { padding: 20px 12px !important; }
  .bottom-cta h2 { font-size: 16px !important; }
}

/* Cards (product single page shared cards) */
@media (max-width: 480px) {
  .card-head { padding: 12px 16px; }
  .card-body { padding: 14px 16px; }
}

@media (max-width: 360px) {
  .card-head { padding: 10px 12px; }
  .card-body { padding: 12px; }
}

/* Property grid */
@media (max-width: 480px) {
  .props { grid-template-columns: 1fr 1fr; gap: 6px; }
  .prop { padding: 10px 12px; }
  .prop-val { font-size: 11px; }
}

@media (max-width: 360px) {
  .props { grid-template-columns: 1fr; }
}

/* Breadcrumbs */
@media (max-width: 480px) {
  .breadcrumbs { flex-wrap: wrap; gap: 3px 4px; font-size: 10px !important; padding: 6px 14px !important; }
}

@media (max-width: 360px) {
  .breadcrumbs { font-size: 9px !important; padding: 5px 12px !important; }
}

/* Tags */
@media (max-width: 480px) {
  .tag { font-size: 10px; padding: 4px 10px; }
}

/* ─────────────────────────────────────────────────────────────
   11. TABLET REFINEMENTS (768px – 1024px)
   ───────────────────────────────────────────────────────────── */

@media (min-width: 768px) and (max-width: 1024px) {
  /* Keep sidebars in flow (not sticky) on tablets */
  .sidebar { position: static; }
  .filter-sidebar { position: static; }

  /* Contact form grid — tighter on tablets */
  .contact-grid { gap: 28px; }

  /* Procurement */
  .proc-hero { padding: 44px 32px; }
  .proc-body { padding: 44px 32px; }
  .proc-services-grid { grid-template-columns: repeat(2, 1fr); }

  /* Archive filter + product grid */
  .archive-layout { padding: 24px 28px 56px; }
  .archive-header { padding: 32px 28px; }

  /* Tile/family grids */
  .tile-grid { grid-template-columns: repeat(2, 1fr); }
  .families-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (min-width: 768px) and (max-width: 960px) {
  .product-body { padding: 24px 28px; }
  .product-hero { padding: 40px 28px; }
}

/* ─────────────────────────────────────────────────────────────
   12. LANDSCAPE PHONE FIX (e.g. iPhone in landscape, ~568–812px wide, ≤430px tall)
   ───────────────────────────────────────────────────────────── */

@media (max-height: 500px) and (max-width: 960px) {
  /* Hero section: compress height */
  .hero { min-height: auto; height: auto; }
  .hero-text-col { padding: 24px 20px; }
  .hero-text h1 { font-size: 22px; margin-bottom: 8px; }
  .hero-text .tagline { font-size: 12px; margin-bottom: 10px; }
  .hero-chips { margin-bottom: 10px; }
  .hero-ctas { gap: 8px; }
  /* rfq-float in landscape: restrict height more */
  .rfq-float { max-height: 95vh; }
  /* Product hero */
  .product-hero { padding: 24px 20px; }
  h1.product-name { font-size: 22px; }
}

/* ─────────────────────────────────────────────────────────────
   13. REDUCED MOTION SAFETY NET
   ───────────────────────────────────────────────────────────── */

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
  .rfq-float { transition: none !important; }
  .hero-cta { animation: none !important; }
  .reveal, .reveal-stagger > * { opacity: 1 !important; transform: none !important; }
}
