/* ── Hero ─────────────────────────────── */
.comp-hero { background:var(--dark); color:#fff; padding:72px 0 56px; position:relative; overflow:hidden; }
.comp-hero::before { content:''; position:absolute; inset:0;
  background: radial-gradient(ellipse 60% 60% at 80% 30%,rgba(108,43,217,.35) 0%,transparent 70%),
              radial-gradient(ellipse 40% 40% at 20% 80%,rgba(192,38,211,.25) 0%,transparent 60%); }
.comp-hero-inner { position:relative; z-index:1; display:flex; align-items:center; justify-content:space-between; gap:40px; }
.comp-hero-text .hero-tag { margin-bottom:16px; }
.comp-hero-text h1 { font-size:clamp(2rem,5vw,3rem); font-weight:900; margin-bottom:12px; }
.comp-hero-text h1 span { background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.comp-hero-text p { color:rgba(255,255,255,.7); font-size:1.05rem; max-width:750px; }
.comp-hero-stats { display:flex; gap:28px; margin-top:32px; }
.comp-hero-stat { text-align:center; }
.comp-hero-stat strong { display:block; font-size:1.8rem; font-weight:900; background:var(--grad); -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text; }
.comp-hero-stat span { font-size:.75rem; color:rgba(255,255,255,.55); text-transform:uppercase; letter-spacing:.06em; }
.hero-merchants { display:flex; flex-direction:column; gap:10px; flex-shrink:0; }
.merchant-badge { display:flex; align-items:center; gap:10px; background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.12); border-radius:10px; padding:8px 14px; font-size:.82rem; color:rgba(255,255,255,.85); white-space:nowrap; }
.merchant-dot { width:10px; height:10px; border-radius:50%; flex-shrink:0; }

/* ── Barre principale — Design 3 (2 lignes catégorisées) ── */
.comp-filters-wrap { background:#fff; border-bottom:1px solid var(--surface); position:sticky; top:60px; z-index:90; box-shadow:0 2px 12px rgba(0,0,0,.06); }

/* Ligne 1 : technologie + budget + actions */
.comp-filters-row1 { display:flex; align-items:center; gap:0; padding:9px 0; border-bottom:1px solid rgba(108,43,217,.08); overflow-x:auto; scrollbar-width:none; }
.comp-filters-row1::-webkit-scrollbar { display:none; }

/* Ligne 2 : filtres secondaires */
.comp-filters-row2 { display:flex; align-items:center; gap:0; padding:7px 0; background:#fbfaff; overflow-x:auto; scrollbar-width:none; }
.comp-filters-row2::-webkit-scrollbar { display:none; }

/* Groupe labelisé */
.fg { display:flex; align-items:center; gap:7px; padding-right:16px; margin-right:16px; border-right:1.5px solid var(--surface); flex-shrink:0; }
.fg:last-child, .fg.fg-end { border-right:none; padding-right:0; margin-right:0; margin-left:auto; }
.fg-label { font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-3); white-space:nowrap; flex-shrink:0; }

.filter-group { display:flex; gap:4px; flex-shrink:0; }
.filter-chip { padding:5px 12px; border-radius:20px; border:1.5px solid var(--surface); background:#fff; color:var(--ink-2); font-size:.78rem; font-weight:500; cursor:pointer; transition:all .18s; white-space:nowrap; text-decoration:none; display:inline-block; }
.filter-chip:hover { border-color:var(--p1); color:var(--p1); }
.filter-chip.active { background:var(--p1); border-color:var(--p1); color:#fff; }
.filter-sep { width:1px; background:var(--surface); margin:0 4px; flex-shrink:0; align-self:stretch; }
.filter-select { padding:5px 26px 5px 10px; border-radius:20px; border:1.5px solid var(--surface); background:#fff url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b6888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 8px center; color:var(--ink-2); font-size:.78rem; font-weight:500; cursor:pointer; flex-shrink:0; appearance:none; }
.filter-select.has-value { border-color:var(--p1); color:var(--p1); background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236c2bd9' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.filter-results { font-size:.78rem; color:var(--ink-3); white-space:nowrap; flex-shrink:0; font-weight:600; }

/* Bouton filtres avancés */
.btn-adv-filters { padding:5px 12px; border-radius:20px; border:1.5px solid var(--p1); background:#fff; color:var(--p1); font-size:.78rem; font-weight:600; cursor:pointer; display:inline-flex; align-items:center; gap:6px; white-space:nowrap; flex-shrink:0; transition:all .15s; }
.btn-adv-filters:hover, .btn-adv-filters.open { background:#ede9fe; }
.btn-adv-filters.has-active { background:#ede9fe; }
.adv-badge { display:inline-flex; align-items:center; justify-content:center; min-width:18px; height:18px; padding:0 4px; background:var(--p1); color:#fff; border-radius:9px; font-size:.65rem; font-weight:800; }

/* ── Chips filtres actifs ─────────────── */
.active-chips-wrap { background:#faf9ff; border-bottom:1px solid rgba(108,43,217,.08); }
.active-chips { display:flex; align-items:center; gap:6px; padding:7px 0; flex-wrap:wrap; }
.active-chip { display:inline-flex; align-items:center; gap:5px; padding:4px 10px; border-radius:20px; background:#ede9fe; color:var(--p1); font-size:.75rem; font-weight:600; text-decoration:none; border:1.5px solid rgba(108,43,217,.2); transition:all .15s; white-space:nowrap; }
.active-chip:hover { background:#ddd6fe; border-color:rgba(108,43,217,.4); }
.active-chip .cx { opacity:.6; font-size:.9rem; line-height:1; }
.chips-reset { font-size:.75rem; color:var(--ink-3); text-decoration:none; padding:4px 10px; border-radius:20px; border:1.5px solid var(--surface); margin-left:4px; white-space:nowrap; transition:all .15s; }
.chips-reset:hover { color:var(--p1); border-color:var(--p1); }

/* ── Drawer avancé ────────────────────── */
.comp-filters-drawer { background:#fff; border-bottom:2px solid rgba(108,43,217,.1); box-shadow:0 8px 32px rgba(0,0,0,.1); display:none; position:sticky; top:calc(60px + 90px); z-index:88; }
.comp-filters-drawer.open { display:block; }
.drawer-inner { display:grid; grid-template-columns:repeat(5,1fr); gap:0; padding:20px 0 16px; border-bottom:1px solid var(--surface); }
.drawer-section { padding:0 20px 0 0; border-right:1px solid var(--surface); }
.drawer-section:last-child { border-right:none; padding-right:0; }
.drawer-section h4 { font-size:.68rem; font-weight:800; text-transform:uppercase; letter-spacing:.08em; color:var(--ink-3); margin:0 0 10px; padding-bottom:6px; border-bottom:1.5px solid var(--surface); }
.drawer-check { display:flex; align-items:center; gap:7px; margin-bottom:6px; cursor:pointer; font-size:.8rem; color:var(--ink); line-height:1.3; }
.drawer-check input[type=checkbox] { width:14px; height:14px; accent-color:var(--p1); cursor:pointer; flex-shrink:0; }
.drawer-select { width:100%; padding:5px 8px; border-radius:8px; border:1.5px solid var(--surface); font-size:.78rem; color:var(--ink); margin-bottom:8px; background:#fff; }
.drawer-select.has-value { border-color:var(--p1); color:var(--p1); }
.drawer-footer { display:flex; align-items:center; justify-content:flex-end; gap:10px; padding:12px 0; }
.btn-drawer-reset { font-size:.8rem; color:var(--ink-3); text-decoration:none; padding:7px 14px; border-radius:9px; border:1.5px solid var(--surface); transition:all .15s; }
.btn-drawer-reset:hover { color:var(--p1); border-color:var(--p1); }
.btn-drawer-apply { background:var(--grad); color:#fff; padding:8px 20px; border-radius:9px; border:none; font-size:.85rem; font-weight:700; cursor:pointer; transition:opacity .15s; }
.btn-drawer-apply:hover { opacity:.9; }

/* ── Grid ─────────────────────────────── */
.comp-section { padding:32px 0 80px; }
.comp-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }

/* ── D10 : Hero TV Card ────────────────────── */
.hero-tv-wrap { margin-bottom:24px; }
.hero-tv-card { background:#fff; border:1.5px solid var(--surface); border-radius:16px; overflow:hidden; display:flex; min-height:190px; transition:box-shadow .22s; position:relative; }
.hero-tv-card:hover { box-shadow:0 12px 40px rgba(108,43,217,.13); }
.hero-tv-accent { width:5px; flex-shrink:0; }
.hero-tv-img-link { width:210px; flex-shrink:0; background:#f5f4fb; display:flex; align-items:center; justify-content:center; overflow:hidden; text-decoration:none; }
.hero-tv-img-link img { max-height:165px; max-width:90%; object-fit:contain; transition:transform .3s; }
.hero-tv-card:hover .hero-tv-img-link img { transform:scale(1.04); }
.hero-tv-info { flex:1; padding:20px 24px; display:flex; flex-direction:column; justify-content:center; gap:8px; min-width:0; }
.hero-tv-top { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.hero-tv-tech { padding:4px 12px; border-radius:20px; font-size:.72rem; font-weight:900; letter-spacing:.04em; text-transform:uppercase; color:#fff; }
.hero-tv-badge { background:#dcfce7; color:#059669; padding:4px 10px; border-radius:20px; font-size:.68rem; font-weight:700; }
.hero-tv-brand { font-size:.7rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--ink-3); }
.hero-tv-name { font-size:1.1rem; font-weight:800; color:var(--ink); line-height:1.25; text-decoration:none; transition:color .15s; display:block; }
.hero-tv-name:hover { color:var(--p1); }
.hero-tv-specs { display:flex; flex-wrap:wrap; gap:5px; }
.hero-tv-price-section { width:195px; flex-shrink:0; border-left:1px solid var(--surface); display:flex; flex-direction:column; align-items:center; justify-content:center; gap:10px; padding:20px 16px; background:#fafaff; }
.hero-tv-price { font-size:2rem; font-weight:900; color:var(--p1); line-height:1; }
.hero-tv-at { font-size:.7rem; color:var(--ink-3); text-align:center; }
.hero-tv-cta { width:100%; }
.hero-tv-cta .btn-see-price { border-radius:10px; padding:10px; font-size:.82rem; }
.hero-tv-fiche { font-size:.72rem; color:var(--ink-3); text-align:center; text-decoration:none; transition:color .15s; display:block; }
.hero-tv-fiche:hover { color:var(--p1); }

/* ── D10 : liseré gauche coloré par tech ──── */
.tv-card-accent { position:absolute; left:0; top:0; bottom:0; width:4px; z-index:1; }
.tech-accent-oled    { background:linear-gradient(180deg,#7c3aed,#a855f7); }
.tech-accent-miniled { background:linear-gradient(180deg,#d97706,#f59e0b); }
.tech-accent-qled    { background:linear-gradient(180deg,#0284c7,#38bdf8); }
.tech-accent-led     { background:linear-gradient(180deg,#059669,#34d399); }

/* ── D10 : tech tag coloré dans le body ────── */
.tv-card-tech-tag { font-size:.6rem; font-weight:900; text-transform:uppercase; letter-spacing:.06em; display:block; margin-bottom:2px; }
.tech-tag-oled    { color:#7c3aed; }
.tech-tag-miniled { color:#d97706; }
.tech-tag-qled    { color:#0284c7; }
.tech-tag-led     { color:#059669; }

/* ── D10 : filter chips colorés par tech ───── */
.filter-chip.fc-oled:not(.active)    { border-color:rgba(124,58,237,.35); color:#7c3aed; }
.filter-chip.fc-oled.active          { background:#7c3aed; border-color:#7c3aed; color:#fff; }
.filter-chip.fc-miniled:not(.active) { border-color:rgba(217,119,6,.35);  color:#d97706; }
.filter-chip.fc-miniled.active       { background:#d97706; border-color:#d97706; color:#fff; }
.filter-chip.fc-qled:not(.active)    { border-color:rgba(2,132,199,.35);  color:#0284c7; }
.filter-chip.fc-qled.active          { background:#0284c7; border-color:#0284c7; color:#fff; }
.filter-chip.fc-led:not(.active)     { border-color:rgba(5,150,105,.35);  color:#059669; }
.filter-chip.fc-led.active           { background:#059669; border-color:#059669; color:#fff; }

/* ── Card ─────────────────────────────── */
.tv-card { background:#fff; border:1.5px solid var(--surface); border-radius:16px; overflow:hidden; transition:transform .2s,box-shadow .2s,border-color .2s; display:flex; flex-direction:column; position:relative; }
.tv-card:hover { transform:translateY(-4px); box-shadow:0 12px 32px rgba(108,43,217,.12); border-color:rgba(108,43,217,.25); }
.tv-card.selected { border-color:var(--p1); box-shadow:0 0 0 3px rgba(108,43,217,.15); }
.tv-card-img { height:150px; background:#f5f4fb; display:flex; align-items:center; justify-content:center; overflow:hidden; position:relative; }
.tv-card-img img { max-height:130px; max-width:88%; object-fit:contain; transition:transform .3s; }
.tv-card:hover .tv-card-img img { transform:scale(1.04); }
.tv-card-img .no-img { font-size:3rem; opacity:.15; }
/* ── M7 : badge glassmorphism sur image ── */
.tv-card-tech { position:absolute; top:9px; left:9px; padding:4px 10px; border-radius:20px; font-size:.64rem; font-weight:800; letter-spacing:.04em; display:flex; align-items:center; gap:5px; backdrop-filter:blur(8px); -webkit-backdrop-filter:blur(8px); }
.tc-dot { width:6px; height:6px; border-radius:50%; flex-shrink:0; display:inline-block; }
.tech-oled    { background:rgba(124,58,237,.13); border:1.5px solid rgba(124,58,237,.38); color:#7c3aed; }
.tech-oled    .tc-dot { background:#7c3aed; }
.tech-miniled { background:rgba(217,119,6,.13);  border:1.5px solid rgba(217,119,6,.38);  color:#d97706; }
.tech-miniled .tc-dot { background:#d97706; }
.tech-qled    { background:rgba(2,132,199,.13);  border:1.5px solid rgba(2,132,199,.38);  color:#0284c7; }
.tech-qled    .tc-dot { background:#0284c7; }
.tech-led     { background:rgba(5,150,105,.13);  border:1.5px solid rgba(5,150,105,.38);  color:#059669; }
.tech-led     .tc-dot { background:#059669; }
/* ── M6 : séparateur coloré sous la photo ── */
.img-tech-sep { height:3px; flex-shrink:0; }
.sep-oled    { background:linear-gradient(90deg,#7c3aed,#a855f7); }
.sep-miniled { background:linear-gradient(90deg,#d97706,#f59e0b); }
.sep-qled    { background:linear-gradient(90deg,#0284c7,#38bdf8); }
.sep-led     { background:linear-gradient(90deg,#059669,#34d399); }
.tv-card-select { position:absolute; top:8px; right:8px; width:24px; height:24px; border-radius:50%; border:2px solid rgba(108,43,217,.3); background:#fff; display:flex; align-items:center; justify-content:center; cursor:pointer; transition:all .18s; }
.tv-card-select:hover { border-color:var(--p1); }
.tv-card-select svg { display:none; }
.tv-card.selected .tv-card-select { background:var(--p1); border-color:var(--p1); }
.tv-card.selected .tv-card-select svg { display:block; }
.tv-card-body { padding:12px 14px 14px; flex:1; display:flex; flex-direction:column; }
.tv-card-brand { font-size:.68rem; font-weight:700; color:var(--p1); text-transform:uppercase; letter-spacing:.06em; margin-bottom:3px; }
.tv-card-specs { display:flex; flex-wrap:wrap; gap:4px; margin-bottom:10px; }
.spec-badge { display:inline-flex; align-items:center; gap:3px; padding:2px 7px; border-radius:6px; font-size:.65rem; font-weight:600; background:var(--surface); color:var(--ink-2); white-space:nowrap; }
.spec-badge.highlight { background:#ede9fe; color:#6c2bd9; }
.spec-badge.gaming   { background:#fef3c7; color:#92400e; }
.spec-badge.hdr      { background:#1c1c2e; color:#c9b8ff; }
.spec-badge.audio    { background:#ecfdf5; color:#065f46; }
.tv-card-prices { margin-top:auto; }
.tv-card-best-price { display:flex; align-items:baseline; gap:6px; margin-bottom:7px; flex-wrap:nowrap; overflow:hidden; }
.tv-card-price-val { font-size:1.4rem; font-weight:900; color:var(--p1); white-space:nowrap; flex-shrink:0; }
.tv-card-price-at  { font-size:.72rem; color:var(--ink-3); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; min-width:0; }
.mkt-suffix { font-size:.75em; font-style:italic; font-weight:400; }
.tv-card-cta { display:flex; gap:7px; }
.btn-see-price { flex:1; display:block; text-align:center; background:var(--grad); color:#fff; padding:8px 10px; border-radius:9px; font-size:.8rem; font-weight:600; text-decoration:none; transition:opacity .18s,transform .15s; }
.btn-see-price:hover { opacity:.9; transform:translateY(-1px); }
.btn-add-compare { padding:8px 10px; border-radius:9px; border:1.5px solid var(--surface); background:#fff; color:var(--ink-2); font-size:.8rem; cursor:pointer; transition:all .18s; display:flex; align-items:center; justify-content:center; }
.btn-add-compare:hover { border-color:var(--p1); color:var(--p1); }
.tv-card.selected .btn-add-compare { background:#f0eeff; border-color:var(--p1); color:var(--p1); }
@media (max-width:768px) { .btn-add-compare { display:none !important; } }
.tv-card-img-link { display:block; text-decoration:none; }
.tv-card-name { text-decoration:none; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; font-size:.84rem; font-weight:600; color:var(--ink); line-height:1.35; margin-bottom:8px; transition:color .15s; }
.tv-card-name:hover { color:var(--p1); }
.btn-fiche { padding:8px 10px; border-radius:9px; border:1.5px solid var(--surface); background:#fff; color:var(--ink-2); font-size:.8rem; cursor:pointer; transition:all .18s; display:flex; align-items:center; justify-content:center; text-decoration:none; }
.btn-fiche:hover { border-color:var(--p1); color:var(--p1); }
.price-drawer { display:none; background:#f5f4fb; border-top:1px solid rgba(108,43,217,.1); padding:10px 14px; }
.tv-card.open .price-drawer { display:block; }
.price-row { display:flex; align-items:center; justify-content:space-between; padding:5px 0; border-bottom:1px solid rgba(108,43,217,.06); }
.price-row:last-child { border-bottom:none; }
.price-row-merchant { display:flex; align-items:center; gap:6px; font-size:.78rem; font-weight:600; color:var(--ink); }
.price-row-val { font-size:.88rem; font-weight:700; }
.price-row-link { font-size:.7rem; font-weight:600; color:var(--p1); text-decoration:none; }
.price-row-link:hover { text-decoration:underline; }

/* ── Compare bar ──────────────────────── */
.compare-bar { position:fixed; bottom:0; left:0; right:0; background:var(--dark); border-top:2px solid rgba(108,43,217,.4); padding:10px 0; z-index:200; transform:translateY(100%); transition:transform .3s cubic-bezier(.22,1,.36,1); }
.compare-bar.visible { transform:translateY(0); }
.compare-bar-inner { display:flex; align-items:center; gap:14px; }
.compare-slots { display:flex; gap:8px; flex:1; }
.compare-slot { flex:1; max-width:180px; background:rgba(255,255,255,.08); border:1.5px dashed rgba(255,255,255,.2); border-radius:9px; padding:7px 10px; display:flex; align-items:center; gap:7px; min-height:48px; }
.compare-slot.filled { border-style:solid; border-color:rgba(108,43,217,.6); background:rgba(108,43,217,.15); }
.compare-slot-name { font-size:.72rem; font-weight:600; color:#fff; line-height:1.3; flex:1; }
.compare-slot-empty { font-size:.72rem; color:rgba(255,255,255,.35); }
.compare-slot-remove { cursor:pointer; color:rgba(255,255,255,.5); font-size:1rem; line-height:1; }
.compare-slot-remove:hover { color:#fff; }
.btn-compare-now { background:var(--grad); color:#fff; padding:9px 18px; border-radius:9px; font-size:.83rem; font-weight:700; border:none; cursor:pointer; white-space:nowrap; transition:opacity .18s; }
.btn-compare-now:hover { opacity:.9; }
.btn-compare-now:disabled { opacity:.4; cursor:default; }
.compare-bar-hint { font-size:.72rem; color:rgba(255,255,255,.4); white-space:nowrap; }

/* ── Compare modal ────────────────────── */
.compare-modal-overlay { display:none; position:fixed; inset:0; background:rgba(13,13,20,.8); z-index:300; align-items:flex-start; justify-content:center; padding:32px 16px; overflow-y:auto; }
.compare-modal-overlay.open { display:flex; }
.compare-modal { background:#fff; border-radius:20px; width:100%; max-width:960px; position:relative; overflow:hidden; }
.compare-modal-close { position:absolute; top:14px; right:14px; width:32px; height:32px; border-radius:50%; background:var(--surface); border:none; cursor:pointer; font-size:1.1rem; color:var(--ink-2); display:flex; align-items:center; justify-content:center; z-index:1; }
.compare-modal-close:hover { background:#e5e2f5; }
.cmp-products-header { display:grid; gap:0; border-bottom:2px solid var(--surface); }
.cmp-header-row { display:flex; }
.cmp-label-col { width:170px; flex-shrink:0; padding:16px; background:var(--surface); font-weight:700; font-size:.82rem; color:var(--ink); display:flex; align-items:center; border-right:1px solid #e5e2f5; }
.cmp-prod-col { flex:1; padding:14px 12px; text-align:center; border-right:1px solid var(--surface); min-width:0; }
.cmp-prod-col:last-child { border-right:none; }
.cmp-prod-col img { max-height:70px; max-width:110px; object-fit:contain; display:block; margin:0 auto 6px; }
.cmp-prod-brand { font-size:.68rem; font-weight:700; color:var(--p1); text-transform:uppercase; }
.cmp-prod-name { font-size:.75rem; font-weight:600; line-height:1.3; margin-top:3px; }
.cmp-prod-price { font-size:1.1rem; font-weight:900; color:var(--p1); margin-top:6px; }
.cmp-prod-merchant { font-size:.68rem; color:var(--ink-3); }
.cmp-section-title { background:var(--dark); color:#fff; padding:8px 16px; font-size:.75rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; display:flex; align-items:center; gap:8px; }
.cmp-row { display:flex; border-bottom:1px solid var(--surface); }
.cmp-row:last-child { border-bottom:none; }
.cmp-row:hover { background:#fafafa; }
.cmp-lbl { width:170px; flex-shrink:0; padding:9px 16px; font-size:.78rem; font-weight:600; color:var(--ink-2); border-right:1px solid var(--surface); display:flex; align-items:center; }
.cmp-val { flex:1; padding:9px 12px; font-size:.8rem; color:var(--ink); border-right:1px solid var(--surface); display:flex; align-items:center; justify-content:center; text-align:center; min-width:0; }
.cmp-val:last-child { border-right:none; }
.cmp-val.best { color:#059669; font-weight:700; }
.cmp-val.na { color:var(--ink-3); }
.cmp-check { color:#059669; font-size:1rem; }
.cmp-cross { color:#dc2626; font-size:.9rem; }
.cmp-neutral { color:var(--ink-3); }
.cmp-merchant-row { display:flex; border-bottom:1px solid var(--surface); }
.cmp-merchant-lbl { width:170px; flex-shrink:0; padding:8px 16px; display:flex; align-items:center; gap:7px; font-size:.78rem; font-weight:600; border-right:1px solid var(--surface); }
.cmp-merchant-val { flex:1; padding:8px 12px; font-size:.85rem; font-weight:700; border-right:1px solid var(--surface); display:flex; align-items:center; justify-content:center; gap:8px; min-width:0; }
.cmp-merchant-val:last-child { border-right:none; }
.cmp-merchant-val.best-price { color:#059669; }
.btn-go { display:inline-block; padding:4px 10px; border-radius:6px; background:var(--grad); color:#fff; font-size:.7rem; font-weight:600; text-decoration:none; white-space:nowrap; }

/* ── Energy badge ─────────────────────── */
.energy-badge { display:inline-flex; align-items:center; justify-content:center; width:22px; height:22px; border-radius:4px; font-size:.7rem; font-weight:800; color:#fff; }
.energy-A { background:#00a550; } .energy-B { background:#52b920; }
.energy-C { background:#b0d136; color:#333; } .energy-D { background:#fff200; color:#333; }
.energy-E { background:#ffb800; color:#333; } .energy-F { background:#f7751b; }
.energy-G { background:#e02020; }

/* ── Budget range inline ──────────────────── */
.budget-popup-btn { padding:5px 12px; border-radius:20px; border:1.5px solid var(--surface); background:#fff; color:var(--ink-2); font-size:.78rem; font-weight:500; cursor:pointer; white-space:nowrap; display:flex; align-items:center; gap:6px; line-height:1.5; flex-shrink:0; }
.budget-popup-btn.active { border-color:var(--p1); color:var(--p1); }
.budget-inline-panel { display:none; align-items:center; gap:7px; }
.budget-inline-panel.open { display:flex; }
.bp-input-wrap { display:flex; align-items:center; border:1.5px solid var(--surface); border-radius:9px; overflow:hidden; background:#fff; transition:border-color .18s; flex-shrink:0; }
.bp-input-wrap:focus-within { border-color:var(--p1); }
.bp-input-wrap input[type=number] { border:none; outline:none; padding:5px 6px; font-size:.82rem; font-weight:700; color:var(--ink); width:58px; background:transparent; -moz-appearance:textfield; text-align:right; }
.bp-input-wrap input[type=number]::-webkit-inner-spin-button,
.bp-input-wrap input[type=number]::-webkit-outer-spin-button { -webkit-appearance:none; margin:0; }
.bp-input-wrap .bp-currency { font-size:.75rem; font-weight:600; color:var(--ink-2); padding-right:7px; white-space:nowrap; }
.bp-sep { color:var(--ink-2); font-size:.9rem; font-weight:300; flex-shrink:0; }
.dual-range { position:relative; height:28px; margin-bottom:2px; }
.dual-range-track { position:absolute; top:50%; left:0; right:0; height:4px; background:var(--surface); transform:translateY(-50%); border-radius:2px; }
.dual-range-fill { position:absolute; top:0; height:100%; background:var(--p1); border-radius:2px; }
.dual-range input[type=range] { position:absolute; width:100%; background:transparent; pointer-events:none; appearance:none; -webkit-appearance:none; margin:0; top:50%; transform:translateY(-50%); height:4px; }
.dual-range input[type=range]::-webkit-slider-thumb { pointer-events:all; width:18px; height:18px; border-radius:50%; background:var(--p1); border:2.5px solid #fff; box-shadow:0 1px 5px rgba(108,43,217,.35); appearance:none; -webkit-appearance:none; cursor:pointer; }
.dual-range input[type=range]::-moz-range-thumb { pointer-events:all; width:14px; height:14px; border-radius:50%; background:var(--p1); border:2px solid #fff; box-shadow:0 1px 4px rgba(108,43,217,.3); cursor:pointer; }

/* ── No results ───────────────────────── */
.no-results-msg { text-align:center; padding:60px 20px; color:var(--ink-3); }
.no-results-msg .ico { font-size:3rem; margin-bottom:16px; }
.no-results-msg strong { font-size:1.1rem; font-weight:600; color:var(--ink); display:block; margin-bottom:8px; }

/* ── Responsive ───────────────────────── */
@media (max-width:1100px) {
  .comp-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
  .drawer-inner { grid-template-columns:repeat(3,1fr); }
  .fg { padding-right:12px; margin-right:12px; }
  .hero-tv-price-section { width:160px; }
  .hero-tv-info { padding:16px 18px; }
}
@media (max-width:900px) {
  .comp-filters-row2 .fg-label { display:none; }
  .fg { padding-right:10px; margin-right:10px; }
}
@media (max-width:768px) {
  .comp-hero-inner { flex-direction:column; }
  .hero-merchants { flex-direction:row; flex-wrap:wrap; }
  .comp-hero-stats { gap:16px; }
  .comp-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .compare-slots { display:none; }
  .cmp-label-col,.cmp-lbl,.cmp-merchant-lbl { width:100px; }
  .drawer-inner { grid-template-columns:repeat(2,1fr); }
  .comp-filters-row1 .fg-label { display:none; }
  .comp-filters-drawer { top:calc(60px + 80px); }
  .hero-tv-card { flex-wrap:wrap; }
  .hero-tv-img-link { width:100%; height:160px; }
  .hero-tv-price-section { width:100%; border-left:none; border-top:1px solid var(--surface); flex-direction:row; gap:12px; padding:14px 16px; background:#fafaff; }
  .hero-tv-cta { flex:1; }
}
@media (max-width:480px) {
  .comp-grid { grid-template-columns:1fr 1fr; gap:10px; }
  .drawer-inner { grid-template-columns:1fr 1fr; }
}

/* ═══ D6 LAYOUT — Sidebar filtres ═════════════ */
.d6-layout { display:grid; grid-template-columns:260px 1fr; gap:24px; align-items:start; }
.d6-sidebar { position:sticky; top:80px; background:#fff; border:1.5px solid var(--surface); border-radius:16px; overflow:hidden; max-height:calc(100vh - 100px); overflow-y:auto; scrollbar-width:thin; scrollbar-color:rgba(108,43,217,.2) transparent; }
.d6-sidebar::-webkit-scrollbar { width:4px; }
.d6-sidebar::-webkit-scrollbar-thumb { background:rgba(108,43,217,.2); border-radius:4px; }
.d6-sidebar-header { padding:13px 16px 11px; border-bottom:1px solid var(--surface); display:flex; align-items:center; justify-content:space-between; position:sticky; top:0; background:#fff; z-index:2; }
.d6-sidebar-header h3 { font-size:.72rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-3); margin:0; }
.d6-section { padding:12px 16px; border-bottom:1px solid var(--surface); }
.d6-section:last-child { border-bottom:none; }
.d6-section-title { font-size:.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.07em; color:var(--ink-3); margin:0 0 8px; display:block; }
.d6-tech-btn { display:flex; align-items:center; gap:8px; width:100%; padding:7px 11px; border-radius:10px; border:1.5px solid var(--surface); background:#fff; color:var(--ink-2); font-size:.8rem; font-weight:600; cursor:pointer; text-decoration:none; margin-bottom:5px; transition:all .15s; }
.d6-tech-btn:last-child { margin-bottom:0; }
.d6-tech-btn:hover { background:#faf9ff; }
.d6-tech-dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; }
.d6-tech-count { margin-left:auto; font-size:.7rem; font-weight:600; opacity:.5; }
.d6-tech-btn.d6-all.active     { background:#f0eeff; border-color:var(--p1); color:var(--p1); font-weight:700; }
.d6-tech-btn.d6-oled           { border-color:rgba(124,58,237,.25); color:#6d28d9; }
.d6-tech-btn.d6-oled.active    { background:rgba(124,58,237,.09); border-color:#7c3aed; color:#7c3aed; font-weight:700; }
.d6-tech-btn.d6-miniled        { border-color:rgba(217,119,6,.25); color:#b45309; }
.d6-tech-btn.d6-miniled.active { background:rgba(217,119,6,.09); border-color:#d97706; color:#d97706; font-weight:700; }
.d6-tech-btn.d6-qled           { border-color:rgba(2,132,199,.25); color:#0369a1; }
.d6-tech-btn.d6-qled.active    { background:rgba(2,132,199,.09); border-color:#0284c7; color:#0284c7; font-weight:700; }
.d6-tech-btn.d6-led            { border-color:rgba(5,150,105,.25); color:#047857; }
.d6-tech-btn.d6-led.active     { background:rgba(5,150,105,.09); border-color:#059669; color:#059669; font-weight:700; }
.d6-select { width:100%; padding:7px 26px 7px 9px; border-radius:9px; border:1.5px solid var(--surface); background:#fff url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b6888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 8px center; color:var(--ink-2); font-size:.78rem; font-weight:500; cursor:pointer; appearance:none; margin-bottom:7px; }
.d6-select:last-of-type { margin-bottom:0; }
.d6-select:focus { outline:none; border-color:var(--p1); }
.d6-select.has-value { border-color:var(--p1); color:var(--p1); background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236c2bd9' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); }
.d6-check { display:flex; align-items:center; gap:7px; margin-bottom:6px; cursor:pointer; font-size:.79rem; color:var(--ink); line-height:1.3; }
.d6-check:last-of-type { margin-bottom:0; }
.d6-check input[type=checkbox] { width:14px; height:14px; accent-color:var(--p1); cursor:pointer; flex-shrink:0; }
.d6-budget-row { display:flex; align-items:center; gap:6px; }
.d6-budget-input { flex:1; min-width:0; padding:6px 7px; border-radius:8px; border:1.5px solid var(--surface); font-size:.8rem; font-weight:600; color:var(--ink); -moz-appearance:textfield; text-align:center; }
.d6-budget-input::-webkit-inner-spin-button,.d6-budget-input::-webkit-outer-spin-button { -webkit-appearance:none; }
.d6-budget-input:focus { outline:none; border-color:var(--p1); }
.d6-budget-sep { color:var(--ink-3); font-size:.9rem; flex-shrink:0; }
.d6-apply-btn { width:100%; padding:9px 12px; background:var(--grad); color:#fff; border:none; border-radius:10px; font-size:.82rem; font-weight:700; cursor:pointer; transition:opacity .15s; }
.d6-apply-btn:hover { opacity:.88; }
.d6-reset-link { display:block; text-align:center; font-size:.72rem; color:var(--ink-3); text-decoration:none; padding:8px 0 0; transition:color .15s; }
.d6-reset-link:hover { color:var(--p1); }
.d6-main { min-width:0; }
.d6-results-header { display:flex; align-items:center; flex-wrap:wrap; gap:8px; margin-bottom:18px; padding-bottom:12px; border-bottom:1.5px solid var(--surface); }
.d6-results-count { font-size:.82rem; color:var(--ink-3); font-weight:700; }
.d6-active-chips { display:flex; align-items:center; gap:5px; flex-wrap:wrap; }
@media (max-width:1050px) { .d6-layout { grid-template-columns:220px 1fr; gap:18px; } }
@media (max-width:820px)  { .d6-layout { grid-template-columns:1fr; } .d6-sidebar { display:none!important; } }

/* ═══ MOBILE FILTERS UI ═══════════════════════════════ */
.mob-fbar{display:none}
.mob-fdrawer-overlay{display:none}
.mob-fdrawer{display:none}
.mob-sort-sheet{display:none}
@media(max-width:820px){
  .mob-fbar{display:flex;gap:8px;padding:10px 12px;background:#fff;border-bottom:1px solid var(--surface);position:sticky;top:60px;z-index:90;box-shadow:0 2px 8px rgba(0,0,0,.06)}
  .mob-fbar-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px;background:#fff;border:1.5px solid var(--surface);border-radius:8px;font-size:.85rem;font-weight:600;color:var(--ink);cursor:pointer;position:relative;min-width:0}
  .mob-fbar-btn:active{background:#f9fafb}
  .mob-fbar-btn.active{border-color:var(--p1);color:var(--p1);background:#f0eeff}
  .mob-fbar-btn .badge{position:absolute;top:-6px;right:-6px;display:inline-flex;align-items:center;justify-content:center;background:var(--p1);color:#fff;border-radius:10px;font-size:.62rem;font-weight:800;min-width:18px;height:18px;padding:0 5px}
  .mob-fbar-bottom{position:fixed;left:0;right:0;top:auto;bottom:-100px;z-index:60;border-top:1px solid var(--surface);border-bottom:none;box-shadow:0 -2px 12px rgba(0,0,0,.08);transition:bottom .25s cubic-bezier(.4,0,.2,1);background:#fff;padding:10px 12px}
  .mob-fbar-bottom.show{bottom:0}
  #mobFBarTop{transition:opacity .2s}
  #mobFBarTop.mob-fbar-hidden{opacity:0;pointer-events:none}
  .mob-fdrawer-overlay{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:99;opacity:0;pointer-events:none;transition:opacity .2s}
  .mob-fdrawer-overlay.open{opacity:1;pointer-events:auto}
  .mob-fdrawer{display:flex;flex-direction:column;position:fixed;left:0;right:0;bottom:-100vh;z-index:100;background:#fff;border-radius:14px 14px 0 0;max-height:88vh;transition:bottom .28s cubic-bezier(.4,0,.2,1)}
  .mob-fdrawer.open{bottom:0}
  .mob-fdrawer-handle{width:38px;height:4px;background:#d1d5db;border-radius:2px;margin:8px auto 4px;flex-shrink:0}
  .mob-fdrawer-head{padding:6px 16px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--surface);flex-shrink:0}
  .mob-fdrawer-head h3{font-size:1.05rem;font-weight:700;color:var(--ink);margin:0}
  .mob-fdrawer-head button{background:none;border:none;color:var(--ink-3);font-size:.82rem;font-weight:600;cursor:pointer;padding:6px 10px;border-radius:6px}
  .mob-fdrawer-body{flex:1;overflow-y:auto;padding:18px 16px;-webkit-overflow-scrolling:touch}
  .mob-fdrawer-foot{flex-shrink:0;padding:12px 16px;border-top:1px solid var(--surface);background:#fff}
  .mob-fdrawer-apply{width:100%;background:var(--grad);color:#fff;border:none;padding:14px;border-radius:8px;font-weight:700;font-size:.95rem;cursor:pointer}
  .mob-fdrawer-apply:active{opacity:.85}
  .mob-fsec{margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid #f0f0f0}
  .mob-fsec:last-child{border-bottom:none;padding-bottom:0;margin-bottom:0}
  .mob-fsec h4{font-size:.72rem;font-weight:800;color:var(--ink-3);text-transform:uppercase;letter-spacing:.6px;margin-bottom:12px}
  .mob-ftech-grid{display:flex;flex-wrap:wrap;gap:7px}
  .mob-ftech-chip{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;border-radius:9px;border:1.5px solid var(--surface);background:#fff;color:var(--ink-2);font-size:.82rem;font-weight:600;text-decoration:none;transition:all .15s}
  .mob-ftech-chip.active{border-color:var(--p1);background:#f0eeff;color:var(--p1)}
  .mob-ftech-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
  .mob-fselect{width:100%;padding:9px 26px 9px 10px;border-radius:9px;border:1.5px solid var(--surface);background:#fff url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236b6888' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") no-repeat right 8px center;color:var(--ink-2);font-size:.85rem;font-weight:500;cursor:pointer;appearance:none}
  .mob-fselect.has-value{border-color:var(--p1);color:var(--p1)}
  .mob-fbudget-row{display:flex;align-items:center;gap:8px}
  .mob-fbudget-inp{flex:1;min-width:0;padding:9px 10px;border-radius:9px;border:1.5px solid var(--surface);font-size:.85rem;font-weight:600;color:var(--ink);-moz-appearance:textfield;text-align:center;background:#fff}
  .mob-fbudget-inp::-webkit-inner-spin-button,.mob-fbudget-inp::-webkit-outer-spin-button{-webkit-appearance:none}
  .mob-fbudget-inp:focus{outline:none;border-color:var(--p1)}
  .mob-fbudget-sep{color:var(--ink-3);font-size:.9rem;flex-shrink:0}
  .mob-fcheck{display:flex;align-items:center;gap:8px;padding:9px 4px;border-bottom:1px solid #f3f4f6;cursor:pointer;font-size:.88rem;color:var(--ink)}
  .mob-fcheck:last-child{border-bottom:none}
  .mob-fcheck input[type=checkbox]{width:16px;height:16px;accent-color:var(--p1);cursor:pointer;flex-shrink:0}
  .mob-sort-sheet{display:flex;flex-direction:column;position:fixed;left:0;right:0;bottom:-100vh;z-index:100;background:#fff;border-radius:14px 14px 0 0;transition:bottom .28s cubic-bezier(.4,0,.2,1);padding:0 0 16px}
  .mob-sort-sheet.open{bottom:0}
  .mob-sort-head{padding:8px 16px 12px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--surface)}
  .mob-sort-head h3{font-size:1rem;font-weight:700;color:var(--ink);margin:0}
  .mob-sort-head button{background:none;border:none;color:var(--ink-3);font-size:.82rem;font-weight:600;cursor:pointer;padding:6px 10px;border-radius:6px}
  .mob-sort-item{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid #f3f4f6;text-decoration:none;font-size:.9rem;font-weight:600;color:var(--ink)}
  .mob-sort-item:last-child{border-bottom:none}
  .mob-sort-item.active{color:var(--p1)}
  .mob-sort-check{color:var(--p1);font-weight:800}
}

/* ── Pagination ───────────────────────── */
.comp-pagination { display:flex; align-items:center; justify-content:center; gap:8px; padding:32px 0 16px; flex-wrap:wrap; }
.cpag-btn { display:inline-flex; align-items:center; padding:8px 18px; border-radius:20px; border:1.5px solid var(--surface); background:#fff; color:var(--ink-2); font-size:.82rem; font-weight:600; text-decoration:none; transition:all .18s; white-space:nowrap; }
.cpag-btn:hover { border-color:var(--p1); color:var(--p1); }
.cpag-pages { display:flex; align-items:center; gap:4px; }
.cpag-num { display:inline-flex; align-items:center; justify-content:center; width:34px; height:34px; border-radius:50%; border:1.5px solid var(--surface); background:#fff; color:var(--ink-2); font-size:.82rem; font-weight:600; text-decoration:none; transition:all .18s; }
.cpag-num:hover { border-color:var(--p1); color:var(--p1); }
.cpag-num.active { background:var(--p1); border-color:var(--p1); color:#fff; }
.cpag-ellipsis { color:var(--ink-3); font-size:.85rem; padding:0 2px; }
