/* ============================================================
   BLING THEME  ·  Home redesign (template/home_page.html)
   All classes namespaced with `bl-` so they never collide
   with color16.css / custom.css which remain loaded.
   ============================================================ */

/* ─── TOKENS ─────────────────────────────────────────────── */
.bl-scope {
  --bl-ivory:      #FBFAF6;
  --bl-ivory-mid:  #F2EDE3;
  --bl-ink:        #18140F;
  --bl-ink-mid:    #3A3028;
  --bl-ink-soft:   #7A6E60;
  --bl-gold:       #C4923A;
  --bl-gold-light: #DEB96E;
  --bl-gold-pale:  #F7EDD8;
  --bl-rose:       #C9836A;
  --bl-teal:       #4A8B8C;
  --bl-rule:       rgba(196,146,58,0.2);
  --bl-nav-h:      68px;
  --bl-serif: 'Cormorant Garamond', Georgia, serif;
  --bl-sans: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* ─── BASE (scoped to body.bl-scope) ─────────────────────── */
body.bl-scope {
  font-family: var(--bl-sans);
  background: var(--bl-ivory);
  color: var(--bl-ink);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
body.bl-scope img,
body.bl-scope svg { max-width: 100%; }
.bl-scope a { text-decoration: none; color: inherit; }
.bl-scope button { cursor: pointer; }
.bl-scope *, .bl-scope *::before, .bl-scope *::after { box-sizing: border-box; }

/* ─── ANNOUNCEMENT BAR ───────────────────────────────────── */
.bl-topbar {
  background: var(--bl-ink);
  color: rgba(255,255,255,0.78);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.bl-topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  max-width: 1280px;
  margin: 0 auto;
  padding: 0.5rem 2rem;
}
.bl-topbar-marquee { flex: 1; overflow: hidden; }
.bl-topbar-socials { display: flex; gap: 0.9rem; align-items: center; }
.bl-topbar-socials a { color: rgba(255,255,255,0.6); transition: color 0.2s; font-size: 13px; }
.bl-topbar-socials a:hover { color: var(--bl-gold-light); }
.bl-topbar-account { display: flex; gap: 1.2rem; align-items: center; white-space: nowrap; }
.bl-topbar-account a { color: rgba(255,255,255,0.7); transition: color 0.2s; }
.bl-topbar-account a:hover { color: var(--bl-gold-light); }
@media (max-width: 768px){ .bl-topbar-marquee{ display:none; } .bl-topbar-inner{ justify-content:center; } }

/* ─── NAV ─────────────────────────────────────────────────── */
.bl-nav {
  position: sticky;
  top: 0;
  z-index: 200;
  height: var(--bl-nav-h);
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 2.5rem;
  background: rgba(251,250,246,0.94);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 0.5px solid var(--bl-rule);
  transition: box-shadow 0.3s;
}
.bl-nav.bl-scrolled { box-shadow: 0 2px 24px rgba(24,20,15,0.07); }

.bl-nav-logo img { height: 40px; width: auto; display: block; }

.bl-nav-links { display: flex; align-items: center; gap: 2.5rem; list-style: none; margin: 0; padding: 0; height: 100%; }
.bl-nav-links > li { position: static; height: 100%; display: flex; align-items: center; }
.bl-nav-links > li > a {
  display: flex; align-items: center; gap: 0.35rem;
  font-size: 11px; font-weight: 400; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--bl-ink-mid);
  transition: color 0.2s; padding: 0.4rem 0; cursor: pointer;
  height: 100%;
}
.bl-nav-links > li > a:hover,
.bl-nav-links > li.bl-open > a { color: var(--bl-gold); }
.bl-nav-links > li > a .bl-caret { font-size: 9px; opacity: 0.5; }

/* mega dropdown — full-width like Holloway Diamonds */
.bl-mega {
  position: fixed;
  top: var(--bl-nav-h);
  left: 0 !important;
  right: 0 !important;
  width: 100vw !important;
  min-width: 100vw !important;
  max-width: none !important;
  background: #fff;
  border-top: 1px solid var(--bl-rule);
  border-bottom: 1px solid var(--bl-rule);
  box-shadow: 0 18px 50px rgba(24,20,15,0.10);
  padding: 3rem 6rem 3.5rem;
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.22s;
  z-index: 250;
  margin-left: 0;
  transform: none;
  border-radius: 0;
}
.bl-nav-links > li:hover > .bl-mega { opacity: 1; visibility: visible; pointer-events: auto; }
/* Bridge to prevent hover gap between nav link and dropdown */
.bl-nav-links > li:hover::after { content: ''; position: fixed; top: var(--bl-nav-h); left: 0; right: 0; height: 12px; z-index: 249; }
.bl-mega--wide { display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 1rem 3rem; max-width: 1200px; margin: 0 auto; padding: 0 0 0 2rem; }
.bl-mega-col-title {
  font-family: var(--bl-sans); font-size: 11px; font-weight: 400 !important; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--bl-ink) !important;
  padding: 0 0 0.75rem; border-bottom: none; margin-bottom: 0.5rem;
}
.bl-mega a {
  display: block; font-size: 14px; font-weight: 300; color: var(--bl-ink-soft);
  padding: 0.35rem 0; border-radius: 0; transition: color 0.18s;
  letter-spacing: 0;
  text-transform: none;
}
.bl-mega a:hover { background: none; color: var(--bl-gold); }
.bl-mega a.bl-shopall { color: var(--bl-gold); font-weight: 400; font-size: 13px; margin-top: 0.5rem; }

