/* Brightcore v2 — Product comparison page (.bcc-*) */
.bcc-hero { padding: 150px 0 56px; border-bottom: 1px solid var(--bc-line); background: radial-gradient(circle at 70% 20%, rgba(111, 227, 154, .08), transparent 30%), radial-gradient(circle at 20% 60%, rgba(109, 182, 238, .06), transparent 30%); }
.bcc-hero h1 { font-family: var(--bc-display); font-size: clamp(42px, 4.6vw, 68px); line-height: .98; letter-spacing: -.04em; font-weight: 800; margin: 22px 0 18px; max-width: 880px; text-wrap: balance; }
.bcc-hero h1 span { color: var(--bc-green); }
.bcc-hero p { max-width: 640px; color: var(--bc-muted); font-size: 18px; line-height: 1.55; margin: 0 0 26px; }

/* filter chips */
.bcc-toolbar { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 22px; }
.bcc-toolbar button { padding: 9px 16px; border: 1px solid var(--bc-line-strong); border-radius: 999px; background: transparent; color: var(--bc-muted); font-family: var(--bc-body); font-size: 12.5px; font-weight: 600; cursor: pointer; transition: border-color .25s ease, color .25s ease, background .25s ease, transform .25s var(--bc-ease); }
.bcc-toolbar button:hover { border-color: rgba(111, 227, 154, .5); color: var(--bc-ink); transform: translateY(-1px); }
.bcc-toolbar button.is-active { background: rgba(111, 227, 154, .12); border-color: var(--bc-green); color: var(--bc-green); }

/* workbench: cards + fit finder */
.bcc-workbench { display: grid; grid-template-columns: 1.55fr .45fr; gap: 14px; align-items: start; }
.bcc-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.bcc-card { --accent: var(--bc-green); position: relative; border: 1px solid var(--bc-line); border-radius: 10px; padding: 24px; background: rgba(8, 19, 17, .6); transition: transform .4s var(--bc-ease), border-color .4s ease, box-shadow .4s ease, opacity .4s ease; overflow: hidden; }
.bcc-card::before { content: ""; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, var(--accent), transparent 70%); opacity: .8; }
.bcc-card:hover { transform: translateY(-4px); border-color: color-mix(in oklab, var(--accent) 40%, transparent); box-shadow: 0 26px 60px rgba(0, 0, 0, .35); }
.bcc-card.is-dimmed { opacity: .25; }
.bcc-card-head { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.bcc-badge { display: grid; place-items: center; width: 42px; height: 42px; border: 1px solid color-mix(in oklab, var(--accent) 55%, transparent); border-radius: 10px; color: var(--accent); font-family: var(--bc-display); font-size: 15px; font-weight: 800; letter-spacing: .02em; }
.bcc-card h3 { font-family: var(--bc-display); font-size: 21px; font-weight: 800; margin: 0; }
.bcc-card-head small { display: block; color: var(--bc-dim); font-size: 11.5px; margin-top: 2px; }
.bcc-card > p { color: var(--bc-muted); font-size: 13.5px; line-height: 1.55; margin: 0 0 14px; }
.bcc-facts { list-style: none; margin: 0 0 16px; padding: 0; display: grid; grid-template-columns: 1fr 1fr; gap: 7px 14px; }
.bcc-facts li { display: grid; grid-template-columns: 12px 1fr; gap: 8px; align-items: baseline; color: #c9d6d2; font-size: 12.5px; }
.bcc-facts li::before { content: "—"; color: var(--accent); }
.bcc-card a { display: inline-flex; gap: 9px; align-items: center; color: var(--accent); font-size: 13.5px; font-weight: 600; }
.bcc-card a .bc-icon { width: 14px; height: 14px; transition: transform .25s var(--bc-ease); }
.bcc-card a:hover .bc-icon { transform: translateX(4px); }

/* best-fit finder */
.bcc-fit { position: sticky; top: 96px; border: 1px solid var(--bc-line-strong); border-radius: 12px; padding: 22px; background: rgba(4, 14, 19, .9); }
.bcc-fit > small { display: block; color: var(--bc-blue); text-transform: uppercase; letter-spacing: .18em; font-size: 10.5px; font-weight: 800; margin-bottom: 8px; }
.bcc-fit h3 { font-family: var(--bc-display); font-size: 19px; font-weight: 800; margin: 0 0 14px; }
.bcc-fit-options { display: grid; gap: 8px; margin-bottom: 16px; }
.bcc-fit-options button { text-align: left; padding: 11px 13px; border: 1px solid var(--bc-line); border-radius: 7px; background: rgba(10, 24, 30, .5); color: #c9d6d2; font-family: var(--bc-body); font-size: 12.5px; line-height: 1.4; cursor: pointer; transition: border-color .25s ease, background .25s ease, transform .25s var(--bc-ease); }
.bcc-fit-options button:hover { border-color: var(--bc-line-strong); transform: translateX(3px); }
.bcc-fit-options button.is-active { border-color: rgba(111, 227, 154, .55); background: rgba(111, 227, 154, .08); color: var(--bc-ink); }
.bcc-fit-result { border: 1px solid color-mix(in oklab, var(--accent, #6fe39a) 45%, transparent); border-radius: 8px; padding: 14px 16px; background: rgba(7, 18, 22, .8); }
.bcc-fit-result small { display: block; color: #9eafbd; text-transform: uppercase; letter-spacing: .08em; font-size: 10px; font-weight: 700; margin-bottom: 5px; }
.bcc-fit-result strong { display: block; font-family: var(--bc-display); font-size: 18px; font-weight: 800; color: var(--accent, var(--bc-green)); }
.bcc-fit-result p { margin: 6px 0 0; color: var(--bc-muted); font-size: 12.5px; line-height: 1.5; }

/* comparison matrix */
.bcc-matrix-wrap { overflow-x: auto; border: 1px solid var(--bc-line-strong); border-radius: 12px; background: rgba(4, 14, 19, .9); -webkit-overflow-scrolling: touch; }
.bcc-matrix { width: 100%; min-width: 980px; border-collapse: collapse; font-size: 13px; }
.bcc-matrix th, .bcc-matrix td { padding: 13px 16px; border-bottom: 1px solid var(--bc-line); text-align: left; vertical-align: top; line-height: 1.45; }
.bcc-matrix thead th { font-family: var(--bc-display); font-size: 15px; font-weight: 800; color: var(--bc-ink); border-bottom: 1px solid var(--bc-line-strong); white-space: nowrap; }
.bcc-matrix thead th span { display: inline-flex; align-items: center; gap: 9px; }
.bcc-matrix thead th i { width: 9px; height: 9px; border-radius: 50%; background: var(--accent, var(--bc-green)); box-shadow: 0 0 10px var(--accent, var(--bc-green)); }
.bcc-matrix tbody th { position: sticky; left: 0; min-width: 150px; background: #081715; color: #9eafbd; text-transform: uppercase; letter-spacing: .07em; font-size: 10.5px; font-weight: 700; white-space: nowrap; }
.bcc-matrix td { color: #c9d6d2; min-width: 170px; }
.bcc-matrix tbody tr:last-child th, .bcc-matrix tbody tr:last-child td { border-bottom: 0; }
.bcc-matrix tbody tr:hover td { background: rgba(111, 227, 154, .03); }

@media (max-width: 1100px) {
  .bcc-workbench { grid-template-columns: 1fr; }
  .bcc-fit { position: static; }
}
@media (max-width: 760px) {
  .bcc-grid, .bcc-facts { grid-template-columns: 1fr; }
  .bcc-hero { padding-top: 120px; }
}
