/* ============================================
   SKINCARE PAGE MOBILE - Mobile-Specific Styles
   Organic Urban — Clean Skincare Page Mobile Layout
   ============================================
   
   This file handles mobile-specific skincare page styles.
   Uses CSS custom properties and proper specificity.
   Zero !important usage.
   ============================================ */

@media screen and (max-width: 768px) {

  /* ============================================
     HERO SECTION
     ============================================ */

  .skincare-hero {
    padding: calc(var(--header-height-mobile, 60px) + var(--mobile-spacing-md, 1rem)) var(--mobile-padding-section, 1rem) var(--mobile-spacing-xl, 2rem);
    min-height: auto;
    position: relative;
    overflow: hidden;
  }

  .skincare-hero-content {
    max-width: 100%;
    text-align: center;
  }

  .skincare-eyebrow {
    font-size: var(--mobile-font-size-xs, 12px);
    margin-bottom: var(--mobile-spacing-sm, 0.75rem);
  }

  .skincare-title {
    font-size: var(--mobile-heading-size-h1, 1.75rem);
    line-height: 1.2;
    margin-bottom: var(--mobile-spacing-md, 1rem);
  }

  .skincare-subtitle {
    font-size: var(--mobile-font-size-base, 16px);
    line-height: 1.6;
    max-width: 100%;
    margin: 0 auto var(--mobile-spacing-lg, 1.5rem);
  }

  .quiz-prompt {
    padding: var(--mobile-spacing-sm, 0.75rem) var(--mobile-spacing-md, 1rem);
    font-size: var(--mobile-font-size-sm, 14px);
    min-height: var(--mobile-touch-target-min, 44px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }

  /* ============================================
     SKIN TYPES SECTION
     ============================================ */

  .skin-types-section {
    padding: var(--mobile-spacing-xl, 2rem) var(--mobile-padding-section, 1rem);
    background: #FFFFFF;
  }

  .section-intro {
    max-width: 100%;
    margin-bottom: var(--mobile-spacing-xl, 2rem);
    text-align: center;
  }

  .section-intro h2 {
    font-size: var(--mobile-heading-size-h2, 1.5rem);
    margin-bottom: var(--mobile-spacing-sm, 0.75rem);
  }

  .section-intro p {
    font-size: var(--mobile-font-size-sm, 14px);
    line-height: 1.6;
  }

  /* Skin Type Cards - Stack vertically on mobile */
  .skin-type-cards {
    display: flex;
    flex-direction: column;
    gap: var(--mobile-spacing-lg, 1.5rem);
    max-width: 100%;
  }

  .skin-type-card {
    border-radius: 16px;
    overflow: hidden;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
  }

  .skin-type-card:active {
    transform: scale(0.98);
  }

  .skin-card-header {
    padding: var(--mobile-spacing-lg, 1.5rem) var(--mobile-spacing-md, 1rem);
  }

  .skin-icon {
    width: 48px;
    height: 48px;
    margin-bottom: var(--mobile-spacing-sm, 0.75rem);
  }

  .skin-icon svg {
    width: 24px;
    height: 24px;
  }

  .skin-card-header h3 {
    font-size: var(--mobile-heading-size-h3, 1.25rem);
    margin-bottom: 0.25rem;
  }

  .skin-card-header .subtitle {
    font-size: var(--mobile-font-size-sm, 14px);
  }

  .skin-card-body {
    padding: var(--mobile-spacing-md, 1rem);
  }

  .skin-description {
    font-size: var(--mobile-font-size-sm, 14px);
    line-height: 1.6;
    margin-bottom: var(--mobile-spacing-md, 1rem);
  }

  /* Product Categories */
  .product-category {
    margin-bottom: var(--mobile-spacing-md, 1rem);
  }

  .product-category:last-child {
    margin-bottom: 0;
  }

  .category-label {
    font-size: var(--mobile-font-size-xs, 12px);
    margin-bottom: var(--mobile-spacing-sm, 0.75rem);
  }

  /* Product Pills - Horizontal scroll on mobile */
  .product-pills {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: var(--mobile-spacing-xs, 0.5rem);
    padding-bottom: var(--mobile-spacing-xs, 0.5rem);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
  }

  .product-pills::-webkit-scrollbar {
    height: 4px;
  }

  .product-pills::-webkit-scrollbar-thumb {
    background: var(--border-soft, #E5E0D8);
    border-radius: 2px;
  }

  .product-pill {
    flex-shrink: 0;
    padding: var(--mobile-spacing-xs, 0.5rem) var(--mobile-spacing-sm, 0.75rem);
    font-size: var(--mobile-font-size-sm, 14px);
    min-height: var(--mobile-touch-target-min, 44px);
    display: inline-flex;
    align-items: center;
    white-space: nowrap;
    max-width: 100%;
    overflow: hidden;
    /* Prevent text expansion from forcing massive width */
  }

  /* CRITICAL: Force image to stay tiny and never stretch */
  body .product-pill img,
  html body .product-pill img {
    min-width: 20px !important;
    max-width: 20px !important;
    width: 20px !important;
    min-height: 20px !important;
    max-height: 20px !important;
    height: 20px !important;
    flex: 0 0 20px !important;
    object-fit: cover !important;
    border-radius: 50% !important;
    margin: 0 !important;
    padding: 0 !important;
  }

  .product-pill.more-btn {
    font-weight: 500;
  }

  /* Tips Section */
  .skin-tips {
    margin-top: var(--mobile-spacing-md, 1rem);
    padding-top: var(--mobile-spacing-md, 1rem);
  }

  .tips-label {
    font-size: var(--mobile-font-size-xs, 12px);
    margin-bottom: var(--mobile-spacing-sm, 0.75rem);
  }

  .tips-list {
    display: flex;
    flex-wrap: wrap;
    gap: var(--mobile-spacing-xs, 0.5rem);
  }

  .tip-tag {
    font-size: var(--mobile-font-size-xs, 12px);
    padding: var(--mobile-spacing-xs, 0.5rem) var(--mobile-spacing-sm, 0.75rem);
  }

  /* View All Button */
  .skin-card-footer {
    padding: var(--mobile-spacing-md, 1rem);
  }

  .view-all-btn {
    padding: var(--mobile-spacing-sm, 0.75rem);
    font-size: var(--mobile-font-size-sm, 14px);
    min-height: var(--mobile-touch-target-min, 44px);
  }

  .view-all-btn svg {
    width: 14px;
    height: 14px;
  }

  /* ============================================
     ALL PRODUCTS SECTION
     ============================================ */

  .all-products-section {
    padding: var(--mobile-spacing-xl, 2rem) var(--mobile-padding-section, 1rem);
    background: var(--bg-cream, #F7F5F2);
  }

  .all-products-header {
    margin-bottom: var(--mobile-spacing-lg, 1.5rem);
    text-align: center;
  }

  .all-products-header h2 {
    font-size: var(--mobile-heading-size-h2, 1.5rem);
    margin-bottom: var(--mobile-spacing-xs, 0.5rem);
  }

  .all-products-header p {
    font-size: var(--mobile-font-size-sm, 14px);
  }

  /* Category Filters - Horizontal scroll */
  .category-filters {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    gap: var(--mobile-spacing-xs, 0.5rem);
    margin-bottom: var(--mobile-spacing-lg, 1.5rem);
    padding-bottom: var(--mobile-spacing-xs, 0.5rem);
    -webkit-overflow-scrolling: touch;
    scrollbar-width: thin;
    justify-content: flex-start;
  }

  .category-filters::-webkit-scrollbar {
    height: 4px;
  }

  .category-filters::-webkit-scrollbar-thumb {
    background: var(--border-soft, #E5E0D8);
    border-radius: 2px;
  }

  .filter-btn {
    flex-shrink: 0;
    padding: var(--mobile-spacing-sm, 0.75rem) var(--mobile-spacing-md, 1rem);
    font-size: var(--mobile-font-size-sm, 14px);
    min-height: var(--mobile-touch-target-min, 44px);
    white-space: nowrap;
  }

  /* Skincare product cards — now handled by components/product-card.css (ou-product-card) */
  .skincare-products-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: var(--mobile-spacing-sm, 0.75rem);
    max-width: 100%;
  }

  /* ============================================
     CTA SECTION
     ============================================ */

  .skincare-cta {
    padding: var(--mobile-spacing-xl, 2rem) var(--mobile-padding-section, 1rem);
    text-align: center;
  }

  .skincare-cta h2 {
    font-size: var(--mobile-heading-size-h2, 1.5rem);
    margin-bottom: var(--mobile-spacing-sm, 0.75rem);
  }

  .skincare-cta p {
    font-size: var(--mobile-font-size-sm, 14px);
    max-width: 100%;
    margin: 0 auto var(--mobile-spacing-md, 1rem);
    line-height: 1.6;
  }

  .skincare-cta .btn-primary {
    padding: var(--mobile-spacing-sm, 0.75rem) var(--mobile-spacing-lg, 1.5rem);
    font-size: var(--mobile-font-size-base, 16px);
    min-height: var(--mobile-touch-target-min, 44px);
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
}

/* ============================================
   EXTRA SMALL MOBILE (≤480px)
   ============================================ */

@media screen and (max-width: 480px) {

  .skincare-products-grid {
    grid-template-columns: 1fr;
    gap: var(--mobile-spacing-md, 1rem);
  }

  .skin-type-card {
    border-radius: 12px;
  }

  .skin-card-header {
    padding: var(--mobile-spacing-md, 1rem);
  }

  .skin-card-body {
    padding: var(--mobile-spacing-sm, 0.75rem);
  }

  .skincare-product-content {
    padding: var(--mobile-spacing-sm, 0.75rem);
  }
}