.bl-nav-cta {
  padding: 0.55rem 1.3rem !important;
  border: 0.5px solid var(--bl-ink);
  border-radius: 40px;
  color: var(--bl-ink) !important;
  transition: background 0.2s, color 0.2s;
}
.bl-nav-cta:hover { background: var(--bl-ink); color: var(--bl-ivory) !important; }

/* nav icons */
.bl-nav-icons { display: flex; align-items: center; gap: 1.25rem; }
.bl-nav-icons .bl-ico { position: relative; color: var(--bl-ink-mid); font-size: 18px; line-height: 1; transition: color 0.2s; background: none; border: none; padding: 0; }
.bl-nav-icons .bl-ico:hover { color: var(--bl-gold); }
.bl-nav-icons .bl-search-text { display: inline-flex; align-items: center; gap: 6px; font-size: 10px; font-weight: 400; letter-spacing: 0.14em; text-transform: uppercase; font-family: var(--bl-sans); }
.bl-nav-icons .bl-search-text i { font-size: 13px; }
.bl-nav-text-link { font-size: 10px; font-weight: 400; letter-spacing: 0.14em; text-transform: uppercase; color: var(--bl-ink-mid); transition: color 0.2s; font-family: var(--bl-sans); }
.bl-nav-text-link:hover { color: var(--bl-gold); }
.bl-cart-count {
  position: absolute; top: -8px; right: -10px;
  background: var(--bl-gold); color: #fff;
  font-size: 10px; font-weight: 600; font-family: var(--bl-sans);
  min-width: 17px; height: 17px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; padding: 0 4px;
}
.bl-hamburger { display: none; flex-direction: column; gap: 5px; width: 26px; background: none; border: none; }
.bl-hamburger span { display: block; height: 1.5px; background: var(--bl-ink); border-radius: 2px; }

