/** Shopify CDN: Minification failed

Line 289:18 Unexpected "="
Line 292:7 Expected ":"
Line 293:7 Expected ":"
Line 294:4 Expected ":"
Line 296:5 Unexpected "("
Line 297:4 Comments in CSS use "/* ... */" instead of "//"
Line 299:9 Expected ":"
Line 300:6 Expected ":"
Line 301:6 Expected ":"
Line 304:7 Expected ":"
... and 5 more hidden warnings

**/

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body { font-family: 'DM Sans', sans-serif; background: #fafaf8; color: #1a1a18; }
.page { max-width: 1400px; margin: 0 auto; padding: 0 48px 48px; }

.em-nav { display: flex; align-items: center; justify-content: space-between; padding: 20px 0; border-bottom: 0.5px solid #e0dfd8; }
.em-logo { font-family: 'Playfair Display', serif; font-size: 22px; letter-spacing: -0.5px; color: #1a1a18; cursor: pointer; }
.em-logo span { font-style: italic; }
.em-nav-links { display: flex; gap: 24px; font-size: 13px; color: #888780; }
.em-nav-links a { color: inherit; text-decoration: none; cursor: pointer; }
.em-nav-links a:hover { color: #1a1a18; }
.em-nav-btn { font-size: 13px; font-family: 'DM Sans', sans-serif; background: #1a1a18; color: #fafaf8; border: none; padding: 9px 20px; border-radius: 999px; cursor: pointer; font-weight: 500; }
.em-nav-btn:hover { background: #333; }

.em-hero { display: grid; grid-template-columns: 1fr 1fr; gap: 60px; padding: 56px 0 48px; align-items: center; }
.em-hero-tag { display: inline-block; font-size: 11px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; background: #f1efe8; color: #888780; padding: 5px 12px; border-radius: 999px; margin-bottom: 20px; border: 0.5px solid #d3d1c7; }
.em-hero h1 { font-family: 'Playfair Display', serif; font-size: 42px; font-weight: 600; line-height: 1.15; margin: 0 0 16px; letter-spacing: -0.5px; color: #1a1a18; }
.em-hero h1 em { font-style: italic; }
.em-hero p { font-size: 15px; color: #5f5e5a; line-height: 1.7; margin: 0 0 28px; }
.em-hero-btns { display: flex; gap: 12px; align-items: center; }
.em-btn-primary { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 500; background: #1a1a18; color: #fafaf8; border: none; padding: 12px 24px; border-radius: 999px; cursor: pointer; }
.em-btn-primary:hover { background: #333; }
.em-btn-ghost { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 400; background: transparent; color: #5f5e5a; border: 0.5px solid #b4b2a9; padding: 12px 24px; border-radius: 999px; cursor: pointer; }
.em-btn-ghost:hover { background: #f1efe8; }
.em-hero-price { font-size: 12px; color: #888780; margin-top: 12px; }

.em-envelope-preview { background: #f1efe8; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 28px; }
.em-envelope-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: #888780; margin-bottom: 14px; }
.em-envelope-items { display: flex; flex-direction: column; gap: 10px; }
.em-env-item { display: flex; align-items: center; gap: 10px; background: #fff; border: 0.5px solid #d3d1c7; border-radius: 8px; padding: 10px 14px; }
.em-env-icon { font-size: 18px; color: #5f5e5a; }
.em-env-name { font-weight: 500; font-size: 13px; color: #1a1a18; }
.em-env-desc { font-size: 11px; color: #888780; }

.em-divider { border: none; border-top: 0.5px solid #e0dfd8; margin: 48px 0; }
.em-section-label { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: #888780; text-align: center; margin-bottom: 8px; }
.em-section-title { font-family: 'Playfair Display', serif; font-size: 28px; font-weight: 600; text-align: center; margin: 0 0 6px; letter-spacing: -0.3px; color: #1a1a18; }
.em-section-sub { font-size: 14px; color: #5f5e5a; text-align: center; margin: 0 0 32px; }

.em-how-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.em-step { text-align: center; padding: 8px; }
.em-step-num { width: 36px; height: 36px; border-radius: 50%; background: #f1efe8; border: 0.5px solid #d3d1c7; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 500; margin: 0 auto 12px; color: #1a1a18; }
.em-step-title { font-weight: 500; font-size: 14px; margin-bottom: 6px; color: #1a1a18; }
.em-step-desc { font-size: 12px; color: #5f5e5a; line-height: 1.6; }

/* HOBBY CARDS — 2x2 grid for 4 envelopes */
.em-hobby-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 16px; margin-bottom: 16px; }
.em-hobby-card { background: #fff; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 22px; cursor: pointer; transition: border-color 0.15s, transform 0.1s; display: flex; flex-direction: column; gap: 6px; }
.em-hobby-card:hover { border-color: #888780; transform: translateY(-2px); }
.em-hobby-icon { font-size: 26px; margin-bottom: 6px; color: #5f5e5a; }
.em-hobby-name { font-weight: 500; font-size: 15px; color: #1a1a18; }
.em-hobby-tag { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: #888780; }
.em-hobby-price { font-size: 13px; color: #5f5e5a; margin-top: 4px; }
.em-hobby-shortdesc { font-size: 12px; color: #5f5e5a; line-height: 1.6; margin-top: 4px; }

/* PLAN CARDS */
.plan-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 12px; margin-bottom: 20px; }
.em-plan-card { background: #fff; border: 1.5px solid #d3d1c7; border-radius: 12px; padding: 22px 18px; cursor: pointer; transition: border-color 0.15s, transform 0.1s; position: relative; }
.em-plan-card:hover { border-color: #888780; transform: translateY(-2px); }
.em-plan-card.featured { border-color: #378add; }
.em-plan-card.selected { border: 2.5px solid #1a1a18 !important; transform: translateY(-2px); }
.em-selected-badge { position: absolute; top: -11px; right: 14px; background: #1a1a18; color: #fafaf8; font-size: 10px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; padding: 3px 10px; border-radius: 999px; }
.em-plan-badge { font-size: 10px; font-weight: 500; letter-spacing: 1px; text-transform: uppercase; background: #e6f1fb; color: #185fa5; padding: 4px 10px; border-radius: 999px; display: inline-block; margin-bottom: 14px; }
.em-plan-name { font-weight: 500; font-size: 16px; margin-bottom: 4px; color: #1a1a18; }
.em-plan-price { font-family: 'Playfair Display', serif; font-size: 32px; font-weight: 600; color: #1a1a18; }
.em-plan-price span { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 400; color: #888780; }
.em-plan-desc { font-size: 12px; color: #888780; margin: 8px 0 16px; }
.em-plan-features { font-size: 13px; color: #5f5e5a; display: flex; flex-direction: column; gap: 7px; padding: 0; }
.em-plan-features li { list-style: none; display: flex; align-items: center; gap: 7px; }
.em-check { color: #3b6d11; font-size: 15px; }
.plan-cta-row { display: flex; align-items: center; gap: 14px; margin-top: 8px; }
.plan-checkout-btn { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 500; background: #1a1a18; color: #fafaf8; border: none; padding: 13px 28px; border-radius: 999px; cursor: pointer; transition: background 0.15s; }
.plan-checkout-btn:hover:not(:disabled) { background: #333; }
.plan-checkout-btn:disabled { background: #b4b2a9; cursor: not-allowed; }
.plan-hint { font-size: 12px; color: #888780; transition: opacity 0.2s; }

.em-footer { border-top: 0.5px solid #e0dfd8; padding: 28px 0; display: flex; justify-content: space-between; align-items: center; font-size: 12px; color: #888780; }
.em-footer-logo { font-family: 'Playfair Display', serif; font-size: 16px; color: #1a1a18; }

.breadcrumb { display: flex; align-items: center; gap: 6px; font-size: 12px; color: #888780; margin: 24px 0 0; }
.breadcrumb span { cursor: pointer; }
.breadcrumb span:hover { color: #1a1a18; }
.breadcrumb .sep { color: #d3d1c7; cursor: default; }

.hobbies-full-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.hobby-detail-card { background: #fff; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 24px; cursor: pointer; transition: border-color 0.15s, transform 0.1s; }
.hobby-detail-card:hover { border-color: #1a1a18; transform: translateY(-2px); }
.hd-icon { font-size: 30px; margin-bottom: 12px; color: #5f5e5a; }
.hd-name { font-family: 'Playfair Display', serif; font-weight: 600; font-size: 18px; color: #1a1a18; margin-bottom: 4px; }
.hd-tag { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: #888780; margin-bottom: 10px; }
.hd-desc { font-size: 13px; color: #5f5e5a; line-height: 1.65; margin-bottom: 14px; }
.hd-price { font-size: 14px; font-weight: 500; color: #1a1a18; }
.hd-cta { font-size: 12px; color: #888780; margin-top: 4px; }

.hs-header { display: grid; grid-template-columns: 1fr 1fr; gap: 40px; align-items: start; margin-bottom: 40px; margin-top: 24px; }
.hs-tag { display: inline-block; font-size: 10px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; background: #f1efe8; color: #888780; padding: 5px 12px; border-radius: 999px; margin-bottom: 16px; border: 0.5px solid #d3d1c7; }
.hs-title { font-family: 'Playfair Display', serif; font-size: 34px; font-weight: 600; line-height: 1.2; margin-bottom: 12px; color: #1a1a18; }
.hs-desc { font-size: 15px; color: #5f5e5a; line-height: 1.7; margin-bottom: 24px; }
.hs-price-row { display: flex; align-items: baseline; gap: 8px; margin-bottom: 8px; }
.hs-price-big { font-family: 'Playfair Display', serif; font-size: 36px; font-weight: 600; color: #1a1a18; }
.hs-price-sub { font-size: 14px; color: #888780; }
.hs-pricing-note { font-size: 12px; color: #888780; margin-bottom: 20px; }
.hs-meta { display: flex; flex-direction: column; gap: 10px; }
.hs-meta-item { font-size: 12px; color: #888780; display: flex; align-items: center; gap: 6px; }
.hs-sample-box { background: #f1efe8; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 24px; }
.hs-sample-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: #888780; margin-bottom: 14px; }
.hs-sample-items { display: flex; flex-direction: column; gap: 10px; }
.hs-sample-item { background: #fff; border: 0.5px solid #d3d1c7; border-radius: 8px; padding: 10px 14px; display: flex; align-items: center; gap: 10px; }
.si-icon { font-size: 18px; color: #5f5e5a; }
.si-name { font-weight: 500; font-size: 13px; color: #1a1a18; }
.si-desc { font-size: 11px; color: #888780; }
.hs-why-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
.hs-why-card { background: #fff; border: 0.5px solid #d3d1c7; border-radius: 10px; padding: 16px; }
.wc-icon { font-size: 20px; color: #5f5e5a; margin-bottom: 8px; }
.wc-title { font-weight: 500; font-size: 13px; color: #1a1a18; margin-bottom: 4px; }
.wc-desc { font-size: 12px; color: #5f5e5a; line-height: 1.6; }

.faq-item { border-top: 0.5px solid #e0dfd8; padding: 16px 0; }
.faq-q { font-weight: 500; font-size: 14px; color: #1a1a18; margin-bottom: 8px; }
.faq-a { font-size: 13px; color: #5f5e5a; line-height: 1.7; }

.hiw-step { display: grid; grid-template-columns: 56px 1fr; gap: 24px; margin-bottom: 40px; }
.hiw-step-num { width: 48px; height: 48px; border-radius: 50%; background: #f1efe8; border: 0.5px solid #d3d1c7; display: flex; align-items: center; justify-content: center; font-size: 15px; font-weight: 500; color: #1a1a18; flex-shrink: 0; }
.hiw-connector { width: 1px; height: 32px; background: #e0dfd8; margin: -24px 0 0 23px; }

.gift-options { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; margin-bottom: 32px; }
.gift-option-card { background: #fff; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 22px 18px; }
.go-icon { font-size: 26px; color: #5f5e5a; margin-bottom: 12px; }
.go-title { font-weight: 500; font-size: 15px; color: #1a1a18; margin-bottom: 6px; }
.go-desc { font-size: 12px; color: #5f5e5a; line-height: 1.6; margin-bottom: 12px; }
.go-btn { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500; background: #1a1a18; color: #fafaf8; border: none; padding: 10px 20px; border-radius: 999px; cursor: pointer; display: inline-block; text-decoration: none; }
.go-btn:hover { background: #333; }

/* SHOPIFY INTEGRATION PAGE */
.shopify-hero { padding: 48px 0 32px; }
.shopify-hero h1 { font-family: 'Playfair Display', serif; font-size: 36px; font-weight: 600; margin-bottom: 10px; color: #1a1a18; }
.shopify-hero p { font-size: 15px; color: #5f5e5a; line-height: 1.7; max-width: 600px; }
.shopify-steps-grid { display: grid; grid-template-columns: 1fr; gap: 0; margin: 32px 0; }
.shopify-step-card { background: #fff; border: 0.5px solid #d3d1c7; border-radius: 0; padding: 24px 28px; border-bottom: none; display: grid; grid-template-columns: 48px 1fr; gap: 20px; align-items: start; }
.shopify-step-card:first-child { border-radius: 12px 12px 0 0; }
.shopify-step-card:last-child { border-radius: 0 0 12px 12px; border-bottom: 0.5px solid #d3d1c7; }
.shopify-step-num { width: 36px; height: 36px; border-radius: 50%; background: #1a1a18; color: #fafaf8; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 500; flex-shrink: 0; margin-top: 2px; }
.shopify-step-body h3 { font-weight: 500; font-size: 15px; color: #1a1a18; margin-bottom: 6px; }
.shopify-step-body p { font-size: 13px; color: #5f5e5a; line-height: 1.7; margin-bottom: 8px; }
.shopify-step-body .code-block { background: #f1efe8; border: 0.5px solid #d3d1c7; border-radius: 8px; padding: 10px 14px; font-size: 12px; font-family: monospace; color: #1a1a18; margin-top: 8px; line-height: 1.6; }
.shopify-step-body .tip { font-size: 12px; color: #888780; background: #fafaf8; border-left: 2px solid #d3d1c7; padding: 8px 12px; margin-top: 8px; border-radius: 0 6px 6px 0; }
.shopify-apps { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; margin: 24px 0; }
.shopify-app-card { background: #fff; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 18px; }
.shopify-app-card .app-icon { font-size: 22px; color: #5f5e5a; margin-bottom: 10px; }
.shopify-app-card .app-name { font-weight: 500; font-size: 14px; color: #1a1a18; margin-bottom: 4px; }
.shopify-app-card .app-desc { font-size: 12px; color: #5f5e5a; line-height: 1.6; margin-bottom: 10px; }
.shopify-app-card .app-tag { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: #888780; }
.shopify-cta-box { background: #f1efe8; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 28px; text-align: center; margin: 32px 0; }
.shopify-cta-box h3 { font-family: 'Playfair Display', serif; font-size: 22px; color: #1a1a18; margin-bottom: 8px; }
.shopify-cta-box p { font-size: 14px; color: #5f5e5a; margin-bottom: 20px; }


  /* ── ENVELOPE SHOWCASE CARDS ── */
  .env-showcase { display: flex; flex-direction: column; gap: 0; margin-bottom: 48px; }
  .env-showcase-card { display: grid; grid-template-columns: 1fr 1fr; gap: 0; border: 0.5px solid #d3d1c7; background: #fff; overflow: hidden; }
  .env-showcase-card:first-child { border-radius: 16px 16px 0 0; }
  .env-showcase-card:last-child { border-radius: 0 0 16px 16px; border-top: none; }
  .env-showcase-card:not(:first-child) { border-top: none; }
  .env-showcase-card:nth-child(even) { direction: rtl; }
  .env-showcase-card:nth-child(even) > * { direction: ltr; }
  .env-showcase-left { padding: 48px 52px; display: flex; flex-direction: column; justify-content: center; }
  .env-showcase-right { padding: 40px 44px; background: #f7f6f2; border-left: 0.5px solid #e0dfd8; display: flex; flex-direction: column; justify-content: center; gap: 10px; }
  .env-showcase-card:nth-child(even) .env-showcase-right { border-left: none; border-right: 0.5px solid #e0dfd8; }
  .env-showcase-tag { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 500; letter-spacing: 1.5px; text-transform: uppercase; color: #888780; background: #f1efe8; border: 0.5px solid #d3d1c7; padding: 5px 12px; border-radius: 999px; margin-bottom: 20px; width: fit-content; }
  .env-showcase-tag i { font-size: 14px; }
  .env-showcase-title { font-family: 'Playfair Display', serif; font-size: 38px; font-weight: 600; line-height: 1.1; color: #1a1a18; margin-bottom: 16px; letter-spacing: -0.5px; }
  .env-showcase-desc { font-size: 15px; color: #5f5e5a; line-height: 1.75; margin-bottom: 28px; }
  .env-showcase-price-row { display: flex; align-items: baseline; gap: 6px; margin-bottom: 20px; }
  .env-showcase-price { font-family: 'Playfair Display', serif; font-size: 32px; font-weight: 600; color: #1a1a18; }
  .env-showcase-price-sub { font-size: 13px; color: #888780; }
  .env-showcase-btns { display: flex; gap: 10px; align-items: center; }
  .env-showcase-btn-primary { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 500; background: #1a1a18; color: #fafaf8; border: none; padding: 12px 24px; border-radius: 999px; cursor: pointer; }
  .env-showcase-btn-primary:hover { background: #333; }
  .env-showcase-btn-ghost { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 400; background: transparent; color: #5f5e5a; border: 0.5px solid #b4b2a9; padding: 12px 24px; border-radius: 999px; cursor: pointer; }
  .env-showcase-btn-ghost:hover { background: #f1efe8; }
  .env-showcase-contents-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: #888780; margin-bottom: 14px; }
  .env-showcase-item { display: flex; align-items: flex-start; gap: 14px; padding: 14px 16px; background: #fff; border: 0.5px solid #d3d1c7; border-radius: 10px; }
  .env-showcase-item-icon { width: 34px; height: 34px; border-radius: 8px; background: #f1efe8; border: 0.5px solid #d3d1c7; display: flex; align-items: center; justify-content: center; font-size: 16px; color: #5f5e5a; flex-shrink: 0; }
  .env-showcase-item-name { font-weight: 500; font-size: 13px; color: #1a1a18; margin-bottom: 2px; }
  .env-showcase-item-desc { font-size: 12px; color: #888780; line-height: 1.5; }
  .env-showcase-why { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
  .env-showcase-why-pill { font-size: 11px; color: #5f5e5a; background: #fff; border: 0.5px solid #d3d1c7; padding: 4px 10px; border-radius: 999px; display: flex; align-items: center; gap: 5px; }
  .env-showcase-why-pill i { font-size: 12px; color: #888780; }
  .env-showcase-divider { height: 0.5px; background: #e0dfd8; margin: 20px 0; }
  @media (max-width: 768px) {
    .env-showcase-card { grid-template-columns: 1fr; direction: ltr !important; }
    .env-showcase-card:nth-child(even) { direction: ltr; }
    .env-showcase-left { padding: 32px 24px 24px; }
    .env-showcase-right { padding: 24px; border-left: none !important; border-right: none !important; border-top: 0.5px solid #e0dfd8; }
    .env-showcase-title { font-size: 28px; }
  }


  /* ── FAQ PAGE ── */
  .faq-page-grid { display: grid; grid-template-columns: 240px 1fr; gap: 56px; padding-bottom: 64px; align-items: start; }
  .faq-sidebar { position: sticky; top: 24px; }
  .faq-sidebar-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: #888780; margin-bottom: 14px; }
  .faq-category-btn { display: flex; align-items: center; gap: 10px; width: 100%; background: none; border: none; padding: 10px 12px; border-radius: 8px; cursor: pointer; font-family: 'DM Sans', sans-serif; font-size: 14px; color: #5f5e5a; text-align: left; transition: background 0.15s, color 0.15s; margin-bottom: 2px; }
  .faq-category-btn:hover { background: #f1efe8; color: #1a1a18; }
  .faq-category-btn.active { background: #1a1a18; color: #fafaf8; }
  .faq-category-btn i { font-size: 16px; }
  .faq-main {}
  .faq-group { margin-bottom: 48px; }
  .faq-group-title { font-family: 'Playfair Display', serif; font-size: 22px; font-weight: 600; color: #1a1a18; margin-bottom: 4px; }
  .faq-group-sub { font-size: 13px; color: #888780; margin-bottom: 20px; }
  .faq-item { border-top: 0.5px solid #e0dfd8; padding: 20px 0; }
  .faq-item:last-child { border-bottom: 0.5px solid #e0dfd8; }
  .faq-q { font-weight: 500; font-size: 15px; color: #1a1a18; margin-bottom: 8px; cursor: pointer; display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
  .faq-q i { font-size: 16px; color: #b4b2a9; flex-shrink: 0; margin-top: 2px; transition: transform 0.2s; }
  .faq-q.open i { transform: rotate(180deg); color: #1a1a18; }
  .faq-a { font-size: 14px; color: #5f5e5a; line-height: 1.75; display: none; padding-top: 4px; }
  .faq-a.open { display: block; }
  .faq-contact-box { background: #f1efe8; border: 0.5px solid #d3d1c7; border-radius: 12px; padding: 28px 32px; margin-top: 48px; }
  .faq-contact-box h3 { font-family: 'Playfair Display', serif; font-size: 20px; color: #1a1a18; margin-bottom: 8px; }
  .faq-contact-box p { font-size: 14px; color: #5f5e5a; margin-bottom: 16px; line-height: 1.6; }
  @media (max-width: 768px) {
    .faq-page-grid { grid-template-columns: 1fr; gap: 24px; }
    .faq-sidebar { position: static; }
  }

  /* ── ENVELOPE ACCORDION ── */
  .env-accordion-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 0; margin-bottom: 16px; border: 0.5px solid #d3d1c7; border-radius: 14px; overflow: hidden; }
  .env-accordion-item { border-bottom: 0.5px solid #d3d1c7; border-right: 0.5px solid #d3d1c7; }
  .env-accordion-item:nth-child(even) { border-right: none; }
  .env-accordion-item:nth-last-child(-n+2) { border-bottom: none; }
  .env-accordion-header { display: flex; align-items: center; gap: 14px; padding: 20px 22px; cursor: pointer; background: #fff; transition: background 0.15s; user-select: none; }
  .env-accordion-header:hover { background: #f7f6f2; }
  .env-accordion-header.open { background: #f1efe8; }
  .env-acc-icon { font-size: 22px; color: #5f5e5a; flex-shrink: 0; width: 36px; height: 36px; background: #f1efe8; border: 0.5px solid #d3d1c7; border-radius: 8px; display: flex; align-items: center; justify-content: center; transition: background 0.15s; }
  .env-accordion-header.open .env-acc-icon { background: #1a1a18; color: #fafaf8; border-color: #1a1a18; }
  .env-acc-text { flex: 1; min-width: 0; }
  .env-acc-name { font-weight: 500; font-size: 15px; color: #1a1a18; margin-bottom: 2px; }
  .env-acc-sub { font-size: 12px; color: #888780; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
  .env-acc-chevron { font-size: 16px; color: #b4b2a9; transition: transform 0.2s; flex-shrink: 0; }
  .env-accordion-header.open .env-acc-chevron { transform: rotate(180deg); color: #1a1a18; }
  .env-accordion-body { display: none; background: #fafaf8; border-top: 0.5px solid #e0dfd8; padding: 0; }
  .env-accordion-body.open { display: block; }
  .env-acc-inner { padding: 20px 22px 22px; }
  .env-acc-desc { font-size: 14px; color: #5f5e5a; line-height: 1.7; margin-bottom: 16px; }
  .env-acc-contents-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: #888780; margin-bottom: 10px; }
  .env-acc-items { display: flex; flex-direction: column; gap: 7px; margin-bottom: 16px; }
  .env-acc-item { display: flex; align-items: center; gap: 10px; font-size: 13px; color: #5f5e5a; }
  .env-acc-item i { font-size: 15px; color: #888780; width: 18px; text-align: center; flex-shrink: 0; }
  .env-acc-item strong { color: #1a1a18; font-weight: 500; }
  .env-acc-footer { display: flex; align-items: center; justify-content: space-between; padding-top: 14px; border-top: 0.5px solid #e0dfd8; }
  .env-acc-price { font-family: 'Playfair Display', serif; font-size: 22px; font-weight: 600; color: #1a1a18; }
  .env-acc-price span { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 400; color: #888780; }
  .env-acc-btns { display: flex; gap: 8px; }
  .env-acc-btn-primary { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 500; background: #1a1a18; color: #fafaf8; border: none; padding: 9px 18px; border-radius: 999px; cursor: pointer; }
  .env-acc-btn-primary:hover { background: #333; }
  .env-acc-btn-ghost { font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 400; background: transparent; color: #5f5e5a; border: 0.5px solid #b4b2a9; padding: 9px 18px; border-radius: 999px; cursor: pointer; }
  .env-acc-btn-ghost:hover { background: #f1efe8; }
  @media (max-width: 768px) {
    .env-accordion-grid { grid-template-columns: 1fr; }
    .env-accordion-item { border-right: none; }
    .env-accordion-item:nth-last-child(-n+2) { border-bottom: 0.5px solid #d3d1c7; }
    .env-accordion-item:last-child { border-bottom: none; }
  }
  /* Gift cards — selectable */
  .gift-option-card { cursor: pointer; transition: border-color 0.15s, transform 0.1s; }
  .gift-option-card:hover { border-color: #888780; transform: translateY(-2px); }
  .gift-option-card.gift-selected { border: 2.5px solid #1a1a18 !important; transform: translateY(-2px); }
  .gift-checkout-btn { font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 500; background: #1a1a18; color: #fafaf8; border: none; padding: 13px 32px; border-radius: 999px; cursor: pointer; margin-top: 24px; }
  .gift-checkout-btn:hover:not(:disabled) { background: #333; }
  .gift-checkout-btn:disabled { background: #b4b2a9; cursor: not-allowed; }

  
/* ── ENVELOPE ACCORDION ── */
let openAccordion = null;

function toggleAccordion(id) {
  const header = document.querySelector(`.env-accordion-header[data-id="${id}"]`);
  const body   = document.querySelector(`.env-accordion-body[data-id="${id}"]`);
  if (!header || !body) return;

  if (openAccordion && openAccordion !== id) {
    // close the previously open one
    const ph = document.querySelector(`.env-accordion-header[data-id="${openAccordion}"]`);
    const pb = document.querySelector(`.env-accordion-body[data-id="${openAccordion}"]`);
    if (ph) ph.classList.remove("open");
    if (pb) pb.classList.remove("open");
  }

  const isOpen = body.classList.contains("open");
  header.classList.toggle("open", !isOpen);
  body.classList.toggle("open", !isOpen);
  openAccordion = isOpen ? null : id;

  if (!isOpen) {
    // Smooth scroll so the expanded card is visible
    setTimeout(() => header.scrollIntoView({ behavior: "smooth", block: "nearest" }), 60);
  }
}

/* ── SEARCH ── */
  .search-icon-btn { background: none; border: none; cursor: pointer; color: #888780; font-size: 20px; padding: 6px; border-radius: 8px; margin-right: 8px; transition: color 0.15s; display: flex; align-items: center; }
  .search-icon-btn:hover { color: #1a1a18; }
  .search-overlay { display: none; position: fixed; inset: 0; z-index: 1000; background: rgba(26,26,24,0.5); backdrop-filter: blur(4px); align-items: flex-start; justify-content: center; padding-top: 80px; }
  .search-overlay.open { display: flex; }
  .search-modal { background: #fafaf8; border-radius: 16px; width: 100%; max-width: 620px; box-shadow: 0 24px 80px rgba(0,0,0,0.18); overflow: hidden; }
  .search-input-row { display: flex; align-items: center; gap: 12px; padding: 18px 20px; border-bottom: 0.5px solid #e0dfd8; }
  .search-input-row i { font-size: 20px; color: #888780; flex-shrink: 0; }
  .search-input { flex: 1; font-family: 'DM Sans', sans-serif; font-size: 16px; border: none; background: transparent; color: #1a1a18; outline: none; }
  .search-input::placeholder { color: #b4b2a9; }
  .search-close { background: none; border: none; cursor: pointer; font-size: 13px; color: #888780; padding: 4px 10px; border-radius: 999px; border: 0.5px solid #d3d1c7; }
  .search-close:hover { color: #1a1a18; border-color: #888780; }
  .search-results { max-height: 420px; overflow-y: auto; padding: 8px 0; }
  .search-empty { padding: 32px 20px; text-align: center; font-size: 14px; color: #888780; }
  .search-result-item { display: flex; align-items: center; gap: 14px; padding: 12px 20px; cursor: pointer; transition: background 0.1s; }
  .search-result-item:hover { background: #f1efe8; }
  .search-result-icon { width: 36px; height: 36px; border-radius: 8px; background: #f1efe8; border: 0.5px solid #d3d1c7; display: flex; align-items: center; justify-content: center; font-size: 16px; color: #5f5e5a; flex-shrink: 0; }
  .search-result-title { font-weight: 500; font-size: 14px; color: #1a1a18; margin-bottom: 2px; }
  .search-result-sub { font-size: 12px; color: #888780; }
  .search-result-tag { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: #888780; background: #f1efe8; border: 0.5px solid #d3d1c7; padding: 2px 8px; border-radius: 999px; flex-shrink: 0; margin-left: auto; }
  .search-section-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: #b4b2a9; padding: 10px 20px 4px; }
  .search-highlight { background: #fef3c7; border-radius: 2px; }
  /* Responsive — fills full screen width */
  @media (min-width: 1200px) {
    .em-hobby-grid { grid-template-columns: repeat(4, 1fr); }
    .hobbies-full-grid { grid-template-columns: repeat(4, 1fr); }
    .em-how-grid { grid-template-columns: repeat(4, 1fr); gap: 32px; }
    .hs-header { gap: 60px; }
    .plan-grid { gap: 20px; }
    .em-hero h1 { font-size: 52px; }
  }
  @media (max-width: 768px) {
    .page { padding: 0 20px 48px; }
    .em-hero { grid-template-columns: 1fr; }
    .em-hobby-grid { grid-template-columns: 1fr; }
    .hobbies-full-grid { grid-template-columns: 1fr; }
    .plan-grid { grid-template-columns: 1fr; }
    .hs-header { grid-template-columns: 1fr; }
    .hs-why-grid { grid-template-columns: 1fr 1fr; }
    .em-how-grid { grid-template-columns: repeat(2, 1fr); }
    .em-nav-links { display: none; }
    .gift-options { grid-template-columns: 1fr; }
    .shopify-apps { grid-template-columns: 1fr; }
    .em-footer { flex-direction: column; gap: 12px; text-align: center; }
  }
