/** Shopify CDN: Minification failed

Line 97:12 Expected identifier but found whitespace
Line 97:13 Unexpected "0"

**/
/* ============================================================
   SKINCARISMA — Product description block styles
   ============================================================ */

  /* Color tokens promoted to :root so theme sections below .pp can use them too */
  :root {
    --pp-ink: #0d1f2d;
    --pp-ink-2: #475569;
    --pp-ink-3: #94a3b8;
    --pp-rule: #e2e8f0;
    --pp-rule-2: #f1f5f9;
    --pp-canvas: #ffffff;
    --pp-soft: #f8fafc;
    --pp-card: #ffffff;
    --pp-accent: #5bb8f5;
    --pp-accent-light: #91d1ff;
    --pp-accent-deep: #1d6fa5;
    --pp-accent-tint: #e0f2fe;
    --pp-safe: #22c55e;
    --pp-safe-deep: #15803d;
    --pp-safe-tint: #dcfce7;
    --pp-warn: #f59e0b;
    --pp-warn-deep: #b45309;
    --pp-warn-tint: #fef3c7;
    --pp-danger: #ef4444;
    --pp-danger-deep: #b91c1c;
    --pp-danger-tint: #fee2e2;
    --pp-radius-lg: 18px;
    --pp-radius: 14px;
    --pp-radius-sm: 10px;
  }

  .pp {
    --pp-ink: #0d1f2d;
    --pp-ink-2: #475569;
    --pp-ink-3: #94a3b8;
    --pp-rule: #e2e8f0;
    --pp-rule-2: #f1f5f9;
    --pp-canvas: #ffffff;
    --pp-soft: #f8fafc;
    --pp-card: #ffffff;
    --pp-accent: #5bb8f5;
    --pp-accent-light: #91d1ff;
    --pp-accent-deep: #1d6fa5;
    --pp-accent-tint: #e0f2fe;
    --pp-safe: #22c55e;
    --pp-safe-deep: #15803d;
    --pp-safe-tint: #dcfce7;
    --pp-warn: #f59e0b;
    --pp-warn-deep: #b45309;
    --pp-warn-tint: #fef3c7;
    --pp-danger: #ef4444;
    --pp-danger-deep: #b91c1c;
    --pp-danger-tint: #fee2e2;
    --pp-star: #f59e0b;
    --pp-radius-lg: 18px;
    --pp-radius: 14px;
    --pp-radius-sm: 10px;

    font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    color: var(--pp-ink);
    line-height: 1.6;
    font-size: 15px;
    -webkit-font-smoothing: antialiased;
    scroll-behavior: smooth;
  }
  /* White card background only — width/padding/margin controlled by theme (.page-width default + theme settings) */
  section[id*="__product_overview"] > .page-width,
  section.shopify-section.section:has(.pp) > .page-width {
    background: #ffffff;
    border-radius: var(--pp-radius-lg);
    box-shadow: 0 1px 3px rgba(13, 31, 45, 0.04), 0 12px 32px -16px rgba(13, 31, 45, 0.08);
  }
  /* Reduce gap from product image to description section — theme default is too large */
  section[id*="__product_overview"],
  section.shopify-section.section:has(.pp) {
    margin-top: 0 !important;
    padding-top: 12px !important;
    padding-bottom: 24px !important;
  }
  /* Theme's product-info section has 100px bottom padding — too much before description */
  product-info.section,
  product-info[id*="MainProduct"] {
    padding-bottom: 16px !important;
  }
  /* Also reduce the next section's top margin if any */
  product-info.section + * { margin-top: 0 !important; }
  /* .pp uses full available width from theme — no internal max-width override */
  .pp [id] { scroll-margin-top: 24px; }
  .pp .pp-hero[id], .pp .pp-title[id] { scroll-margin-top: 32px; }
    padding: 0;
    -webkit-font-smoothing: antialiased;
  }

  /* v1.8 — Breadcrumb nav (top of product description) for SEO interlinking */
  .pp-breadcrumb {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
    font-size: 12px;
    color: var(--pp-ink-3);
    margin-bottom: 16px;
    padding: 8px 0 12px;
    border-bottom: 1px solid var(--pp-rule-2);
  }
  .pp-breadcrumb a {
    color: var(--pp-ink-2);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.15s ease;
  }
  .pp-breadcrumb a:hover { color: var(--pp-accent-deep); text-decoration: underline; }
  .pp-breadcrumb .sep {
    color: var(--pp-ink-3);
    font-size: 13px;
    opacity: 0.6;
  }
  .pp-breadcrumb .current {
    color: var(--pp-ink);
    font-weight: 600;
    /* Truncate long product names on mobile */
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  @media (max-width: 600px) {
    .pp-breadcrumb { font-size: 11px; }
    .pp-breadcrumb .current { max-width: 160px; }
  }

  /* v1.8 — Browse Related section (bottom of product description) — internal link grid for SEO */
  .pp-browse {
    margin: 32px 0 16px;
    padding: 24px 28px;
    background: linear-gradient(180deg, var(--pp-soft) 0%, var(--pp-canvas) 100%);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
  }
  .pp-browse-title {
    font-family: var(--font-display, "Pretendard", inherit);
    font-size: 16px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--pp-ink);
    margin-bottom: 16px;
  }
  .pp-browse-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 16px;
  }
  .pp-browse-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .pp-browse-label {
    font-size: 10px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--pp-ink-3);
    margin-bottom: 4px;
  }
  .pp-browse-link {
    display: inline-block;
    font-size: 13.5px;
    font-weight: 500;
    color: var(--pp-accent-deep);
    text-decoration: none;
    padding: 4px 0;
    transition: color 0.15s ease, transform 0.15s ease;
  }
  .pp-browse-link:hover {
    color: var(--pp-ink);
    transform: translateX(3px);
  }
  @media (max-width: 600px) {
    .pp-browse { padding: 18px 20px; }
    .pp-browse-grid { gap: 14px; }
    .pp-browse-title { font-size: 15px; }
  }
  .pp *, .pp *::before, .pp *::after { box-sizing: border-box; }
  /* Defensive reset for theme.css conflicts on generic SVG classes (.alert, .check, .x, .pin, .arrow).
     Theme has a global .alert { padding: 1.6rem } rule for newsletter/error banners — combined with
     box-sizing: border-box, it expands our 18px icon SVGs to 32x32 with zero content. Strip padding,
     border, and background on every SVG inside .pp namespace. */
  .pp svg { padding: 0 !important; border: 0 !important; background: none !important; }
  /* Reset wrapped in :where() so specificity is 0 — any .pp-* class rule wins. */
  :where(.pp h2, .pp h3, .pp h4, .pp p, .pp ul, .pp li) { margin: 0; padding: 0; }
  :where(.pp ul) { list-style: none; }
  /* Higher-specificity ul list-style:none to beat theme's ul { list-style: disc } */
  .pp ul, .pp .pp-fit-box ul, .pp .pp-pc ul, .pp .pp-pros ul, .pp .pp-cons ul {
    list-style: none !important;
    padding-left: 0 !important;
  }
  /* pp-science needs its own padding (gray callout box layout) — preserve */
  .pp .pp-science {
    list-style: none !important;
    padding: 18px 22px 18px 32px !important;
  }
  /* Align how-to step number circles to top of text */
  .pp .pp-step { align-items: flex-start; }
  /* Accordion expanded content needs padding for readable layout */
  .pp .pp-acc-content { padding: 0; }
  .pp .pp-accordion input:checked ~ .pp-acc-content { padding: 16px 22px 18px; }
  .pp .pp-acc-content p { margin: 0 0 10px; }
  .pp .pp-acc-content p:last-child { margin-bottom: 0; }
  .pp .pp-acc-content strong { color: var(--pp-ink); font-weight: 700; }
  .pp a { color: inherit; }
  /* Force font-family inheritance — theme has h2/h3/h4/etc. font-family rules that beat .pp inheritance otherwise */
  .pp h1, .pp h2, .pp h3, .pp h4, .pp h5, .pp h6,
  .pp p, .pp span, .pp div, .pp li, .pp a, .pp button, .pp input, .pp label, .pp strong, .pp em {
    font-family: inherit;
  }

  /* Visually hidden but readable by screen readers & search engines */
  .pp .pp-sr-only {
    position: absolute !important; width: 1px; height: 1px; padding: 0; margin: -1px;
    overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0;
  }

  /* shared icon component */
  .pp .ico { width: 18px; height: 18px; stroke: currentColor; stroke-width: 1.6; fill: none; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; display: inline-block; vertical-align: middle; }
  .pp .ico-lg { width: 22px; height: 22px; }
  .pp .ico-xl { width: 28px; height: 28px; }

  /* ===== Section titles ===== */
  .pp-title {
    display: flex;
    align-items: baseline;
    gap: 14px;
    margin: 36px 0 18px;
    padding-bottom: 14px;
    border-bottom: 1px solid var(--pp-rule);
  }
  .pp-title .eyebrow { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--pp-ink-3); font-weight: 600; }
  .pp-title h2 { font-size: 26px; line-height: 1.15; letter-spacing: -0.022em; font-weight: 700; color: var(--pp-ink); flex: 1; }
  .pp-title .num { font-size: 11px; letter-spacing: 0.18em; color: var(--pp-ink-3); font-weight: 600; font-variant-numeric: tabular-nums; }

  /* ============ HERO ============ */
  .pp-hero { padding: 8px 0 12px; }
  .pp-hero .pp-origin {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 7px 14px 7px 10px;
    background: var(--pp-accent-tint);
    border: 1px solid color-mix(in srgb, var(--pp-accent) 25%, transparent);
    border-radius: 999px;
    font-size: 12px;
    color: var(--pp-accent-deep);
    font-weight: 600;
    letter-spacing: 0.02em;
    margin-bottom: 20px;
  }
  .pp-hero .pp-origin .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--pp-accent); }
  .pp-hero .pp-origin .pin { width: 14px; height: 14px; stroke: var(--pp-accent-deep); stroke-width: 1.8; fill: none; stroke-linecap: round; stroke-linejoin: round; }
  .pp-hero .pp-subtitle {
    font-size: 18px;
    line-height: 1.55;
    color: var(--pp-ink);
    letter-spacing: -0.011em;
    max-width: 720px;
    margin: 0 0 24px;
    text-wrap: pretty;
  }
  .pp-hero .pp-subtitle strong { font-weight: 600; }
  .pp-badges { display: flex; flex-wrap: wrap; gap: 6px; }
  .pp-badge {
    display: inline-flex; align-items: center; gap: 6px;
    padding: 6px 12px;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: 999px;
    font-size: 12px;
    color: var(--pp-ink);
    font-weight: 500;
    letter-spacing: -0.005em;
    transition: border-color 0.15s ease, background 0.15s ease;
  }
  .pp-badge:hover { border-color: var(--pp-accent); background: var(--pp-accent-tint); }
  .pp-badge svg { width: 12px; height: 12px; stroke: var(--pp-safe); stroke-width: 2.2; fill: none; stroke-linecap: round; stroke-linejoin: round; }

  /* ===== Section nav ===== */
  .pp-nav {
    margin-top: 28px;
    padding: 18px;
    background: linear-gradient(135deg, var(--pp-accent-tint) 0%, #f0f9ff 100%);
    border: 1px solid color-mix(in srgb, var(--pp-accent) 25%, transparent);
    border-radius: var(--pp-radius-lg);
  }
  .pp-nav-head {
    display: flex; align-items: center; gap: 10px;
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--pp-accent-deep); font-weight: 700;
    margin-bottom: 14px;
  }
  .pp-nav-head::after {
    content: ""; flex: 1; height: 1px;
    background: color-mix(in srgb, var(--pp-accent) 30%, transparent);
  }
  .pp-nav-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }
  .pp-nav-list a {
    display: flex; align-items: center; gap: 10px;
    padding: 12px 14px;
    background: #fff;
    border: 1px solid color-mix(in srgb, var(--pp-accent) 20%, transparent);
    border-radius: 10px;
    font-size: 13px;
    font-weight: 600;
    letter-spacing: -0.005em;
    color: var(--pp-ink);
    text-decoration: none;
    transition: transform 0.18s ease, border-color 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
  }
  .pp-nav-list a:hover {
    border-color: var(--pp-accent);
    background: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 18px -8px rgba(91, 184, 245, 0.55);
  }
  .pp-nav-list a .ico {
    width: 16px; height: 16px;
    color: var(--pp-accent-deep);
    flex-shrink: 0;
  }
  .pp-nav-list a .lbl { flex: 1; }
  .pp-nav-list a .arrow {
    width: 14px; height: 14px;
    color: var(--pp-ink-3);
    transition: transform 0.18s ease, color 0.18s ease;
  }
  .pp-nav-list a:hover .arrow { transform: translateX(3px); color: var(--pp-accent-deep); }

  /* ============ QUICK INFO + SPECS ============ */
  .pp-scorecard {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0;
    margin: 32px 0 0;
    padding: 22px 0;
    border-top: 1px solid var(--pp-rule);
    border-bottom: 1px solid var(--pp-rule);
  }
  .pp-scorecard > div { padding: 0 24px; border-right: 1px solid var(--pp-rule); }
  .pp-scorecard > div:last-child { border-right: none; }
  .pp-scorecard .lbl { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pp-ink-3); font-weight: 600; margin-bottom: 8px; }
  .pp-scorecard .val { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; color: var(--pp-ink); display: flex; align-items: center; gap: 8px; }
  .pp-scorecard .val .check { width: 18px; height: 18px; stroke: var(--pp-safe); stroke-width: 2.2; fill: none; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
  .pp-scorecard .val .alert { width: 18px; height: 18px; stroke: var(--pp-warn); stroke-width: 2.2; fill: none; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
  .pp-scorecard .val .x { width: 18px; height: 18px; stroke: var(--pp-danger); stroke-width: 2.2; fill: none; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; }
  .pp-scorecard .val.caution { color: var(--pp-warn-deep); }
  .pp-scorecard .val.warning { color: var(--pp-danger-deep); }
  .pp-scorecard .val small { font-size: 13px; color: var(--pp-ink-3); font-weight: 500; }

  .pp-specs {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0;
    margin: 16px 0 0;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius);
    overflow: hidden;
  }
  .pp-spec { padding: 18px 16px; border-right: 1px solid var(--pp-rule); }
  .pp-spec:last-child { border-right: none; }
  .pp-spec .ico-wrap { display: flex; width: 32px; height: 32px; border-radius: 8px; background: var(--pp-accent-tint); align-items: center; justify-content: center; color: var(--pp-accent-deep); margin-bottom: 10px; }
  .pp-spec .ico-wrap svg { width: 16px; height: 16px; }
  .pp-spec .lbl { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pp-ink-3); font-weight: 600; margin-bottom: 4px; }
  .pp-spec .val { font-size: 14px; font-weight: 600; color: var(--pp-ink); letter-spacing: -0.005em; }

  @media (max-width: 700px) {
    .pp-scorecard { grid-template-columns: 1fr; padding: 0; }
    .pp-scorecard > div { padding: 16px 20px; border-right: none; border-bottom: 1px solid var(--pp-rule); }
    .pp-scorecard > div:last-child { border-bottom: none; }
    .pp-specs { grid-template-columns: repeat(2, 1fr); }
    .pp-spec { border-bottom: 1px solid var(--pp-rule); }
    .pp-spec:nth-last-child(-n+1):nth-child(odd) { border-right: 1px solid var(--pp-rule); }
  }

  /* ============ SENSORY ============ */
  .pp-sensory {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px;
    margin: 28px 0 0;
  }
  .pp-sensory-item {
    padding: 18px;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius);
    display: flex;
    flex-direction: column;
    gap: 6px;
  }
  .pp-sensory-item .top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 8px; }
  .pp-sensory-item .ico-wrap { width: 28px; height: 28px; border-radius: 7px; background: var(--pp-accent-tint); display: flex; align-items: center; justify-content: center; color: var(--pp-accent-deep); }
  .pp-sensory-item .ico-wrap svg { width: 14px; height: 14px; }
  .pp-sensory-item .lbl { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pp-ink-3); font-weight: 600; }
  .pp-sensory-item .val { font-size: 15px; font-weight: 600; letter-spacing: -0.01em; color: var(--pp-ink); }
  @media (max-width: 700px) { .pp-sensory { grid-template-columns: repeat(2, 1fr); } }

  /* ============ FEATURES ============ */
  .pp-features {
    display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
    margin: 28px 0 0;
  }
  .pp-feature {
    padding: 22px;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
    transition: border-color 0.2s ease, transform 0.2s ease;
  }
  .pp-feature:hover { border-color: var(--pp-accent); transform: translateY(-2px); }
  .pp-feature .ico-wrap {
    width: 40px; height: 40px;
    border-radius: 10px;
    background: var(--pp-accent-tint);
    color: var(--pp-accent-deep);
    display: flex; align-items: center; justify-content: center;
    margin-bottom: 16px;
  }
  .pp-feature .ico-wrap svg { width: 20px; height: 20px; stroke-width: 1.7; }
  .pp-feature h4 { font-size: 16px; font-weight: 700; letter-spacing: -0.015em; margin-bottom: 6px; }
  .pp-feature p { font-size: 14px; line-height: 1.55; color: var(--pp-ink-2); }
  @media (max-width: 600px) { .pp-features { grid-template-columns: 1fr; } }

  /* ============ SAFETY LIST ============ */
  .pp-safety { display: grid; grid-template-columns: 1fr 1fr; gap: 0; background: var(--pp-card); border: 1px solid var(--pp-rule); border-radius: var(--pp-radius-lg); overflow: hidden; }
  .pp-safety-item { display: flex; align-items: flex-start; gap: 14px; padding: 20px 22px; border-right: 1px solid var(--pp-rule); border-bottom: 1px solid var(--pp-rule); }
  .pp-safety-item:nth-child(2n) { border-right: none; }
  .pp-safety-item:nth-last-child(-n+2) { border-bottom: none; }
  .pp-safety-item .ico-wrap { width: 28px; height: 28px; border-radius: 8px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
  .pp-safety-item.safe .ico-wrap { background: var(--pp-safe-tint); color: var(--pp-safe); }
  .pp-safety-item.info .ico-wrap { background: var(--pp-accent-tint); color: var(--pp-accent-deep); }
  .pp-safety-item.caution .ico-wrap { background: var(--pp-warn-tint); color: var(--pp-warn); }
  .pp-safety-item .ico-wrap svg { width: 15px; height: 15px; stroke-width: 2; }
  .pp-safety-item strong { display: block; font-size: 14px; font-weight: 700; color: var(--pp-ink); margin-bottom: 4px; letter-spacing: -0.005em; }
  .pp-safety-item p { font-size: 13px; line-height: 1.55; color: var(--pp-ink-2); }
  @media (max-width: 600px) {
    .pp-safety { grid-template-columns: 1fr; }
    .pp-safety-item { border-right: none; }
    .pp-safety-item:nth-last-child(-n+2):not(:last-child) { border-bottom: 1px solid var(--pp-rule); }
  }

  /* ============ FEATURED HIGHLIGHT ("Why it's different") ============ */
  .pp-highlight {
    margin: 18px 0 4px;
    padding: 22px 26px;
    background: linear-gradient(135deg, var(--pp-accent-tint) 0%, #ffffff 100%);
    border: 1px solid color-mix(in srgb, var(--pp-accent) 25%, transparent);
    border-radius: var(--pp-radius-lg);
    position: relative;
    overflow: hidden;
  }
  .pp-highlight::before {
    content: ""; position: absolute;
    top: 0; left: 0; bottom: 0; width: 4px;
    background: linear-gradient(180deg, var(--pp-accent) 0%, var(--pp-accent-deep) 100%);
  }
  .pp-highlight .eyebrow {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--pp-accent-deep); font-weight: 700;
    margin-bottom: 10px;
  }
  .pp-highlight .eyebrow svg { width: 13px; height: 13px; }
  .pp-highlight h3 {
    font-size: 22px; font-weight: 700; letter-spacing: -0.022em;
    line-height: 1.2; color: var(--pp-ink);
    margin-bottom: 8px;
    text-wrap: pretty;
  }
  .pp-highlight p {
    font-size: 14.5px; line-height: 1.6; color: var(--pp-ink-2);
    margin: 0;
    text-wrap: pretty;
  }
  .pp-highlight p strong { color: var(--pp-ink); font-weight: 700; }
  @media (max-width: 600px) {
    .pp-highlight { padding: 20px 22px 20px 24px; }
    .pp-highlight h3 { font-size: 19px; }
    .pp-highlight p { font-size: 13.5px; }
  }

  /* ============ AGGREGATE REVIEWS SUMMARY ============ */
  .pp-reviews-summary {
    display: grid; grid-template-columns: auto 1fr; gap: 0 28px;
    align-items: center;
    padding: 22px 26px;
    background: var(--pp-soft);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
    margin-top: 24px;
  }
  .pp-reviews-summary .num {
    font-size: 48px; font-weight: 800; letter-spacing: -0.03em;
    line-height: 1; color: var(--pp-ink);
    font-variant-numeric: tabular-nums;
  }
  .pp-reviews-summary .body { display: flex; flex-direction: column; gap: 4px; }
  .pp-reviews-summary .stars {
    color: var(--pp-star); letter-spacing: 2px; font-size: 16px;
  }
  .pp-reviews-summary .count {
    font-size: 13.5px; color: var(--pp-ink); font-weight: 600;
  }
  .pp-reviews-summary .count strong {
    font-weight: 800;
  }
  .pp-reviews-summary .sources {
    font-size: 12px; color: var(--pp-ink-3); letter-spacing: 0.02em;
  }
  @media (max-width: 480px) {
    .pp-reviews-summary { padding: 18px 22px; gap: 0 18px; }
    .pp-reviews-summary .num { font-size: 38px; }
    .pp-reviews-summary .stars { font-size: 14px; letter-spacing: 1.5px; }
  }

  /* ============ INGREDIENTS ============ */
  .pp-ingredient {
    padding: 24px;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
    margin-bottom: 12px;
    position: relative;
  }
  .pp-ingredient .ing-head {
    display: flex; align-items: center; gap: 14px;
    margin-bottom: 14px;
  }
  .pp-ingredient .ing-icon {
    width: 44px; height: 44px;
    border-radius: 10px;
    background: var(--pp-accent-tint);
    color: var(--pp-accent-deep);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
  }
  .pp-ingredient .ing-icon svg { width: 22px; height: 22px; stroke-width: 1.7; }
  .pp-ingredient h3 {
    font-size: 19px; font-weight: 700; letter-spacing: -0.018em;
    display: flex; align-items: center; flex-wrap: wrap; gap: 8px;
    flex: 1; min-width: 0;
  }
  .pp-ingredient h3 .conc {
    font-size: 11px; padding: 3px 9px; background: var(--pp-soft);
    border: 1px solid var(--pp-rule); border-radius: 999px;
    color: var(--pp-ink-2); font-weight: 600; letter-spacing: 0.02em;
  }
  .pp-ingredient h3 .tag {
    font-size: 11px; padding: 3px 9px; border-radius: 999px;
    font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  }
  .pp-ingredient h3 .tag.proven { background: var(--pp-safe-tint); color: var(--pp-safe-deep); }
  .pp-ingredient h3 .tag.supporting { background: var(--pp-accent-tint); color: var(--pp-accent-deep); }
  .pp-ingredient .ing-desc { font-size: 14px; line-height: 1.6; color: var(--pp-ink-2); margin-bottom: 14px; }
  .pp-science {
    padding: 18px 22px 18px 32px;
    background: var(--pp-soft);
    border-radius: var(--pp-radius);
    border: 1px solid var(--pp-rule-2);
    display: grid; gap: 10px;
  }
  .pp-science li {
    font-size: 13px; line-height: 1.55; color: var(--pp-ink);
    padding: 0;
  }
  .pp-science li strong { color: var(--pp-ink); font-weight: 700; }
  .pp-callout { display: flex; align-items: flex-start; gap: 10px; padding: 12px 14px; border-radius: var(--pp-radius); margin-top: 12px; font-size: 13px; line-height: 1.55; }
  .pp-callout.positive { background: var(--pp-safe-tint); color: var(--pp-safe-deep); }
  .pp-callout.positive svg { stroke: var(--pp-safe); }
  .pp-callout svg { width: 16px; height: 16px; stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; margin-top: 1px; }

  /* ============ INCI ACCORDION ============ */
  .pp-accordion { margin-top: 16px; }
  .pp-accordion input[type="checkbox"] { position: absolute; opacity: 0; pointer-events: none; }
  .pp-accordion label {
    display: flex; align-items: center; gap: 12px;
    padding: 16px 20px;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius);
    cursor: pointer;
    font-size: 14px; font-weight: 600; color: var(--pp-ink);
    user-select: none;
    transition: border-color 0.15s ease;
  }
  .pp-accordion label:hover { border-color: var(--pp-accent); }
  .pp-accordion label .lbl-ico { width: 18px; height: 18px; color: var(--pp-accent-deep); }
  .pp-accordion label .chev { width: 18px; height: 18px; margin-left: auto; transition: transform 0.25s ease; color: var(--pp-ink-3); }
  .pp-accordion input:checked + label { border-radius: var(--pp-radius) var(--pp-radius) 0 0; border-bottom-color: transparent; }
  .pp-accordion input:checked + label .chev { transform: rotate(180deg); }
  .pp-accordion .pp-acc-content { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; border: 0 solid var(--pp-rule); border-radius: 0 0 var(--pp-radius) var(--pp-radius); background: var(--pp-soft); }
  .pp-accordion input:checked ~ .pp-acc-content { max-height: 600px; border-width: 0 1px 1px 1px; }
  .pp-acc-inner { padding: 18px 20px; }
  .pp-acc-inner .count { font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pp-ink-3); font-weight: 600; margin-bottom: 8px; }
  .pp-acc-inner .inci { font-size: 13px; line-height: 1.7; color: var(--pp-ink); margin-bottom: 14px; }
  .pp-acc-inner .free { padding-top: 14px; border-top: 1px dashed var(--pp-rule); font-size: 12px; color: var(--pp-ink-2); line-height: 1.7; }
  .pp-acc-inner .free strong { color: var(--pp-ink); font-weight: 700; letter-spacing: 0.04em; text-transform: uppercase; font-size: 11px; }

  /* ============ ROUTINE FLOW ============ */
  .pp-routine {
    display: grid; grid-template-columns: repeat(6, 1fr);
    gap: 0;
    margin: 28px 0 0;
    padding: 28px 16px 22px;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
    position: relative;
  }
  .pp-routine::before {
    content: "";
    position: absolute;
    top: 47px; left: 38px; right: 38px;
    height: 2px;
    background: repeating-linear-gradient(to right, var(--pp-rule) 0 6px, transparent 6px 12px);
    transform: translateY(-50%);
    z-index: 0;
  }
  .pp-routine-step {
    position: relative; z-index: 1;
    display: flex; flex-direction: column; align-items: center; gap: 12px;
    text-align: center;
  }
  .pp-routine-step .num {
    width: 38px; height: 38px;
    background: var(--pp-card);
    border: 1.5px solid var(--pp-rule);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 13px; font-weight: 700; color: var(--pp-ink-3);
    font-variant-numeric: tabular-nums;
    flex-shrink: 0;
    transition: transform 0.2s ease;
  }
  .pp-routine-step .name {
    font-size: 12px; font-weight: 500; color: var(--pp-ink-2);
    line-height: 1.3;
    min-height: 16px;
  }
  .pp-routine-step.current .num {
    background: var(--pp-accent);
    border-color: var(--pp-accent);
    color: #fff;
    box-shadow: 0 0 0 5px var(--pp-accent-tint);
    animation: pp-pulse-ring 2.4s ease-in-out infinite;
  }
  .pp-routine-step.current .name { color: var(--pp-ink); font-weight: 700; }
  .pp-routine-note { text-align: center; font-size: 13px; color: var(--pp-ink-2); margin-top: 16px; line-height: 1.55; }
  @media (max-width: 700px) {
    .pp-routine { grid-template-columns: repeat(3, 1fr); row-gap: 20px; padding: 22px 14px; }
    .pp-routine::before { display: none; }
  }

  /* ============ HOW TO USE ============ */
  .pp-steps { display: grid; gap: 10px; margin-top: 24px; }
  .pp-step {
    display: flex; gap: 8px;
    padding: 18px 22px;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
    align-items: center;
  }
  /* v1.5 — Large translucent step number (no pill), accent-tinted */
  .pp-step .num {
    width: auto; height: auto;
    background: transparent;
    color: color-mix(in srgb, var(--pp-accent-deep) 35%, transparent);
    border-radius: 0;
    display: flex; align-items: center; justify-content: center;
    font-size: 56px; font-weight: 800;
    line-height: 1;
    letter-spacing: -0.04em;
    flex-shrink: 0;
    font-variant-numeric: tabular-nums;
    min-width: 56px;
    padding-right: 14px;
    text-align: center;
  }
  .pp-step h4 { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 4px; }
  .pp-step p { font-size: 14px; color: var(--pp-ink-2); line-height: 1.55; }

  /* ============ FIT FOR ============ */
  .pp-fit { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 24px; }
  .pp-fit-box { padding: 24px; border-radius: var(--pp-radius-lg); }
  .pp-fit-box.yes { background: var(--pp-safe-tint); border: 1px solid color-mix(in srgb, var(--pp-safe) 25%, transparent); }
  .pp-fit-box.no { background: var(--pp-danger-tint); border: 1px solid color-mix(in srgb, var(--pp-danger) 25%, transparent); }
  .pp-fit-box h4 { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
  .pp-fit-box.yes h4 { color: var(--pp-safe-deep); }
  .pp-fit-box.no h4 { color: var(--pp-danger-deep); }
  .pp-fit-box ul { display: grid; gap: 10px; }
  .pp-fit-box li { display: flex; align-items: flex-start; gap: 10px; font-size: 13.5px; line-height: 1.5; color: var(--pp-ink); }
  .pp-fit-box li svg { width: 16px; height: 16px; stroke-width: 2.2; flex-shrink: 0; margin-top: 2px; }
  .pp-fit-box.yes li svg { stroke: var(--pp-safe); }
  .pp-fit-box.no li svg { stroke: var(--pp-danger); }
  @media (max-width: 600px) { .pp-fit { grid-template-columns: 1fr; } }

  /* ============ SKIN TYPES ============ */
  .pp-skin-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 24px; }
  .pp-skin-card {
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
    padding: 20px;
  }
  .pp-skin-card .row { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
  .pp-skin-card .type { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; }
  .pp-skin-card .rate { font-size: 11px; padding: 4px 10px; border-radius: 999px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
  .pp-skin-card .rate.excellent { background: var(--pp-safe-tint); color: var(--pp-safe-deep); }
  .pp-skin-card .rate.good { background: #ecfccb; color: #4d7c0f; }
  .pp-skin-card .rate.moderate { background: var(--pp-warn-tint); color: var(--pp-warn-deep); }
  .pp-skin-card .meter { display: flex; gap: 4px; margin-bottom: 12px; }
  .pp-skin-card .meter span { flex: 1; height: 6px; border-radius: 3px; background: var(--pp-rule-2); }
  .pp-skin-card .meter span.on { background: var(--pp-accent); }
  .pp-skin-card p { font-size: 13px; line-height: 1.55; color: var(--pp-ink-2); }
  @media (max-width: 600px) { .pp-skin-grid { grid-template-columns: 1fr; } }

  /* ============ TIMELINE ============ */
  .pp-timeline { margin-top: 24px; position: relative; padding-left: 28px; }
  .pp-timeline::before {
    content: ""; position: absolute; left: 11px; top: 8px; bottom: 8px;
    width: 2px; background: var(--pp-rule);
  }
  .pp-tl-item { position: relative; padding: 4px 0 28px; }
  .pp-tl-item:last-child { padding-bottom: 0; }
  .pp-tl-item::before {
    content: ""; position: absolute; left: -23px; top: 8px;
    width: 12px; height: 12px; border-radius: 50%;
    background: #fff; border: 2.5px solid var(--pp-accent);
  }
  .pp-tl-item .time { display: inline-block; font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pp-accent-deep); font-weight: 700; margin-bottom: 4px; }
  .pp-tl-item h4 { font-size: 17px; font-weight: 700; letter-spacing: -0.015em; margin-bottom: 6px; }
  .pp-tl-item p { font-size: 14px; line-height: 1.55; color: var(--pp-ink-2); margin-bottom: 10px; }
  .pp-tl-item .percent {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 12px; font-weight: 600; color: var(--pp-safe-deep);
    padding: 4px 10px; background: var(--pp-safe-tint); border-radius: 999px;
  }
  .pp-tl-item .percent svg { width: 11px; height: 11px; stroke: currentColor; stroke-width: 2.4; fill: none; stroke-linecap: round; stroke-linejoin: round; }

  /* ============ REVIEWS ============ */
  .pp-reviews { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; margin-top: 24px; }
  .pp-review-card { background: var(--pp-card); border: 1px solid var(--pp-rule); border-radius: var(--pp-radius-lg); padding: 22px; }
  .pp-review-card .platform { display: flex; align-items: center; gap: 10px; font-size: 15px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 16px; }
  .pp-review-card .platform .ico-wrap { width: 28px; height: 28px; border-radius: 7px; background: var(--pp-canvas); display: flex; align-items: center; justify-content: center; color: var(--pp-ink-2); }
  .pp-review-card .platform .ico-wrap svg { width: 14px; height: 14px; }
  .pp-review-card .stats { display: flex; gap: 24px; padding: 14px 0; border-top: 1px solid var(--pp-rule); border-bottom: 1px solid var(--pp-rule); margin-bottom: 14px; }
  .pp-review-card .stat .num { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; color: var(--pp-ink); }
  .pp-review-card .stat .stars { color: var(--pp-star); letter-spacing: 1px; font-size: 11px; margin-top: 2px; }
  .pp-review-card .stat .lbl { font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--pp-ink-3); font-weight: 600; margin-top: 4px; }
  .pp-review-card .complaint { font-size: 13px; line-height: 1.55; color: var(--pp-ink-2); display: flex; gap: 10px; align-items: flex-start; }
  .pp-review-card .complaint svg { width: 14px; height: 14px; stroke: var(--pp-warn); stroke-width: 2; fill: none; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; margin-top: 3px; }
  @media (max-width: 600px) { .pp-reviews { grid-template-columns: 1fr; } }

  /* ============ PROS / CONS ============ */
  .pp-proscons { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; margin-top: 24px; }
  .pp-pc {
    padding: 24px;
    border-radius: var(--pp-radius-lg);
    border: 1px solid var(--pp-rule);
    background: var(--pp-card);
  }
  .pp-pc h4 { font-size: 15px; font-weight: 700; letter-spacing: -0.01em; margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
  .pp-pc h4 .ico-wrap { width: 26px; height: 26px; border-radius: 7px; display: flex; align-items: center; justify-content: center; }
  .pp-pc.pros h4 .ico-wrap { background: var(--pp-safe-tint); color: var(--pp-safe); }
  .pp-pc.cons h4 .ico-wrap { background: var(--pp-danger-tint); color: var(--pp-danger); }
  .pp-pc h4 svg { width: 14px; height: 14px; stroke-width: 2.4; }
  .pp-pc ul { display: grid; gap: 10px; }
  .pp-pc li { display: flex; align-items: flex-start; gap: 10px; font-size: 13.5px; line-height: 1.5; color: var(--pp-ink); }
  .pp-pc li svg { width: 14px; height: 14px; stroke-width: 2.4; flex-shrink: 0; margin-top: 4px; }
  .pp-pc.pros li svg { stroke: var(--pp-safe); }
  .pp-pc.cons li svg { stroke: var(--pp-danger); }
  @media (max-width: 600px) { .pp-proscons { grid-template-columns: 1fr; } }

  /* ============ DUPES ============ */
  .pp-dupes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-top: 24px; }
  .pp-dupe-card {
    position: relative;
    background: var(--pp-card);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-lg);
    overflow: hidden;
  }
  .pp-dupe-card .photo { aspect-ratio: 4/5; background: var(--pp-canvas); position: relative; overflow: hidden; }
  .pp-dupe-card .photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .pp-dupe-card .photo .photo-fallback { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--pp-ink-3); }
  .pp-dupe-card .match {
    position: absolute; top: 12px; left: 12px;
    padding: 5px 10px;
    background: rgba(13,31,45,0.85);
    color: #fff;
    border-radius: 999px;
    font-size: 11px; font-weight: 700; letter-spacing: 0.04em;
    backdrop-filter: blur(8px);
  }
  .pp-dupe-card .body { padding: 18px 20px 20px; }
  .pp-dupe-card .name { font-size: 13.5px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.35; margin-bottom: 10px; min-height: 36px; }
  .pp-dupe-card .price-row { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; }
  .pp-dupe-card .price-row .amount { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; color: var(--pp-ink); }
  .pp-dupe-card .price-row .tag { font-size: 10px; padding: 3px 8px; border-radius: 999px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; }
  .pp-dupe-card .price-row .tag.budget { background: var(--pp-safe-tint); color: var(--pp-safe-deep); }
  .pp-dupe-card .price-row .tag.similar { background: var(--pp-warn-tint); color: var(--pp-warn-deep); }
  .pp-dupe-card .diff { font-size: 12.5px; line-height: 1.55; color: var(--pp-ink-2); padding-top: 12px; border-top: 1px solid var(--pp-rule); }
  /* Dupes horizontal scroll-slider — always exactly 3 visible, scroll for 4+ */
  .pp-dupes {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-color: var(--pp-accent) var(--pp-soft);
    scrollbar-width: thin;
    gap: 8px;
    margin-top: 24px;
    padding-bottom: 14px;
  }
  /* Custom scrollbar for Webkit browsers (Chrome/Safari/Edge) — branded style */
  .pp-dupes::-webkit-scrollbar,
  .pp-compare::-webkit-scrollbar { height: 8px; }
  .pp-dupes::-webkit-scrollbar-track,
  .pp-compare::-webkit-scrollbar-track {
    background: var(--pp-soft);
    border-radius: 999px;
    margin: 0 6px;
  }
  .pp-dupes::-webkit-scrollbar-thumb,
  .pp-compare::-webkit-scrollbar-thumb {
    background: linear-gradient(90deg, var(--pp-accent) 0%, var(--pp-accent-deep) 100%);
    border-radius: 999px;
    border: 1px solid var(--pp-canvas);
  }
  .pp-dupes::-webkit-scrollbar-thumb:hover,
  .pp-compare::-webkit-scrollbar-thumb:hover {
    background: linear-gradient(90deg, var(--pp-accent-deep) 0%, var(--pp-accent) 100%);
  }
  .pp-dupes .pp-dupe-card {
    flex: 0 0 calc((100% - 16px) / 3);
    min-width: 0;
    scroll-snap-align: start;
  }
  @media (max-width: 640px) {
    .pp-dupes .pp-dupe-card { flex: 0 0 78%; }
  }

  /* ============ COMPARE — 3 visible + slider for 4+ ============ */
  .pp-compare {
    display: flex;
    overflow-x: auto;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    scrollbar-color: var(--pp-accent) var(--pp-soft);
    scrollbar-width: thin;
    gap: 8px;
    margin-top: 24px;
    padding-bottom: 14px;
  }
  .pp-compare .pp-compare-card {
    flex: 0 0 calc((100% - 16px) / 3);
    min-width: 0;
    scroll-snap-align: start;
  }
  @media (max-width: 640px) {
    .pp-compare .pp-compare-card { flex: 0 0 82%; }
  }
  /* Neat 2-col grid inside compare row for clean label/value alignment */
  .pp-compare-card .body .pp-compare-row {
    display: grid !important;
    grid-template-columns: 80px 1fr;
    align-items: center;
    gap: 10px;
  }
  .pp-compare-card .body .pp-compare-row .label,
  .pp-compare-card .body .pp-compare-row .lbl {
    font-size: 9.5px !important;
    letter-spacing: 0.04em;
    color: var(--pp-ink-3) !important;
    font-weight: 600;
    text-transform: uppercase;
    line-height: 1.3;
  }
  .pp-compare-card .body .pp-compare-row .value,
  .pp-compare-card .body .pp-compare-row .val {
    font-size: 12px !important;
    font-weight: 600;
    color: var(--pp-ink);
    text-align: right;
    line-height: 1.35;
    word-wrap: break-word;
  }

  /* Skin-card meter colors by filled segment count */
  .pp-skin-card .meter span.on { background: var(--pp-accent); }
  .pp-skin-card .meter.tier-poor span.on { background: var(--pp-danger); }
  .pp-skin-card .meter.tier-moderate span.on { background: var(--pp-warn); }
  .pp-skin-card .meter.tier-good span.on { background: var(--pp-accent); }

  /* Inline check/x icons inside value cells — uniform style across page */
  .pp .ico.inline-check { stroke: var(--pp-safe); stroke-width: 2.4; }
  .pp .ico.inline-x { stroke: var(--pp-danger); stroke-width: 2.4; }

  /* motion-element wrapper inherits display contents — doesn't break flex/grid */
  .pp motion-element { display: contents; }

  /* Constrain Shopify theme's product image + column height — was too large by default */
  body.product-template .product__media-wrapper,
  body[class*="product"] .product__media-wrapper {
    max-width: 480px;
    max-height: 520px;
    margin-left: auto;
    margin-right: auto;
  }
  body.product-template .product__media,
  body[class*="product"] .product__media {
    max-width: 480px;
    max-height: 520px;
  }
  body.product-template .product__media img,
  body[class*="product"] .product__media img,
  body.product-template .product__media video,
  body[class*="product"] .product__media video {
    max-height: 520px;
    width: 100%;
    height: auto;
    object-fit: contain;
  }
  /* Stop the .product flex container from stretching tall — align cols to top */
  body.product-template .product,
  body[class*="product"] .product {
    align-items: flex-start !important;
  }
  @media (max-width: 768px) {
    body.product-template .product__media-wrapper,
    body[class*="product"] .product__media-wrapper {
      max-width: 100%;
      max-height: 400px;
    }
    body.product-template .product__media,
    body[class*="product"] .product__media {
      max-height: 400px;
    }
    body.product-template .product__media img,
    body[class*="product"] .product__media img {
      max-height: 380px;
    }
  }

  /* OLD class names (.label/.value) match NEW design (.lbl/.val) — old HTML uses former, new CSS expects latter */
  .pp .pp-sensory-item .label,
  .pp .pp-sensory-item .lbl {
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pp-ink-3);
    font-weight: 600;
    margin-bottom: 2px;
  }
  .pp .pp-sensory-item .value,
  .pp .pp-sensory-item .val {
    font-size: 15px;
    font-weight: 600;
    letter-spacing: -0.01em;
    color: var(--pp-ink);
  }
  .pp .pp-spec .label,
  .pp .pp-spec .lbl {
    font-size: 10px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pp-ink-3);
    font-weight: 600;
    margin-bottom: 4px;
  }
  .pp .pp-spec .value,
  .pp .pp-spec .val {
    font-size: 14px;
    font-weight: 600;
    color: var(--pp-ink);
    letter-spacing: -0.005em;
  }
  .pp .pp-quickinfo-item .label,
  .pp .pp-quickinfo-item .lbl {
    font-size: 11px;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--pp-ink-3);
    font-weight: 600;
    margin-bottom: 6px;
  }
  .pp .pp-quickinfo-item .value,
  .pp .pp-quickinfo-item .val {
    font-size: 18px;
    font-weight: 700;
    color: var(--pp-ink);
  }
  /* Compare row value coloring */
  .pp-compare-card .body .pp-compare-row .value { font-weight: 600; }
  .pp-compare-card .body .pp-compare-row .value.good { color: var(--pp-safe-deep); font-weight: 700; }
  .pp-compare-card .body .pp-compare-row .value.bad { color: var(--pp-danger-deep); font-weight: 700; }
  .pp-compare-card .body .pp-compare-row .value.neutral { color: var(--pp-ink-2); }
  .pp-compare-card .body .pp-compare-row .value strong { color: inherit; font-weight: 700; }
  /* v0.9 — YouTube Shorts player block, lives inside .pp-hero above .pp-highlight */
  .pp-videos { margin: 18px 0 6px; }
  .pp-videos > .eyebrow {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--pp-accent-deep); font-weight: 700;
    margin-bottom: 12px;
  }
  .pp-videos > .eyebrow svg { width: 13px; height: 13px; color: var(--pp-accent-deep); }
  .pp-videos-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
  }
  .pp-videos-frame {
    position: relative;
    width: 100%;
    aspect-ratio: 9 / 16;
    border-radius: var(--pp-radius-lg);
    overflow: hidden;
    background: #000;
    box-shadow: 0 4px 16px -4px rgba(13, 31, 45, 0.18);
    transition: transform 0.2s ease, box-shadow 0.2s ease;
  }
  .pp-videos-frame:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 24px -6px rgba(13, 31, 45, 0.28);
  }
  .pp-videos-frame iframe {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    border: 0;
    display: block;
  }
  @media (max-width: 760px) {
    .pp-videos-grid { gap: 8px; }
  }
  /* v1.3 — Mobile: horizontal scroll-snap carousel with left inset, smaller frames */
  @media (max-width: 520px) {
    .pp-videos-grid {
      display: flex;
      grid-template-columns: none;
      overflow-x: auto;
      scroll-snap-type: x mandatory;
      -webkit-overflow-scrolling: touch;
      scrollbar-color: var(--pp-accent) var(--pp-soft);
      scrollbar-width: thin;
      gap: 10px;
      padding: 4px 18px 12px 18px;
      margin: 0 -18px;
      scroll-padding-left: 18px;
    }
    .pp-videos-frame {
      flex: 0 0 165px;
      max-width: 165px;
      scroll-snap-align: start;
    }
    .pp-videos-grid::-webkit-scrollbar { height: 6px; }
    .pp-videos-grid::-webkit-scrollbar-track { background: var(--pp-soft); border-radius: 999px; }
    .pp-videos-grid::-webkit-scrollbar-thumb {
      background: linear-gradient(90deg, var(--pp-accent) 0%, var(--pp-accent-deep) 100%);
      border-radius: 999px;
    }
  }

  /* Verdict score block */
  .pp-verdict .verdict-score {
    display: flex; align-items: baseline; gap: 12px;
    margin: 12px 0 18px;
  }
  .pp-verdict .verdict-score .num {
    font-size: 42px; font-weight: 800; letter-spacing: -0.03em;
    color: var(--pp-ink); line-height: 1;
  }
  .pp-verdict .verdict-score .num .den {
    font-size: 18px; font-weight: 500; color: var(--pp-ink-3);
    margin-left: 2px;
  }
  .pp-verdict .verdict-score .meter {
    display: flex; gap: 3px;
  }
  .pp-verdict .verdict-score .meter span {
    width: 16px; height: 16px; border-radius: 50%;
    background: var(--pp-rule-2);
  }
  .pp-verdict .verdict-score .meter span.on {
    background: linear-gradient(135deg, var(--pp-star) 0%, #f59e0b 100%);
  }
  .pp-compare-card { background: var(--pp-card); border: 1px solid var(--pp-rule); border-radius: var(--pp-radius-lg); overflow: hidden; }
  .pp-compare-card.featured { border: 2px solid var(--pp-ink); }
  .pp-compare-card .photo { aspect-ratio: 4/5; background: var(--pp-canvas); position: relative; }
  .pp-compare-card .photo img { width: 100%; height: 100%; object-fit: cover; display: block; }
  .pp-compare-card .photo .placeholder { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--pp-ink-3); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }
  .pp-compare-card.featured .photo::before {
    content: "OUR PICK"; position: absolute; top: 12px; right: 12px;
    background: var(--pp-ink); color: #fff;
    padding: 5px 10px; border-radius: 999px; font-size: 10px; letter-spacing: 0.12em; font-weight: 700;
  }
  .pp-compare-card .head { padding: 16px 18px 12px; border-bottom: 1px solid var(--pp-rule); }
  .pp-compare-card .head h4 { font-size: 13px; font-weight: 700; letter-spacing: -0.01em; line-height: 1.3; margin-bottom: 6px; min-height: 34px; }
  .pp-compare-card .head .price { font-size: 18px; font-weight: 700; letter-spacing: -0.02em; color: var(--pp-ink); }
  .pp-compare-card .body { padding: 8px 18px 18px; }
  .pp-compare-row { display: flex; justify-content: space-between; align-items: center; gap: 8px; padding: 10px 0; border-bottom: 1px solid var(--pp-rule-2); }
  .pp-compare-row:last-child { border-bottom: none; }
  .pp-compare-row .lbl { font-size: 11px; letter-spacing: 0.06em; color: var(--pp-ink-3); font-weight: 500; text-transform: uppercase; }
  .pp-compare-row .val { font-size: 12.5px; font-weight: 600; color: var(--pp-ink); text-align: right; max-width: 60%; }
  .pp-compare-row .val.good { color: var(--pp-safe-deep); }
  .pp-compare-row .val.bad { color: var(--pp-danger-deep); }
  .pp-compare-row .val.bad svg, .pp-compare-row .val.good svg { width: 11px; height: 11px; stroke-width: 2.5; vertical-align: -1px; margin-right: 3px; }
  @media (max-width: 720px) { .pp-compare { grid-template-columns: 1fr; } }

  /* ============ FAQ ============ */
  .pp-faq { margin-top: 24px; border-top: 1px solid var(--pp-rule); }
  .pp-faq-item { border-bottom: 1px solid var(--pp-rule); position: relative; }
  .pp-faq-item input[type="checkbox"] { position: absolute; opacity: 0; pointer-events: none; }
  .pp-faq-item label {
    display: flex; align-items: center; gap: 16px;
    padding: 20px 0;
    font-size: 16px; font-weight: 600; letter-spacing: -0.01em;
    color: var(--pp-ink);
    cursor: pointer;
    user-select: none;
  }
  .pp-faq-item label:hover { color: var(--pp-accent-deep); }
  .pp-faq-item label .q { flex: 1; }
  .pp-faq-item label .ico {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: var(--pp-canvas);
    display: flex; align-items: center; justify-content: center;
    color: var(--pp-ink-2);
    flex-shrink: 0;
    transition: transform 0.25s ease, background 0.2s ease, color 0.2s ease;
  }
  .pp-faq-item label .ico svg { width: 12px; height: 12px; stroke-width: 2.5; }
  .pp-faq-item input:checked + label .ico { background: var(--pp-ink); color: #fff; transform: rotate(45deg); }
  .pp-faq-answer { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; }
  .pp-faq-item input:checked ~ .pp-faq-answer { max-height: 500px; }
  .pp-faq-answer p { font-size: 14px; line-height: 1.7; color: var(--pp-ink-2); padding: 0 44px 22px 0; text-wrap: pretty; }

  /* ============ VERDICT ============ */
  .pp-verdict {
    margin: 56px 0 24px;
    padding: 40px;
    background: var(--pp-accent-tint);
    color: var(--pp-ink);
    border: 1px solid color-mix(in srgb, var(--pp-accent) 30%, transparent);
    border-radius: var(--pp-radius-lg);
    position: relative;
    overflow: hidden;
  }
  .pp-verdict .eyebrow { font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--pp-accent-deep); font-weight: 700; margin-bottom: 16px; position: relative; }
  .pp-verdict .score-row { display: flex; align-items: baseline; gap: 16px; margin-bottom: 20px; position: relative; }
  .pp-verdict .score { font-size: 48px; font-weight: 800; letter-spacing: -0.03em; line-height: 1; font-variant-numeric: tabular-nums; color: var(--pp-ink); }
  .pp-verdict .max { font-size: 18px; color: var(--pp-ink-3); font-weight: 500; }
  .pp-verdict .stars { color: var(--pp-star); letter-spacing: 3px; font-size: 18px; margin-left: auto; }
  .pp-verdict p { font-size: 15.5px; line-height: 1.7; color: var(--pp-ink-2); position: relative; max-width: 700px; text-wrap: pretty; }
  .pp-verdict p strong { color: var(--pp-ink); font-weight: 700; }

  @media (max-width: 600px) {
    .pp { font-size: 14px; }
    .pp-title { margin: 40px 0 20px; padding-bottom: 12px; gap: 10px; }
    .pp-title h2 { font-size: 20px; letter-spacing: -0.02em; }
    .pp-title .eyebrow, .pp-title .num { font-size: 10px; letter-spacing: 0.14em; }
    .pp-title .num { display: none; }
    .pp-hero { padding: 4px 0 28px; }
    .pp-hero .pp-subtitle { font-size: 16px; line-height: 1.5; }
    .pp-hero .pp-origin { font-size: 11px; padding: 6px 12px 6px 9px; margin-bottom: 16px; }
    .pp-badge { font-size: 11px; padding: 5px 10px; }
    .pp-nav { margin-top: 22px; padding: 14px; }
    .pp-nav-head { font-size: 10px; margin-bottom: 12px; }
    .pp-nav-list { grid-template-columns: repeat(2, 1fr); gap: 6px; }
    .pp-nav-list a { font-size: 12.5px; padding: 11px 12px; gap: 8px; }
    .pp-nav-list a .ico { width: 14px; height: 14px; }
    .pp-nav-list a .arrow { width: 12px; height: 12px; }
    .pp-scorecard { margin-top: 22px; }
    .pp-scorecard .val { font-size: 18px; }
    .pp-scorecard .lbl { font-size: 10px; }
    .pp-specs { grid-template-columns: repeat(2, 1fr); }
    .pp-spec { padding: 14px 12px; border-bottom: 1px solid var(--pp-rule); }
    .pp-spec:nth-child(odd) { border-right: 1px solid var(--pp-rule); }
    .pp-spec:nth-last-child(-n+1) { border-bottom: none; }
    .pp-spec .val { font-size: 13px; }
    .pp-sensory-item { padding: 14px; }
    .pp-feature { padding: 18px; }
    .pp-feature .ico-wrap { width: 36px; height: 36px; margin-bottom: 12px; }
    .pp-feature h4 { font-size: 15px; }
    .pp-feature p { font-size: 13px; }
    .pp-safety-item { padding: 16px 18px; gap: 12px; }
    .pp-safety-item strong { font-size: 13.5px; }
    .pp-safety-item p { font-size: 12.5px; }
    .pp-ingredient { padding: 20px 18px; }
    .pp-ingredient h3 { font-size: 17px; }
    .pp-ingredient .ing-icon { width: 38px; height: 38px; }
    .pp-ingredient .ing-icon svg { width: 19px; height: 19px; }
    .pp-ingredient .ing-head { gap: 12px; }
    .pp-ingredient .ing-head p { font-size: 13.5px; }
    .pp-science li { font-size: 12.5px; }
    .pp-step { padding: 16px 18px; gap: 4px; }
    .pp-step .num { font-size: 44px; min-width: 44px; padding-right: 10px; }
    .pp-step h4 { font-size: 14px; }
    .pp-step p { font-size: 13px; }
    .pp-fit-box { padding: 20px; }
    .pp-skin-card { padding: 18px; }
    .pp-skin-card .type { font-size: 14px; }
    .pp-timeline { padding-left: 24px; }
    .pp-timeline::before { left: 9px; }
    .pp-tl-item::before { left: -19px; width: 10px; height: 10px; border-width: 2px; }
    .pp-tl-item h4 { font-size: 15.5px; }
    .pp-tl-item p { font-size: 13.5px; }
    .pp-review-card { padding: 18px; }
    .pp-review-card .stats { gap: 18px; }
    .pp-review-card .stat .num { font-size: 19px; }
    .pp-pc { padding: 20px; }
    .pp-dupe-card .body { padding: 14px 16px 16px; }
    .pp-dupe-card .name { font-size: 13px; min-height: 0; }
    .pp-compare-card .head { padding: 14px 16px 10px; }
    .pp-compare-card .body { padding: 6px 16px 16px; }
    .pp-compare-card .head h4 { font-size: 13px; min-height: 0; }
    .pp-compare-card .head .price { font-size: 16px; }
    .pp-faq-item label { font-size: 15px; padding: 18px 0; gap: 12px; }
    .pp-faq-item label .ico { width: 26px; height: 26px; }
    .pp-faq-answer p { font-size: 13.5px; padding: 0 36px 18px 0; }
    .pp-verdict { padding: 28px 22px; margin: 44px 0 16px; }
    .pp-verdict .score { font-size: 38px; }
    .pp-verdict p { font-size: 14.5px; }
  }

  /* ============================================================
     ANIMATIONS — subtle, mobile-aware. Falls back to no-anim
     where view-timeline isn't supported (Safari, older Chrome).
     ============================================================ */
  @keyframes pp-fade-up {
    from { opacity: 0; transform: translateY(14px); }
    to   { opacity: 1; transform: translateY(0); }
  }
  @keyframes pp-fade-in {
    from { opacity: 0; }
    to   { opacity: 1; }
  }
  @keyframes pp-pulse-ring {
    0%, 100% { box-shadow: 0 0 0 5px var(--pp-accent-tint); }
    50%      { box-shadow: 0 0 0 10px color-mix(in srgb, var(--pp-accent) 18%, transparent); }
  }
  @keyframes pp-meter-fill {
    from { transform: scaleX(0); }
    to   { transform: scaleX(1); }
  }
  @keyframes pp-shine {
    0%   { background-position: -200% 0; }
    100% { background-position: 200% 0; }
  }

  /* Meter bars: animate width from 0 */
  .pp .pp-skin-card .meter span.on { transform-origin: left center; }

  /* Tooltip-style hover lift on cards (uniform) */
  .pp .pp-feature, .pp .pp-ingredient, .pp .pp-skin-card,
  .pp .pp-review-card, .pp .pp-dupe-card, .pp .pp-compare-card,
  .pp .pp-step, .pp .pp-tl-item, .pp .pp-pc {
    transition: transform 0.22s cubic-bezier(0.2, 0.8, 0.2, 1),
                box-shadow 0.22s ease,
                border-color 0.22s ease;
  }
  .pp .pp-feature:hover, .pp .pp-ingredient:hover, .pp .pp-skin-card:hover,
  .pp .pp-review-card:hover, .pp .pp-dupe-card:hover, .pp .pp-compare-card:hover,
  .pp .pp-tl-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px -8px rgba(13, 31, 45, 0.08);
  }

  /* Animated chevron lift on accordion & faq labels */
  .pp .pp-accordion label .lbl-ico,
  .pp .pp-faq-item label .q { transition: color 0.2s ease; }

  /* Verdict score — static color, no shine animation */
  .pp .pp-verdict .score { color: var(--pp-accent-deep); }

  /* Scroll-triggered fade-up on cards (view-timeline) */
  @supports (animation-timeline: view()) {
    .pp .pp-feature,
    .pp .pp-ingredient,
    .pp .pp-sensory-item,
    .pp .pp-skin-card,
    .pp .pp-tl-item,
    .pp .pp-review-card,
    .pp .pp-dupe-card,
    .pp .pp-compare-card,
    .pp .pp-step,
    .pp .pp-fit-box,
    .pp .pp-pc,
    .pp .pp-faq-item,
    .pp .pp-safety-item,
    .pp .pp-spec {
      animation: pp-fade-up 0.7s cubic-bezier(0.2, 0.8, 0.2, 1) both;
      animation-timeline: view();
      animation-range: entry 0% cover 22%;
    }
    .pp .pp-title {
      animation: pp-fade-in 0.5s ease both;
      animation-timeline: view();
      animation-range: entry 0% cover 18%;
    }
    .pp .pp-skin-card .meter span.on {
      animation: pp-meter-fill 0.9s cubic-bezier(0.2, 0.8, 0.2, 1) both;
      animation-timeline: view();
      animation-range: entry 10% cover 30%;
    }
  }

  /* ============================================================
     SCROLL REVEALS — cross-browser fallback for animation-timeline: view().
     Cards are visible by default. When the inline script at the end
     of .pp runs, it adds .pp-anim-ready to the root — then cards hide
     and IntersectionObserver adds .is-visible to fade them in on scroll.
     If the script is stripped (some Shopify themes do), content stays
     visible — graceful degradation.
     ============================================================ */
  @media (prefers-reduced-motion: no-preference) {
    .pp.pp-anim-ready .pp-feature,
    .pp.pp-anim-ready .pp-ingredient,
    .pp.pp-anim-ready .pp-sensory-item,
    .pp.pp-anim-ready .pp-skin-card,
    .pp.pp-anim-ready .pp-tl-item,
    .pp.pp-anim-ready .pp-review-card,
    .pp.pp-anim-ready .pp-dupe-card,
    .pp.pp-anim-ready .pp-compare-card,
    .pp.pp-anim-ready .pp-step,
    .pp.pp-anim-ready .pp-fit-box,
    .pp.pp-anim-ready .pp-pc,
    .pp.pp-anim-ready .pp-faq-item,
    .pp.pp-anim-ready .pp-safety-item,
    .pp.pp-anim-ready .pp-spec {
      opacity: 0;
      transform: translateY(16px);
      transition: opacity 0.6s cubic-bezier(0.2, 0.8, 0.2, 1),
                  transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
      will-change: opacity, transform;
    }
    .pp.pp-anim-ready .is-visible {
      opacity: 1 !important;
      transform: translateY(0) !important;
    }
  }

  /* Tap feedback — native mobile feel */
  @media (hover: none) and (pointer: coarse) {
    .pp .pp-feature:active, .pp .pp-ingredient:active,
    .pp .pp-skin-card:active, .pp .pp-review-card:active,
    .pp .pp-dupe-card:active, .pp .pp-compare-card:active,
    .pp .pp-step:active, .pp .pp-pc:active, .pp .pp-tl-item:active,
    .pp .pp-sensory-item:active, .pp .pp-fit-box:active,
    .pp .pp-nav-list a:active, .pp .pp-badge:active,
    .pp .pp-faq-item label:active, .pp .pp-accordion label:active {
      transform: scale(0.985);
      transition: transform 0.08s ease-out;
    }
  }

  /* ===== Back-to-top floating button (mobile-focused) ===== */
  .pp-back-to-top {
    position: fixed;
    bottom: 20px;
    right: 20px;
    width: 46px; height: 46px;
    border-radius: 50%;
    background: var(--pp-ink);
    color: #fff;
    border: none;
    display: flex; align-items: center; justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 18px rgba(13, 31, 45, 0.22);
    opacity: 0;
    transform: translateY(20px) scale(0.9);
    pointer-events: none;
    transition: opacity 0.25s ease, transform 0.3s cubic-bezier(0.2, 0.8, 0.2, 1);
    z-index: 50;
    -webkit-tap-highlight-color: transparent;
  }
  .pp-back-to-top.is-visible {
    opacity: 1;
    transform: translateY(0) scale(1);
    pointer-events: auto;
  }
  .pp-back-to-top:active { transform: translateY(0) scale(0.92); }
  .pp-back-to-top svg {
    width: 18px; height: 18px;
    stroke: currentColor; stroke-width: 2; fill: none;
    stroke-linecap: round; stroke-linejoin: round;
  }
  @media (min-width: 900px) { .pp-back-to-top { display: none; } }

  /* Decorative hero corner accent — removed per design feedback */
  .pp-hero { position: relative; }
  .pp-hero::before { display: none; }
  .pp-hero > * { position: relative; z-index: 1; }

  /* Respect motion preferences */
  @media (prefers-reduced-motion: reduce) {
    .pp *, .pp *::before, .pp *::after {
      animation-duration: 0.001ms !important;
      animation-iteration-count: 1 !important;
      transition-duration: 0.001ms !important;
    }
    .pp .pp-verdict .score {
      background: none;
      -webkit-text-fill-color: currentColor;
      color: var(--pp-ink);
    }
  }

  /* ============================================================
     HARMONIZE — Theme "Product Overview" section below .pp
     Restyles Skincarisma's Quick Product Notes / EWG / skin-type
     / ingredient-list to feel native to the new .pp design.
     ============================================================ */

  /* Section headings: h2.top-line and .title-with-tooltip.top-line */
  h2.top-line,
  .title-with-tooltip.top-line {
    border-top: none !important;
    margin: 24px 0 16px !important;
    padding: 0 !important;
    font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.022em;
    line-height: 1.25;
    color: var(--pp-ink);
    position: relative;
  }
  /* First top-line ("Product Description") at top of section — minimal top margin */
  h2.top-line:first-child,
  .product__block:first-child h2.top-line,
  section[id*="__product_overview"] .page-width > h2.top-line:first-of-type {
    margin-top: 4px !important;
  }
  h2.top-line::before,
  .title-with-tooltip.top-line::before {
    content: "";
    display: block;
    width: 32px;
    height: 3px;
    background: linear-gradient(90deg, var(--pp-accent) 0%, var(--pp-accent-deep) 100%);
    border-radius: 999px;
    margin-bottom: 12px;
  }

  /* Sub-section h3 (Quick Product Notes, Notable Effects, etc.) */
  .title-with-tooltip h3 {
    font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
    font-size: 17px;
    font-weight: 700;
    letter-spacing: -0.01em;
    color: var(--pp-ink);
    margin: 24px 0 6px;
  }
  .title-with-tooltip {
    display: flex;
    align-items: center;
    gap: 8px;
  }
  .caption-more-info {
    font-size: 12.5px;
    color: var(--pp-ink-3);
    margin-bottom: 14px;
    letter-spacing: 0.01em;
  }

  /* Quick Product Notes grid */
  .quick-products-container {
    gap: 10px;
    margin: 8px 0 28px !important;
  }
  .quick-products-container > div {
    background: var(--pp-soft);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-sm);
    padding: 10px 12px !important;
    transition: border-color 0.15s ease, background 0.15s ease;
  }
  .quick-products-container > div:hover {
    border-color: var(--pp-accent);
    background: var(--pp-accent-tint);
  }
  .qn-icon span {
    border-bottom: none !important;
    font-size: 13.5px;
    font-weight: 600;
    color: var(--pp-ink);
  }

  /* Notable ingredients pills */
  .notable-ingredients {
    margin: 8px 0 28px;
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
  }
  .notable-ingredients span {
    background: var(--pp-accent-tint) !important;
    color: var(--pp-accent-deep) !important;
    border: 1px solid color-mix(in srgb, var(--pp-accent) 25%, transparent);
    border-radius: 999px !important;
    padding: 5px 11px !important;
    font-size: 12.5px !important;
    font-weight: 600;
    letter-spacing: 0.005em;
  }

  /* Skin-type categories */
  .skin-type-categories {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
    gap: 8px;
    margin: 8px 0 28px;
  }
  .skin-type-container .skin-type {
    background: var(--pp-soft);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius-sm);
    padding: 10px 12px;
    font-size: 13.5px;
    color: var(--pp-ink);
  }
  .skin-type-label {
    font-weight: 600;
    color: var(--pp-ink-2);
    margin-right: 6px;
  }

  /* Risk breakdown — recolor squares using design tokens */
  .risk-breakdown-container {
    background: var(--pp-soft);
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius);
    padding: 16px 18px !important;
    margin: 12px 0 28px;
  }
  .risk-breakdown-label {
    font-weight: 600;
    color: var(--pp-ink);
    margin-bottom: 8px !important;
  }
  .risk-square {
    border-radius: 4px !important;
    width: 12px !important;
    height: 12px !important;
    display: inline-block;
  }
  .risk-square.low-risk,
  .low-risk.risk-square { background: var(--pp-safe) !important; }
  .risk-square.medium-risk,
  .medium-risk.risk-square { background: var(--pp-warn) !important; }
  .risk-square.high-risk,
  .high-risk.risk-square { background: var(--pp-danger) !important; }

  /* EWG rating circles */
  .cir-rating {
    width: 28px; height: 28px;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 12px;
    font-weight: 700;
    color: #fff;
  }
  .cir-rating.low-risk { background: var(--pp-safe); }
  .cir-rating.cir-medium { background: var(--pp-warn); }
  .cir-rating[class*="high"] { background: var(--pp-danger); }

  /* Ingredient list table */
  table.ingredient-list {
    width: 100%;
    border-collapse: separate;
    border-spacing: 0;
    margin: 16px 0;
    font-family: "Pretendard Variable", Pretendard, -apple-system, BlinkMacSystemFont, sans-serif;
    font-size: 13.5px;
  }
  table.ingredient-list thead th {
    background: var(--pp-soft);
    color: var(--pp-ink-2);
    font-weight: 600;
    font-size: 12px;
    letter-spacing: 0.04em;
    text-transform: uppercase;
    padding: 12px 10px !important;
    border-bottom: 2px solid var(--pp-rule) !important;
  }
  table.ingredient-list tbody tr.ingredient-row {
    transition: background 0.15s ease;
  }
  table.ingredient-list tbody tr.ingredient-row:hover {
    background: var(--pp-accent-tint);
  }
  table.ingredient-list tbody td {
    padding: 10px !important;
    border-bottom: 1px solid var(--pp-rule-2) !important;
    color: var(--pp-ink);
  }
  table.ingredient-list .ingredient-list-caption {
    font-size: 12.5px;
    color: var(--pp-ink-3);
    margin: 4px 0 12px;
  }

  /* Contains/Doesn't-contain badges */
  .contains-ingredient {
    display: inline-block;
    padding: 3px 10px;
    border-radius: 999px;
    font-size: 11.5px;
    font-weight: 700;
    letter-spacing: 0.02em;
    text-transform: uppercase;
  }
  .contains-ingredient[class*="yes"],
  .contains-ingredient.yes { background: var(--pp-danger-tint); color: var(--pp-danger-deep); }
  .contains-ingredient[class*="no"],
  .contains-ingredient.no { background: var(--pp-safe-tint); color: var(--pp-safe-deep); }

  /* Tooltips */
  .tooltip-custom .tooltiptext {
    background: #ffffff !important;
    border: 1px solid var(--pp-rule);
    border-radius: var(--pp-radius);
    box-shadow: 0 10px 30px rgba(13, 31, 45, 0.12);
    color: var(--pp-ink);
    padding: 16px 18px !important;
    font-size: 13.5px;
    line-height: 1.55;
  }
  .tooltip-header {
    color: var(--pp-ink);
    font-weight: 700;
    font-size: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 6px;
  }
  .close-tooltip {
    background: var(--pp-accent);
    color: #ffffff;
    border-radius: var(--pp-radius-sm);
    padding: 8px 14px;
    font-weight: 600;
    font-size: 13px;
    cursor: pointer;
    transition: background 0.15s ease;
  }
  .close-tooltip:hover { background: var(--pp-accent-deep); }

  /* Modals */
  .modal-window {
    background: #ffffff !important;
    border-radius: var(--pp-radius-lg) !important;
    box-shadow: 0 24px 60px rgba(13, 31, 45, 0.18) !important;
    border: 1px solid var(--pp-rule);
  }
  .modal-close {
    color: var(--pp-ink-3);
    transition: color 0.15s ease;
  }
  .modal-close:hover { color: var(--pp-ink); }

  /* Accordion panels (disclaimers, etc.) */
  .accordion-panel {
    background: var(--pp-soft);
    border-radius: var(--pp-radius-sm);
    padding: 12px 14px;
    margin: 8px 0;
    font-size: 13.5px;
    color: var(--pp-ink-2);
    line-height: 1.55;
  }

  /* Mobile tweaks for harmonized section */
  @media (max-width: 600px) {
    h2.top-line,
    .title-with-tooltip.top-line { font-size: 19px; margin-top: 32px !important; }
    .quick-products-container { gap: 8px; }
    .skin-type-categories { grid-template-columns: 1fr; }
    table.ingredient-list { font-size: 12.5px; }
  }