/* Copied from ../styles/main.css top-page footer styles. Keep in sync with index.html. */
    .hk-footer-section {
      background: #f4f1e9;
      color: #232116;
      font-family: var(--font-sans, 'BIZ UDPGothic', sans-serif);
      letter-spacing: 0;
    }

    .hk-footer-section *,
    .hk-footer-section *::before,
    .hk-footer-section *::after {
      box-sizing: border-box;
      letter-spacing: 0;
    }

    .hk-footer-line {
      height: 4px;
      background: #1f5b4f;
    }

    .hk-footer-inner {
      width: min(calc(100% - 32px), 1080px);
      margin: 0 auto;
      padding: 38px 0 34px;
    }

    .hk-footer-top {
      display: grid;
      grid-template-columns: minmax(260px, 0.95fr) minmax(360px, 1fr);
      gap: 36px;
      align-items: center;
      padding-bottom: 26px;
      border-bottom: 1px solid rgba(35, 33, 22, 0.18);
    }

    .hk-footer-brand {
      width: min(100%, 320px);
      display: flex;
      align-items: center;
      gap: 15px;
      color: inherit;
      text-decoration: none;
    }

    .hk-footer-brand-mark {
      width: 82px;
      height: 82px;
      flex: 0 0 82px;
      border: 1px solid rgba(181, 154, 91, 0.38);
      border-radius: 999px;
      background: #fffefb;
      object-fit: contain;
      box-shadow: 0 10px 20px rgba(61, 40, 23, 0.08);
    }

    .hk-footer-brand-text {
      min-width: 0;
      display: grid;
      gap: 4px;
    }

    .hk-footer-brand-eyebrow {
      color: #1f5b4f;
      font-size: 0.88rem;
      font-weight: 900;
      line-height: 1.25;
    }

    .hk-footer-brand-name {
      color: #3d2817;
      font-family: var(--font-heading);
      font-size: 1.85rem;
      font-weight: 900;
      line-height: 1.1;
      white-space: nowrap;
    }

    .hk-footer-brand-note {
      color: #4b4034;
      font-size: 0.8rem;
      font-weight: 900;
      line-height: 1.3;
    }

    .hk-footer-info {
      display: grid;
      gap: 5px;
      justify-items: end;
      color: #2a271d;
      font-style: normal;
      font-size: 0.94rem;
      font-weight: 800;
      line-height: 1.65;
      text-align: right;
    }

    .hk-footer-info strong {
      color: #1f5b4f;
      font-size: 1.08rem;
      font-weight: 900;
    }

    .hk-footer-info a {
      color: #1f5b4f;
      font-size: 1rem;
      font-weight: 900;
      text-decoration: none;
    }

    .hk-footer-nav {
      display: flex;
      flex-wrap: wrap;
      justify-content: center;
      gap: 10px 0;
      padding: 22px 0 18px;
      border-bottom: 1px solid rgba(35, 33, 22, 0.18);
    }

    .hk-footer-nav a {
      display: inline-flex;
      align-items: center;
      min-height: 28px;
      padding: 0 13px;
      border-right: 1px solid rgba(35, 33, 22, 0.22);
      color: #2a271d;
      font-size: 0.9rem;
      font-weight: 900;
      line-height: 1.35;
      text-decoration: none;
      transition: color 0.18s ease;
    }

    .hk-footer-nav a:first-child {
      border-left: 1px solid rgba(35, 33, 22, 0.22);
    }

    .hk-footer-nav a:hover,
    .hk-footer-nav a:focus-visible,
    .hk-footer-review a:hover,
    .hk-footer-review a:focus-visible {
      color: #1f5b4f;
    }

    .hk-footer-symptoms {
      max-width: 900px;
      margin: 18px auto 0;
      color: #3d382b;
      text-align: center;
      font-size: 0.88rem;
      font-weight: 800;
      line-height: 1.85;
    }

    .hk-footer-symptoms-label {
      margin-bottom: 3px;
      color: #1f5b4f;
      font-size: 0.8rem;
      font-weight: 900;
    }

    .hk-footer-review {
      margin: 15px 0 0;
      color: #3d382b;
      text-align: center;
      font-size: 0.9rem;
      font-weight: 900;
      line-height: 1.7;
    }

    .hk-footer-review a {
      color: #1f5b4f;
      text-decoration: underline;
      text-decoration-thickness: 1px;
      text-underline-offset: 4px;
    }

    .hk-footer-note {
      max-width: 760px;
      margin: 12px auto 0;
      color: rgba(35, 33, 22, 0.68);
      text-align: center;
      font-size: 0.75rem;
      font-weight: 800;
      line-height: 1.7;
    }

    .hk-footer-copy {
      padding: 13px 16px;
      background: #1f5b4f;
      color: #fff;
      text-align: center;
      font-size: 0.82rem;
      font-weight: 900;
      line-height: 1.5;
    }

    @media (max-width: 767px) {
      .hk-footer-inner {
        width: min(calc(100% - 28px), 1080px);
        padding: 32px 0 28px;
      }

      .hk-footer-top {
        grid-template-columns: 1fr;
        gap: 22px;
        justify-items: center;
        text-align: center;
      }

      .hk-footer-brand {
        width: min(100%, 260px);
        justify-content: center;
      }

      .hk-footer-brand-mark {
        width: 66px;
        height: 66px;
        flex-basis: 66px;
      }

      .hk-footer-brand-eyebrow {
        font-size: 0.76rem;
      }

      .hk-footer-brand-name {
        font-size: 1.34rem;
      }

      .hk-footer-brand-note {
        font-size: 0.7rem;
      }

      .hk-footer-info {
        justify-items: center;
        text-align: center;
        font-size: 0.88rem;
      }

      .hk-footer-nav {
        display: grid;
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 8px;
      }

      .hk-footer-nav a,
      .hk-footer-nav a:first-child {
        min-height: 42px;
        justify-content: center;
        padding: 8px 10px;
        border: 1px solid rgba(35, 33, 22, 0.18);
        border-radius: 999px;
        background: rgba(255, 255, 255, 0.45);
        font-size: 0.84rem;
      }

      .hk-footer-symptoms {
        text-align: left;
        font-size: 0.84rem;
      }

      .hk-footer-symptoms-label,
      .hk-footer-review,
      .hk-footer-note {
        text-align: center;
      }

      .hk-footer-copy {
        padding: 13px 16px 98px;
      }
    }
