
/* ===== EKO ASTRO BRAND VARIABLES ===== */
:root {
  --eko-green: #1F572C;
  --eko-green-deep: #0E2A14;
  --eko-green-mid: #133A1E;
  --eko-bright: #2D8B47;
  --eko-glow: #4FCF74;
  --eko-cream: #F5F1E8;
  --eko-cream-l: #FAFAF7;
  --eko-cream-section: #F4F6F2;
  --eko-gold: #E6B33F;
  --eko-text: #0F2A18;
  --eko-muted: #6B7A6F;
  --eko-line: #e8ede9;
  --eko-black: #000;
  --eko-white: #fff;
  --font-display: 'Playfair Display', Georgia, serif;
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --radius-sm: 6px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-pill: 999px;
  --shadow-sm: 0 1px 2px rgba(15,42,24,.04), 0 1px 3px rgba(15,42,24,.08);
  --shadow-md: 0 4px 14px rgba(15,42,24,.06), 0 10px 24px rgba(15,42,24,.08);
  --shadow-lg: 0 12px 32px rgba(15,42,24,.10), 0 24px 56px rgba(15,42,24,.10);
}

@layer dooh {
  * { box-sizing: border-box; margin: 0; padding: 0; }
  html { scroll-behavior: smooth; }
  body {
    font-family: var(--font-sans);
    background: var(--eko-cream-l);
    color: var(--eko-text);
    font-size: 15px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }
  h1, h2, h3, h4 { font-family: var(--font-display); color: var(--eko-green-deep); line-height: 1.1; font-weight: 700; }
  a { color: inherit; text-decoration: none; }
  button { font-family: inherit; cursor: pointer; }
  img { max-width: 100%; display: block; }
}
.eyebrow {
  font-size: .68rem; font-weight: 700; color: var(--eko-green);
  letter-spacing: .22em; text-transform: uppercase;
  margin-bottom: 12px; display: inline-block;
}

/* ===== HEADER ===== */

.header-inner {
  max-width: 1480px; margin: 0 auto;
  padding: 14px 24px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 24px;
}
.brand { display: flex; align-items: center; gap: 14px; transition: opacity .2s ease; }
.brand:hover { opacity: .85; }
.brand-logo {
  height: 72px;
  width: auto;
  display: block;
}
.header-nav {
  display: flex; gap: 8px; align-items: center;
}
.nav-pill {
  padding: 9px 18px;
  border-radius: var(--radius-pill);
  font-size: 13px; font-weight: 600;
  color: var(--eko-text);
  text-decoration: none;
  letter-spacing: .04em;
  transition: all .2s ease;
  border: 1px solid transparent;
}
.nav-pill:hover {
  background: var(--eko-cream-section);
  color: var(--eko-green);
}
.nav-pill.cta {
  background: var(--eko-green);
  color: var(--eko-white);
  padding: 10px 22px;
}
.nav-pill.cta:hover {
  background: var(--eko-bright);
  color: var(--eko-white);
  transform: translateY(-1px);
}

