/* ================================================================
   ie-showrooms.css — InteriorsExpress Showrooms Module
   Design: White luxury upmarket marketplace
   Fonts: Playfair Display + DM Sans
================================================================ */

/* Google Fonts (also add to Astra > Custom Fonts or Elementor > Site Settings) */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;0,800;1,400&family=DM+Sans:wght@300;400;500;600&family=Rajdhani:wght@500;600;700&display=swap');

/* ── CSS Variables ── */
:root {
  --ies-white:      #FFFFFF;
  --ies-off-white:  #FAFAF8;
  --ies-warm-white: #F5F2EC;
  --ies-cream:      #EDE9E0;
  --ies-gold:       #B8860B;
  --ies-gold-l:     #C9A84C;
  --ies-gold-rich:  #9A6E00;
  --ies-gold-pale:  #F0E8D0;
  --ies-gold-bg:    #FBF6EB;
  --ies-charcoal:   #1A1814;
  --ies-ink:        #2C2820;
  --ies-stone:      #5C564E;
  --ies-pebble:     #8C867E;
  --ies-mist:       #C4BEB6;
  --ies-fog:        #E2DDD6;
  --ies-border:     #E0DAD0;
  --ies-border-l:   #EDE9E0;
  --ies-teal:       #0A9488;
  --ies-shadow-sm:  0 2px 12px rgba(26,24,20,.08);
  --ies-shadow-md:  0 8px 30px rgba(26,24,20,.10);
  --ies-shadow-lg:  0 20px 60px rgba(26,24,20,.12);
  --ies-shadow-xl:  0 40px 100px rgba(26,24,20,.14);
  --ies-ease:       .28s cubic-bezier(.25,.46,.45,.94);
}

/* ── Base reset inside plugin scope ── */
.ies-wrap * { box-sizing: border-box; }
.ies-wrap a { color: inherit; text-decoration: none; }
.ies-wrap button { cursor: pointer; font-family: inherit; }

/* ================================================================
   BROWSE PAGE LAYOUT
================================================================ */
.ies-browse-layout {
  max-width: 1640px;
  margin: 0 auto;
  padding: 2rem 2rem;
  display: grid;
  grid-template-columns: 280px 1fr;
  gap: 2rem;
  align-items: start;
}

/* ── FILTER BAR ── */
.ies-filter-bar {
  background: var(--ies-white);
  border-bottom: 1px solid var(--ies-border-l);
  padding: 14px 0;
  position: sticky;
  top: 112px;
  z-index: 80;
  box-shadow: var(--ies-shadow-sm);
}
.ies-filter-bar .container { max-width: 1640px; margin: 0 auto; padding: 0 2rem; }
.ies-filter-row { display: flex; gap: 10px; align-items: center; flex-wrap: wrap; margin-bottom: 8px; }
.ies-filter-row:last-child { margin-bottom: 0; }

.ies-search-box { position: relative; flex: 1; min-width: 240px; }
.ies-search-box input {
  width: 100%;
  border: 1.5px solid var(--ies-border);
  border-radius: 7px;
  padding: 11px 14px 11px 42px;
  font-size: 15px;
  font-family: 'DM Sans', sans-serif;
  color: var(--ies-ink);
  background: var(--ies-white);
  outline: none;
  transition: border .2s;
}
.ies-search-box input:focus { border-color: var(--ies-charcoal); }
.ies-search-box input::placeholder { color: var(--ies-mist); }
.ies-search-ico {
  position: absolute; left: 14px; top: 50%;
  transform: translateY(-50%); color: var(--ies-pebble); font-size: 16px;
}

.ies-filter-select {
  border: 1.5px solid var(--ies-border);
  border-radius: 7px;
  padding: 10px 30px 10px 13px;
  font-size: 14px;
  font-family: 'DM Sans', sans-serif;
  color: var(--ies-stone);
  background: var(--ies-white);
  outline: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238C867E' d='M6 9L1 4h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 10px center;
  cursor: pointer;
  transition: border .2s;
  min-width: 130px;
}
.ies-filter-select:focus { border-color: var(--ies-charcoal); }

.ies-size-filter {
  display: flex; align-items: center; gap: 8px;
  border: 1.5px solid var(--ies-border);
  border-radius: 7px; padding: 8px 14px;
  font-size: 13px; color: var(--ies-stone); white-space: nowrap;
}
.ies-size-filter input[type=range] { accent-color: var(--ies-gold-rich); width: 80px; cursor: pointer; }
.ies-size-val { font-size: 13.5px; font-weight: 600; color: var(--ies-charcoal); min-width: 70px; }