/* search dropdown panel */
.bl-search-panel {
  position: fixed;
  top: var(--bl-nav-h); left: 0; right: 0;
  background: rgba(251,250,246,0.98);
  backdrop-filter: blur(14px);
  border-bottom: 0.5px solid var(--bl-rule);
  box-shadow: 0 18px 40px rgba(24,20,15,0.1);
  padding: 1.5rem 2.5rem 2rem;
  transform: translateY(-12px);
  opacity: 0; visibility: hidden; pointer-events: none;
  transition: opacity 0.25s, transform 0.25s;
  z-index: 190;
}
.bl-search-panel.bl-open { opacity: 1; visibility: visible; pointer-events: auto; transform: translateY(0); }
.bl-search-form { max-width: 760px; margin: 0 auto; display: flex; align-items: center; border-bottom: 1px solid var(--bl-ink); }
.bl-search-form input {
  flex: 1; border: none; background: transparent; outline: none;
  font-family: var(--bl-serif); font-size: 1.6rem; font-weight: 300;
  color: var(--bl-ink); padding: 0.6rem 0;
}
.bl-search-form input::placeholder { color: var(--bl-ink-soft); opacity: 0.6; }
.bl-search-form button { background: none; border: none; color: var(--bl-gold); font-size: 20px; padding: 0 0.5rem; }
.bl-search-tags { max-width: 760px; margin: 1rem auto 0; display: flex; flex-wrap: wrap; gap: 0.5rem; }
.bl-search-tags span { font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bl-ink-soft); margin-right: 0.25rem; }
.bl-search-tags a { font-size: 12px; padding: 0.3rem 0.85rem; border: 0.5px solid var(--bl-rule); border-radius: 40px; color: var(--bl-ink-mid); transition: all 0.18s; }
.bl-search-tags a:hover { background: var(--bl-gold); color: #fff; border-color: var(--bl-gold); }

/* cart mini dropdown */
.bl-cart-drop {
  position: absolute; top: calc(100% + 12px); right: 0;
  width: 340px; max-width: calc(100vw - 2rem); max-height: 460px; overflow-y: auto;
  background: #fff; border: 0.5px solid var(--bl-rule);
  border-radius: 12px; box-shadow: 0 18px 50px rgba(24,20,15,0.14);
  padding: 1rem; z-index: 250;
  opacity: 0; visibility: hidden; transform: translateY(8px);
  transition: opacity 0.2s, transform 0.2s;
}
.bl-cart-wrap:hover .bl-cart-drop,
.bl-cart-drop.bl-open { opacity: 1; visibility: visible; transform: translateY(0); }
.bl-cart-item { display: flex; gap: 0.75rem; padding: 0.6rem 0; border-bottom: 0.5px solid var(--bl-rule); }
.bl-cart-item img { width: 56px; height: 56px; object-fit: cover; border-radius: 8px; flex-shrink: 0; }
.bl-cart-item h4 { font-size: 13px; font-weight: 500; color: var(--bl-ink); margin: 0 0 4px; line-height: 1.3; }
.bl-cart-item .bl-cart-qty { font-size: 12px; color: var(--bl-ink-soft); }
.bl-cart-item .bl-cart-x { margin-left: auto; color: var(--bl-ink-soft); font-size: 12px; }
.bl-cart-item .bl-cart-x:hover { color: var(--bl-rose); }
.bl-cart-foot { padding-top: 0.85rem; }
.bl-cart-foot .bl-cart-sub { display: flex; justify-content: space-between; font-size: 14px; margin-bottom: 0.85rem; }
.bl-cart-foot .bl-cart-sub strong { font-family: var(--bl-serif); font-size: 1.2rem; }
.bl-cart-empty { padding: 1.5rem 0.5rem; text-align: center; color: var(--bl-ink-soft); font-size: 13px; }

/* ─── MOBILE DRAWER ──────────────────────────────────────── */
.bl-drawer-overlay { position: fixed; inset: 0; background: rgba(24,20,15,0.45); opacity: 0; visibility: hidden; transition: opacity 0.3s; z-index: 998; }
.bl-drawer-overlay.bl-open { opacity: 1; visibility: visible; }
.bl-drawer {
  position: fixed; top: 0; left: 0; bottom: 0; width: 86%; max-width: 360px;
  background: var(--bl-ivory); z-index: 999; transform: translateX(-100%);
  transition: transform 0.32s cubic-bezier(0.22,1,0.36,1); overflow-y: auto;
  display: flex; flex-direction: column;
}
.bl-drawer.bl-open { transform: translateX(0); }
.bl-drawer-head { display: flex; align-items: center; justify-content: space-between; padding: 1.1rem 1.25rem; border-bottom: 0.5px solid var(--bl-rule); }
.bl-drawer-head img { height: 34px; }
.bl-drawer-close { background: none; border: none; font-size: 24px; color: var(--bl-ink); line-height: 1; }
.bl-drawer-search { padding: 1rem 1.25rem; border-bottom: 0.5px solid var(--bl-rule); }
.bl-drawer-search form { display: flex; align-items: center; border: 0.5px solid var(--bl-rule); border-radius: 40px; padding: 0.2rem 0.4rem 0.2rem 1rem; background: #fff; }
.bl-drawer-search input { flex: 1; border: none; outline: none; background: transparent; font-size: 14px; padding: 0.5rem 0; font-family: var(--bl-sans); }
.bl-drawer-search button { background: var(--bl-gold); color: #fff; border: none; width: 34px; height: 34px; border-radius: 50%; }
.bl-drawer-nav { list-style: none; margin: 0; padding: 0.5rem 0 2rem; }
.bl-drawer-nav > li { display: block; width: 100%; list-style: none; border-bottom: 0.5px solid var(--bl-rule); }
.bl-drawer-nav > li > a, .bl-drawer-acc-btn {
  display: flex; align-items: center; justify-content: space-between; width: 100%;
  padding: 0.95rem 1.25rem; font-size: 13px; font-weight: 500; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--bl-ink); background: none; border: none; text-align: left;
}
.bl-drawer-acc-btn .bl-acc-ico { transition: transform 0.25s; color: var(--bl-gold); }
.bl-drawer-acc.bl-open .bl-acc-ico { transform: rotate(45deg); }
.bl-drawer-sub { list-style: none; margin: 0; padding: 0; max-height: 0; overflow: hidden; transition: max-height 0.3s ease; background: var(--bl-ivory-mid); }
.bl-drawer-acc.bl-open .bl-drawer-sub { max-height: 1200px; }
.bl-drawer-sub li { display: block; width: 100%; list-style: none; }
.bl-drawer-sub li a { display: block; padding: 0.7rem 1.75rem; font-size: 13px; color: var(--bl-ink-soft); }
.bl-drawer-sub li a:hover { color: var(--bl-gold); }

/* ─── SECTION SHARED ──────────────────────────────────────── */
.bl-wrap { max-width: 1400px; margin: 0 auto; padding: 0 2.5rem; }
.bl-section { padding: 4rem 0; }
.bl-section-head { display: flex; align-items: flex-end; justify-content: space-between; gap: 2rem; margin-bottom: 2rem; }
.bl-kicker { font-size: 11px; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--bl-gold); margin-bottom: 0.75rem; }
.bl-title { font-family: var(--bl-serif); font-size: clamp(2rem, 3.5vw, 2.75rem); font-weight: 300; line-height: 1.15; color: var(--bl-ink); margin: 0; }
.bl-title em { font-style: italic; }
.bl-sub { font-size: 15px; font-weight: 300; color: var(--bl-ink-soft); max-width: 360px; line-height: 1.7; text-align: right; }

.bl-btn-primary { display: inline-block; padding: 0.85rem 2rem; background: var(--bl-gold); color: #fff !important; font-size: 12px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 40px; transition: background 0.25s, transform 0.2s; }
.bl-btn-primary:hover { background: var(--bl-gold-light); transform: translateY(-1px); }
.bl-btn-ghost { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 12px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bl-ink-mid); transition: color 0.2s; }
.bl-btn-ghost i { transition: transform 0.2s; }
.bl-btn-ghost:hover { color: var(--bl-gold); }
.bl-btn-ghost:hover i { transform: translateX(3px); }

/* ─── HERO ────────────────────────────────────────────────── */
.bl-hero { display: grid; grid-template-columns: 1fr 1fr; align-items: stretch; min-height: 78vh; max-width: none; padding: 0; }
.bl-hero-left { padding: 3.5rem 3rem 3.5rem 2.5rem; display: flex; flex-direction: column; justify-content: center; max-width: 700px; margin-left: auto; }
.bl-hero-eyebrow { display: inline-flex; align-items: center; gap: 0.75rem; font-size: 11px; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; color: var(--bl-gold); margin-bottom: 1.5rem; }
.bl-hero-eyebrow::before { content: ''; width: 32px; height: 0.5px; background: var(--bl-gold); }
.bl-hero-title { font-family: var(--bl-serif); font-size: clamp(2.8rem, 5vw, 5rem); font-weight: 300; line-height: 1.04; color: var(--bl-ink); margin: 0 0 1.5rem; }
.bl-hero-title em { font-style: italic; color: var(--bl-gold); }
.bl-hero-body { font-size: 17px; font-weight: 300; color: var(--bl-ink-soft); max-width: 440px; line-height: 1.75; margin-bottom: 2.5rem; }
.bl-hero-actions { display: flex; align-items: center; gap: 1.25rem; flex-wrap: wrap; }
.bl-hero-trust { display: flex; align-items: center; gap: 2rem; margin-top: 2.75rem; padding-top: 2rem; border-top: 0.5px solid var(--bl-rule); flex-wrap: wrap; }
.bl-trust-item { display: flex; flex-direction: column; gap: 2px; }
.bl-trust-item strong { font-family: var(--bl-serif); font-size: 1.4rem; font-weight: 400; color: var(--bl-ink); }
.bl-trust-item span { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--bl-ink-soft); }
.bl-hero-right { position: relative; overflow: hidden; background: var(--bl-ink); border-radius: 0; min-height: 380px; }
.bl-hero-right img, .bl-hero-right .bl-gem-canvas { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.bl-hero-badge { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); background: rgba(251,250,246,0.12); backdrop-filter: blur(8px); border: 0.5px solid rgba(255,255,255,0.18); border-radius: 50px; padding: 0.6rem 1.25rem; font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.78); white-space: nowrap; }

