
    /* ===== Inline scoped styles for new index UI ===== */
    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    body { font-family: 'DM Sans', 'Inter', -apple-system, sans-serif; background: #FFFFFF; color: #1A1A2E; line-height: 1.5; }
    a { text-decoration: none; color: inherit; }
    button { font-family: inherit; cursor: pointer; border: none; background: none; }
    img { display: block; }

    /* ===== Hero Banner (warm coral gradient) ===== */
    .hero-banner { position: relative; background: #FFFFFF; padding: 0; overflow: hidden; display: flex; align-items: center; justify-content: center; }
    .hero-banner__inner { max-width: 1600px; margin: 0 auto; display: flex; align-items: center; justify-content: space-between; gap: 40px; width: 100%; }
    .hero-banner__text { flex: 1; max-width: 507px; text-align: left; position: absolute; left: 40px; top: calc(50% + 60px); transform: translateY(-50%); z-index: 10; background: rgba(255,255,255,0.1); padding: 10px; border-radius: 16px; backdrop-filter: blur(8px); font-size: 120%; }
    .hero-banner__title { font-size: 30px; font-weight: 700; color: #1A1A2E; line-height: 1.25; margin-bottom: 12px; font-family: 'DM Sans', sans-serif; }
    .hero-banner__subtitle { font-size: 16px; color: #777; margin-bottom: 20px; line-height: 1.5; }
    @media (max-width: 767px) {
      .hero-banner__title { font-size: 20px; }
    }
    .hero-banner__ctas { display: flex; gap: 10px; flex-wrap: wrap; }
    .hero-banner__cta { display: inline-flex; align-items: center; padding: 12px 28px; border-radius: 8px; font-size: 14px; font-weight: 600; transition: background .2s, color .2s, border-color .2s; text-decoration: none; }
    .hero-banner__cta--primary { background: #1A1A2E; color: #fff; }
    .hero-banner__cta--primary:hover { background: #444; }
    .hero-banner__cta--outline { border: 2px solid #1A1A2E; color: #1A1A2E; }
    .hero-banner__cta--outline:hover { background: #1A1A2E; color: #fff; }
    .hero-banner__proof { margin-top: 16px; font-size: 13px; color: #999; }
    .hero-banner__proof strong { color: #1A1A2E; }
    .hero-banner__trust { display: grid; grid-template-columns: 1fr 1fr; gap: 10px 16px; margin-top: 18px; padding-top: 16px; border-top: 1px solid #eee; }
    .hero-banner__trust-item { display: flex; align-items: center; gap: 6px; font-size: 12px; color: #555; line-height: 1.3; }
    .hero-banner__trust-item .trust-icon { flex-shrink: 0; }
    .hero-banner__trust-item strong { color: #1A1A2E; font-size: 12px; white-space: nowrap; }
    .hero-banner__trust-sub { color: #888; font-size: 11px; display: block; }
    @media (max-width: 767px) {
      .hero-banner__trust { grid-template-columns: 1fr 1fr; gap: 8px 12px; }
      .hero-banner__trust-item { flex-wrap: wrap; gap: 2px 6px; }
      .hero-banner__trust-sub { width: 100%; padding-left: 22px; }
    }
    .hero-banner__img { flex: 1 1 auto; max-width: 1440px; width: 100%; display: none; position: relative; aspect-ratio: 16/6; overflow: hidden; }
    @media (max-width: 767px) {
      .hero-banner { flex-direction: column; padding: 0; }
      .hero-banner__inner { flex-direction: column-reverse; gap: 16px; padding: 24px 20px 16px; }
      .hero-banner__text { position: static; max-width: 1440px; text-align: center; transform: none; z-index: auto; background: transparent; backdrop-filter: none; font-size: 100%; }
      .hero-banner__img { display: block; position: relative; max-width: 1440px; width: 100%; z-index: 0; background: transparent; }
      .hero-banner__img img { position: relative; inset: auto; width: 100%; aspect-ratio: 16/6; border-radius: 0; }
      .hero-banner__ctas { justify-content: center; }
      .hero-banner__proof { text-align: center; }
    }
    .hero-banner__img img { width: 100%; z-index: 1; aspect-ratio: 16/6; object-fit: cover; border-radius: 0; opacity: 0; transition: opacity 0.8s ease; position: absolute; inset: 0; }
    .hero-banner__img img.active { opacity: 1; }
    .hero-banner__dots { position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%); display: flex; gap: 8px; z-index: 10; pointer-events: auto; }
    .hero-banner__dot { width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,.5); transition: background .3s, width .3s; border: none; cursor: pointer; }
    .hero-banner__dot.active { background: #fff; width: 24px; border-radius: 4px; }
    .hero-banner__arrow { position: absolute; top: 50%; transform: translateY(-50%); z-index: 10; width: 36px; height: 36px; border-radius: 50%; background: rgba(255,255,255,.85); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; font-size: 18px; color: #333; box-shadow: 0 2px 8px rgba(0,0,0,.12); transition: opacity .2s, background .2s; opacity: 0; pointer-events: none; }
    .hero-banner__img:hover .hero-banner__arrow { opacity: 1; pointer-events: auto; }
    .hero-banner__arrow:hover { background: #fff; }
    .hero-banner__arrow--prev { left: 8px; }
    .hero-banner__arrow--next { right: 8px; }
    @media (max-width: 767px) {
      .hero-banner__arrow { width: 30px; height: 30px; font-size: 14px; opacity: 0.7; pointer-events: auto; }
      .hero-banner__arrow--prev { left: 4px; }
      .hero-banner__arrow--next { right: 4px; }
    }
    @media (min-width: 768px) {
      .hero-banner { padding: 0; }
      .hero-banner__title { font-size: 36px; }
      .hero-banner__img { display: block; }
    }



    /* ===== Section Common ===== */
    .home-section { max-width: 1440px; margin: 0 auto; padding: 20px 20px; content-visibility: auto; contain-intrinsic-size: 600px; }
    .home-section--alt { background: #ffffff; max-width: 1440px; padding: 20px; }
    @media (max-width: 768px) { .home-section--alt { padding: 20px; } }
    .home-section__header { text-align: left; margin-bottom: 20px; }
    .home-section__header--split { display: flex; align-items: center; justify-content: space-between; text-align: left; }
    .home-section__title { font-size: 22px; font-weight: 700; color: #1A1A2E; font-family: 'DM Sans', sans-serif; }
    .home-section__link { font-size: 13px; font-weight: 600; color: #8B9E8B; transition: color .15s; white-space: nowrap; }
    .home-section__link:hover { color: #6b8a6b; }

    /* ===== Shop By Recipient ===== */
    .recipient-grid { display: grid; grid-template-columns: repeat(6, 1fr); gap: 16px; }
    .recipient-card { text-align: center; cursor: pointer; transition: transform .2s; text-decoration: none; }
    .recipient-card:hover { transform: translateY(-4px); }
    .recipient-card__circle { width: 100%; max-width: 160px; aspect-ratio: 1; border-radius: 50%; background: #f0ede8; margin: 0 auto 10px; overflow: hidden; transition: box-shadow .2s; }
    .recipient-card:hover .recipient-card__circle { box-shadow: 0 4px 16px rgba(139,158,139,.3); }
    .recipient-card__circle img { width: 100%; height: 100%; object-fit: cover; border-radius: 50%; }
    .recipient-card__label { font-size: 13px; font-weight: 600; color: #1A1A2E; }
    .recipient-card__sub { font-size: 11px; color: #999; margin-top: 2px; }
    @media (max-width: 768px) {
      .recipient-grid { display: flex; gap: 12px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; flex-wrap: nowrap; }
      .recipient-card { flex: 0 0 120px; }
      .recipient-card__circle { width: 100%; max-width: 120px; aspect-ratio: 1; }
    }

    /* ===== Shop By Occasion ===== */
    .occasion-scroll { display: flex; gap: 16px; overflow-x: auto; padding: 0 4px 8px; -webkit-overflow-scrolling: touch; scrollbar-width: none; justify-content: flex-start; }
    .occasion-scroll::-webkit-scrollbar { display: none; }
    .occasion-card { flex-shrink: 0; width: 372px; border-radius: 12px; overflow: hidden; cursor: pointer; position: relative; transition: transform .2s; text-decoration: none; }
    .occasion-card:hover { transform: translateY(-4px); }
    .occasion-card img { width: 372px; height: 279px; object-fit: cover; border-radius: 12px; display: block; }
    .occasion-card__overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px 12px 10px; background: linear-gradient(transparent, rgba(0,0,0,.55)); border-radius: 0 0 12px 12px; text-align: center; }
    .occasion-card__name { font-size: 19px; font-weight: 600; color: #fff; word-wrap: break-word; text-shadow: 0 1px 4px rgba(0,0,0,.4); }
    .occasion-card__count { font-size: 16px; color: rgba(255,255,255,.8); }
    .empty-hint { text-align: center; color: #bbb; font-size: 14px; padding: 32px 16px; }
    @media (max-width: 768px) {
      .occasion-scroll { display: flex; gap: 12px; overflow-x: auto; -webkit-overflow-scrolling: touch; scrollbar-width: none; justify-content: flex-start; }
      .occasion-card { width: 140px; flex-shrink: 0; overflow: visible; border-radius: 12px; background: transparent; }
      .occasion-card img { width: 100%; height: 180px; object-fit: cover; border-radius: 12px; }
      .occasion-card__overlay { position: static; background: transparent; padding: 6px 2px 0; border-radius: 0; text-align: center; }
      .occasion-card__name { font-size: 12px; color: #1A1A2E; text-shadow: none; }
      .occasion-card__count { font-size: 11px; color: #999; }
    }

    /* ===== Product Scroll Row ===== */
    .product-scroll { display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 16px; }
    .product-scroll .product-card { width: auto; display: block; }
    @media (max-width: 768px) {
      .product-scroll { grid-template-columns: repeat(2, 1fr); gap: 10px; }
    }

    /* ===== Category Quick Links ===== */
    .cat-quick-grid { display: flex; gap: 16px; overflow-x: auto; padding: 0 4px 8px; -webkit-overflow-scrolling: touch; scrollbar-width: none; justify-content: flex-start; }
    .scroll-wrap { position: relative; }
    .scroll-arrow { display: flex; position: absolute; top: 50%; transform: translateY(-50%); z-index: 2; width: 32px; height: 32px; border-radius: 50%; background: rgba(255,255,255,.9); border: 1px solid #eee; align-items: center; justify-content: center; font-size: 16px; cursor: pointer; box-shadow: 0 2px 8px rgba(0,0,0,.1); transition: opacity .2s; color: #333; }
    .scroll-arrow:hover { background: #fff; }
    .scroll-arrow--left { left: -4px; }
    .scroll-arrow--right { right: -4px; }
    .scroll-arrow--hidden { opacity: 0; pointer-events: none; }
    @media (max-width: 768px) {
      .cat-quick-grid { justify-content: flex-start; gap: 12px; }
      .cat-quick-card { width: 130px; }
      .cat-quick-card img { width: 100%; height: 98px; }
    }
    .cat-quick-grid::-webkit-scrollbar { display: none; }
    .cat-quick-card { flex-shrink: 0; width: 372px; position: relative; border-radius: 12px; overflow: hidden; cursor: pointer; text-decoration: none; transition: transform .2s; }
    .cat-quick-card:hover { transform: translateY(-4px); }
    .cat-quick-card img { width: 372px; height: 279px; object-fit: cover; transition: transform .4s; }
    .cat-quick-card:hover img { transform: scale(1.05); }
    .cat-quick-card__overlay { position: absolute; bottom: 0; left: 0; right: 0; padding: 24px 12px 10px; background: linear-gradient(transparent, rgba(0,0,0,.55)); border-radius: 0 0 12px 12px; text-align: center; }
    .cat-quick-card__name { font-size: 19px; font-weight: 600; color: #fff; word-wrap: break-word; text-shadow: 0 1px 4px rgba(0,0,0,.4); }
    .cat-quick-card__count { font-size: 16px; color: rgba(255,255,255,.8); }
    @media (max-width: 768px) {
      .cat-quick-card { width: 140px; }
    }

    /* ===== Promo Banner ===== */

    /* ===== Reviews / What They Say ===== */
    .reviews-scroll { display: flex; gap: 20px; overflow-x: auto; padding-bottom: 12px; -webkit-overflow-scrolling: touch; scrollbar-width: none; }
    .reviews-scroll::-webkit-scrollbar { display: none; }
    .review-card { flex-shrink: 0; width: 300px; background: #fff; border-radius: 12px; padding: 24px; box-shadow: 0 2px 12px rgba(0,0,0,.06); border: 1px solid #f0ede8; }
    .review-card__stars { font-size: 16px; margin-bottom: 12px; letter-spacing: -2px; }
    .review-card__text { font-size: 14px; color: #555; line-height: 1.6; margin-bottom: 16px; font-style: italic; }
    .review-card__author { font-size: 13px; font-weight: 700; color: #E8364E; }
    @media (max-width: 480px) {
      .review-card { width: 260px; padding: 20px; }
    }
    .promo-banner { background: #1A1A2E; padding: 48px 20px; text-align: center; content-visibility: auto; contain-intrinsic-size: 200px; }
    .promo-banner__inner { max-width: 1440px; margin: 0 auto; }
    .promo-banner__title { font-size: 28px; font-weight: 700; color: #fff; margin-bottom: 12px; }
    .promo-banner__text { font-size: 15px; color: rgba(255,255,255,.7); margin-bottom: 24px; }
    .promo-banner__code { display: none; }
    .promo-banner__form { display: flex; gap: 8px; justify-content: center; margin-bottom: 16px; flex-wrap: wrap; }
    .promo-banner__input { padding: 12px 20px; border-radius: 8px; border: 1px solid rgba(255,255,255,.2); background: #fff; font-size: 14px; width: 280px; max-width: 1440px; color: #333; outline: none; }
    .promo-banner__input::placeholder { color: #999; }
    .promo-banner__submit { padding: 12px 24px; border-radius: 8px; border: none; background: #E8364E; color: #fff; font-size: 14px; font-weight: 600; cursor: pointer; transition: background .15s; }
    .promo-banner__submit:hover { background: #d4673f; }
    .promo-banner__btn { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; font-weight: 600; color: #E8364E; transition: color .15s; text-decoration: none; }
    .promo-banner__btn:hover { color: #fff; }

    /* ===== Accessibility: Focus Visible ===== */
    a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible, select:focus-visible {
      outline: 2px solid #8B9E8B;
      outline-offset: 2px;
    }
    .hero-banner__cta:focus-visible { outline-offset: 3px; }
    .scroll-arrow:focus-visible, .hero-banner__arrow:focus-visible {
      outline: 2px solid #1A1A2E;
      outline-offset: 2px;
    }
    .hero-banner__dot:focus-visible {
      outline: 2px solid #1A1A2E;
      outline-offset: 2px;
      opacity: 1 !important;
    }

    /* ===== Reduced Motion ===== */
    @media (prefers-reduced-motion: reduce) {
      *, *::before, *::after {
        animation-duration: 0.01ms !important;
        animation-iteration-count: 1 !important;
        transition-duration: 0.01ms !important;
        scroll-behavior: auto !important;
      }
      .hero-banner__img img { transition: none !important; }
      .recipient-card, .occasion-card, .cat-quick-card { transition: none !important; }
    }
  