.ies-tour-toggle {
  display: flex; align-items: center; gap: 5px;
  padding: 9px 14px; border-radius: 7px;
  border: 1.5px solid var(--ies-border);
  font-size: 13.5px; font-weight: 500; color: var(--ies-stone);
  cursor: pointer; transition: all .2s; white-space: nowrap;
  background: var(--ies-white);
}
.ies-tour-toggle:hover { border-color: var(--ies-charcoal); color: var(--ies-charcoal); }
.ies-tour-toggle.active.video { background: var(--ies-gold-bg); border-color: var(--ies-gold-l); color: var(--ies-gold-rich); }
.ies-tour-toggle.active.vr    { background: rgba(10,148,136,.07); border-color: rgba(10,148,136,.3); color: var(--ies-teal); }

/* Active filter tags */
.ies-active-filters-wrap { padding-top: 6px; }
#ies-active-tags { display: flex; gap: 6px; flex-wrap: wrap; }
.ies-active-tag {
  display: flex; align-items: center; gap: 5px;
  padding: 4px 10px; border-radius: 20px;
  background: var(--ies-gold-bg);
  border: 1px solid var(--ies-gold-pale);
  color: var(--ies-gold-rich); font-size: 12.5px; font-weight: 500;
}
.ies-active-tag__remove {
  background: none; border: none; color: var(--ies-gold-rich);
  cursor: pointer; font-size: 15px; line-height: 1; padding: 0; margin-left: 2px;
}
.ies-result-count { font-size: 14px; color: var(--ies-stone); margin-left: auto; white-space: nowrap; }
.ies-result-count strong { color: var(--ies-charcoal); }

/* ── CATEGORY STRIP ── */
.ies-cat-strip {
  background: var(--ies-off-white);
  border-bottom: 1px solid var(--ies-border-l);
  padding: .7rem 0; overflow-x: auto; scrollbar-width: none;
}
.ies-cat-strip::-webkit-scrollbar { display: none; }
.ies-cat-strip-inner {
  max-width: 1640px; margin: 0 auto; padding: 0 2rem;
  display: flex; gap: 7px;
}
.ies-cat-pill {
  display: flex; align-items: center; gap: 4px;
  padding: 6px 14px; border-radius: 20px; font-size: 13px;
  font-family: 'Rajdhani', sans-serif; font-weight: 700; letter-spacing: .5px;
  cursor: pointer; transition: all .2s; white-space: nowrap;
  border: 1.5px solid var(--ies-border); background: var(--ies-white); color: var(--ies-stone);
}
.ies-cat-pill:hover { border-color: var(--ies-charcoal); color: var(--ies-charcoal); }
.ies-cat-pill.active { background: var(--ies-charcoal); color: var(--ies-white); border-color: var(--ies-charcoal); }
.ies-cat-pill .ies-count { font-size: 10px; background: rgba(0,0,0,.1); padding: 1px 5px; border-radius: 10px; }
.ies-cat-pill.active .ies-count { background: rgba(255,255,255,.2); }