/* hero slider (real banners) */
.bl-hero-slider { position: absolute; inset: 0; }
.bl-hero-slide { position: absolute; inset: 0; opacity: 0; transition: opacity 0.9s ease; }
.bl-hero-slide.bl-active { opacity: 1; }
.bl-hero-slide img { width: 100%; height: 100%; object-fit: cover; }
.bl-hero-dots { position: absolute; bottom: 1.1rem; right: 1.25rem; display: flex; gap: 6px; z-index: 3; }
.bl-hero-dots button { width: 8px; height: 8px; border-radius: 50%; border: none; background: rgba(255,255,255,0.5); padding: 0; }
.bl-hero-dots button.bl-active { background: var(--bl-gold-light); }

/* ─── FEATURE STRIP ──────────────────────────────────────── */
.bl-features { border-top: 0.5px solid var(--bl-rule); border-bottom: 0.5px solid var(--bl-rule); background: #fff; }
.bl-features-inner { max-width: 1200px; margin: 0 auto; padding: 1.1rem 2.5rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.bl-feature { display: flex; align-items: center; gap: 0.6rem; font-size: 12px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--bl-ink-mid); }
.bl-feature .material-icons { font-size: 20px; color: var(--bl-gold); }

/* ─── SERVICES ────────────────────────────────────────────── */
.bl-services-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.bl-svc-card { position: relative; border-radius: 16px; overflow: hidden; display: flex; flex-direction: column; min-height: 480px; transition: transform 0.35s cubic-bezier(0.22,1,0.36,1); }
.bl-svc-card:hover { transform: translateY(-6px); }
.bl-svc-card--daily { background: var(--bl-ivory-mid); border: 0.5px solid var(--bl-rule); }
.bl-svc-card--mto { background: var(--bl-ink); }
.bl-svc-card--bespoke { background: var(--bl-gold); }
.bl-svc-gem-wrap { flex: 1; display: flex; align-items: center; justify-content: center; padding: 3rem 2rem 2rem; }
.bl-svc-gem { width: 140px; height: 140px; transition: transform 0.6s cubic-bezier(0.22,1,0.36,1); }
.bl-svc-card:hover .bl-svc-gem { transform: rotate(15deg) scale(1.05); }
.bl-svc-body { padding: 2rem 2rem 2.5rem; }
.bl-svc-tier { font-size: 10px; font-weight: 500; letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 0.6rem; }
.bl-svc-card--daily .bl-svc-tier { color: var(--bl-gold); }
.bl-svc-card--mto .bl-svc-tier { color: rgba(255,255,255,0.5); }
.bl-svc-card--bespoke .bl-svc-tier { color: rgba(255,255,255,0.65); }
.bl-svc-name { font-family: var(--bl-serif); font-size: 1.75rem; font-weight: 400; line-height: 1.15; margin-bottom: 0.9rem; }
.bl-svc-card--daily .bl-svc-name { color: var(--bl-ink); }
.bl-svc-card--mto .bl-svc-name, .bl-svc-card--bespoke .bl-svc-name { color: #fff; }
.bl-svc-desc { font-size: 14px; font-weight: 300; line-height: 1.7; margin-bottom: 1.75rem; }
.bl-svc-card--daily .bl-svc-desc { color: var(--bl-ink-mid); }
.bl-svc-card--mto .bl-svc-desc { color: rgba(255,255,255,0.6); }
.bl-svc-card--bespoke .bl-svc-desc { color: rgba(255,255,255,0.75); }
.bl-svc-link { display: inline-flex; align-items: center; gap: 0.5rem; font-size: 12px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; border-bottom: 0.5px solid currentColor; padding-bottom: 2px; transition: gap 0.2s; }
.bl-svc-link:hover { gap: 0.85rem; }
.bl-svc-card--daily .bl-svc-link { color: var(--bl-gold); }
.bl-svc-card--mto .bl-svc-link { color: rgba(255,255,255,0.85); }
.bl-svc-card--bespoke .bl-svc-link { color: #fff; }

/* ─── CATEGORIES (real collections) ──────────────────────── */
.bl-cat-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.25rem; }
.bl-cat-card { display: block; border-radius: 14px; overflow: hidden; background: var(--bl-ivory-mid); border: 0.5px solid var(--bl-rule); transition: transform 0.3s, box-shadow 0.3s; }
.bl-cat-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(24,20,15,0.1); }
.bl-cat-thumb { aspect-ratio: 1 / 1; overflow: hidden; background: var(--bl-gold-pale); }
.bl-cat-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s; }
.bl-cat-card:hover .bl-cat-thumb img { transform: scale(1.06); }
.bl-cat-body { padding: 1.1rem 1.25rem 1.4rem; text-align: center; }
.bl-cat-body h5 { font-family: var(--bl-serif); font-size: 1.3rem; font-weight: 400; color: var(--bl-ink); margin: 0 0 0.25rem; }
.bl-cat-body span { font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bl-gold); }

