

/* ===== ALL ORIGINAL UI STYLES PRESERVED ===== */
.home-banner { height: 600px; width: 100%; border-radius: 20px; background: #fff; margin: 0 auto;
    background-image: url('https://lgd.net.au/wp-content/themes/labgrowndiamonds/assets/banners/lab-grown-diamonds-1-scaled.jpg');
    background-size: cover; }
.home-shapes-wrap { min-height: 120px; padding: 30px 0; width: 100%; max-width: 1620px; border-radius: 20px; background: #fff; margin: 50px 0; }
.home-intro-img, .home-intro-step, .home-intro-post { background: #fff; border-radius: 20px; }
.home-intro-img { min-height: 400px; }
.shape-btn { width: 60%; text-align: center; font-size: 15px; cursor: pointer; }
.home-shape-btns { display: grid; grid-template-columns: repeat(10, minmax(0, 1fr)); }
.insight_core_breadcrumb { display: none !important; }

/* Diamond Cards */
.diamond-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 20px; padding: 10px; }
.diamond-card { background: #fff; border: 1px solid #eee; border-radius: 12px; overflow: hidden;
    transition: transform .3s, box-shadow .3s; display: flex; flex-direction: column; }
.diamond-card:hover { transform: translateY(-5px); box-shadow: 0 10px 20px rgba(0,0,0,.1); border-color: #591E72; }
.card-header { padding: 15px; background: #fcfcfc; border-bottom: 1px solid #f5f5f5; }
.card-shape-icon svg { width: 50px; height: 50px; color: #591E72; }
.compare-label { font-size: 12px; color: #999; display: flex; align-items: center; gap: 5px; cursor: pointer; margin-right: auto; }
.card-body { padding: 20px 20px 0; flex-grow: 1; }
.diamond-title { margin: 0 0 15px 0; font-size: 18px; color: #333; font-weight: 700; }
.stats-row { display: flex; justify-content: space-between; margin-bottom: 15px; background: #f9f9f9; padding: 10px; border-radius: 8px; }
.stat { display: flex; flex-direction: column; text-align: center; }
.stat .label { font-size: 10px; text-transform: uppercase; color: #aaa; letter-spacing: .5px; }
.stat .val { font-size: 14px; font-weight: 600; color: #444; }
.card-footer { padding: 15px 20px; background: #fff; border-top: 1px solid #f5f5f5; display: flex; justify-content: space-between; align-items: center; }
.card-price { font-size: 20px; font-weight: 800; color: #27ae60; }
.table-btn { display: flex;align-items: center;height: 30px;background: purple; color: white; padding: 0px 15px; border-radius: 6px; font-size: 13px; font-weight: 600; cursor: pointer; }

.wish-btn {
    cursor: pointer;
    text-align: center;
    font-size: 20px;
    color: #888;
}
.wish-btn:hover {
    cursor: pointer;
    text-align: center;
    font-size: 20px;
    color: red
}

/* Loader */
.spinner { width: 40px; height: 40px; border: 4px solid #f3f3f3; border-top: 4px solid #591E72; border-radius: 50%; animation: spin 1s linear infinite; }
@keyframes spin { 0% { transform: rotate(0deg); } 100% { transform: rotate(360deg); } }

/* Shape filter */
.cheap-diamond-filter-section .shape-btn { background: #fff;width: 94px !important; text-align: center; font-size: 15px;
    display: flex; flex-direction: column; align-items: center; border: 1px solid #ddd;
    height: max-content; border-radius: 10px; padding: 5px; }
.shape-btn.active { color: #333; font-weight: 500; border-color: purple !important; background: #f8f5ff; }
.shape-btn svg { transition: transform .2s; }
.shape-btn:hover svg { transform: scale(1.1); }

#home-ajax-target { transition: opacity .3s; }
@media (max-width: 1200px) { .diamond-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 768px)  { .diamond-grid { grid-template-columns: repeat(1, 1fr); } }

/* Colored cards */
.home-colored-cards { padding: 0; border: 1px solid #ddd; border-radius: 20px; background: #fff;
    box-shadow: rgb(0 0 0 / 10%) 0 4px 6px -1px, rgb(0 0 0 / 6%) 0 2px 4px -1px !important; }
.home-colored-card-img, .home-colored-card-img img { max-width: 250px; max-height: 250px; border-top-left-radius: 20px; border-top-right-radius: 20px; }
.home-colored-type { height: 50px; padding: 0 20px; display: flex; align-items: center; border-bottom-left-radius: 20px; border-bottom-right-radius: 20px; }

/* Featured table */
.home-featured-tr th { padding: 0; text-align: center; height: 60px; color: #fff; }
.home-featured-tr td { padding: 0; text-align: center; height: 45px; color: #666; }
.shape-icon svg { width: 45px; }
.tc { text-align: center; }

/* Compare bar */
.diamonds-compare-bar { position: fixed; bottom: -100px; left: 0; right: 0; background: #591E72;
    color: white; padding: 15px 0; transition: bottom .4s; z-index: 9999; box-shadow: 0 -5px 15px rgba(0,0,0,.2); }
.diamonds-compare-bar.active { bottom: 0; }
.compare-container { max-width: 1200px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; padding: 0 20px; }
.btn-compare-now { background: #fff; color: #591E72; border: none; padding: 10px 20px; font-weight: bold; border-radius: 4px; cursor: pointer; margin-left: 15px; }
.btn-clear { background: transparent; color: #fff; border: 1px solid #fff; padding: 8px 15px; cursor: pointer; border-radius: 4px; }

.nav-counter { background: #591E72; color: #fff; border-radius: 50%; padding: 2px 8px; font-size: 11px; margin-left: 5px; min-width: 20px; display: inline-block; text-align: center; }

.content-btn {
    height: 40px;
  width: max-content;
  padding: 0px 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border: 1px solid purple;
  border-radius: 10px;
  color: #888;
}

.content-btn:hover,
.content-btn:focus {
    height: 40px;
  width: max-content;
  padding: 0px 30px;
  display: flex;
  justify-content: center;
  align-items: center;
  background: #fff;
  border: 1px solid purple;
  border-radius: 10px;
  color: #333;
}

.home-intro-step {
    width: 25%;
  min-height: 200px;
  background: #fff;
  text-align: center;
  padding: 30px !important;
  border: 1px solid #eee;
  background: #fff;
  box-shadow: rgba(0, 0, 0, 0.1) 0 4px 6px -1px, rgba(0, 0, 0, 0.06) 0 2px 4px -1px !important;
}


.filter-pills {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  align-items: center;
  border-radius: 10px;
  min-height: 40px;
}

.home-watchprice-cta,
.home-smartprice-cta, 
.home-smartprice-cta, 
.home-pricematch-cta {
    width: 25%;
  min-height: 200px;
  background: #fff;
  text-align: center;
  padding: 30px !important;
  border: 1px solid #eee;
  background: #fff;
  box-shadow: rgba(0, 0, 0, 0.1) 0 4px 6px -1px, rgba(0, 0, 0, 0.06) 0 2px 4px -1px !important;
}