/* ===== LANGUAGE TOGGLE (RO/EN) ===== */
.lang-toggle{display:flex;gap:2px;background:#fff;border:1.5px solid var(--eko-line);border-radius:var(--radius-pill);padding:3px;margin-right:6px}
.lang-toggle button{padding:5px 12px;border:none;background:transparent;border-radius:var(--radius-pill);font-size:11px;font-weight:800;color:var(--eko-muted);transition:all .15s;letter-spacing:.05em;font-family:var(--font-sans);cursor:pointer}
.lang-toggle button.active{background:var(--eko-green);color:#fff}

/* ===== CURRENCY TOGGLE ===== */
.curr-toggle{display:flex;gap:2px;background:#fff;border:1.5px solid var(--eko-line);border-radius:var(--radius-pill);padding:3px;margin-right:6px}
.curr-toggle button{padding:5px 11px;border:none;background:transparent;border-radius:var(--radius-pill);font-size:11px;font-weight:800;color:var(--eko-muted);transition:all .15s;letter-spacing:.05em;font-family:var(--font-sans);cursor:pointer}
.curr-toggle button.active{background:var(--eko-black);color:#fff}

/* ===== COMPARE FAB + BTN (DOOH: bottom-right, above cart-fab) ===== */
.compare-fab{position:fixed;bottom:88px;right:24px;display:none;align-items:center;gap:10px;padding:14px 22px;background:var(--eko-black);color:#fff;border-radius:var(--radius-sm);font-weight:800;font-size:12px;letter-spacing:.12em;text-transform:uppercase;box-shadow:0 12px 28px rgba(0,0,0,.30),0 4px 12px rgba(0,0,0,.15);z-index:140;transition:all .25s;cursor:pointer;border:2px solid var(--eko-black);font-family:var(--font-sans)}
.compare-fab.show{display:inline-flex}
.compare-fab:hover{background:var(--eko-green);border-color:var(--eko-green);transform:translateY(-2px)}
.compare-fab .compare-count{background:#fff;color:var(--eko-black);font-weight:900;font-size:11px;padding:2px 8px;border-radius:var(--radius-pill);min-width:22px;text-align:center}
.compare-fab:hover .compare-count{color:var(--eko-green)}
.btn-compare{padding:7px 11px;background:#fff;color:var(--eko-black);border:2px solid var(--eko-black);border-radius:var(--radius-sm);font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;transition:all .15s;font-family:var(--font-sans);white-space:nowrap}
.btn-compare:hover{background:var(--eko-black);color:#fff}
.btn-compare.added{background:var(--eko-black);color:#fff}

/* ===== COMPARE MODAL ===== */
.compare-modal-bg{position:fixed;inset:0;background:rgba(15,42,24,.55);backdrop-filter:blur(8px);z-index:400;opacity:0;visibility:hidden;transition:all .25s}
.compare-modal-bg.open{opacity:1;visibility:visible}
.compare-modal{position:fixed;inset:24px;background:#fff;border-radius:var(--radius-lg);z-index:401;display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}
.compare-modal.open{opacity:1;visibility:visible}
.compare-modal-head{padding:24px 32px;border-bottom:1px solid var(--eko-line);background:var(--eko-green);color:#fff;display:flex;justify-content:space-between;align-items:center}
.compare-modal-head h2{font-family:var(--font-display);font-size:24px;font-weight:600;color:#fff;letter-spacing:-.01em}
.compare-modal-head .compare-clear-btn{background:transparent;color:#fff;border:1.5px solid rgba(255,255,255,.35);padding:8px 16px;border-radius:var(--radius-sm);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;cursor:pointer;margin-right:12px;font-family:var(--font-sans)}
.compare-modal-head .compare-clear-btn:hover{background:#fff;color:var(--eko-green);border-color:#fff}
.compare-modal-close{width:42px;height:42px;border-radius:var(--radius-sm);background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.25);display:grid;place-items:center;color:#fff;cursor:pointer;transition:all .15s}
.compare-modal-close:hover{background:#fff;color:var(--eko-green)}
.compare-modal-body{flex:1;overflow:auto;padding:24px 28px}
.compare-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13.5px;min-width:600px}
.compare-table thead th{position:sticky;top:0;background:#fff;padding:14px 12px;border-bottom:2px solid var(--eko-green);text-align:left;font-weight:800;color:var(--eko-text);font-size:11px;text-transform:uppercase;letter-spacing:.12em;z-index:2}
.compare-table thead th.compare-row-label{background:var(--eko-cream-l);min-width:140px;border-right:1px solid var(--eko-line)}
.compare-table thead th.compare-loc{min-width:220px;border-right:1px solid var(--eko-line)}
.compare-table thead th.compare-loc .loc-name{color:var(--eko-green);font-size:14px;text-transform:none;letter-spacing:-.01em;font-family:var(--font-display);font-weight:700;display:block}
.compare-table thead th.compare-loc .cat-tag-c{display:inline-block;font-size:9.5px;margin-top:6px;padding:3px 10px;background:var(--eko-cream-section);color:var(--eko-green);border-radius:var(--radius-sm);font-weight:800;letter-spacing:.1em}
.compare-table thead th.compare-loc .compare-remove{float:right;background:transparent;border:none;color:var(--eko-muted);cursor:pointer;font-size:18px;line-height:1;padding:4px 8px;border-radius:var(--radius-sm)}
.compare-table thead th.compare-loc .compare-remove:hover{background:var(--eko-black);color:#fff}
.compare-table tbody td{padding:14px 12px;border-bottom:1px solid var(--eko-line);vertical-align:middle;font-weight:500;color:var(--eko-text)}
.compare-table tbody td.compare-row-label{background:var(--eko-cream-l);font-weight:800;color:var(--eko-muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em;border-right:1px solid var(--eko-line)}
.compare-table tbody td.compare-cell{border-right:1px solid var(--eko-line);font-family:var(--font-sans);color:var(--eko-text)}
.compare-table tbody td.compare-cell.price{font-family:var(--font-display);color:var(--eko-green);font-weight:600;font-size:16px}
.compare-table tbody td.compare-cell .check-y{color:var(--eko-bright);font-weight:800}
.compare-table tbody td.compare-cell .check-n{color:var(--eko-muted);font-weight:700}
.compare-table tbody tr:last-child td{border-bottom:none}
.compare-empty{text-align:center;padding:80px 30px;color:var(--eko-muted)}
.compare-empty h3{font-family:var(--font-display);font-size:24px;color:var(--eko-text);margin-bottom:10px}

/* ===== ENTERPRISE ALERT (cart modal) ===== */
.cart-enterprise{margin:14px 0;padding:18px 20px;background:linear-gradient(135deg,var(--eko-black) 0%,#1a1a1a 100%);color:#fff;border-radius:var(--radius-sm);border:1px solid var(--eko-black);position:relative;overflow:hidden;cursor:pointer;transition:all .2s}
.cart-enterprise:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}
.cart-enterprise::before{content:"";position:absolute;top:0;right:0;width:120px;height:120px;background:radial-gradient(circle,rgba(255,255,255,.06) 0%,transparent 70%);pointer-events:none}
.cart-enterprise-eyebrow{font-size:9.5px;font-weight:800;color:#bbb;letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px}
.cart-enterprise-title{font-family:var(--font-display);font-size:18px;font-weight:600;letter-spacing:-.01em;line-height:1.2;margin-bottom:6px;color:#fff}
.cart-enterprise-msg{font-size:12px;color:rgba(255,255,255,.75);line-height:1.5;margin-bottom:10px}
.cart-enterprise-cta{display:inline-flex;align-items:center;gap:6px;padding:8px 14px;background:#fff;color:var(--eko-black);border-radius:var(--radius-sm);font-weight:800;font-size:11px;letter-spacing:.1em;text-transform:uppercase;border:none;cursor:pointer;font-family:var(--font-sans)}
.cart-enterprise-cta:hover{background:var(--eko-green);color:#fff}

/* ===== WIZARD MODAL ===== */
.wiz-bg{position:fixed;inset:0;background:rgba(15,42,24,.55);backdrop-filter:blur(8px);z-index:500;opacity:0;visibility:hidden;transition:all .25s}
.wiz-bg.open{opacity:1;visibility:visible}
.wiz-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:min(640px,calc(100vw - 40px));max-height:90vh;background:#fff;border-radius:var(--radius-lg);z-index:501;display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:var(--shadow-lg)}
.wiz-modal.open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.wiz-head{padding:28px 32px 24px;background:linear-gradient(135deg,var(--eko-black) 0%,var(--eko-green-deep) 100%);color:#fff;position:relative}
.wiz-head-eyebrow{font-size:10.5px;font-weight:800;color:var(--eko-glow);letter-spacing:.2em;text-transform:uppercase;margin-bottom:8px}
.wiz-head h2{font-family:var(--font-display);font-size:24px;color:#fff;font-weight:600;letter-spacing:-.01em;line-height:1.2}
.wiz-head p{font-size:13px;color:rgba(255,255,255,.65);margin-top:6px;line-height:1.5}
.wiz-close{position:absolute;top:18px;right:20px;width:36px;height:36px;border-radius:var(--radius-sm);background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.2);color:#fff;cursor:pointer;font-size:20px;display:grid;place-items:center}
.wiz-close:hover{background:#fff;color:var(--eko-black)}
.wiz-progress{display:flex;gap:6px;padding:18px 32px;background:var(--eko-cream-l);border-bottom:1px solid var(--eko-line)}
.wiz-step-bar{flex:1;height:5px;background:var(--eko-line);border-radius:999px;overflow:hidden;transition:all .3s}
.wiz-step-bar.done{background:var(--eko-green)}
.wiz-step-bar.current{background:linear-gradient(90deg,var(--eko-green) 0%,var(--eko-bright) 100%);box-shadow:0 0 8px rgba(45,139,71,.4)}
.wiz-body{flex:1;overflow-y:auto;padding:28px 32px}
.wiz-step-num{font-size:11px;font-weight:800;color:var(--eko-green);letter-spacing:.16em;text-transform:uppercase;margin-bottom:10px}
.wiz-step-title{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--eko-text);letter-spacing:-.01em;line-height:1.25;margin-bottom:8px}
.wiz-step-hint{font-size:13.5px;color:var(--eko-muted);line-height:1.55;margin-bottom:20px}
.wiz-input{width:100%;padding:14px 18px;background:#fff;border:1.5px solid var(--eko-line);border-radius:var(--radius-sm);color:var(--eko-text);font-size:15px;transition:all .15s;font-weight:500;font-family:var(--font-sans)}
.wiz-input:focus{outline:none;border-color:var(--eko-green);box-shadow:0 0 0 3px rgba(31,87,44,.15)}
.wiz-textarea{min-height:96px;resize:vertical}
.wiz-chips{display:flex;gap:8px;flex-wrap:wrap}
.wiz-chip{padding:10px 16px;background:#fff;border:1.5px solid var(--eko-line);border-radius:var(--radius-sm);font-size:13px;font-weight:700;color:var(--eko-muted);cursor:pointer;transition:all .15s;font-family:var(--font-sans)}
.wiz-chip:hover{border-color:var(--eko-green);color:var(--eko-green)}
.wiz-chip.selected{background:var(--eko-green);color:#fff;border-color:var(--eko-green)}
.wiz-foot{padding:20px 32px;border-top:1px solid var(--eko-line);display:flex;gap:10px;justify-content:space-between;background:var(--eko-cream-l)}
.wiz-btn{padding:14px 22px;border-radius:var(--radius-sm);font-size:12px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .15s;font-family:var(--font-sans);border:2px solid transparent}
.wiz-btn-prev{background:transparent;color:var(--eko-muted);border-color:var(--eko-line)}
.wiz-btn-prev:hover{border-color:var(--eko-text);color:var(--eko-text)}
.wiz-btn-next{background:var(--eko-green);color:#fff;border-color:var(--eko-green);margin-left:auto}
.wiz-btn-next:hover{background:var(--eko-bright);border-color:var(--eko-bright)}
.wiz-btn-finish{background:var(--eko-black);color:#fff;border-color:var(--eko-black);margin-left:auto}
.wiz-btn-finish:hover{background:var(--eko-green);border-color:var(--eko-green)}
.wiz-btn:disabled{opacity:.45;cursor:not-allowed}
.wiz-summary{background:var(--eko-cream-l);border:1px solid var(--eko-line);border-radius:var(--radius-sm);padding:16px 20px;margin-bottom:18px}
.wiz-summary-row{display:flex;justify-content:space-between;padding:6px 0;font-size:13px}
.wiz-summary-row span:first-child{color:var(--eko-muted);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.1em}
.wiz-summary-row span:last-child{color:var(--eko-text);font-weight:700}

/* ===== SHARE BUTTON ===== */
.cart-share-btn{width:100%;padding:13px;background:var(--eko-cream-section);border:1.5px solid var(--eko-green);color:var(--eko-green);border-radius:var(--radius-sm);font-weight:800;font-size:11px;margin-top:8px;transition:all .15s;text-transform:uppercase;letter-spacing:.12em;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-family:var(--font-sans)}
.cart-share-btn:hover{background:var(--eko-green);color:#fff}
.cart-share-btn.copied{background:var(--eko-bright);color:#fff;border-color:var(--eko-bright)}

/* ===== HERO ===== */
.hero {
  background: linear-gradient(135deg, var(--eko-green-deep) 0%, var(--eko-green) 50%, var(--eko-green-mid) 100%);
  color: var(--eko-white);
  padding: 160px 24px 80px;
  position: relative;
  overflow: hidden;
}
.hero::before {
  content: ''; position: absolute; inset: 0;
  background: radial-gradient(ellipse at top right, rgba(79,207,116,.18), transparent 50%),
              radial-gradient(ellipse at bottom left, rgba(230,179,63,.10), transparent 40%);
  pointer-events: none;
}
.hero-inner {
  max-width: 1480px; margin: 0 auto;
  position: relative; z-index: 1;
}
.hero-eyebrow {
  color: var(--eko-glow);
  font-size: .72rem; font-weight: 700;
  letter-spacing: .3em; text-transform: uppercase;
  margin-bottom: 18px;
}
.hero h1 {
  color: var(--eko-white);
  font-size: clamp(2.6rem, 5.5vw, 4.6rem);
  font-weight: 700;
  letter-spacing: -.02em;
  max-width: 920px;
}
.hero h1 em {
  font-style: italic;
  color: var(--eko-glow);
  font-weight: 400;
}
.hero p.sub {
  font-size: clamp(1.05rem, 1.4vw, 1.25rem);
  color: rgba(255,255,255,0.85);
  margin-top: 22px;
  max-width: 740px;
  line-height: 1.6;
}

.hero-stats {
  margin-top: 56px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 12px;
  max-width: 1280px;
}
.stat-card {
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: var(--radius-lg);
  padding: 22px 24px;
  backdrop-filter: blur(8px);
}
.stat-num {
  font-family: var(--font-display);
  font-size: clamp(2rem, 3vw, 2.6rem);
  font-weight: 700;
  color: var(--eko-white);
  line-height: 1;
  letter-spacing: -.02em;
}
.stat-num em {
  font-style: italic; color: var(--eko-glow);
  font-weight: 400;
}
.stat-label {
  font-size: .72rem; font-weight: 600;
  color: rgba(255,255,255,0.75);
  text-transform: uppercase;
  letter-spacing: .2em;
  margin-top: 10px;
}
.stat-sub {
  font-size: .85rem;
  color: rgba(255,255,255,0.55);
  margin-top: 4px;
}

.hero-actions {
  margin-top: 40px;
  display: flex; gap: 12px; flex-wrap: wrap;
}
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 14px 26px;
  border-radius: var(--radius-pill);
  font-weight: 700; font-size: 14px;
  letter-spacing: .08em; text-transform: uppercase;
  border: none; cursor: pointer;
  text-decoration: none;
  transition: all .2s ease;
  font-family: var(--font-sans);
}
.btn-primary {
  background: var(--eko-white);
  color: var(--eko-green-deep);
}
.btn-primary:hover {
  background: var(--eko-glow);
  color: var(--eko-green-deep);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.btn-ghost {
  background: transparent;
  color: var(--eko-white);
  border: 2px solid rgba(255,255,255,0.4);
}
.btn-ghost:hover {
  border-color: var(--eko-glow);
  color: var(--eko-glow);
}

/* ===== MAIN ===== */
main { max-width: 1480px; margin: 0 auto; padding: 56px 24px; }

/* ===== CATEGORIES STRIP ===== */
.cat-strip {
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 32px;
  padding-bottom: 28px;
  border-bottom: 1px solid var(--eko-line);
}
.cat-pill {
  padding: 10px 18px;
  border-radius: var(--radius-pill);
  font-size: 13px; font-weight: 600;
  cursor: pointer;
  background: var(--eko-white);
  border: 1px solid var(--eko-line);
  color: var(--eko-text);
  transition: all .15s ease;
  display: inline-flex; align-items: center; gap: 8px;
  white-space: nowrap;
}
.cat-pill:hover {
  border-color: var(--eko-green);
  color: var(--eko-green);
}
.cat-pill.active {
  background: var(--eko-green);
  color: var(--eko-white);
  border-color: var(--eko-green);
}
.cat-pill .count {
  background: rgba(0,0,0,0.08);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: 700;
}
.cat-pill.active .count {
  background: rgba(255,255,255,0.2);
  color: var(--eko-white);
}

/* ===== FILTERS BAR ===== */
.filters-bar {
  background: var(--eko-white);
  border: 1px solid var(--eko-line);
  border-radius: var(--radius-lg);
  padding: 18px 22px;
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr auto;
  gap: 12px;
  align-items: center;
  margin-bottom: 24px;
  box-shadow: var(--shadow-sm);
}
.filter-input, .filter-select {
  width: 100%;
  padding: 11px 14px;
  border: 1px solid var(--eko-line);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: 14px;
  background: var(--eko-cream-l);
  color: var(--eko-text);
  transition: border-color .15s ease;
}
.filter-input:focus, .filter-select:focus {
  outline: none; border-color: var(--eko-green);
  background: var(--eko-white);
}
.filter-clear {
  background: transparent;
  border: 1px solid var(--eko-line);
  color: var(--eko-muted);
  padding: 11px 18px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-weight: 600;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .08em;
  transition: all .15s ease;
}
.filter-clear:hover { border-color: var(--eko-green); color: var(--eko-green); }

/* ===== TABS ===== */
.view-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 24px;
  background: var(--eko-white);
  padding: 6px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--eko-line);
  width: fit-content;
  box-shadow: var(--shadow-sm);
}
.tab-btn {
  padding: 10px 22px;
  border-radius: var(--radius-pill);
  font-size: 13px; font-weight: 600;
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--eko-muted);
  letter-spacing: .04em;
  transition: all .2s ease;
  font-family: var(--font-sans);
  display: inline-flex; align-items: center; gap: 8px;
}
.tab-btn:hover { color: var(--eko-green); }
.tab-btn.active {
  background: var(--eko-green);
  color: var(--eko-white);
}

.results-info {
  font-size: 13px;
  color: var(--eko-muted);
  margin-bottom: 18px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.results-info strong {
  color: var(--eko-green-deep);
  font-weight: 700;
}

/* ===== GALLERY VIEW ===== */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(290px, 1fr));
  gap: 22px;
}
.card {
  background: var(--eko-white);
  border: 1px solid var(--eko-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all .25s ease;
  display: flex; flex-direction: column;
  cursor: pointer;
}
.card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: rgba(31,87,44,0.3);
}
.card-img {
  width: 100%;
  height: 200px;
  object-fit: cover;
  background: var(--eko-cream-section);
  display: block;
}
.card-img-placeholder {
  width: 100%; height: 200px;
  background: linear-gradient(135deg, var(--eko-green-mid) 0%, var(--eko-green) 100%);
  display: flex; align-items: center; justify-content: center;
  color: var(--eko-glow);
  font-family: var(--font-display);
  font-style: italic;
  font-size: 48px;
  font-weight: 700;
}
.card-body { padding: 18px 20px; flex: 1; display: flex; flex-direction: column; }
.card-cats {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-bottom: 10px;
}
.card-cat {
  font-size: 10px;
  font-weight: 700;
  color: var(--eko-green);
  background: var(--eko-cream-section);
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  letter-spacing: .1em;
  text-transform: uppercase;
}
.card-name {
  font-family: var(--font-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--eko-green-deep);
  line-height: 1.25;
  margin-bottom: 6px;
}
.card-addr {
  font-size: 12px;
  color: var(--eko-muted);
  margin-bottom: 14px;
  line-height: 1.4;
}
.card-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  border-top: 1px solid var(--eko-line);
  padding-top: 14px;
  margin-top: auto;
}
.card-stat-label {
  font-size: 10px;
  color: var(--eko-muted);
  text-transform: uppercase;
  letter-spacing: .12em;
  font-weight: 600;
}
.card-stat-val {
  font-family: var(--font-display);
  font-size: 17px;
  font-weight: 700;
  color: var(--eko-green-deep);
  margin-top: 2px;
}
.card-footer {
  margin-top: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.card-price {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 17px;
  color: var(--eko-green);
}
.card-price small { font-size: 11px; color: var(--eko-muted); font-weight: 500; font-family: var(--font-sans); }
.btn-add {
  background: var(--eko-green);
  color: var(--eko-white);
  border: none;
  padding: 8px 16px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: .1em;
  text-transform: uppercase;
  transition: all .15s ease;
}
.btn-add:hover { background: var(--eko-bright); }
.btn-add.added { background: var(--eko-gold); color: var(--eko-green-deep); }

/* ===== TABLE VIEW ===== */
.table-wrap {
  background: var(--eko-white);
  border: 1px solid var(--eko-line);
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.dooh-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
}
.dooh-table th {
  background: var(--eko-cream-section);
  color: var(--eko-green-deep);
  font-weight: 700;
  text-align: left;
  padding: 14px 18px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .12em;
  border-bottom: 1px solid var(--eko-line);
  position: sticky; top: 0;
  z-index: 5;
}
.dooh-table th.sortable { cursor: pointer; user-select: none; }
.dooh-table th.sortable:hover { color: var(--eko-green); }
.dooh-table td {
  padding: 13px 18px;
  border-bottom: 1px solid var(--eko-line);
  vertical-align: top;
}
.dooh-table tr:last-child td { border-bottom: none; }
.dooh-table tr:hover { background: var(--eko-cream-l); }
.t-name { font-weight: 600; color: var(--eko-green-deep); }
.t-thumb {
  width: 50px; height: 50px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  background: var(--eko-cream-section);
}
.t-thumb-placeholder {
  width: 50px; height: 50px;
  background: var(--eko-green);
  border-radius: var(--radius-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--eko-glow);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 700;
  font-size: 20px;
}
.t-cat-mini {
  font-size: 9px;
  font-weight: 700;
  color: var(--eko-green);
  background: var(--eko-cream-section);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
  letter-spacing: .1em;
  text-transform: uppercase;
  display: inline-block;
  margin-right: 4px;
}
.t-price { font-weight: 700; color: var(--eko-green); }

/* ===== MAP VIEW ===== */
.map-wrap {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: 16px;
  height: 680px;
}
#map {
  background: var(--eko-cream-section);
  border-radius: var(--radius-lg);
  border: 1px solid var(--eko-line);
  overflow: hidden;
}
.map-side {
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.map-card {
  background: var(--eko-white);
  border: 1px solid var(--eko-line);
  border-radius: var(--radius-md);
  padding: 14px 16px;
  cursor: pointer;
  transition: all .15s ease;
}
.map-card:hover {
  border-color: var(--eko-green);
  transform: translateX(-2px);
}
.map-card-name {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 14px;
  color: var(--eko-green-deep);
  line-height: 1.2;
}
.map-card-meta {
  font-size: 11px;
  color: var(--eko-muted);
  margin-top: 4px;
}
.map-card-stats {
  display: flex;
  gap: 12px;
  margin-top: 8px;
  font-size: 11px;
}
.map-card-stats span {
  color: var(--eko-text);
  font-weight: 600;
}
.map-card-stats span small { color: var(--eko-muted); font-weight: 400; }

.leaflet-popup-content-wrapper {
  border-radius: var(--radius-lg);
  padding: 0; overflow: hidden;
}
.leaflet-popup-content { margin: 0; width: 280px !important; }
.popup-img { width: 100%; height: 140px; object-fit: cover; display: block; }
.popup-body { padding: 14px 16px; }
.popup-name { font-family: var(--font-display); font-weight: 700; color: var(--eko-green-deep); font-size: 15px; line-height: 1.2; }
.popup-meta { font-size: 11px; color: var(--eko-muted); margin: 4px 0 8px; }
.popup-stats { display: flex; gap: 10px; font-size: 11px; margin-top: 8px; }
.popup-stats span { color: var(--eko-text); }
.popup-stats span strong { color: var(--eko-green); font-weight: 700; }

/* ===== BUILDER (CART) FLOATING ===== */
#cart-fab {
  position: fixed;
  bottom: 24px; right: 24px;
  background: var(--eko-green);
  color: var(--eko-white);
  border-radius: var(--radius-pill);
  padding: 16px 26px;
  font-weight: 700;
  font-size: 13px;
  letter-spacing: .08em;
  text-transform: uppercase;
  cursor: pointer;
  z-index: 50;
  box-shadow: var(--shadow-lg);
  transition: all .2s ease;
  display: none;
  align-items: center;
  gap: 12px;
  border: none;
  font-family: var(--font-sans);
}
#cart-fab:hover { background: var(--eko-bright); transform: translateY(-2px); }
#cart-fab.show { display: inline-flex; }
.cart-count {
  background: var(--eko-glow);
  color: var(--eko-green-deep);
  padding: 4px 10px;
  border-radius: var(--radius-pill);
  font-size: 12px;
  font-weight: 800;
}

/* ===== MODAL ===== */
.modal-overlay {
  position: fixed; inset: 0;
  background: rgba(14,42,20,0.6);
  backdrop-filter: blur(4px);
  z-index: 1001;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 24px;
}
.modal-overlay.show { display: flex; }
.modal {
  background: var(--eko-white);
  border-radius: var(--radius-lg);
  max-width: 720px;
  width: 100%;
  max-height: 90vh;
  overflow-y: hidden;
  box-shadow: var(--shadow-lg);
  display: flex;
  flex-direction: column;
}
.modal-header { flex-shrink: 0; }
#cartModal .modal-header {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  padding: 12px 20px;
}
#cartModal .modal-title { display: none; }
.modal-close {
  background: transparent;
  border: none;
  font-size: 24px;
  cursor: pointer;
  color: var(--eko-muted);
  line-height: 1;
  padding: 4px;
}
.modal-close:hover { color: var(--eko-green); }
.modal-body { padding: 26px; flex: 1; overflow-y: auto; }

.cart-item {
  display: flex;
  gap: 14px;
  padding: 14px 0;
  border-bottom: 1px solid var(--eko-line);
  align-items: center;
}
.cart-item:last-child { border-bottom: none; }
.cart-item img {
  width: 60px; height: 60px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  background: var(--eko-cream-section);
}
.cart-item-info { flex: 1; }
.cart-item-name { font-weight: 700; font-size: 14px; color: var(--eko-green-deep); }
.cart-item-meta { font-size: 11px; color: var(--eko-muted); margin-top: 2px; }
.cart-item-price { font-weight: 700; color: var(--eko-green); font-size: 15px; }
.cart-item-remove {
  background: transparent;
  border: 1px solid var(--eko-line);
  width: 28px; height: 28px;
  border-radius: 50%;
  cursor: pointer;
  color: var(--eko-muted);
  font-size: 18px;
  line-height: 1;
  display: flex; align-items: center; justify-content: center;
}
.cart-item-remove:hover { background: #fee; border-color: #f88; color: #c33; }

.cart-totals {
  background: var(--eko-cream-section);
  border-radius: var(--radius-md);
  padding: 20px 22px;
  margin-top: 18px;
}
.cart-row {
  display: flex;
  justify-content: space-between;
  padding: 6px 0;
  font-size: 14px;
}
.cart-row.total {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--eko-green-deep);
  border-top: 2px solid var(--eko-green);
  padding-top: 14px;
  margin-top: 10px;
}

.form-group { margin-top: 16px; }
.form-label {
  display: block;
  font-size: 11px;
  font-weight: 700;
  color: var(--eko-green-deep);
  letter-spacing: .12em;
  text-transform: uppercase;
  margin-bottom: 6px;
}
.form-input, .form-textarea {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid var(--eko-line);
  border-radius: var(--radius-sm);
  font-family: var(--font-sans);
  font-size: 14px;
  background: var(--eko-cream-l);
  color: var(--eko-text);
}
.form-input:focus, .form-textarea:focus {
  outline: none; border-color: var(--eko-green);
  background: var(--eko-white);
}
.form-textarea { min-height: 90px; resize: vertical; }

.modal-footer {
  padding: 18px 26px;
  border-top: 1px solid var(--eko-line);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-shrink: 0;
}
#cartModal .modal-footer > div:first-child {
  justify-content: center;
}

/* DETAIL MODAL */
.detail-hero {
  height: 280px;
  background-size: cover;
  background-position: center;
  background-color: var(--eko-green);
  position: relative;
}
.detail-hero-fallback {
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, var(--eko-green-mid), var(--eko-green));
  color: var(--eko-glow);
  height: 100%;
  font-family: var(--font-display);
  font-style: italic;
  font-size: 60px;
  font-weight: 700;
}
.detail-body { padding: 28px; }
.detail-cats { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 12px; }
.detail-name {
  font-family: var(--font-display);
  font-size: 32px;
  font-weight: 700;
  color: var(--eko-green-deep);
  line-height: 1.1;
}
.detail-addr {
  font-size: 13px;
  color: var(--eko-muted);
  margin-top: 6px;
}
.detail-desc {
  font-size: 14px;
  line-height: 1.7;
  color: var(--eko-text);
  margin: 18px 0 22px;
  padding: 16px 18px;
  background: var(--eko-cream-section);
  border-left: 3px solid var(--eko-green);
  border-radius: var(--radius-sm);
}
.detail-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px;
}
.detail-stat {
  background: var(--eko-cream-l);
  border: 1px solid var(--eko-line);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.detail-stat-label {
  font-size: 10px;
  color: var(--eko-muted);
  text-transform: uppercase;
  letter-spacing: .14em;
  font-weight: 600;
}
.detail-stat-val {
  font-family: var(--font-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--eko-green-deep);
  margin-top: 6px;
}
.detail-stat-val small { font-size: 12px; color: var(--eko-muted); font-weight: 500; font-family: var(--font-sans); }

/* FOOTER */
footer {
  background: var(--eko-green-deep);
  color: rgba(255,255,255,0.7);
  padding: 56px 24px 36px;
  margin-top: 80px;
}
.footer-inner {
  max-width: 1480px; margin: 0 auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: 36px;
}
.footer-brand h3 {
  color: var(--eko-white);
  font-size: 22px;
  margin-bottom: 8px;
}
.footer-brand p {
  font-size: 13px;
  margin-bottom: 16px;
  max-width: 320px;
}
.footer-col h4 {
  color: var(--eko-glow);
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: .15em;
  margin-bottom: 14px;
  font-weight: 700;
}
.footer-col a {
  color: rgba(255,255,255,0.7);
  text-decoration: none;
  font-size: 13px;
  display: block;
  margin-bottom: 8px;
  transition: color .15s ease;
}
.footer-col a:hover { color: var(--eko-glow); }
.footer-bottom {
  max-width: 1480px;
  margin: 36px auto 0;
  padding-top: 22px;
  border-top: 1px solid rgba(255,255,255,0.1);
  text-align: center;
  font-size: 12px;
  color: rgba(255,255,255,0.5);
}

/* ===== RESPONSIVE ===== */
@media (max-width: 1100px) {
  .map-wrap { grid-template-columns: 1fr; height: auto; }
  #map { height: 480px; }
  .filters-bar { grid-template-columns: 1fr 1fr; }
  .footer-inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 700px) {
  .header-inner { flex-wrap: wrap; }
  .hero { padding: 104px 20px 56px; }
  .hero-stats { grid-template-columns: 1fr 1fr; }
  .filters-bar { grid-template-columns: 1fr; }
  .footer-inner { grid-template-columns: 1fr; }
  main { padding: 36px 16px; }
  /* view-tabs: centrat pe pagină */
  .view-tabs { flex-wrap: nowrap !important; align-items: center !important; justify-content: center !important; gap: 6px !important; margin-bottom: 12px !important; width: 100% !important; }
  .view-tabs-btns { display: flex !important; flex: 0 0 auto !important; width: auto !important; margin-right: 0 !important; }
  .tab-btn { flex: 0 0 auto !important; justify-content: center !important; padding: 9px 14px !important; font-size: 11px !important; gap: 4px !important; }
  .lang-toggle { flex-shrink: 0 !important; margin: 0 !important; }
  .curr-toggle { display: none !important; }
  .results-info { display: block !important; text-align: center !important; margin-bottom: 14px !important; }
  .results-info > div:last-child { display: none !important; }
  /* reco-box: single column pe mobil, QR ascuns */
  .reco-box { grid-template-columns: 1fr !important; gap: 20px !important; padding: 24px 20px !important; }
  .reco-box > div:nth-child(2) { display: none !important; }
  /* combo-box: single column pe mobil */
  .combo-box { padding: 28px 20px !important; }
  .combo-grid { grid-template-columns: 1fr !important; gap: 24px !important; }
  .combo-stats { grid-template-columns: 1fr !important; gap: 8px !important; }
  /* Stack vertically on right: compara above, pachet below — both compact */
  #cart-fab { bottom:16px; right:16px; padding:10px 16px; font-size:11px; gap:8px; border-radius:var(--radius-sm); }
  #cart-fab #cartTotal { display:none; }
  .compare-fab { bottom:68px; right:16px; padding:8px 12px; font-size:10px; gap:7px; }
  .compare-modal { inset:8px }
  .compare-modal-head { padding:16px 18px }
  .compare-modal-head h2 { font-size:18px }
  .wiz-modal { width:calc(100vw - 16px); max-height:94vh }
  .wiz-head { padding:18px 20px 16px }
  .wiz-head h2 { font-size:19px }
  .wiz-body { padding:18px 20px }
  .wiz-foot { padding:14px 20px }
  /* Filters bar becomes sticky on mobile when scrolled to */
  .filters-bar {
    position: sticky;
    top: 0;
    z-index: 50;
    grid-template-columns: 1fr;
    border-radius: 0;
    margin-left: -16px;
    margin-right: -16px;
    border-left: none;
    border-right: none;
    border-top: none;
    border-bottom: 2px solid var(--eko-line);
    padding: 10px 14px 8px;
    margin-bottom: 20px;
    background: var(--eko-cream-l);
    box-shadow: 0 4px 14px rgba(15,42,24,.08);
  }
  /* Compact [Filtre] + [Pachetul meu] — always visible */
  .mob-compact-row { display: flex; gap: 10px; align-items: center; }
  .mob-compact-filters {
    flex: 1; display: flex; align-items: center; justify-content: center; gap: 8px;
    padding: 11px 14px; border-radius: var(--radius-sm); border: 1.5px solid var(--eko-line);
    background: var(--eko-white); font-size: 13px; font-weight: 700; color: var(--eko-text);
    cursor: pointer; font-family: var(--font-sans); transition: all .15s;
  }
  .mob-compact-filters.active { background: var(--eko-green); color: #fff; border-color: var(--eko-green); }
  .mob-compact-cart { flex-shrink: 0; }
  /* Hide filter inputs by default — show when expanded */
  .filters-bar .dooh-search-wrap,
  .filters-bar .filter-select,
  .filters-bar .filter-clear,
  .filters-bar .mob-cart-strip { display: none !important; }
  .filters-bar.expanded .dooh-search-wrap { display: block !important; }
  .filters-bar.expanded .filter-select { display: block !important; width: 100%; }
  .filters-bar.expanded .filter-clear { display: block !important; width: 100%; }
}

/* Mob-bar elements fully hidden — no longer used */
.dooh-mob-bar,.dooh-mob-filter-close,.dooh-mob-filter-apply { display:none !important; }
/* mob-cart-strip hidden (replaced by mob-compact-row) */
.mob-cart-strip { display: none !important; }
/* mob-compact-row hidden on desktop */
.mob-compact-row { display: none; }
html[data-blog-theme="dark"] .mob-compact-filters { background:#1c2128; border-color:#30363d; color:#c9d1d9; }
html[data-blog-theme="dark"] .filters-bar { background:rgba(13,17,23,.97); border-bottom-color:#30363d; }

/* ===== WHATSAPP FAB ===== */
.fabs-stack-left{position:fixed;bottom:24px;left:24px;display:flex;flex-direction:column;align-items:center;gap:12px;z-index:150}
.fab{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;color:#fff;transition:transform .2s,box-shadow .2s;text-decoration:none;cursor:pointer}
.fab:hover{transform:scale(1.1)}
.fab-whatsapp,.wa-fab{background:#25D366;box-shadow:0 8px 24px rgba(37,211,102,.45);animation:wa-pulse 2.6s ease-out infinite}
.fab-whatsapp:hover,.wa-fab:hover{box-shadow:0 12px 32px rgba(37,211,102,.6)}
.fab-telegram{background:#2AABEE;box-shadow:0 8px 20px rgba(42,171,238,.4);animation:tg-pulse 2.6s ease-out 1.3s infinite}
.fab-telegram:hover{box-shadow:0 12px 28px rgba(42,171,238,.6)}
@keyframes wa-pulse{0%{box-shadow:0 8px 24px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 8px 24px rgba(37,211,102,.45),0 0 0 14px rgba(37,211,102,0)}100%{box-shadow:0 8px 24px rgba(37,211,102,.45),0 0 0 0 rgba(37,211,102,0)}}
@keyframes tg-pulse{0%{box-shadow:0 8px 20px rgba(42,171,238,.4),0 0 0 0 rgba(42,171,238,.45)}70%{box-shadow:0 8px 20px rgba(42,171,238,.4),0 0 0 14px rgba(42,171,238,0)}100%{box-shadow:0 8px 20px rgba(42,171,238,.4),0 0 0 0 rgba(42,171,238,0)}}
@media (max-width:700px){.fabs-stack-left{bottom:16px;left:16px}.fab{width:48px;height:48px}}

/* Hidden by default */

.loading {
  text-align: center;
  padding: 80px 20px;
  color: var(--eko-muted);
}

/* Pagination */
.pagination {
  display: flex;
  gap: 6px;
  justify-content: center;
  margin-top: 32px;
}
.pagination button {
  padding: 8px 14px;
  border: 1px solid var(--eko-line);
  background: var(--eko-white);
  color: var(--eko-text);
  font-weight: 600;
  border-radius: var(--radius-sm);
  cursor: pointer;
  font-family: var(--font-sans);
  font-size: 13px;
}
.pagination button:hover { border-color: var(--eko-green); color: var(--eko-green); }
.pagination button.active { background: var(--eko-green); color: var(--eko-white); border-color: var(--eko-green); }
.pagination button:disabled { opacity: .4; cursor: not-allowed; }

.cat-icon {
  width: 14px; height: 14px;
  display: inline-block;
  border-radius: 50%;
}

/* ===== CONVERSION FEATURES (4 NEW) ===== */

/* === 1. EXIT-INTENT POPUP === */
@keyframes pulseGreen{0%{box-shadow:0 0 0 0 rgba(79,207,116,.7)}70%{box-shadow:0 0 0 12px rgba(79,207,116,0)}100%{box-shadow:0 0 0 0 rgba(79,207,116,0)}}
.exit-popup-backdrop{position:fixed;inset:0;background:rgba(15,42,24,.55);backdrop-filter:blur(8px);z-index:400;opacity:0;visibility:hidden;transition:all .25s}
.exit-popup-backdrop.open{opacity:1;visibility:visible}
.exit-popup{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.92);width:min(520px,calc(100vw - 32px));background:var(--eko-cream-l);border-radius:14px;border:1px solid var(--eko-line);z-index:401;display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 30px 80px -20px rgba(15,42,24,.45);font-family:var(--font-sans)}
.exit-popup.open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.exit-popup-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:6px;background:#fff;border:1.5px solid var(--eko-line);display:grid;place-items:center;transition:all .15s;cursor:pointer;color:var(--eko-muted);z-index:2;font-size:18px;font-weight:600}
.exit-popup-close:hover{background:#000;color:#fff;border-color:#000}
.exit-popup-head{padding:42px 36px 22px;text-align:center;background:linear-gradient(180deg,rgba(79,207,116,.10) 0%,var(--eko-cream-l) 100%);position:relative}
.exit-popup-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:10.5px;font-weight:800;color:var(--eko-green);letter-spacing:.22em;text-transform:uppercase;margin-bottom:14px;padding:6px 14px;background:#fff;border-radius:999px;border:1px solid rgba(79,207,116,.18)}
.exit-popup-eyebrow::before{content:"";width:7px;height:7px;background:var(--eko-bright);border-radius:50%;animation:pulseGreen 2.4s ease-out infinite}
.exit-popup-title{font-family:var(--font-display);font-size:28px;font-weight:600;color:var(--eko-text);letter-spacing:-.02em;line-height:1.18;margin-bottom:12px}
.exit-popup-title em{font-style:italic;color:var(--eko-green);font-weight:500}
.exit-popup-sub{font-size:14px;color:var(--eko-muted);line-height:1.55;max-width:380px;margin:0 auto}
.exit-popup-sub b{color:#000;font-weight:700}
.exit-popup-body{padding:24px 36px 32px}
.exit-popup-form{display:flex;flex-direction:column;gap:10px}
.exit-popup-input{padding:14px 16px;border:1.5px solid var(--eko-line);border-radius:6px;font-family:var(--font-sans);font-size:14px;background:#fff;color:var(--eko-text);transition:all .15s;width:100%}
.exit-popup-input:focus{outline:none;border-color:var(--eko-green);box-shadow:0 0 0 4px rgba(31,87,44,.08)}
.exit-popup-btn{padding:14px 24px;background:#000;color:#fff;border:none;border-radius:6px;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.14em;cursor:pointer;transition:all .15s;font-family:var(--font-sans);display:flex;align-items:center;justify-content:center;gap:8px}
.exit-popup-btn:hover{background:var(--eko-green);transform:translateY(-1px);box-shadow:0 6px 16px rgba(31,87,44,.25)}
.exit-popup-foot{font-size:11px;color:var(--eko-muted);text-align:center;margin-top:14px;line-height:1.5}
.exit-popup-foot b{color:var(--eko-green)}

/* === 2. STICKY CTA BAR === */
.sticky-cta-bar{display:none !important;visibility:hidden !important;pointer-events:none !important}
/* Push cart-fab up when sticky bar is showing */
.sticky-cta-bar.show ~ #cart-fab{bottom:96px}
.sticky-cta-bar.show ~ .compare-fab{bottom:96px}
.sticky-cta-bar.show ~ .wa-fab{bottom:96px}
.sticky-cta-bar.show ~ .wa-tooltip{bottom:108px}
.sticky-cta-inner{max-width:1480px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap}
.sticky-cta-info{display:flex;align-items:center;gap:22px;flex:1;min-width:0;flex-wrap:wrap}
.sticky-cta-eyebrow{font-size:9.5px;font-weight:800;color:var(--eko-green);letter-spacing:.22em;text-transform:uppercase;margin-bottom:3px}
.sticky-cta-count{font-family:var(--font-display);font-size:22px;font-weight:600;color:var(--eko-text);letter-spacing:-.015em;line-height:1.1}
.sticky-cta-count b{color:var(--eko-green);font-weight:700}
.sticky-cta-divider{width:1px;height:36px;background:var(--eko-line)}
.sticky-cta-total-eyebrow{font-size:9.5px;font-weight:800;color:var(--eko-muted);letter-spacing:.22em;text-transform:uppercase;margin-bottom:3px}
.sticky-cta-total{font-family:var(--font-display);font-size:24px;font-weight:700;color:#000;letter-spacing:-.02em;line-height:1.1;font-variant-numeric:tabular-nums}
.sticky-cta-btn{padding:14px 28px;background:var(--eko-green);color:#fff;border:none;border-radius:6px;font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.14em;cursor:pointer;transition:all .15s;font-family:var(--font-sans);display:inline-flex;align-items:center;gap:8px;white-space:nowrap}
.sticky-cta-btn:hover{background:var(--eko-bright);transform:translateY(-1px);box-shadow:0 6px 16px rgba(31,87,44,.3)}
.sticky-cta-close{width:32px;height:32px;border-radius:6px;background:transparent;border:1.5px solid var(--eko-line);display:grid;place-items:center;cursor:pointer;color:var(--eko-muted);transition:all .15s;flex-shrink:0;font-size:14px;line-height:1}
.sticky-cta-close:hover{background:#000;color:#fff;border-color:#000}
@media (max-width:780px){
 .sticky-cta-bar{padding:12px 16px}
 .sticky-cta-inner{gap:12px}
 .sticky-cta-info{gap:14px}
 .sticky-cta-count{font-size:16px}
 .sticky-cta-total{font-size:18px}
 .sticky-cta-divider{display:none}
 .sticky-cta-btn{padding:11px 16px;font-size:11px;letter-spacing:.1em}
}

/* === 3. LIVE COUNTER === */
.live-counter{margin:36px 0 0;display:inline-flex;align-items:center;gap:14px;padding:13px 22px;background:rgba(255,255,255,.08);border:1px solid rgba(79,207,116,.32);border-radius:999px;backdrop-filter:blur(8px);font-family:var(--font-sans)}
.live-counter-dot{width:9px;height:9px;background:var(--eko-glow);border-radius:50%;animation:pulseGreen 2.4s ease-out infinite;box-shadow:0 0 0 0 var(--eko-glow);flex-shrink:0}
.live-counter-label{font-size:10.5px;font-weight:800;color:var(--eko-glow);letter-spacing:.22em;text-transform:uppercase}
.live-counter-num{font-family:var(--font-display);font-size:22px;font-weight:700;color:#fff;letter-spacing:-.015em;font-variant-numeric:tabular-nums}
.live-counter-text{font-size:13px;color:rgba(255,255,255,.78);font-weight:500}
.live-counter-text b{color:#fff;font-weight:700}
@media (max-width:560px){
 .live-counter{padding:10px 16px;gap:10px;flex-wrap:wrap;justify-content:center}
 .live-counter-num{font-size:18px}
 .live-counter-text{font-size:12px}
 .live-counter-label{font-size:9.5px}
}

/* === 4. CART PROGRESS BAR (gamification) === */
.cart-progress{padding:18px 28px 38px 20px;background:linear-gradient(135deg,rgba(79,207,116,.08) 0%,#fff 100%);border:1.5px solid rgba(79,207,116,.18);border-radius:10px;margin-bottom:18px;font-family:var(--font-sans);overflow:hidden}
.cart-progress-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:12px;gap:8px}
.cart-progress-eyebrow{font-size:9.5px;font-weight:800;color:var(--eko-green);letter-spacing:.22em;text-transform:uppercase}
.cart-progress-pct{font-family:var(--font-display);font-size:18px;font-weight:700;color:var(--eko-green);letter-spacing:-.01em;font-variant-numeric:tabular-nums}
.cart-progress-bar{position:relative;height:10px;background:#fff;border:1px solid var(--eko-line);border-radius:999px;overflow:visible;margin-bottom:12px}
.cart-progress-fill{position:absolute;left:0;top:0;bottom:0;background:linear-gradient(90deg,var(--eko-green) 0%,var(--eko-bright) 100%);border-radius:999px;transition:width .5s cubic-bezier(.4,0,.2,1)}
.cart-progress-marker{position:absolute;top:50%;transform:translate(-50%,-50%);width:18px;height:18px;background:#fff;border:2.5px solid var(--eko-line);border-radius:50%;display:grid;place-items:center;font-size:9px;font-weight:800;color:var(--eko-muted);font-family:var(--font-sans);transition:all .3s;z-index:1}
.cart-progress-marker.reached{background:var(--eko-green);border-color:var(--eko-green);color:#fff;box-shadow:0 2px 8px rgba(31,87,44,.3)}
.cart-progress-marker-label{position:absolute;top:24px;left:50%;transform:translateX(-50%);font-size:9.5px;font-weight:800;color:var(--eko-muted);text-transform:uppercase;letter-spacing:.1em;white-space:nowrap}
.cart-progress-marker.reached .cart-progress-marker-label{color:var(--eko-green)}
.cart-progress-msg{margin-top:22px;font-size:12.5px;color:var(--eko-text);line-height:1.5}
.cart-progress-msg b{color:var(--eko-green);font-weight:700}
.cart-progress-msg em{font-style:italic;color:#000;font-weight:600}

/* ===== AUTOCOMPLETE DROPDOWN ===== */
.dooh-search-wrap{position:relative}
.autocomplete-dropdown{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--eko-white);border:1.5px solid var(--eko-line);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:120;max-height:380px;overflow-y:auto;display:none}
.autocomplete-dropdown.open{display:block}
.ac-section{padding:8px 0;border-bottom:1px solid var(--eko-line)}
.ac-section:last-child{border-bottom:none}
.ac-section-title{font-size:10px;font-weight:800;color:var(--eko-green);letter-spacing:.18em;text-transform:uppercase;padding:6px 16px 8px;font-family:var(--font-sans)}
.ac-item{padding:10px 16px;cursor:pointer;display:flex;align-items:center;gap:10px;font-size:13.5px;color:var(--eko-text);font-weight:500;transition:background .12s;border-left:3px solid transparent}
.ac-item:hover,.ac-item.focused{background:var(--eko-cream-section);border-left-color:var(--eko-green)}
.ac-item-icon{font-size:16px;flex-shrink:0;width:20px;text-align:center}
.ac-item-text{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ac-item-text mark{background:rgba(45,139,71,.18);color:var(--eko-green);font-weight:800;border-radius:2px;padding:0 2px}
.ac-item-meta{font-size:10.5px;color:var(--eko-muted);text-transform:uppercase;letter-spacing:.1em;font-weight:700;flex-shrink:0}

/* ===== HOVER PREVIEW POPUP ===== */
.hover-preview{position:fixed;background:var(--eko-white);border:1.5px solid var(--eko-line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:250;width:420px;max-width:calc(100vw - 32px);overflow:hidden;opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .18s,transform .18s,visibility .18s;pointer-events:none}
.hover-preview.open{opacity:1;visibility:visible;transform:translateY(0)}
.hover-preview-img{width:100%;height:240px;object-fit:cover;background:var(--eko-cream-section);display:block}
.hover-preview-img-placeholder{width:100%;height:240px;background:linear-gradient(135deg,var(--eko-green-mid),var(--eko-green));display:flex;align-items:center;justify-content:center;color:var(--eko-glow);font-family:var(--font-display);font-style:italic;font-size:42px;font-weight:700}
.hover-preview-info{padding:14px 18px 16px}
.hover-preview-cats{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:6px}
.hover-preview-cat{font-size:10px;font-weight:800;color:var(--eko-green);text-transform:uppercase;letter-spacing:.14em;background:var(--eko-cream-section);padding:3px 10px;border-radius:var(--radius-pill)}
.hover-preview-title{font-family:var(--font-display);font-size:18px;font-weight:600;color:var(--eko-green-deep);letter-spacing:-.015em;margin-bottom:6px;line-height:1.25}
.hover-preview-addr{font-size:12px;color:var(--eko-muted);line-height:1.5;margin-bottom:10px}
.hover-preview-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;border-top:1px solid var(--eko-line);padding-top:10px;margin-bottom:8px}
.hover-preview-stat-lbl{font-size:9.5px;font-weight:800;color:var(--eko-muted);text-transform:uppercase;letter-spacing:.12em;margin-bottom:2px}
.hover-preview-stat-val{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--eko-green-deep);line-height:1}
.hover-preview-price{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--eko-green);margin-top:8px;padding-top:8px;border-top:1px solid var(--eko-line)}
@media(max-width:780px){.hover-preview{display:none !important}}

/* ===== GDPR COOKIES BANNER ===== */
.gdpr-banner{position:fixed;bottom:18px;left:50%;transform:translateX(-50%) translateY(120px);width:320px;max-width:calc(100vw - 24px);background:var(--eko-white);border:1.5px solid var(--eko-line);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:18px 18px 16px;z-index:400;opacity:0;visibility:hidden;transition:opacity .35s,transform .35s,visibility .35s;font-family:var(--font-sans)}
.gdpr-banner.open{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.gdpr-icon{font-size:22px;margin-bottom:6px}
.gdpr-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--eko-green-deep);margin-bottom:6px;letter-spacing:-.01em}
.gdpr-text{font-size:11.5px;color:var(--eko-muted);line-height:1.5;margin-bottom:12px}
.gdpr-text b{color:var(--eko-green-deep)}
.gdpr-text a{color:var(--eko-green);text-decoration:underline;font-weight:600;cursor:pointer}
.gdpr-actions{display:flex;flex-direction:column;gap:6px}
.gdpr-btn{padding:9px 12px;border-radius:var(--radius-sm);font-size:10.5px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .15s;font-family:var(--font-sans);border:1.5px solid transparent;text-align:center;line-height:1}
.gdpr-btn-accept{background:var(--eko-green);color:var(--eko-white);border-color:var(--eko-green)}
.gdpr-btn-accept:hover{background:var(--eko-bright);border-color:var(--eko-bright)}
.gdpr-btn-settings{background:var(--eko-white);color:var(--eko-muted);border-color:var(--eko-line)}
.gdpr-btn-settings:hover{border-color:var(--eko-green);color:var(--eko-green)}
.gdpr-btn-reject{background:transparent;color:var(--eko-muted);border-color:transparent;font-weight:600;padding:6px 10px}
.gdpr-btn-reject:hover{color:var(--eko-black)}
.gdpr-modal-backdrop{position:fixed;inset:0;background:rgba(15,42,24,.55);backdrop-filter:blur(6px);z-index:410;opacity:0;visibility:hidden;transition:all .25s}
.gdpr-modal-backdrop.open{opacity:1;visibility:visible}
.gdpr-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%) scale(.95);width:min(440px,calc(100vw - 32px));max-height:88vh;background:var(--eko-white);border-radius:var(--radius-lg);z-index:411;display:flex;flex-direction:column;overflow:hidden;opacity:0;visibility:hidden;transition:all .25s;box-shadow:var(--shadow-lg)}
.gdpr-modal.open{opacity:1;visibility:visible;transform:translate(-50%,-50%) scale(1)}
.gdpr-modal-head{padding:20px 24px 14px;border-bottom:1px solid var(--eko-line)}
.gdpr-modal-head h3{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--eko-green-deep);letter-spacing:-.01em;margin-bottom:4px}
.gdpr-modal-head p{font-size:12px;color:var(--eko-muted);line-height:1.5}
.gdpr-modal-body{padding:18px 24px;overflow-y:auto;flex:1}
.gdpr-toggle-row{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:12px 0;border-bottom:1px solid var(--eko-line)}
.gdpr-toggle-row:last-child{border-bottom:none}
.gdpr-toggle-info{flex:1;min-width:0}
.gdpr-toggle-name{font-size:12.5px;font-weight:800;color:var(--eko-green-deep);text-transform:uppercase;letter-spacing:.06em;margin-bottom:3px}
.gdpr-toggle-desc{font-size:11.5px;color:var(--eko-muted);line-height:1.5}
.gdpr-switch{position:relative;width:42px;height:24px;flex-shrink:0;margin-top:2px}
.gdpr-switch input{opacity:0;width:0;height:0;position:absolute}
.gdpr-switch-slider{position:absolute;cursor:pointer;inset:0;background:var(--eko-line);border-radius:999px;transition:.2s}
.gdpr-switch-slider::before{content:"";position:absolute;height:18px;width:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.18)}
.gdpr-switch input:checked + .gdpr-switch-slider{background:var(--eko-green)}
.gdpr-switch input:checked + .gdpr-switch-slider::before{transform:translateX(18px)}
.gdpr-switch input:disabled + .gdpr-switch-slider{background:var(--eko-green);opacity:.6;cursor:not-allowed}
.gdpr-modal-foot{padding:16px 24px;border-top:1px solid var(--eko-line);display:flex;gap:8px;background:var(--eko-cream-l)}
.gdpr-modal-foot .gdpr-btn{flex:1}
.gdpr-policy-modal{font-size:13px;line-height:1.7;color:var(--eko-muted)}
.gdpr-policy-modal h4{font-family:var(--font-display);font-size:15px;color:var(--eko-green-deep);font-weight:600;margin:14px 0 6px}
.gdpr-policy-modal p{margin-bottom:10px}

/* ===== DARK MODE ===== */
html[data-blog-theme="dark"] {
  --eko-cream-l: #0d1117;
  --eko-cream-section: #161b22;
  --eko-cream: #1c2128;
  --eko-line: #30363d;
  --eko-green: #4ade80;
  --eko-bright: #4ade80;
  --eko-text: #e6edf3;
  --eko-muted: #8b949e;
  --shadow-sm: 0 1px 2px rgba(0,0,0,.3), 0 1px 3px rgba(0,0,0,.4);
  --shadow-md: 0 4px 14px rgba(0,0,0,.4), 0 10px 24px rgba(0,0,0,.4);
  --shadow-lg: 0 12px 32px rgba(0,0,0,.5), 0 24px 56px rgba(0,0,0,.5);
}
html[data-blog-theme="dark"] body { background: #0d1117; color: #c9d1d9; }

/* Headings (from @layer dooh: h1-h4 use var(--eko-green-deep)) */
html[data-blog-theme="dark"] h2,
html[data-blog-theme="dark"] h3,
html[data-blog-theme="dark"] h4 { color: #e6edf3; }
/* Hero h1 stays white — its own rule overrides */

/* Main */
html[data-blog-theme="dark"] main { background: #0d1117; }

/* Nav pills */
html[data-blog-theme="dark"] .nav-pill { color: #c9d1d9; }
html[data-blog-theme="dark"] .nav-pill:hover { background: #1c2128; color: #4FCF74; }
html[data-blog-theme="dark"] .lang-toggle,
html[data-blog-theme="dark"] .curr-toggle { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .lang-toggle button,
html[data-blog-theme="dark"] .curr-toggle button { color: #8b949e; }

/* Categories strip */
html[data-blog-theme="dark"] .cat-strip { border-bottom-color: #30363d; }
html[data-blog-theme="dark"] .cat-pill { background: #1c2128; border-color: #30363d; color: #c9d1d9; }
html[data-blog-theme="dark"] .cat-pill:hover { border-color: var(--eko-green); color: #4FCF74; }

/* Filters bar */
html[data-blog-theme="dark"] .filters-bar { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .filter-input,
html[data-blog-theme="dark"] .filter-select { background: #161b22; border-color: #30363d; color: #c9d1d9; }
html[data-blog-theme="dark"] .filter-input:focus,
html[data-blog-theme="dark"] .filter-select:focus { background: #1c2128; }
html[data-blog-theme="dark"] .filter-clear { border-color: #30363d; color: #8b949e; }

/* View tabs */
html[data-blog-theme="dark"] .view-tabs { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .tab-btn { color: #8b949e; }

/* Gallery cards */
html[data-blog-theme="dark"] .card { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .card-img { background: #161b22; }
html[data-blog-theme="dark"] .card-cat { background: #161b22; }
html[data-blog-theme="dark"] .card-name { color: #e6edf3; }
html[data-blog-theme="dark"] .card-stats { border-top-color: #30363d; }
html[data-blog-theme="dark"] .card-stat-val { color: #e6edf3; }
html[data-blog-theme="dark"] .btn-compare { background: #1c2128; color: #c9d1d9; border-color: #30363d; }

/* Table view */
html[data-blog-theme="dark"] .table-wrap { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .dooh-table th { background: #161b22; border-bottom-color: #30363d; color: #e6edf3; }
html[data-blog-theme="dark"] .dooh-table td { border-bottom-color: #30363d; color: #c9d1d9; }
html[data-blog-theme="dark"] .dooh-table tr:hover { background: #212830; }
html[data-blog-theme="dark"] .t-name { color: #e6edf3; }
html[data-blog-theme="dark"] .t-cat-mini { background: #161b22; }

/* Map sidebar cards */
html[data-blog-theme="dark"] .map-card { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .map-card-name { color: #e6edf3; }

/* Pagination */
html[data-blog-theme="dark"] .pagination button { background: #1c2128; border-color: #30363d; color: #8b949e; }

/* Detail modal */
html[data-blog-theme="dark"] .modal { background: #161b22; }
html[data-blog-theme="dark"] .modal-body { background: #161b22; }
html[data-blog-theme="dark"] .modal-footer { border-top-color: #30363d; background: #161b22; }
html[data-blog-theme="dark"] .detail-name { color: #e6edf3; }
html[data-blog-theme="dark"] .detail-desc { background: #1c2128; }
html[data-blog-theme="dark"] .detail-stat { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .detail-stat-val { color: #e6edf3; }
html[data-blog-theme="dark"] .cart-totals { background: #1c2128; }
html[data-blog-theme="dark"] .cart-item { border-bottom-color: #30363d; }
html[data-blog-theme="dark"] .cart-item-name { color: #e6edf3; }
html[data-blog-theme="dark"] .cart-item img { background: #161b22; }
html[data-blog-theme="dark"] .form-input,
html[data-blog-theme="dark"] .form-textarea { background: #1c2128; border-color: #30363d; color: #c9d1d9; }
html[data-blog-theme="dark"] .form-input:focus,
html[data-blog-theme="dark"] .form-textarea:focus { background: #212830; }
html[data-blog-theme="dark"] .cart-share-btn { background: #1c2128; }

/* Compare modal */
html[data-blog-theme="dark"] .compare-modal { background: #161b22; }
html[data-blog-theme="dark"] .compare-modal-body { background: #161b22; }
html[data-blog-theme="dark"] .compare-table thead th { background: #1c2128; }
html[data-blog-theme="dark"] .compare-table thead th.compare-row-label,
html[data-blog-theme="dark"] .compare-table tbody td.compare-row-label { background: #161b22; border-color: #30363d; }
html[data-blog-theme="dark"] .compare-table tbody td { border-bottom-color: #30363d; }
html[data-blog-theme="dark"] .compare-table tbody td.compare-cell { border-right-color: #30363d; }
html[data-blog-theme="dark"] .compare-table thead th.compare-loc { border-right-color: #30363d; }

/* Wizard modal */
html[data-blog-theme="dark"] .wiz-modal { background: #161b22; }
html[data-blog-theme="dark"] .wiz-progress { background: #1c2128; border-bottom-color: #30363d; }
html[data-blog-theme="dark"] .wiz-step-bar { background: #30363d; }
html[data-blog-theme="dark"] .wiz-body { background: #161b22; }
html[data-blog-theme="dark"] .wiz-input,
html[data-blog-theme="dark"] .wiz-chip { background: #1c2128; border-color: #30363d; color: #c9d1d9; }
html[data-blog-theme="dark"] .wiz-foot { background: #1c2128; border-top-color: #30363d; }
html[data-blog-theme="dark"] .wiz-summary { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .wiz-btn-prev { color: #8b949e; border-color: #30363d; }

/* Autocomplete */
html[data-blog-theme="dark"] .autocomplete-dropdown { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .ac-section { border-bottom-color: #30363d; }
html[data-blog-theme="dark"] .ac-item:hover,
html[data-blog-theme="dark"] .ac-item.focused { background: #212830; }

/* Hover preview */
html[data-blog-theme="dark"] .hover-preview { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .hover-preview-cat { background: #161b22; }
html[data-blog-theme="dark"] .hover-preview-title { color: #e6edf3; }
html[data-blog-theme="dark"] .hover-preview-stats { border-top-color: #30363d; }
html[data-blog-theme="dark"] .hover-preview-price { border-top-color: #30363d; }
html[data-blog-theme="dark"] .hover-preview-stat-val { color: #e6edf3; }

/* Cart progress */
html[data-blog-theme="dark"] .cart-progress { background: linear-gradient(135deg, rgba(31,87,44,.2) 0%, #1c2128 100%); border-color: rgba(31,87,44,.3); }
html[data-blog-theme="dark"] .cart-progress-bar { background: #30363d; border-color: #3d444d; }
html[data-blog-theme="dark"] .cart-progress-marker { background: #1c2128; border-color: #30363d; }

/* Sticky CTA bar */
html[data-blog-theme="dark"] .sticky-cta-bar { background: #161b22; border-top-color: var(--eko-green); }
html[data-blog-theme="dark"] .sticky-cta-divider { background: #30363d; }
html[data-blog-theme="dark"] .sticky-cta-total { color: #e6edf3; }
html[data-blog-theme="dark"] .sticky-cta-close { border-color: #30363d; color: #8b949e; }

/* Exit popup */
html[data-blog-theme="dark"] .exit-popup { background: #161b22; border-color: #30363d; }
html[data-blog-theme="dark"] .exit-popup-head { background: linear-gradient(180deg, rgba(31,87,44,.2) 0%, #161b22 100%); }
html[data-blog-theme="dark"] .exit-popup-close { background: #1c2128; border-color: #30363d; color: #8b949e; }
html[data-blog-theme="dark"] .exit-popup-input { background: #1c2128; border-color: #30363d; color: #c9d1d9; }
html[data-blog-theme="dark"] .exit-popup-eyebrow { background: #1c2128; border-color: rgba(79,207,116,.25); }

/* GDPR */
html[data-blog-theme="dark"] .gdpr-banner { background: #1c2128; border-color: #30363d; }
html[data-blog-theme="dark"] .gdpr-modal { background: #161b22; }
html[data-blog-theme="dark"] .gdpr-modal-head { border-bottom-color: #30363d; }
html[data-blog-theme="dark"] .gdpr-modal-foot { background: #1c2128; border-top-color: #30363d; }
html[data-blog-theme="dark"] .gdpr-btn-settings { background: #1c2128; border-color: #30363d; color: #8b949e; }
html[data-blog-theme="dark"] .gdpr-switch-slider { background: #30363d; }
html[data-blog-theme="dark"] .gdpr-toggle-row { border-bottom-color: #30363d; }

/* Hero gradient fix — restore original dark green (--eko-green is now #4ade80) */
html[data-blog-theme="dark"] .hero {
  background: linear-gradient(135deg, var(--eko-green-deep) 0%, #1F572C 50%, var(--eko-green-mid) 100%);
}
/* Combo box: păstrează culoarea originală verde și în dark mode */
html[data-blog-theme="dark"] .combo-box {
  background: linear-gradient(135deg, #0E2A14 0%, #1F572C 60%, #133A1E 100%) !important;
}

/* Green backgrounds keep #1F572C so white text stays readable */
html[data-blog-theme="dark"] .btn-add,
html[data-blog-theme="dark"] .btn-add:hover,
html[data-blog-theme="dark"] .nav-pill.cta,
html[data-blog-theme="dark"] .cat-pill.active,
html[data-blog-theme="dark"] .tab-btn.active,
html[data-blog-theme="dark"] .pagination button.active,
html[data-blog-theme="dark"] .lang-toggle button.active,
html[data-blog-theme="dark"] .curr-toggle button.active,
html[data-blog-theme="dark"] .wiz-chip.selected,
html[data-blog-theme="dark"] .wiz-btn-next,
html[data-blog-theme="dark"] .gdpr-btn-accept,
html[data-blog-theme="dark"] .compare-modal-head,
html[data-blog-theme="dark"] .sticky-cta-btn { background-color: #1F572C !important; border-color: #1F572C !important; }

/* ===== DARK MODE — INLINE SECTION OVERRIDES ===== */

/* dooh-sp-chapters: styles are in an inline <style> tag, need !important to win */
html[data-blog-theme="dark"] .dooh-sp-chapters { background: #161b22 !important; }
html[data-blog-theme="dark"] .dooh-sp-eyebrow { color: #8b949e !important; }
html[data-blog-theme="dark"] .dooh-sp-heading { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .dooh-sp-num { color: #6e7681 !important; }
html[data-blog-theme="dark"] .dooh-sp-btn[aria-current="true"] .dooh-sp-num { color: #4ade80 !important; }
html[data-blog-theme="dark"] .dooh-sp-lbl { color: #8b949e !important; }
html[data-blog-theme="dark"] .dooh-sp-btn[aria-current="true"] .dooh-sp-lbl { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .dooh-sp-arrow { color: #6e7681 !important; }
html[data-blog-theme="dark"] .dooh-sp-btn:hover { background: rgba(74,222,128,.08) !important; }
html[data-blog-theme="dark"] .dooh-sp-btn[aria-current="true"] { background: rgba(74,222,128,.12) !important; }
html[data-blog-theme="dark"] .dooh-sp-panel { background: rgba(22,27,34,.96) !important; border-color: #30363d !important; box-shadow: none !important; }
html[data-blog-theme="dark"] .dooh-sp-panel-title { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .dooh-sp-point-title { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .dooh-sp-point-desc { color: #8b949e !important; }

/* Step cards & boxes with inline background: var(--eko-white) inside #cum-functioneaza */
html[data-blog-theme="dark"] #cum-functioneaza div[style*="background: var(--eko-white)"] { background: #1c2128 !important; border-color: #30363d !important; }

/* h3 with inline color: var(--eko-green-deep) — invisible on dark background */
html[data-blog-theme="dark"] #cum-functioneaza h3 { color: #e6edf3 !important; }

/* Positioning block (anvergura) background uses --eko-cream-section/--eko-cream-l — already OK via variables */

/* Brief modal (inline style background:#fff) */
html[data-blog-theme="dark"] #briefModal { background: #161b22 !important; border-color: #30363d !important; }
html[data-blog-theme="dark"] #briefModal h3,
html[data-blog-theme="dark"] #briefModal h4 { color: #e6edf3 !important; }
html[data-blog-theme="dark"] #briefModal input,
html[data-blog-theme="dark"] #briefModal textarea,
html[data-blog-theme="dark"] #briefModal select { background: #1c2128 !important; border-color: #30363d !important; color: #c9d1d9 !important; }
html[data-blog-theme="dark"] #briefModal label { color: #8b949e !important; }

/* ServicesGrid at bottom — scoped Astro styles, override via global selectors */
html[data-blog-theme="dark"] .sg-section { background: #0d1117 !important; }
html[data-blog-theme="dark"] .sg-card { background: #1c2128 !important; border-color: #30363d !important; }
html[data-blog-theme="dark"] .sg-card-title { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .sg-card-desc { color: #8b949e !important; }
html[data-blog-theme="dark"] .sg-price { color: #c9d1d9 !important; }
html[data-blog-theme="dark"] .sg-price strong { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .sg-cta-strip { background: #1c2128 !important; border-color: #30363d !important; }
html[data-blog-theme="dark"] .sg-cta-text { color: #8b949e !important; }
html[data-blog-theme="dark"] .sg-cta-text strong { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .sg-title { color: #e6edf3 !important; }
html[data-blog-theme="dark"] .sg-card--current { background: #1a2820 !important; border-color: #4ade80 !important; }

/* ===== PRINT-FRIENDLY CSS — DOOH ===== */
#print-pachet-dooh-root { display: none; }
.print-header-dooh { display: none; }

@media print {
  * { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }
  html, body {
    background: #fff !important;
    color: #000 !important;
    font-size: 11pt;
    line-height: 1.45;
  }
  body { margin: 0; padding: 0; }
  /* Hide everything */
  header, footer, main, .modal-overlay, .modal, #cart-fab, #wa-fab,
  .wa-tooltip, .filter-bar, .stats-grid, .hero, .map-container,
  #ogPreviewModalDooh, .gdpr-bar, .gdpr-modal, #cookieBanner,
  section, nav, button#cart-fab, button#wa-fab, .recommended-banner {
    display: none !important;
  }
  body > *:not(#print-pachet-dooh-root):not(script):not(style):not(link) { display: none !important; }
  #print-pachet-dooh-root {
    display: block !important;
    padding: 0;
    margin: 0;
  }
  .print-header-dooh {
    display: block !important;
    text-align: center;
    border-bottom: 3px solid #1F572C;
    padding: 0 0 16pt;
    margin-bottom: 18pt;
    page-break-inside: avoid;
  }
  .print-header-dooh img {
    height: 60pt !important;
    width: auto;
    display: inline-block;
    margin-bottom: 10pt;
  }
  .print-header-dooh h1 {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 22pt;
    font-weight: 700;
    color: #1F572C !important;
    margin-bottom: 6pt;
    letter-spacing: -0.01em;
  }
  .print-header-dooh .subtitle {
    font-size: 10pt;
    color: #6B7A6F !important;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 600;
  }
  .print-meta-dooh {
    display: flex;
    justify-content: space-between;
    margin-top: 8pt;
    padding-top: 8pt;
    border-top: 1px solid #e8ede9;
    font-size: 9pt;
    color: #6B7A6F !important;
  }
  .print-sites-grid-dooh {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    gap: 8pt;
    margin: 12pt 0;
  }
  .print-loc-card {
    border: 1px solid #d0d5d0;
    border-radius: 4pt;
    padding: 8pt 10pt;
    background: #fff;
    page-break-inside: avoid;
    break-inside: avoid;
    display: flex;
    flex-direction: column;
    gap: 4pt;
  }
  .print-loc-card .cat {
    font-size: 8pt;
    color: #6B7A6F !important;
    text-transform: uppercase;
    letter-spacing: .1em;
    font-weight: 700;
  }
  .print-loc-card .name {
    font-weight: 800;
    font-size: 11pt;
    color: #1F572C !important;
  }
  .print-loc-card .meta {
    display: flex;
    gap: 10pt;
    font-size: 9pt;
    color: #555 !important;
    flex-wrap: wrap;
  }
  .print-loc-card .price {
    font-weight: 800;
    color: #1F572C !important;
    font-size: 11pt;
    margin-top: 3pt;
  }
  .print-totals-dooh {
    margin-top: 16pt;
    padding: 14pt 16pt;
    background: #F4F6F2 !important;
    border: 2px solid #1F572C !important;
    border-radius: 4pt;
    page-break-inside: avoid;
  }
  .print-totals-dooh h3 {
    font-family: 'Playfair Display', Georgia, serif;
    font-size: 14pt;
    color: #1F572C !important;
    margin-bottom: 8pt;
    font-weight: 700;
  }
  .print-totals-dooh .row {
    display: flex;
    justify-content: space-between;
    padding: 4pt 0;
    font-size: 10pt;
    color: #000 !important;
    border-bottom: 1px solid #e8ede9;
  }
  .print-totals-dooh .row.grand {
    font-size: 13pt;
    font-weight: 800;
    color: #1F572C !important;
    border-top: 2px solid #1F572C;
    border-bottom: none;
    margin-top: 6pt;
    padding-top: 8pt;
  }
  .print-totals-dooh .row.grand b {
    color: #1F572C !important;
    font-size: 18pt;
    font-family: 'Playfair Display', Georgia, serif;
  }
  .print-footer-dooh {
    margin-top: 28pt;
    padding-top: 14pt;
    border-top: 2px solid #1F572C;
    text-align: center;
    page-break-inside: avoid;
  }
  .print-footer-dooh .tagline {
    font-family: 'Playfair Display', Georgia, serif;
    font-style: italic;
    font-size: 13pt;
    color: #1F572C !important;
    margin-bottom: 8pt;
    font-weight: 600;
  }
  .print-footer-dooh .contact {
    font-size: 10pt;
    color: #000 !important;
    line-height: 1.5;
  }
  .print-footer-dooh .contact a, .print-footer-dooh .contact strong {
    color: #1F572C !important;
    font-weight: 700;
  }
  @page {
    size: A4 portrait;
    margin: 14mm 14mm 14mm 14mm;
  }
}

/* ===== SEO BLOCKS GRID ===== */
.dooh-seo-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 48px 64px; }
@media (max-width: 768px) { .dooh-seo-grid { grid-template-columns: 1fr; gap: 2rem; } }

