/* Nexus AI Themes — Affiliate Component Library
   Themed entirely through the design tokens (--c-*, --r, --font-head). */

.nexus-aff{margin:28px 0}
.nexus-aff-disclosure{font-size:12px;color:var(--c-muted);margin:10px 0 0;font-style:italic}

/* ── Buttons ───────────────────────────────────────────────── */
.nexus-aff-btn{display:inline-flex;align-items:center;gap:6px;background:var(--c-primary);color:var(--c-on-primary,#fff);font-weight:700;font-family:var(--font-head);padding:11px 20px;border-radius:var(--r);text-decoration:none;transition:filter .15s,transform .15s;white-space:nowrap}
.nexus-aff-btn:hover{filter:brightness(.93);transform:translateY(-1px);color:var(--c-on-primary,#fff)}
.nexus-aff-btn--sm{padding:7px 14px;font-size:13px}

/* ── Star rating ───────────────────────────────────────────── */
.nexus-stars{position:relative;display:inline-block;font-size:16px;line-height:1;letter-spacing:2px;color:var(--c-border)}
.nexus-stars::before{content:"\2605\2605\2605\2605\2605"}
.nexus-stars-fill{position:absolute;top:0;left:0;overflow:hidden;white-space:nowrap;color:#f5a623}
.nexus-stars-fill::before{content:"\2605\2605\2605\2605\2605"}

/* ── Award badges / ribbons ────────────────────────────────── */
.nexus-aff-badge{position:absolute;top:0;left:18px;transform:translateY(-50%);background:var(--c-primary);color:var(--c-on-primary,#fff);font-family:var(--font-head);font-size:11px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;padding:5px 12px;border-radius:99px;z-index:2}
.nexus-aff-badge--editors-choice{background:var(--c-accent,#7c3aed)}
.nexus-aff-badge--best-value{background:var(--c-success,#16a34a)}
.nexus-aff-badge--bestseller{background:#f5a623;color:#1a1a1a}

/* ── Product box ───────────────────────────────────────────── */
.nexus-product{position:relative;display:grid;grid-template-columns:200px 1fr auto;gap:22px;align-items:center;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:24px}
.nexus-product--featured{border-color:var(--c-primary);box-shadow:0 6px 24px rgba(0,0,0,.07)}
.nexus-product-media{position:relative;text-align:center}
.nexus-product-media img{max-width:100%;max-height:170px;object-fit:contain}
.nexus-aff-score{position:absolute;bottom:-10px;right:-10px;display:flex;flex-direction:column;align-items:center;justify-content:center;width:54px;height:54px;border-radius:50%;background:var(--c-primary);color:var(--c-on-primary,#fff);box-shadow:0 2px 8px rgba(0,0,0,.2)}
.nexus-aff-score-num{font-family:var(--font-head);font-weight:800;font-size:18px;line-height:1}
.nexus-aff-score-label{font-size:8px;text-transform:uppercase;letter-spacing:.03em;opacity:.9}
.nexus-product-name{font-family:var(--font-head);font-size:20px;margin:0 0 6px}
.nexus-product-rating{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.nexus-product-score-inline{font-weight:700;color:var(--c-muted);font-size:13px}
.nexus-product-desc{color:var(--c-muted);font-size:14px;margin:0 0 10px}
.nexus-product-features{list-style:none;margin:0;padding:0;display:grid;gap:5px}
.nexus-product-features li{position:relative;padding-left:22px;font-size:14px}
.nexus-product-features li::before{content:"\2713";position:absolute;left:0;color:var(--c-success,#16a34a);font-weight:800}
.nexus-product-action{text-align:center;min-width:150px}
.nexus-product-price{font-family:var(--font-head);font-weight:800;font-size:22px;margin-bottom:10px}
@media(max-width:760px){.nexus-product{grid-template-columns:1fr;text-align:center}.nexus-product-features{text-align:left}.nexus-aff-score{position:static;margin:10px auto 0}}

/* ── Comparison table ──────────────────────────────────────── */
.nexus-compare-title{font-family:var(--font-head);margin:0 0 14px}
.nexus-compare-table{width:100%;border-collapse:collapse;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);overflow:hidden}
.nexus-compare-table th,.nexus-compare-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--c-border);vertical-align:middle}
.nexus-compare-table th{font-family:var(--font-head);font-size:13px;text-transform:uppercase;letter-spacing:.04em;background:var(--c-bg)}
.nexus-compare-table tr.is-highlight{background:var(--c-tint,color-mix(in srgb,var(--c-primary) 8%,var(--c-surface)))}
.nexus-compare-name{font-weight:700}
.nexus-compare-pick{display:inline-block;background:var(--c-primary);color:var(--c-on-primary,#fff);font-size:10px;font-weight:800;text-transform:uppercase;padding:2px 7px;border-radius:99px;margin-left:6px}
.nexus-compare-score{margin-left:6px;font-weight:700;color:var(--c-muted)}
@media(max-width:640px){
  .nexus-compare-table thead{display:none}
  .nexus-compare-table tr{display:block;border-bottom:2px solid var(--c-border)}
  .nexus-compare-table td{display:flex;justify-content:space-between;border:none;padding:8px 14px}
  .nexus-compare-table td::before{content:attr(data-label);font-weight:700}
}

/* ── Pros & Cons ───────────────────────────────────────────── */
.nexus-proscons-title{font-family:var(--font-head);margin:0 0 14px}
.nexus-proscons-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.nexus-proscons-col{border:1px solid var(--c-border);border-radius:var(--r-lg);padding:18px 20px;background:var(--c-surface)}
.nexus-proscons-col h4{font-family:var(--font-head);margin:0 0 10px;font-size:16px}
.nexus-proscons-pros{border-top:3px solid var(--c-success,#16a34a)}
.nexus-proscons-cons{border-top:3px solid var(--c-danger,#dc2626)}
.nexus-proscons-col ul{list-style:none;margin:0;padding:0;display:grid;gap:8px}
.nexus-proscons-col li{position:relative;padding-left:24px;font-size:14px;line-height:1.45}
.nexus-proscons-pros li::before{content:"\2713";position:absolute;left:0;color:var(--c-success,#16a34a);font-weight:800}
.nexus-proscons-cons li::before{content:"\2715";position:absolute;left:0;color:var(--c-danger,#dc2626);font-weight:800}
@media(max-width:560px){.nexus-proscons-grid{grid-template-columns:1fr}}

/* ── Score card ────────────────────────────────────────────── */
.nexus-scorecard{display:grid;grid-template-columns:160px 1fr;gap:24px;align-items:center;background:var(--c-surface);border:1px solid var(--c-border);border-radius:var(--r-lg);padding:24px}
.nexus-scorecard-overall{text-align:center;display:flex;flex-direction:column;align-items:center}
.nexus-scorecard-num{font-family:var(--font-head);font-weight:800;font-size:54px;line-height:1;color:var(--c-primary)}
.nexus-scorecard-max{color:var(--c-muted);font-weight:700}
.nexus-scorecard-title{font-weight:700;margin:6px 0}
.nexus-scorecard-row{display:grid;grid-template-columns:120px 1fr 36px;gap:12px;align-items:center;margin-bottom:10px}
.nexus-scorecard-label{font-size:13px;font-weight:600}
.nexus-scorecard-bar{height:8px;background:var(--c-border);border-radius:99px;overflow:hidden}
.nexus-scorecard-fill{display:block;height:100%;background:var(--c-primary);border-radius:99px}
.nexus-scorecard-val{font-weight:700;font-size:13px;text-align:right}
.nexus-scorecard-verdict{grid-column:1/-1;color:var(--c-muted);font-style:italic;margin:6px 0 0}
@media(max-width:560px){.nexus-scorecard{grid-template-columns:1fr}}

/* ── CTA box ───────────────────────────────────────────────── */
.nexus-cta{display:flex;align-items:center;justify-content:space-between;gap:24px;border-radius:var(--r-lg);padding:26px 30px}
.nexus-cta--solid{background:var(--c-tint,color-mix(in srgb,var(--c-primary) 8%,var(--c-surface)));border:1px solid var(--c-border)}
.nexus-cta--gradient{background:linear-gradient(120deg,var(--c-primary),var(--c-accent,#7c3aed));color:#fff}
.nexus-cta--gradient .nexus-cta-text{color:rgba(255,255,255,.9)}
.nexus-cta--gradient .nexus-aff-btn{background:#fff;color:var(--c-primary)}
.nexus-cta--bordered{background:var(--c-surface);border:2px dashed var(--c-primary)}
.nexus-cta-title{font-family:var(--font-head);margin:0 0 4px;font-size:22px}
.nexus-cta-text{margin:0;color:var(--c-muted)}
.nexus-cta-action{text-align:center;white-space:nowrap}
.nexus-cta-price{display:block;font-family:var(--font-head);font-weight:800;font-size:20px;margin-bottom:8px}
@media(max-width:640px){.nexus-cta{flex-direction:column;text-align:center}}

/* ── Coupon box ────────────────────────────────────────────── */
.nexus-coupon{display:flex;align-items:center;justify-content:space-between;gap:20px;background:var(--c-surface);border:2px dashed var(--c-primary);border-radius:var(--r-lg);padding:22px 26px}
.nexus-coupon-left{display:flex;flex-direction:column;gap:3px}
.nexus-coupon-merchant{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--c-muted);font-weight:700}
.nexus-coupon-discount{font-family:var(--font-head);font-weight:800;font-size:26px;color:var(--c-primary)}
.nexus-coupon-title{font-size:15px}
.nexus-coupon-expiry{font-size:12px;color:var(--c-muted)}
.nexus-coupon-right{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.nexus-coupon-code{display:flex;align-items:stretch;border:1px solid var(--c-border);border-radius:var(--r);overflow:hidden}
.nexus-coupon-code-text{padding:9px 14px;font-family:monospace;font-weight:700;letter-spacing:1px;background:var(--c-bg);filter:blur(3px);transition:filter .15s;user-select:all}
.nexus-coupon-code.is-revealed .nexus-coupon-code-text{filter:none}
.nexus-coupon-copy{padding:9px 14px;background:var(--c-primary);color:var(--c-on-primary,#fff);border:0;font-weight:700;cursor:pointer}
@media(max-width:640px){.nexus-coupon{flex-direction:column;text-align:center}.nexus-coupon-right{justify-content:center}}
