/* il — page theme (moved out of the blade). Base reset/.reveal/.home-btn in company-base.css */
:root {
        --ink: #2c2a3d;
        --ink-2: #56536a;
        --muted: #7c7989;
        --red: #e2342b;
        --red-deep: #c01f17;
        --paper: #fffdfb;
        --cream: #f7f1e8;
        --sand: #efe6d8;
        --beige: #d8b98c;
        --blush: #f6e7ea;
        --pink: #e3b0b7;
        --mint: #e7f0eb;
        --mint-2: #bcd6c7;
        --blue: #2e57a6;
        --blue-deep: #233f7a;
        --yellow: #fdcc2d;
        --line: rgba(44, 42, 61, 0.12);
        --shadow: 0 26px 64px rgba(44, 42, 61, 0.13);
        --shadow-sm: 0 14px 34px rgba(44, 42, 61, 0.1);
        --r: 20px;
        --sans: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
        --serif: "Montserrat", -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
      }

      * { box-sizing: border-box; }
      html { scroll-behavior: smooth; }
      body {
        margin: 0;
        overflow-x: hidden;
        color: var(--ink);
        background: var(--paper);
        font-family: var(--sans);
        line-height: 1.62;
        -webkit-font-smoothing: antialiased;
      }
      body.menu-open { overflow: hidden; }
      a { color: inherit; text-decoration: none; }
      img { display: block; max-width: 100%; }
      h1, h2, h3, p { margin-top: 0; }

      .container { width: min(1240px, calc(100% - 44px)); margin: 0 auto; }

      h1, h2 { font-family: var(--serif); font-weight: 600; letter-spacing: -0.5px; color: var(--ink); }
      h1 { font-size: clamp(42px, 5.6vw, 78px); line-height: 1.02; margin-bottom: 22px; }
      h2 { font-size: clamp(32px, 4vw, 56px); line-height: 1.06; margin-bottom: 18px; }
      h1 em, h2 em { font-style: italic; color: var(--red); }

      .eyebrow {
        display: inline-flex; align-items: center; gap: 10px;
        color: var(--red); font-size: 11px; font-weight: 800;
        letter-spacing: 2px; text-transform: uppercase; margin-bottom: 18px;
      }
      .eyebrow::before { width: 26px; height: 2px; background: var(--red); content: ""; border-radius: 2px; }
      .eyebrow.alt { color: var(--blue); }
      .eyebrow.alt::before { background: var(--yellow); }
      .eyebrow.light { color: #fff; }
      .eyebrow.light::before { background: var(--yellow); }

      .button {
        display: inline-flex; min-height: 52px; padding: 0 24px;
        align-items: center; justify-content: center; gap: 11px;
        border: 1.5px solid transparent; border-radius: 999px;
        background: var(--red); color: #fff;
        font-family: var(--sans); font-size: 12.5px; font-weight: 800;
        letter-spacing: 0.5px; cursor: pointer; transition: 220ms ease;
      }
      .button:hover { transform: translateY(-3px); box-shadow: 0 16px 28px rgba(226, 52, 43, 0.28); }
      .button.ghost { background: transparent; border-color: var(--line); color: var(--ink); }
      .button.ghost:hover { border-color: var(--ink); box-shadow: none; }
      .button.light { background: #fff; color: var(--ink); }
      .button.navy { background: var(--ink); color: #fff; }
      .button.navy:hover { box-shadow: 0 16px 28px rgba(44, 42, 61, 0.28); }
      .arrow {
        display: grid; width: 25px; height: 25px; place-items: center;
        border-radius: 50%; background: rgba(255, 255, 255, 0.22); font-size: 14px;
      }
      .ghost .arrow, .light .arrow { background: var(--blush); color: var(--red); }

      section { padding: clamp(72px, 9vw, 116px) 0; }
      .body-copy { max-width: 660px; color: var(--ink-2); font-size: 16px; }

      .section-head { max-width: 720px; margin-bottom: 50px; }
      .section-head.center { margin-left: auto; margin-right: auto; text-align: center; }
      .section-head p { margin: 0; color: var(--muted); font-size: 16px; }

      /* ---------------- NAV ---------------- */
      .topbar {
        position: sticky; top: 0; z-index: 50;
        background: rgba(255, 253, 251, 0.85);
        backdrop-filter: saturate(160%) blur(14px);
        border-bottom: 1px solid var(--line);
      }
      nav { display: flex; min-height: 76px; align-items: center; justify-content: space-between; gap: 22px; }
      .brand { display: flex; align-items: center; gap: 12px; }
      .brand img { height: 30px; width: auto; }
      .brand b { font-family: var(--sans); font-weight: 800; font-size: 15px; letter-spacing: 0.5px; color: var(--ink); }
      .brand b span { color: var(--muted); font-weight: 600; }
      .nav-links { display: flex; align-items: center; gap: 26px; }
      .nav-links > a:not(.button) {
        color: var(--ink-2); font-size: 12.5px; font-weight: 700;
        letter-spacing: 0.3px; transition: color 0.2s;
      }
      .nav-links > a:not(.button):hover { color: var(--red); }
      .menu-toggle {
        display: none; width: 44px; height: 44px; border: 1px solid var(--line);
        border-radius: 12px; background: #fff; color: var(--ink); cursor: pointer; font-size: 18px;
      }

      /* ---------------- HERO ---------------- */
      .hero {
        position: relative; overflow: hidden;
        background:
          radial-gradient(circle at 84% 14%, rgba(227, 176, 183, 0.4), transparent 30%),
          radial-gradient(circle at 92% 76%, rgba(253, 204, 45, 0.22), transparent 26%),
          radial-gradient(circle at 6% 86%, rgba(188, 214, 199, 0.4), transparent 30%),
          linear-gradient(180deg, #fffdfb, #faf4ec);
      }
      .hero-grid {
        display: grid; gap: 54px; align-items: center;
        grid-template-columns: 1.04fr 0.96fr;
        padding: clamp(48px, 6vw, 86px) 0 clamp(60px, 6vw, 96px);
      }
      .hero-copy { max-width: 600px; margin-bottom: 30px; color: var(--ink-2); font-size: 17.5px; }
      .hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
      .hero-stats {
        display: grid; grid-template-columns: repeat(4, 1fr);
        margin-top: 52px; gap: 0;
      }
      .hero-stat { padding: 0 18px; border-left: 1px solid var(--line); }
      .hero-stat:first-child { padding-left: 0; border-left: 0; }
      .hero-stat strong { display: block; font-family: var(--serif); font-weight: 600; color: var(--ink); font-size: 30px; line-height: 1; }
      .hero-stat span { display: block; margin-top: 8px; color: var(--muted); font-size: 10.5px; font-weight: 700; letter-spacing: 0.6px; text-transform: uppercase; }

      .hero-visual { position: relative; min-height: 540px; }
      .hero-main {
        position: absolute; inset: 0 0 0 8%;
        border-radius: 30px 30px 30px 90px; overflow: hidden;
        box-shadow: var(--shadow); border: 8px solid #fff;
      }
      .hero-main img { width: 100%; height: 100%; object-fit: cover; }
      .hero-mini {
        position: absolute; left: -6px; bottom: 34px; width: 42%;
        border-radius: 22px; overflow: hidden; border: 7px solid #fff;
        box-shadow: var(--shadow-sm);
      }
      .hero-mini img { width: 100%; height: 200px; object-fit: cover; }
      .hero-chip {
        position: absolute; top: 26px; right: -8px; display: flex; align-items: center; gap: 11px;
        padding: 13px 17px; border-radius: 16px; background: rgba(255, 255, 255, 0.92);
        box-shadow: var(--shadow-sm); border: 1px solid rgba(255, 255, 255, 0.8); backdrop-filter: blur(8px);
      }
      .hero-chip .dot { display: grid; width: 38px; height: 38px; place-items: center; border-radius: 12px; background: var(--mint); color: #2f8161; font-size: 16px; }
      .hero-chip b { display: block; font-size: 13px; color: var(--ink); }
      .hero-chip span { display: block; font-size: 11px; color: var(--muted); }
      .hero-brandtag {
        position: absolute; right: 16px; bottom: -14px; display: flex; gap: 8px; align-items: center;
        padding: 10px 16px; border-radius: 999px; background: var(--ink); color: #fff;
        font-size: 11px; font-weight: 700; letter-spacing: 0.5px; box-shadow: var(--shadow-sm);
      }
      .hero-brandtag i { width: 7px; height: 7px; border-radius: 50%; background: var(--yellow); }

      /* ---------------- MARKETS STRIP ---------------- */
      .markets { background: var(--ink); color: rgba(255, 255, 255, 0.72); padding: 30px 0; }
      .markets .container { display: flex; align-items: center; gap: 30px; flex-wrap: wrap; justify-content: center; }
      .markets-label { font-size: 11px; font-weight: 800; letter-spacing: 1.6px; text-transform: uppercase; color: rgba(255, 255, 255, 0.5); }
      .markets-list { display: flex; flex-wrap: wrap; gap: 10px 12px; justify-content: center; }
      .markets-list span {
        padding: 8px 15px; border: 1px solid rgba(255, 255, 255, 0.18); border-radius: 999px;
        font-size: 12.5px; font-weight: 600; color: rgba(255, 255, 255, 0.86);
      }

      /* ---------------- PHILOSOPHY ---------------- */
      .philosophy { background: var(--cream); }
      .phil-grid { display: grid; grid-template-columns: 1fr 0.92fr; gap: 64px; align-items: center; }
      .phil-quote { font-family: var(--serif); font-style: italic; font-weight: 500; font-size: clamp(26px, 3vw, 38px); line-height: 1.25; color: var(--ink); margin-bottom: 22px; }
      .phil-quote span { color: var(--red); }
      .pillars { display: grid; gap: 14px; margin-top: 30px; }
      .pillar { display: flex; gap: 16px; padding: 20px 22px; background: #fff; border-radius: 16px; border: 1px solid var(--line); box-shadow: var(--shadow-sm); }
      .pillar .ic { display: grid; flex: 0 0 auto; width: 48px; height: 48px; place-items: center; border-radius: 14px; font-size: 22px; }
      .pillar:nth-child(1) .ic { background: var(--blush); }
      .pillar:nth-child(2) .ic { background: var(--sand); }
      .pillar:nth-child(3) .ic { background: var(--mint); }
      .pillar h3 { margin: 0 0 3px; font-family: var(--sans); font-size: 16px; font-weight: 800; color: var(--ink); }
      .pillar p { margin: 0; font-size: 13.5px; color: var(--muted); }
      .phil-collage { position: relative; min-height: 480px; }
      .phil-collage .a { position: absolute; top: 0; left: 0; width: 64%; height: 330px; object-fit: cover; border-radius: 24px; box-shadow: var(--shadow); }
      .phil-collage .b { position: absolute; right: 0; top: 90px; width: 50%; height: 270px; object-fit: cover; border-radius: 24px; border: 7px solid var(--cream); box-shadow: var(--shadow-sm); }
      .phil-collage .c { position: absolute; left: 16%; bottom: 0; width: 46%; height: 210px; object-fit: cover; border-radius: 22px; border: 7px solid var(--cream); box-shadow: var(--shadow-sm); }

      /* ---------------- BRANDS ---------------- */
      .brands-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 26px; }
      .brand-card { position: relative; overflow: hidden; border-radius: 28px; padding: 42px; box-shadow: var(--shadow); }
      .brand-card.nordico { background: linear-gradient(160deg, #fbf6ef, #f1e7da); border: 1px solid rgba(216, 185, 140, 0.4); }
      .brand-card.pawmio { background: linear-gradient(160deg, #2e57a6, #233f7a); color: #fff; }
      .brand-logo { height: 54px; margin-bottom: 26px; }
      .brand-card.nordico .brand-logo { height: 60px; }
      .brand-kind { font-size: 11px; font-weight: 800; letter-spacing: 1.6px; text-transform: uppercase; color: var(--red); margin-bottom: 10px; }
      .brand-card.pawmio .brand-kind { color: var(--yellow); }
      .brand-card h3 { font-family: var(--serif); font-weight: 600; font-size: 26px; margin: 0 0 12px; }
      .brand-card p { font-size: 14.5px; margin-bottom: 22px; }
      .brand-card.nordico p { color: var(--ink-2); }
      .brand-card.pawmio p { color: rgba(255, 255, 255, 0.84); }
      .swatches { display: flex; gap: 9px; flex-wrap: wrap; }
      .swatch { display: flex; flex-direction: column; align-items: center; gap: 6px; }
      .swatch i { width: 34px; height: 34px; border-radius: 10px; box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.06); }
      .swatch span { font-size: 9.5px; font-weight: 700; letter-spacing: 0.4px; color: var(--muted); text-transform: uppercase; }
      .brand-card.pawmio .swatch span { color: rgba(255, 255, 255, 0.7); }

      /* ---------------- MANUFACTURING ---------------- */
      .mfg { background: var(--paper); }
      .mfg-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; }
      .mfg-card { padding: 28px 24px; border-radius: 18px; border: 1px solid var(--line); background: #fff; box-shadow: var(--shadow-sm); }
      .mfg-card .badge { display: inline-flex; align-items: center; justify-content: center; min-width: 56px; height: 30px; padding: 0 12px; border-radius: 999px; font-size: 11px; font-weight: 800; letter-spacing: 0.6px; margin-bottom: 18px; }
      .mfg-card.k .badge { background: var(--ink); color: #fff; }
      .mfg-card.c .badge { background: var(--blush); color: var(--red-deep); }
      .mfg-card.kc .badge { background: var(--mint); color: #2f8161; }
      .mfg-card.mold .badge { background: var(--sand); color: #8a6a36; }
      .mfg-card h3 { font-family: var(--sans); font-size: 16px; font-weight: 800; margin: 0 0 8px; color: var(--ink); }
      .mfg-card p { margin: 0; font-size: 13.5px; color: var(--muted); }

      /* ---------------- TIMELINE ---------------- */
      .timeline { background: var(--ink); color: #fff; overflow: hidden; }
      .timeline .eyebrow { color: var(--yellow); }
      .timeline .eyebrow::before { background: var(--yellow); }
      .timeline h2 { color: #fff; }
      .timeline .section-head p { color: rgba(255, 255, 255, 0.6); }
      .tl-track { display: grid; grid-template-columns: repeat(6, 1fr); gap: 1px; background: rgba(255, 255, 255, 0.14); border-radius: 18px; overflow: hidden; }
      .tl-item { background: var(--ink); padding: 24px 20px; min-height: 158px; transition: background 0.25s; }
      .tl-item:hover { background: #34324a; }
      .tl-item b { display: block; font-family: var(--serif); font-weight: 600; font-size: 25px; color: var(--yellow); margin-bottom: 11px; }
      .tl-item span { font-size: 12.5px; color: rgba(255, 255, 255, 0.78); line-height: 1.5; }

      /* ---------------- PRODUCTS ---------------- */
      .products { background: linear-gradient(180deg, #fffdfb, #f7f1e8); }
      .tabs { display: flex; flex-wrap: wrap; gap: 9px; margin-bottom: 38px; }
      .tab {
        padding: 10px 18px; border-radius: 999px; border: 1.5px solid var(--line);
        background: #fff; color: var(--ink-2); font-family: var(--sans);
        font-size: 12.5px; font-weight: 700; cursor: pointer; transition: 0.2s;
      }
      .tab:hover { border-color: var(--red); color: var(--red); }
      .tab.active { background: var(--red); border-color: var(--red); color: #fff; }
      .product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }
      .pcard {
        display: flex; flex-direction: column; overflow: hidden; background: #fff;
        border-radius: 18px; border: 1px solid var(--line); box-shadow: var(--shadow-sm);
        transition: 240ms ease;
      }
      .pcard:hover { transform: translateY(-6px); box-shadow: var(--shadow); }
      .pcard-img { position: relative; aspect-ratio: 1 / 1; background: #f6f4f1; overflow: hidden; }
      .pcard-img img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s ease; }
      .pcard:hover .pcard-img img { transform: scale(1.05); }
      .pcard-origin {
        position: absolute; top: 12px; left: 12px; padding: 5px 11px; border-radius: 999px;
        font-size: 9.5px; font-weight: 800; letter-spacing: 0.4px; text-transform: uppercase;
        background: rgba(255, 255, 255, 0.92); backdrop-filter: blur(4px);
      }
      .pcard-origin.kr { color: var(--ink); }
      .pcard-origin.cn { color: var(--red-deep); }
      .pcard-body { display: flex; flex-direction: column; flex: 1; padding: 18px 18px 20px; }
      .pcard-cat { font-size: 10px; font-weight: 800; letter-spacing: 0.8px; text-transform: uppercase; color: var(--red); margin-bottom: 7px; }
      .pcard h3 { font-family: var(--sans); font-size: 15.5px; font-weight: 700; line-height: 1.25; margin: 0 0 7px; color: var(--ink); }
      .pcard p { font-size: 12.5px; color: var(--muted); margin: 0 0 15px; }
      .pcard-foot { margin-top: auto; display: flex; align-items: center; justify-content: space-between; padding-top: 13px; border-top: 1px solid var(--line); }
      .pcard-price { font-size: 15px; font-weight: 800; color: var(--ink); }
      .pcard-price small { font-size: 10px; font-weight: 700; color: var(--muted); }
      .pcard-moq { font-size: 10.5px; font-weight: 700; color: var(--muted); }

      /* ---------------- PAWMIO BAND ---------------- */
      .pawband { position: relative; overflow: hidden; background: var(--blue); color: #fff; }
      .pawband::before { content: ""; position: absolute; top: -120px; right: -80px; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(253, 204, 45, 0.22), transparent 70%); }
      .pawband-grid { position: relative; display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 54px; align-items: center; }
      .pawband h2 { color: #fff; }
      .pawband h2 em { color: var(--yellow); }
      .pawband p { color: rgba(255, 255, 255, 0.84); font-size: 16px; }
      .paw-points { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 22px; }
      .paw-points span { padding: 9px 15px; border: 1px solid rgba(255, 255, 255, 0.25); border-radius: 999px; font-size: 12.5px; font-weight: 600; }
      .paw-gallery { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
      .paw-gallery figure { margin: 0; border-radius: 20px; overflow: hidden; background: rgba(255, 255, 255, 0.08); box-shadow: 0 18px 40px rgba(20, 30, 60, 0.3); }
      .paw-gallery img { width: 100%; height: 100%; aspect-ratio: 1 / 1; object-fit: cover; }
      .paw-gallery figure:nth-child(1) { transform: translateY(-14px); }
      .paw-gallery figure:nth-child(4) { transform: translateY(-14px); }

      /* ---------------- QUOTATION ---------------- */
      .quotation { background: var(--paper); }
      .price-wrap { border: 1px solid var(--line); border-radius: 22px; overflow: hidden; box-shadow: var(--shadow-sm); background: #fff; }
      .price-cat { display: grid; grid-template-columns: 1.7fr 0.9fr 0.7fr; gap: 14px; padding: 13px 26px; background: var(--cream); font-size: 11px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--ink); }
      .price-cat span:nth-child(2) { text-align: center; }
      .price-cat span:nth-child(3) { text-align: right; }
      .prow { display: grid; grid-template-columns: 1.7fr 0.9fr 0.7fr; gap: 14px; align-items: center; padding: 14px 26px; border-top: 1px solid var(--line); }
      .prow strong { font-size: 14px; font-weight: 600; color: var(--ink); }
      .prow .origin { justify-self: center; padding: 4px 11px; border-radius: 999px; font-size: 10px; font-weight: 800; letter-spacing: 0.4px; }
      .origin.kr { background: var(--mint); color: #2f8161; }
      .origin.cn { background: var(--blush); color: var(--red-deep); }
      .prow .pp { text-align: right; font-size: 15px; font-weight: 800; color: var(--red); }
      .price-note { margin-top: 18px; color: var(--muted); font-size: 12.5px; max-width: 760px; }
      .price-cta { margin-top: 26px; display: flex; flex-wrap: wrap; gap: 12px; }
      /* Collapsible price table — native <details>/<summary> accordion (one per category) */
      .price-group { border-top: 1px solid var(--line); }
      .price-group:first-of-type { border-top: 0; }
      .price-group > summary {
        display: grid; grid-template-columns: 1.7fr 0.9fr 0.7fr; gap: 14px; align-items: center;
        padding: 15px 26px; background: var(--cream); cursor: pointer; list-style: none;
        transition: background 0.2s ease; -webkit-tap-highlight-color: transparent;
      }
      .price-group > summary::-webkit-details-marker { display: none; }
      .price-group > summary:hover { background: #f2e9da; }
      .price-group > summary:focus-visible { outline: 2px solid var(--red); outline-offset: -2px; }
      .price-group > summary .pg-title { display: flex; align-items: center; gap: 10px; font-size: 11px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--ink); }
      .price-group > summary .pg-count { display: inline-grid; place-items: center; min-width: 34px; height: 19px; padding: 0 8px; border-radius: 999px; background: var(--blush); color: var(--red-deep); font-size: 10px; font-weight: 800; letter-spacing: 0.3px; }
      .price-group > summary .pg-chev { width: 8px; height: 8px; border-right: 2px solid var(--muted); border-bottom: 2px solid var(--muted); transform: rotate(45deg); transition: transform 0.25s ease; flex: 0 0 auto; margin-left: 2px; }
      .price-group[open] > summary .pg-chev { transform: rotate(-135deg); border-color: var(--red); }
      .price-group > summary .pg-orig, .price-group > summary .pg-fob { font-size: 11px; font-weight: 800; letter-spacing: 1px; text-transform: uppercase; color: var(--ink); }
      .price-group > summary .pg-orig { text-align: center; }
      .price-group > summary .pg-fob { text-align: right; }
      .price-group .prow:first-of-type { border-top: 0; }
      .price-group[open] > summary { background: #faf4ec; }
      .price-group[open] > summary:hover { background: #f2e9da; }
      .price-group[open] .prow { animation: pgFade 0.28s ease both; }
      @keyframes pgFade { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: none; } }
      @media (prefers-reduced-motion: reduce) { .price-group > summary .pg-chev { transition: none; } .price-group[open] .prow { animation: none; } }

      /* ---------------- CATALOGUE ---------------- */
      .catalogue { background: var(--cream); }
      .cat-pages { display: grid; grid-template-columns: repeat(5, 1fr); gap: 16px; margin-bottom: 36px; }
      .cat-pages a { display: block; border-radius: 12px; overflow: hidden; box-shadow: var(--shadow-sm); border: 1px solid var(--line); transition: 0.25s; background: #fff; }
      .cat-pages a:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
      .cat-pages img { width: 100%; height: 100%; object-fit: cover; aspect-ratio: 16 / 10; }
      .downloads { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; }
      .dl-card { display: flex; align-items: center; gap: 16px; padding: 22px 24px; border-radius: 18px; background: #fff; border: 1px solid var(--line); box-shadow: var(--shadow-sm); transition: 0.22s; }
      .dl-card:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
      .dl-card .ic { display: grid; flex: 0 0 auto; width: 48px; height: 48px; place-items: center; border-radius: 14px; background: var(--blush); color: var(--red); font-size: 20px; }
      .dl-card b { display: block; font-size: 14.5px; color: var(--ink); }
      .dl-card span { font-size: 11.5px; color: var(--muted); }

      /* ---------------- CERTIFICATIONS ---------------- */
      .certs { background: var(--paper); }
      .cert-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
      .cert { padding: 26px 22px; border-radius: 18px; border: 1px dashed var(--line); text-align: center; }
      .cert .ic { font-size: 26px; margin-bottom: 12px; }
      .cert b { display: block; font-size: 14px; color: var(--ink); margin-bottom: 5px; }
      .cert span { font-size: 12px; color: var(--muted); }

      /* ---------------- CONTACT ---------------- */
      .contact { background: linear-gradient(180deg, #f7f1e8, #fffdfb); padding-bottom: 60px; }
      .contact-card { display: grid; grid-template-columns: 1.05fr 0.95fr; overflow: hidden; border-radius: 28px; background: var(--ink); color: #fff; box-shadow: var(--shadow); }
      .contact-main { padding: 56px; }
      .contact-main .eyebrow { color: var(--yellow); }
      .contact-main .eyebrow::before { background: var(--yellow); }
      .contact-main h2 { color: #fff; }
      .contact-main p { color: rgba(255, 255, 255, 0.78); max-width: 460px; margin-bottom: 26px; }
      .contact-detail { padding: 48px; background: rgba(255, 255, 255, 0.05); display: grid; align-content: start; gap: 18px; }
      .cline { padding-bottom: 16px; border-bottom: 1px solid rgba(255, 255, 255, 0.14); }
      .cline:last-child { padding-bottom: 0; border-bottom: 0; }
      .cline small { display: block; color: var(--yellow); font-size: 10px; font-weight: 800; letter-spacing: 1.2px; text-transform: uppercase; margin-bottom: 6px; }
      .cline span, .cline a { display: block; color: rgba(255, 255, 255, 0.9); font-size: 13.5px; }
      .cline a:hover { color: var(--yellow); }
      .salescard { margin-top: 4px; padding: 16px 18px; border-radius: 14px; background: var(--red); }
      .salescard small { color: rgba(255, 255, 255, 0.8); }
      .salescard b { display: block; font-size: 15px; margin: 4px 0; }

      footer.foot { display: flex; justify-content: space-between; gap: 14px; padding-top: 30px; color: var(--muted); font-size: 12.5px; }

      .reveal { opacity: 0; transform: translateY(24px); transition: opacity 0.65s ease, transform 0.65s ease; }
      .reveal.visible { opacity: 1; transform: none; }

      .home-btn {
        position: fixed; left: 18px; bottom: 18px; z-index: 9999; display: inline-flex; align-items: center; gap: 8px;
        background: #fff; color: var(--ink); font-size: 0.82rem; font-weight: 700; padding: 11px 20px;
        border-radius: 40px; box-shadow: 0 10px 30px -8px rgba(0, 0, 0, 0.35); border: 1px solid rgba(0, 0, 0, 0.06);
      }

      /* ---------------- RESPONSIVE ---------------- */
      @media (max-width: 1024px) {
        .hero-grid, .phil-grid, .brands-grid, .pawband-grid, .contact-card { grid-template-columns: 1fr; }
        .product-grid { grid-template-columns: repeat(3, 1fr); }
        .mfg-grid, .cert-grid { grid-template-columns: repeat(2, 1fr); }
        .tl-track { grid-template-columns: repeat(3, 1fr); }
        .cat-pages { grid-template-columns: repeat(3, 1fr); }
        .phil-grid { gap: 40px; }
        .phil-collage { min-height: 420px; }
        .hero-stats { margin-top: 40px; }
      }
      @media (max-width: 760px) {
        .nav-links {
          position: fixed; inset: 0 0 0 26%; z-index: 60; padding: 92px 30px;
          flex-direction: column; align-items: stretch; gap: 18px;
          background: rgba(255, 253, 251, 0.98); transform: translateX(100%); transition: transform 0.25s ease;
        }
        .menu-open .nav-links { transform: none; }
        .menu-toggle { display: block; z-index: 61; }
        .product-grid { grid-template-columns: repeat(2, 1fr); }
        .tl-track { grid-template-columns: repeat(2, 1fr); }
        .downloads { grid-template-columns: 1fr; }
        .hero-stats { grid-template-columns: repeat(2, 1fr); gap: 24px 0; }
        .hero-stat:nth-child(3) { padding-left: 0; border-left: 0; }
        .price-cat, .price-group > summary, .prow { grid-template-columns: 1.4fr 0.7fr 0.6fr; padding-left: 16px; padding-right: 16px; gap: 8px; }
        .prow strong { font-size: 12.5px; }
        .contact-main, .contact-detail { padding: 34px 26px; }
        footer.foot { flex-direction: column; }
        .hero-mini { display: none; }
      }
      @media (max-width: 480px) {
        .product-grid, .mfg-grid, .cert-grid, .cat-pages { grid-template-columns: 1fr; }
        .brand-card { padding: 32px 26px; }
        .paw-gallery { grid-template-columns: 1fr 1fr; }
        .price-cat span:nth-child(2), .price-group > summary .pg-orig, .prow .origin { display: none; }
        .price-cat, .price-group > summary, .prow { grid-template-columns: 1.6fr 0.6fr; }
      }

      .pillar .ic svg { width: 23px; height: 23px; }
      .dl-card .ic svg { width: 21px; height: 21px; }
      .cert .ic svg { width: 27px; height: 27px; display: inline-block; }
      .hero-chip .dot svg { width: 18px; height: 18px; }
      .salescard .inl svg { width: 13px; height: 13px; vertical-align: -2px; }