/* ─── PRODUCT GRID (wraps existing .product-box cards) ────── */
.bl-product-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
.bl-product-grid .product-box { background: #fff; border: 0.5px solid var(--bl-rule); border-radius: 14px; overflow: hidden; height: 100%; transition: transform 0.3s, box-shadow 0.3s; }
.bl-product-grid .product-box:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(24,20,15,0.1); }
.bl-product-grid .product-box .img-wrapper,
.bl-product-grid .product-box .img-block { aspect-ratio: 1 / 1; height: auto; width: 100%; overflow: hidden; background: #faf9f7; position: relative; }
.bl-product-grid .product-box .img-wrapper .front,
.bl-product-grid .product-box .img-wrapper .front a { display: block; width: 100%; height: 100%; position: absolute; inset: 0; }
.bl-product-grid .product-box .img-wrapper img,
.bl-product-grid .product-box .img-block img { width: 100%; height: 100%; object-fit: cover; display: block; position: absolute; inset: 0; }
.bl-product-grid .product-detail h6 { font-family: var(--bl-sans); font-size: 13px; font-weight: 400; color: var(--bl-ink-mid); }
.bl-product-grid .product-detail h4 { font-family: var(--bl-serif); font-size: 1.3rem; color: var(--bl-ink); }
.bl-product-grid .product-detail h6 + h6 { color: var(--bl-ink-soft); text-decoration: line-through; }

/* ─── PROCESS ─────────────────────────────────────────────── */
.bl-process { background: var(--bl-ink); }
.bl-process .bl-kicker { color: var(--bl-gold-light); }
.bl-process .bl-title { color: #fff; }
.bl-process .bl-sub { color: rgba(255,255,255,0.45); }
.bl-process-steps { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: rgba(255,255,255,0.08); border: 0.5px solid rgba(255,255,255,0.08); border-radius: 16px; overflow: hidden; }
.bl-step { padding: 2.5rem 2rem; background: var(--bl-ink); transition: background 0.3s; }
.bl-step:hover { background: #231e17; }
.bl-step-n { font-family: var(--bl-serif); font-size: 3.5rem; font-weight: 300; color: rgba(196,146,58,0.18); line-height: 1; margin-bottom: 1.25rem; }
.bl-step-title { font-family: var(--bl-serif); font-size: 1.3rem; font-weight: 400; color: #fff; margin-bottom: 0.75rem; }
.bl-step-desc { font-size: 13.5px; font-weight: 300; color: rgba(255,255,255,0.5); line-height: 1.7; }
.bl-process-cta { margin-top: 2.5rem; display: flex; align-items: center; gap: 1.5rem; flex-wrap: wrap; }
.bl-process .bl-btn-ghost { color: rgba(255,255,255,0.55); }
.bl-process .bl-btn-ghost:hover { color: var(--bl-gold-light); }

/* ─── MATERIALS / GOLD ───────────────────────────────────── */
.bl-materials { border-top: 0.5px solid var(--bl-rule); border-bottom: 0.5px solid var(--bl-rule); }
.bl-materials-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 1.5rem; }
.bl-material-tile { display: flex; flex-direction: column; align-items: center; gap: 1rem; text-align: center; padding: 1.5rem 1rem; border-radius: 12px; border: 0.5px solid var(--bl-rule); transition: border-color 0.25s, background 0.25s; }
.bl-material-tile:hover { border-color: var(--bl-gold); background: var(--bl-gold-pale); }
.bl-material-swatch { width: 52px; height: 52px; border-radius: 50%; flex-shrink: 0; }
.bl-material-name { font-family: var(--bl-serif); font-size: 1rem; font-weight: 400; color: var(--bl-ink); }
.bl-material-note { font-size: 12px; color: var(--bl-ink-soft); line-height: 1.5; }

/* ─── WHY ─────────────────────────────────────────────────── */
.bl-why { background: var(--bl-gold-pale); }
.bl-why-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.bl-why-title { font-family: var(--bl-serif); font-size: clamp(2rem, 3.5vw, 2.75rem); font-weight: 300; line-height: 1.15; color: var(--bl-ink); margin: 0 0 1.25rem; }
.bl-why-title em { font-style: italic; }
.bl-why-body { font-size: 16px; font-weight: 300; color: var(--bl-ink-mid); line-height: 1.8; margin-bottom: 2.25rem; max-width: 460px; }
.bl-why-pillars { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; }
.bl-pillar { background: #fff; border-radius: 10px; padding: 1.25rem; border: 0.5px solid var(--bl-rule); }
.bl-pillar i { font-size: 22px; color: var(--bl-gold); margin-bottom: 0.6rem; display: block; }
.bl-pillar-title { font-family: var(--bl-serif); font-size: 1.1rem; font-weight: 400; color: var(--bl-ink); margin-bottom: 0.35rem; }
.bl-pillar-body { font-size: 13px; font-weight: 300; color: var(--bl-ink-soft); line-height: 1.6; }
.bl-why-mosaic { display: grid; grid-template-columns: 1fr 1fr; grid-template-rows: repeat(3, 140px); gap: 1rem; }
.bl-mosaic-cell { border-radius: 12px; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.bl-mosaic-cell img { width: 100%; height: 100%; object-fit: cover; }
.bl-mosaic-label { font-size: 13px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 300; }
.bl-mosaic-cell--yg { background: linear-gradient(135deg,#E8C97A,#C4923A,#8A5E1A); grid-row: span 2; }
.bl-mosaic-cell--rg { background: linear-gradient(135deg,#E8B49A,#C9836A,#8A4830); }
.bl-mosaic-cell--wg { background: linear-gradient(135deg,#E0DFDB,#C0BCBA,#8A8A8A); }
.bl-mosaic-cell--gem { background: linear-gradient(135deg,#7FBDBE,#4A8B8C,#1E5A5B); grid-row: span 2; }
.bl-mosaic-cell--dia { background: linear-gradient(135deg,#F0EDE8,#D0C9C0,#9A9590); }
.bl-mosaic-cell--yg .bl-mosaic-label, .bl-mosaic-cell--rg .bl-mosaic-label, .bl-mosaic-cell--gem .bl-mosaic-label { color: rgba(255,255,255,0.9); }
.bl-mosaic-cell--wg .bl-mosaic-label, .bl-mosaic-cell--dia .bl-mosaic-label { color: rgba(24,20,15,0.5); }

/* ─── TESTIMONIALS ────────────────────────────────────────── */
.bl-testi-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.bl-testi-card { background: var(--bl-ivory-mid); border: 0.5px solid var(--bl-rule); border-radius: 14px; padding: 2rem; }
.bl-testi-stars { display: flex; gap: 3px; margin-bottom: 1.25rem; color: var(--bl-gold); }
.bl-testi-quote { font-family: var(--bl-serif); font-size: 1.15rem; font-weight: 400; font-style: italic; color: var(--bl-ink); line-height: 1.6; margin-bottom: 1.5rem; }
.bl-testi-meta { display: flex; align-items: center; gap: 0.75rem; }
.bl-testi-avatar { width: 42px; height: 42px; border-radius: 50%; object-fit: cover; display: flex; align-items: center; justify-content: center; font-family: var(--bl-serif); font-size: 1.1rem; font-weight: 500; color: #fff; background: var(--bl-gold); flex-shrink: 0; }
.bl-testi-name { font-size: 13px; font-weight: 500; color: var(--bl-ink); }
.bl-testi-loc { font-size: 12px; color: var(--bl-ink-soft); }

/* ─── BLOGS ───────────────────────────────────────────────── */
.bl-blog-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.bl-blog-card { display: flex; flex-direction: column; background: #fff; border: 0.5px solid var(--bl-rule); border-radius: 14px; overflow: hidden; transition: transform 0.3s, box-shadow 0.3s; }
.bl-blog-card:hover { transform: translateY(-5px); box-shadow: 0 16px 40px rgba(24,20,15,0.1); }
.bl-blog-thumb { aspect-ratio: 16 / 10; overflow: hidden; background: var(--bl-gold-pale); }
.bl-blog-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.5s; }
.bl-blog-card:hover .bl-blog-thumb img { transform: scale(1.05); }
.bl-blog-body { padding: 1.5rem; flex: 1; display: flex; flex-direction: column; }
.bl-blog-body h3 { font-family: var(--bl-serif); font-size: 1.35rem; font-weight: 400; color: var(--bl-ink); margin: 0 0 0.6rem; line-height: 1.25; }
.bl-blog-body p { font-size: 14px; font-weight: 300; color: var(--bl-ink-soft); line-height: 1.65; margin: 0 0 1rem; }
.bl-blog-body .bl-blog-more { margin-top: auto; font-size: 12px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; color: var(--bl-gold); }

/* ─── EMAIL STRIP ─────────────────────────────────────────── */
.bl-email { background: var(--bl-ink); padding: 4.5rem 0; text-align: center; }
.bl-email .bl-kicker { color: var(--bl-gold-light); }
.bl-email-title { font-family: var(--bl-serif); font-size: clamp(1.75rem, 3vw, 2.5rem); font-weight: 300; color: #fff; margin: 0 0 0.75rem; }
.bl-email-sub { font-size: 15px; font-weight: 300; color: rgba(255,255,255,0.45); margin-bottom: 2.25rem; }
.bl-email-form { display: flex; align-items: center; justify-content: center; max-width: 460px; margin: 0 auto; border: 0.5px solid rgba(255,255,255,0.2); border-radius: 50px; overflow: hidden; background: rgba(255,255,255,0.05); }
.bl-email-form input { flex: 1; padding: 0.9rem 1.5rem; background: transparent; border: none; outline: none; font-family: var(--bl-sans); font-size: 14px; color: #fff; }
.bl-email-form input::placeholder { color: rgba(255,255,255,0.35); }
.bl-email-form button { padding: 0.75rem 1.5rem; background: var(--bl-gold); color: #fff; border: none; font-family: var(--bl-sans); font-size: 12px; font-weight: 500; letter-spacing: 0.1em; text-transform: uppercase; border-radius: 40px; margin: 4px; transition: background 0.2s; }
.bl-email-form button:hover { background: var(--bl-gold-light); }
.bl-email-msg { margin-top: 1rem; font-size: 13px; color: var(--bl-gold-light); min-height: 18px; }

/* ─── FOOTER ──────────────────────────────────────────────── */
.bl-footer { background: var(--bl-ink); border-top: 0.5px solid rgba(255,255,255,0.06); padding: 3.5rem 0 2rem; }
.bl-footer-inner { max-width: 1200px; margin: 0 auto; padding: 0 2.5rem; }
.bl-footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 3rem; padding-bottom: 3rem; border-bottom: 0.5px solid rgba(255,255,255,0.08); margin-bottom: 2rem; }
.bl-footer-brand img { height: 44px; margin-bottom: 1rem; }
.bl-footer-about { font-size: 14px; font-weight: 300; color: rgba(255,255,255,0.4); line-height: 1.7; max-width: 280px; }
.bl-footer-col-title { font-size: 11px; font-weight: 500; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(255,255,255,0.35); margin-bottom: 1.25rem; }
.bl-footer-links { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 0.75rem; }
.bl-footer-links a { font-size: 14px; font-weight: 300; color: rgba(255,255,255,0.55); transition: color 0.2s; }
.bl-footer-links a:hover { color: var(--bl-gold-light); }
.bl-footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.bl-footer-copy { font-size: 12px; color: rgba(255,255,255,0.3); line-height: 1.7; }
.bl-footer-socials { display: flex; gap: 1rem; }
.bl-footer-socials a { width: 34px; height: 34px; border: 0.5px solid rgba(255,255,255,0.12); border-radius: 50%; display: flex; align-items: center; justify-content: center; color: rgba(255,255,255,0.5); transition: border-color 0.2s, color 0.2s; }
.bl-footer-socials a:hover { border-color: var(--bl-gold); color: var(--bl-gold-light); }
.bl-footer-ack { font-size: 12px; color: rgba(255,255,255,0.28); line-height: 1.7; max-width: 520px; margin-top: 1.5rem; }

/* ─── REVEAL ─────────────────────────────────────────────── */
.bl-reveal { opacity: 0; transform: translateY(28px); transition: opacity 0.7s cubic-bezier(0.22,1,0.36,1), transform 0.7s cubic-bezier(0.22,1,0.36,1); }
.bl-reveal.bl-visible { opacity: 1; transform: none; }
.bl-d1 { transition-delay: 0.1s; }
.bl-d2 { transition-delay: 0.2s; }
.bl-d3 { transition-delay: 0.3s; }

/* ─── RESPONSIVE ─────────────────────────────────────────── */
@media (max-width: 1100px) {
  .bl-cat-grid { grid-template-columns: repeat(3, 1fr); }
  .bl-product-grid { grid-template-columns: repeat(3, 1fr); }
  .bl-materials-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1024px) {
  .bl-nav-links { display: none; }
  .bl-nav-cta { display: none !important; }
  .bl-hamburger { display: flex; }
  .bl-hero { grid-template-columns: 1fr; min-height: auto; }
  .bl-hero-left { padding: 4rem 0 3rem; }
  .bl-hero-right { min-height: 60vw; }
  .bl-services-grid { grid-template-columns: 1fr; }
  .bl-svc-card { min-height: auto; }
  .bl-process-steps { grid-template-columns: repeat(2, 1fr); }
  .bl-why-grid { grid-template-columns: 1fr; gap: 3rem; }
  .bl-footer-grid { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 768px) {
  .bl-nav { padding: 0 1rem; }
  .bl-nav-logo img { height: 34px; }
  .bl-nav-icons { gap: 0.85rem; }
  .bl-nav-icons .bl-ico { font-size: 17px; }
  .bl-wrap { padding: 0 1.25rem; }
  .bl-section { padding: 3.5rem 0; }
  .bl-section-head { flex-direction: column; align-items: flex-start; }
  .bl-sub { text-align: left; }
  .bl-cat-grid { grid-template-columns: repeat(2, 1fr); }
  .bl-product-grid { grid-template-columns: repeat(2, 1fr); gap: 1rem; }
  .bl-materials-grid { grid-template-columns: repeat(2, 1fr); }
  .bl-process-steps { grid-template-columns: 1fr; }
  .bl-testi-grid { grid-template-columns: 1fr; }
  .bl-blog-grid { grid-template-columns: 1fr; }
  .bl-why-mosaic { grid-template-rows: repeat(3, 110px); }
  .bl-footer-grid { grid-template-columns: 1fr; }
  .bl-features-inner { flex-wrap: wrap; justify-content: flex-start; gap: 0.75rem 1rem; }
  .bl-feature { flex: 1 1 42%; white-space: normal; font-size: 11px; }
  .bl-hero-badge { font-size: 9px; letter-spacing: 0.08em; padding: 0.5rem 0.9rem; max-width: calc(100% - 1.5rem); white-space: normal; text-align: center; line-height: 1.45; bottom: 1rem; }
  .bl-hero-title { font-size: clamp(2.5rem, 11vw, 3.4rem); }
  .bl-email-form { flex-direction: column; border: none; background: transparent; gap: 0.6rem; }
  .bl-email-form input { width: 100%; border: 0.5px solid rgba(255,255,255,0.2); border-radius: 40px; background: rgba(255,255,255,0.05); }
  .bl-email-form button { width: 100%; margin: 0; padding: 0.85rem; }
  .bl-process-cta { flex-direction: column; align-items: flex-start; gap: 1rem; }
}
@media (max-width: 480px) {
  .bl-cat-grid { grid-template-columns: 1fr 1fr; }
  .bl-product-grid { grid-template-columns: 1fr 1fr; }
  .bl-search-form input { font-size: 1.2rem; }
}
@media (prefers-reduced-motion: reduce) {
  .bl-reveal { opacity: 1; transform: none; transition: none; }
  .bl-svc-card, .bl-svc-gem { transition: none; }
}