/* ================================================================
   SIDEBAR
================================================================ */
.ies-sidebar { position: sticky; top: 220px; }
.ies-sb-panel {
  background: var(--ies-white);
  border: 1px solid var(--ies-border-l);
  border-radius: 10px; overflow: hidden;
  box-shadow: var(--ies-shadow-sm);
}
.ies-sb-section { border-bottom: 1px solid var(--ies-border-l); }
.ies-sb-section:last-child { border-bottom: none; }
.ies-sb-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 13px 18px; cursor: pointer; transition: background .2s;
}
.ies-sb-head:hover { background: var(--ies-off-white); }
.ies-sb-head-label { font-size: 14px; font-weight: 600; color: var(--ies-charcoal); }
.ies-sb-head-count {
  font-size: 12px; color: var(--ies-pebble);
  background: var(--ies-warm-white); padding: 2px 7px; border-radius: 10px;
}
.ies-sb-body { padding: 6px 18px 14px; }
.ies-sb-search { position: relative; margin-bottom: 8px; }
.ies-sb-search input {
  width: 100%; border: 1.5px solid var(--ies-border); border-radius: 6px;
  padding: 8px 12px 8px 32px; font-size: 13px; font-family: 'DM Sans', sans-serif;
  color: var(--ies-ink); outline: none; transition: border .2s; background: var(--ies-off-white);
}
.ies-sb-search input:focus { border-color: var(--ies-charcoal); background: var(--ies-white); }
.ies-sb-search input::placeholder { color: var(--ies-mist); }
.ies-sb-search-ico { position: absolute; left: 10px; top: 50%; transform: translateY(-50%); font-size: 13px; color: var(--ies-pebble); }
.ies-sb-group-label {
  font-size: 11px; font-family: 'Rajdhani', sans-serif; font-weight: 700;
  letter-spacing: 1.5px; text-transform: uppercase; color: var(--ies-pebble);
  margin: 10px 0 5px;
}
/* Checkbox */
.ies-cb {
  display: flex; align-items: center; gap: 9px;
  padding: 6px 0; font-size: 14px; color: var(--ies-stone);
  cursor: pointer; transition: color .2s;
}
.ies-cb:hover { color: var(--ies-charcoal); }
.ies-cb input[type=checkbox] { accent-color: var(--ies-gold-rich); width: 15px; height: 15px; cursor: pointer; flex-shrink: 0; }
.ies-cb-count {
  margin-left: auto; font-size: 11.5px; color: var(--ies-pebble);
  background: var(--ies-warm-white); padding: 1px 6px; border-radius: 8px;
}
.ies-sb-apply {
  width: 100%; background: var(--ies-charcoal); color: var(--ies-white);
  padding: 11px; border-radius: 6px; font-size: 14px; font-weight: 600;
  border: none; margin-top: 12px; cursor: pointer; transition: all .2s;
  font-family: 'DM Sans', sans-serif;
}
.ies-sb-apply:hover { background: var(--ies-gold-rich); }
.ies-sb-clear {
  width: 100%; background: transparent; color: var(--ies-pebble);
  padding: 7px; font-size: 12.5px; border: none; cursor: pointer;
  text-decoration: underline; margin-top: 5px; transition: color .2s;
}
.ies-sb-clear:hover { color: var(--ies-charcoal); }

/* ================================================================
   SHOWROOM CARDS
================================================================ */
.ies-sort-bar {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 1.4rem; flex-wrap: wrap; gap: 10px;
}
.ies-sort-label { font-size: 14px; color: var(--ies-stone); }
.ies-sort-label strong { color: var(--ies-charcoal); }
.ies-sort-pills { display: flex; gap: 6px; }
.ies-sort-pill {
  padding: 7px 14px; border-radius: 20px; border: 1.5px solid var(--ies-border);
  font-size: 13px; font-weight: 500; color: var(--ies-stone);
  cursor: pointer; transition: all .2s; background: var(--ies-white);
}
.ies-sort-pill:hover, .ies-sort-pill.active {
  background: var(--ies-charcoal); color: var(--ies-white); border-color: var(--ies-charcoal);
}
#ies-cards-wrap {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(310px, 1fr));
  gap: 1.5rem;
}

/* ── CARD ── */
.ies-card {
  background: var(--ies-white);
  border: 1px solid var(--ies-border-l);
  border-radius: 12px; overflow: hidden;
  transition: all var(--ies-ease);
  cursor: pointer;
  opacity: 0; transform: translateY(10px);
}
.ies-card.is-visible { opacity: 1; transform: translateY(0); transition: opacity .4s ease, transform .4s ease, border-color .28s, box-shadow .28s; }
.ies-card:hover { border-color: var(--ies-gold-l); box-shadow: var(--ies-shadow-lg); transform: translateY(-4px); }

/* Thumbnail */
.ies-card__thumb {
  height: 210px; position: relative; overflow: hidden;
  background: var(--ies-warm-white) center/cover no-repeat;
}
.ies-card__thumb-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to bottom, rgba(26,24,20,.06) 0%, rgba(26,24,20,.5) 100%);
}
.ies-card__badges { position: absolute; top: 12px; left: 12px; display: flex; gap: 6px; z-index: 2; }
.ies-badge {
  padding: 3px 9px; border-radius: 4px;
  font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: .5px;
}
.ies-badge--dark   { background: rgba(26,24,20,.85); color: #fff; }
.ies-badge--teal   { background: rgba(10,148,136,.85); color: #fff; }
.ies-badge--gold   { background: rgba(184,134,11,.9); color: #fff; }
.ies-card__size {
  position: absolute; top: 12px; right: 12px; z-index: 2;
  background: rgba(255,255,255,.92); backdrop-filter: blur(4px);
  padding: 4px 10px; border-radius: 20px; font-size: 12px; font-weight: 600; color: var(--ies-charcoal);
}
.ies-card__play {
  position: absolute; inset: 0; z-index: 1;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; transition: opacity .25s;
}
.ies-card:hover .ies-card__play { opacity: 1; }
.ies-card__play-btn {
  width: 56px; height: 56px; border-radius: 50%;
  background: rgba(255,255,255,.92); display: flex; align-items: center; justify-content: center;
  font-size: 20px; box-shadow: var(--ies-shadow-md); backdrop-filter: blur(4px);
}
.ies-card__vr-btn {
  position: absolute; bottom: 12px; right: 12px; z-index: 2;
  background: var(--ies-teal); color: #fff;
  padding: 5px 11px; border-radius: 4px; font-size: 12px; font-weight: 600;
  border: none; cursor: pointer; transition: all .2s;
}
.ies-card__vr-btn:hover { background: #087A73; }
.ies-card__img-title {
  position: absolute; bottom: 14px; left: 14px; z-index: 2;
  font-family: 'Playfair Display', serif; font-size: 17px; font-weight: 700;
  color: #fff; text-shadow: 0 1px 5px rgba(0,0,0,.5); line-height: 1.25; max-width: 68%;
}
.ies-card__img-location { font-size: 12.5px; font-weight: 400; opacity: .85; }

/* Body */
.ies-card__body { padding: 18px 20px 20px; }
.ies-card__brand-line {
  font-size: 13px; color: var(--ies-pebble); font-weight: 500;
  display: flex; align-items: center; gap: 7px; flex-wrap: wrap; margin-bottom: 6px;
}
.ies-brand-tag {
  background: var(--ies-warm-white); border: 1px solid var(--ies-border);
  padding: 2px 8px; border-radius: 3px; font-size: 12px; font-weight: 600; color: var(--ies-stone);
}
.ies-card__name {
  font-family: 'Playfair Display', serif; font-size: 18px; font-weight: 700;
  color: var(--ies-charcoal); line-height: 1.25; margin-bottom: 12px;
}
.ies-card__name a { color: inherit; }

/* Params grid */
.ies-card__params { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; margin-bottom: 12px; }
.ies-param { background: var(--ies-off-white); border-radius: 6px; padding: 8px 10px; }
.ies-param__lbl {
  font-size: 10.5px; color: var(--ies-pebble); text-transform: uppercase;
  letter-spacing: .8px; font-family: 'Rajdhani', sans-serif; font-weight: 700; margin-bottom: 3px;
}
.ies-param__val { font-size: 13.5px; color: var(--ies-charcoal); font-weight: 600; }
.ies-param__val--hl { color: var(--ies-gold-rich); }

/* Tags */
.ies-card__tags { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 12px; }
.ies-tag {
  padding: 4px 10px; border-radius: 4px; font-size: 12.5px; font-weight: 500;
  background: var(--ies-warm-white); color: var(--ies-stone); border: 1px solid var(--ies-border-l);
}

/* Module links */
.ies-card__module-links { display: flex; gap: 7px; margin-bottom: 13px; flex-wrap: wrap; }
.ies-mod-link {
  display: flex; align-items: center; gap: 5px; padding: 5px 11px;
  border-radius: 4px; font-size: 12px; font-weight: 600; cursor: pointer;
  transition: all .2s; border: 1px solid;
}
.ies-mod-link--vendor { border-color: rgba(10,148,136,.25); color: var(--ies-teal); background: rgba(10,148,136,.05); }
.ies-mod-link--vendor:hover { background: rgba(10,148,136,.12); }
.ies-mod-link--products { border-color: rgba(184,134,11,.25); color: var(--ies-gold-rich); background: var(--ies-gold-bg); }
.ies-mod-link--products:hover { background: var(--ies-gold-pale); }

/* Meta */
.ies-card__meta {
  font-size: 13px; color: var(--ies-pebble); margin-bottom: 13px;
  display: flex; gap: 10px; flex-wrap: wrap;
}

/* Actions */
.ies-card__actions { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.ies-btn-tour {
  background: var(--ies-charcoal); color: #fff; padding: 10px; border-radius: 6px;
  font-size: 13.5px; font-weight: 600; border: none; cursor: pointer; transition: all .2s;
  font-family: 'DM Sans', sans-serif;
}
.ies-btn-tour:hover { background: var(--ies-gold-rich); }
.ies-btn-book {
  background: var(--ies-white); color: var(--ies-charcoal); padding: 10px; border-radius: 6px;
  font-size: 13.5px; font-weight: 600; border: 1.5px solid var(--ies-border);
  cursor: pointer; transition: all .2s; font-family: 'DM Sans', sans-serif;
}
.ies-btn-book:hover { border-color: var(--ies-charcoal); }

/* No results */
.ies-no-results { text-align: center; padding: 4rem 2rem; font-size: 16px; color: var(--ies-stone); }
.ies-no-results a { color: var(--ies-gold-rich); text-decoration: underline; cursor: pointer; }

/* Spinner */
#ies-spinner {
  display: none; position: fixed; bottom: 2rem; right: 2rem; z-index: 200;
  background: var(--ies-charcoal); color: #fff; padding: 10px 18px;
  border-radius: 6px; font-size: 13px; font-weight: 500;
  box-shadow: var(--ies-shadow-md);
}

/* Pagination */
.ies-pagination { display: flex; justify-content: center; align-items: center; gap: 6px; padding: 2.5rem 0; }
.ies-pg-btn {
  width: 40px; height: 40px; display: flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--ies-border); border-radius: 6px;
  font-size: 14.5px; font-weight: 500; color: var(--ies-stone);
  cursor: pointer; transition: all .2s; background: var(--ies-white);
}
.ies-pg-btn:hover { border-color: var(--ies-charcoal); color: var(--ies-charcoal); }
.ies-pg-btn.active { background: var(--ies-charcoal); color: #fff; border-color: var(--ies-charcoal); }
.ies-pg-ellipsis { font-size: 14px; color: var(--ies-pebble); line-height: 40px; }

/* ================================================================
   SINGLE SHOWROOM PAGE COMPONENTS
================================================================ */
.ies-detail-hero {
  height: 480px; position: relative; overflow: hidden; background: var(--ies-warm-white);
}
.ies-detail-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to right, rgba(26,24,20,.8) 0%, rgba(26,24,20,.3) 60%, rgba(26,24,20,.05) 100%);
}
.ies-detail-hero-content {
  position: absolute; inset: 0; display: flex; flex-direction: column;
  justify-content: flex-end; padding: 3rem;
}
.ies-hero-name {
  font-family: 'Playfair Display', serif; font-size: 46px; font-weight: 800;
  color: #fff; line-height: 1.05; margin-bottom: 8px;
}
.ies-hero-sub { font-size: 16px; color: rgba(255,255,255,.7); }
.ies-hero-tour-btns {
  position: absolute; top: 2rem; right: 2rem;
  display: flex; flex-direction: column; gap: 10px; z-index: 5;
}
.ies-dtb {
  display: flex; align-items: center; gap: 8px;
  padding: 11px 18px; border-radius: 7px;
  font-size: 13.5px; font-weight: 600; cursor: pointer;
  transition: all .2s; backdrop-filter: blur(8px); border: none;
}
.ies-dtb-video { background: rgba(255,255,255,.9); color: var(--ies-charcoal); }
.ies-dtb-vr    { background: var(--ies-teal); color: #fff; }
.ies-dtb:hover { transform: scale(1.03); box-shadow: var(--ies-shadow-md); }

/* IE Score block */
.ies-score-block {
  display: flex; align-items: center; gap: 1.5rem;
  background: linear-gradient(135deg, var(--ies-gold-bg), var(--ies-warm-white));
  border: 1px solid var(--ies-gold-pale); border-radius: 10px;
  padding: 1.2rem 1.5rem; margin-bottom: 1.5rem;
}
.ies-score-circle {
  width: 76px; height: 76px; border-radius: 50%; border: 3px solid var(--ies-gold);
  display: flex; flex-direction: column; align-items: center; justify-content: center; flex-shrink: 0;
}
.ies-score-num { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 700; color: var(--ies-gold-rich); line-height: 1; }
.ies-score-of  { font-size: 11px; color: var(--ies-pebble); }
.ies-score-label { font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ies-gold-rich); margin-bottom: 8px; }
.ies-score-bar-row { display: flex; align-items: center; gap: 10px; margin-bottom: 5px; }
.ies-score-bar-lbl { font-size: 12px; color: var(--ies-stone); min-width: 160px; }
.ies-score-bar-track { flex: 1; height: 4px; background: var(--ies-cream); border-radius: 2px; overflow: hidden; }
.ies-score-bar-fill { height: 4px; border-radius: 2px; background: var(--ies-gold); }

/* Catalogue CTA */
.ies-catalogue-cta {
  background: linear-gradient(135deg, var(--ies-charcoal) 0%, #2C2820 100%);
  border-radius: 12px; padding: 1.8rem;
  display: flex; align-items: center; justify-content: space-between; gap: 1.5rem;
  margin-bottom: 2rem;
}
.ies-catalogue-cta h3 {
  font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700;
  color: #fff; margin-bottom: 6px;
}
.ies-catalogue-cta p { font-size: 13.5px; color: rgba(255,255,255,.55); line-height: 1.6; }
.ies-catalogue-btns { display: flex; gap: 10px; flex-wrap: wrap; }
.ies-btn-catalogue {
  display: flex; align-items: center; gap: 7px;
  padding: 11px 20px; border-radius: 6px;
  font-size: 13.5px; font-weight: 600; cursor: pointer; transition: all .2s;
  white-space: nowrap; font-family: 'DM Sans', sans-serif;
}
.ies-btn-dl-pdf      { background: var(--ies-gold); color: #fff; border: none; }
.ies-btn-dl-pdf:hover { background: var(--ies-gold-rich); transform: translateY(-1px); }
.ies-btn-dl-other    { background: transparent; color: rgba(255,255,255,.8); border: 1.5px solid rgba(255,255,255,.25); }
.ies-btn-dl-other:hover { border-color: #fff; color: #fff; }

/* Product lines grid */
.ies-product-lines-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(200px,1fr)); gap: 14px; }
.ies-pl-card {
  background: var(--ies-white); border: 1px solid var(--ies-border-l); border-radius: 10px;
  overflow: hidden; transition: all var(--ies-ease); cursor: pointer;
}
.ies-pl-card:hover { border-color: var(--ies-gold-l); box-shadow: var(--ies-shadow-md); transform: translateY(-2px); }
.ies-pl-thumb {
  height: 120px; display: flex; align-items: center; justify-content: center;
  font-size: 44px; background: var(--ies-warm-white); position: relative;
}
.ies-pl-body { padding: 14px; }
.ies-pl-name { font-family: 'Playfair Display', serif; font-size: 15px; font-weight: 700; color: var(--ies-charcoal); margin-bottom: 5px; line-height: 1.25; }
.ies-pl-desc { font-size: 12.5px; color: var(--ies-stone); line-height: 1.55; margin-bottom: 8px; }
.ies-pl-price { font-size: 14px; font-weight: 600; color: var(--ies-gold-rich); }
.ies-pl-actions { display: flex; gap: 6px; margin-top: 10px; }
.ies-pl-btn { flex: 1; padding: 8px; border-radius: 5px; font-size: 12.5px; font-weight: 600; cursor: pointer; transition: all .2s; text-align: center; font-family: 'DM Sans', sans-serif; }
.ies-pl-btn-view { background: var(--ies-charcoal); color: #fff; border: none; }
.ies-pl-btn-view:hover { background: var(--ies-gold-rich); }
.ies-pl-btn-dl   { background: var(--ies-white); color: var(--ies-charcoal); border: 1.5px solid var(--ies-border); }
.ies-pl-btn-dl:hover { border-color: var(--ies-charcoal); }

/* ================================================================
   MARKET CLUSTERS
================================================================ */
.ies-cluster-card {
  background: var(--ies-white); border: 1px solid var(--ies-border-l); border-radius: 12px;
  padding: 22px; cursor: pointer; transition: all var(--ies-ease);
}
.ies-cluster-card:hover { border-color: var(--ies-gold-l); box-shadow: var(--ies-shadow-md); transform: translateY(-2px); }
.ies-cluster-name { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700; color: var(--ies-charcoal); margin-bottom: 6px; line-height: 1.2; }
.ies-cluster-city { font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ies-pebble); margin-bottom: 4px; }
.ies-cluster-products { font-size: 13.5px; color: var(--ies-stone); line-height: 1.6; margin-bottom: 10px; }
.ies-cluster-count { font-family: 'Playfair Display', serif; font-size: 26px; font-weight: 700; color: var(--ies-charcoal); }
.ies-cluster-badge { display: inline-block; background: var(--ies-gold-bg); border: 1px solid var(--ies-gold-pale); color: var(--ies-gold-rich); padding: 3px 10px; border-radius: 3px; font-size: 12px; font-weight: 600; margin-bottom: 10px; }
.ies-cluster-tip { background: var(--ies-off-white); border-radius: 6px; padding: 10px 12px; font-size: 13px; color: var(--ies-stone); line-height: 1.6; margin: 10px 0; }

/* ================================================================
   MODALS
================================================================ */
.ies-modal-ov {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(26,24,20,.65); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity .3s; padding: 2rem;
}
.ies-modal-ov.open { opacity: 1; pointer-events: all; }
.ies-modal-box {
  background: var(--ies-white); border-radius: 14px;
  width: 100%; max-width: 520px; overflow: hidden;
  transform: translateY(18px); transition: transform .3s;
  box-shadow: var(--ies-shadow-xl); position: relative;
}
.ies-modal-ov.open .ies-modal-box { transform: translateY(0); }
.ies-modal-hd { padding: 22px 28px 18px; border-bottom: 1px solid var(--ies-border-l); }
.ies-modal-title { font-family: 'Playfair Display', serif; font-size: 23px; font-weight: 700; color: var(--ies-charcoal); }
.ies-modal-sub { font-size: 13px; color: var(--ies-pebble); margin-top: 4px; }
.ies-modal-cls {
  position: absolute; top: 16px; right: 18px;
  background: var(--ies-off-white); border: 1px solid var(--ies-border);
  width: 32px; height: 32px; border-radius: 50%; font-size: 16px;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: all .2s; color: var(--ies-stone);
}
.ies-modal-cls:hover { background: var(--ies-cream); }

/* Video modal */
.ies-video-box { max-width: 920px !important; }
.ies-vm__hd { padding: 18px 22px; border-bottom: 1px solid var(--ies-border-l); display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.ies-vm__title { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700; color: var(--ies-charcoal); }
.ies-vm__sub   { font-size: 13px; color: var(--ies-pebble); margin-top: 3px; }
.ies-vm__player { background: #111; position: relative; }
.ies-vm__ft { padding: 14px 20px; display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.ies-vm__ft-title { font-size: 15px; font-weight: 600; color: var(--ies-charcoal); }
.ies-vm__ft-btns { display: flex; gap: 8px; }

/* Tour modal */
.ies-tour-ov { padding: 0 !important; align-items: stretch !important; }
.ies-tour-box {
  background: var(--ies-charcoal); width: 100%; height: 100%;
  display: flex; flex-direction: column;
}
.ies-tm__hd {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 20px; border-bottom: 1px solid rgba(255,255,255,.1);
  flex-shrink: 0; flex-wrap: wrap;
}
.ies-tm__title { font-family: 'Playfair Display', serif; font-size: 20px; font-weight: 700; color: #fff; }
.ies-tm__viewer { flex: 1; overflow: hidden; position: relative; }

/* Body overflow lock */
body.ies-modal-open { overflow: hidden; }

/* ================================================================
   VENDOR PORTAL
================================================================ */
.ies-portal-wrap { max-width: 660px; margin: 0 auto; padding: 3rem 2rem; }
.ies-portal-tabs { display: flex; border: 1.5px solid var(--ies-border); border-radius: 8px; overflow: hidden; margin-bottom: 2rem; }
.ies-portal-tab {
  flex: 1; padding: 12px; background: var(--ies-off-white); border: none;
  border-right: 1.5px solid var(--ies-border); font-size: 14px; font-weight: 600;
  color: var(--ies-stone); cursor: pointer; transition: all .2s; font-family: 'DM Sans', sans-serif;
}
.ies-portal-tab:last-child { border-right: none; }
.ies-portal-tab.active { background: var(--ies-charcoal); color: #fff; }
.ies-portal-sec { display: none; }
.ies-portal-sec.active { display: block; }

/* Form elements */
.ies-fg { margin-bottom: 16px; }
.ies-lbl { display: block; font-size: 13px; font-weight: 600; color: var(--ies-charcoal); margin-bottom: 7px; }
.ies-inp {
  width: 100%; border: 1.5px solid var(--ies-border); border-radius: 7px;
  padding: 12px 14px; font-size: 15px; font-family: 'DM Sans', sans-serif;
  color: var(--ies-ink); background: var(--ies-white); outline: none; transition: border .2s;
}
.ies-inp:focus { border-color: var(--ies-charcoal); }
.ies-inp::placeholder { color: var(--ies-mist); }
.ies-frm-row { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.ies-btn-full {
  width: 100%; padding: 13px; border-radius: 7px; font-size: 15px; font-weight: 600;
  cursor: pointer; transition: all .2s; margin-top: 8px; border: none;
  font-family: 'DM Sans', sans-serif; background: var(--ies-charcoal); color: #fff;
  display: flex; align-items: center; justify-content: center; gap: 8px;
}
.ies-btn-full:hover { background: var(--ies-gold-rich); }
.ies-drop-zone {
  border: 2px dashed var(--ies-border); border-radius: 10px;
  padding: 2rem; text-align: center; cursor: pointer; transition: all .25s; margin-bottom: 14px;
}
.ies-drop-zone:hover, .ies-drop-zone.is-drag-over {
  border-color: var(--ies-gold-l); background: var(--ies-gold-bg);
}
.ies-dz-ico { font-size: 36px; display: block; margin-bottom: 10px; }
.ies-dz-title { font-size: 16px; font-weight: 600; color: var(--ies-charcoal); margin-bottom: 5px; }
.ies-dz-sub   { font-size: 13.5px; color: var(--ies-pebble); line-height: 1.55; }
.ies-form-msg { display: none; padding: 12px 16px; border-radius: 7px; margin-bottom: 14px; font-size: 14px; line-height: 1.55; }
.ies-wp-note { background: rgba(10,148,136,.06); border: 1px solid rgba(10,148,136,.2); border-radius: 8px; padding: 16px; margin-bottom: 16px; }
.ies-wp-note-title { font-family: 'Rajdhani', sans-serif; font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--ies-teal); margin-bottom: 6px; }
.ies-wp-note-text { font-size: 13.5px; color: var(--ies-stone); line-height: 1.65; }
.ies-upload-progress { margin-top: 12px; }
.ies-upload-item { margin-bottom: 8px; }
.ies-upload-name { font-size: 12.5px; color: var(--ies-stone); display: block; margin-bottom: 4px; }
.ies-upload-bar { height: 4px; background: var(--ies-fog); border-radius: 2px; overflow: hidden; }
.ies-upload-fill { height: 4px; background: var(--ies-gold); border-radius: 2px; transition: width .3s; }
.ies-preview-thumb { position: relative; display: inline-block; margin: 4px; }
.ies-preview-thumb img { width: 64px; height: 64px; object-fit: cover; border-radius: 5px; border: 1px solid var(--ies-border); }
.ies-preview-remove { position: absolute; top: -4px; right: -4px; background: var(--ies-charcoal); color: #fff; border: none; border-radius: 50%; width: 18px; height: 18px; font-size: 11px; cursor: pointer; display: flex; align-items: center; justify-content: center; }

/* ================================================================
   SHARED BUTTONS
================================================================ */
.ies-btn-primary {
  background: var(--ies-charcoal); color: #fff; padding: 12px 26px; border-radius: 6px;
  font-size: 15px; font-weight: 600; border: none; cursor: pointer; transition: all .2s;
  font-family: 'DM Sans', sans-serif; display: inline-flex; align-items: center; gap: 8px;
}
.ies-btn-primary:hover { background: var(--ies-gold-rich); transform: translateY(-1px); }
.ies-btn-gold {
  background: var(--ies-gold); color: #fff; padding: 12px 26px; border-radius: 6px;
  font-size: 15px; font-weight: 600; border: none; cursor: pointer; transition: all .2s;
  font-family: 'DM Sans', sans-serif;
}
.ies-btn-gold:hover { background: var(--ies-gold-rich); transform: translateY(-1px); }
.ies-btn-outline {
  background: transparent; color: var(--ies-charcoal); padding: 11px 24px; border-radius: 6px;
  font-size: 15px; font-weight: 600; border: 1.5px solid var(--ies-charcoal); cursor: pointer; transition: all .2s;
  font-family: 'DM Sans', sans-serif; display: inline-flex; align-items: center; gap: 8px;
}
.ies-btn-outline:hover { background: var(--ies-charcoal); color: #fff; }

/* ── ASTRA OVERRIDES — match luxury style ── */
.ast-container { max-width: 1640px !important; }
.site-header { border-bottom: 1px solid var(--ies-border-l) !important; box-shadow: var(--ies-shadow-sm) !important; }

/* ── RESPONSIVE ── */
@media (max-width: 1100px) {
  .ies-browse-layout { grid-template-columns: 1fr; }
  .ies-sidebar { display: none; }
}
@media (max-width: 768px) {
  .ies-hero-name { font-size: 30px; }
  .ies-catalogue-cta { flex-direction: column; }
  .ies-card__params { grid-template-columns: 1fr 1fr; }
  .ies-frm-row { grid-template-columns: 1fr; }
  #ies-cards-wrap { grid-template-columns: 1fr; }
}
