/* ================================
   Affinity Page Overrides (v2)
   ================================ */

/* Kill any legacy gradients/orange areas */
.affinity-page,
.affinity-page body,
.affinity-page .ddb-hero,
.affinity-page .ddb-section,
.affinity-page .footer,
.affinity-page .site-footer,
.affinity-page .footer-top,
.affinity-page .footer-bottom {
  background:#0b0f17 !important;
  background-image:none !important;
  box-shadow:none !important;
}

/* Page container rhythm */
.affinity-page .ddb-container{width:min(1200px,92%);margin-inline:auto}

/* Page title + search row */
.affinity-page .aff-headline{
  margin:10px 0 12px;
  font-size:clamp(24px,3.4vw,30px);
  font-weight:900;
}
.affinity-page .ddb-search{
  display:grid; grid-template-columns:1fr auto; gap:10px;
  background:transparent !important; border:0 !important; box-shadow:none !important; padding:0 !important;
}
.affinity-page .ddb-search input{
  height:48px; border-radius:12px; background:#0d121b; color:#fff;
  border:1px solid #2f3750; padding:.55rem .75rem; font-size:16px;
}
.affinity-page .ddb-search input::placeholder{color:#c7d1f1}
.affinity-page .ddb-search .ddb-btn.ddb-primary{
  height:48px; padding:0 18px; border:none;
  background:linear-gradient(180deg, var(--brand), var(--brand2));
  color:#111; font-weight:900; border-radius:999px;
  box-shadow:0 10px 24px rgba(255,122,26,.35);
}

/* Pill row under title */
.affinity-page .aff-eyebrow{
  color:var(--muted); font-size:.88rem; margin-top:4px;
}

/* FILTERS panel — crisp grid */
.affinity-page .aff-panel{
  margin-top:12px;
  background:var(--panel);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:14px;
}
.affinity-page .aff-filters{
  display:grid;
  grid-template-columns:repeat(12,1fr);
  gap:12px;
}
.affinity-page .span-2{grid-column:span 2}
.affinity-page .span-3{grid-column:span 3}
.affinity-page .span-4{grid-column:span 4}
.affinity-page .span-6{grid-column:span 6}
@media (max-width:1000px){ .affinity-page .aff-filters{grid-template-columns:repeat(6,1fr)} .affinity-page .span-6{grid-column:1/-1} }
@media (max-width:640px){ .affinity-page .aff-filters{grid-template-columns:1fr} .affinity-page .span-2,.affinity-page .span-3,.affinity-page .span-4,.affinity-page .span-6{grid-column:1/-1} }

.affinity-page .fg{display:flex;flex-direction:column}
.affinity-page .fg label{font-size:.85rem;color:var(--muted);margin-bottom:4px}
.affinity-page .fg select,
.affinity-page .fg input{
  width:100%; background:#0d121b; color:#fff;
  border:1px solid #2f3750; border-radius:10px; padding:.55rem .6rem; font-size:.92rem;
}
.affinity-page .fg .hint{font-size:.72rem;color:#8a90a2;margin-top:3px}

/* Filter actions row */
.affinity-page .filters-actions{
  display:flex; align-items:center; gap:10px; justify-content:flex-end; margin-top:12px;
}
.affinity-page .filters-actions .ddb-btn{border:1px solid var(--stroke); border-radius:999px; padding:.5rem .9rem}
.affinity-page .filters-actions .ddb-btn.ddb-primary{
  background:linear-gradient(180deg, var(--brand), var(--brand2)); color:#111; border:none; font-weight:900;
}

/* Marketing strategy + persona panels */
.affinity-page .marketing-box{
  margin-top:16px;
  background:var(--panel);
  border:1px solid var(--stroke);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:14px;
}
.affinity-page .marketing-box h3{
  margin:0 0 8px; font-size:1.05rem; font-weight:900;
}
.affinity-page .strategy-list{list-style:disc; padding-left:1.25rem; margin:6px 0; line-height:1.5}
.affinity-page .persona-box{
  margin-top:10px;
  background:#121828; border:1px solid #232a3d; border-radius:12px; padding:10px 12px; color:#dfe7ff;
  font-size:.92rem;
}

/* RESULTS GRID - same density as home */
.affinity-page .results{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:14px}
@media (max-width:1100px){.affinity-page .results{grid-template-columns:repeat(3,1fr)}}
@media (max-width:780px){.affinity-page .results{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.affinity-page .results{grid-template-columns:1fr}}

.affinity-page .ddb-card.aff-card{
  background:#141b26; border:1px solid #21283a; border-radius:16px; overflow:hidden; display:flex;flex-direction:column; min-height:100%;
}
.affinity-page .aff-card .ddb-cover{aspect-ratio:16/9; object-fit:cover; width:100%; background:#222}
.affinity-page .aff-card .ddb-badge{
  position:absolute; top:10px; left:10px; width:36px; height:36px; display:grid; place-items:center;
  background:linear-gradient(180deg,#9cf28d,#3bd37a); color:#0a121a; border-radius:999px; border:none; font-weight:900;
  box-shadow:0 8px 18px rgba(0,0,0,.35)
}
.affinity-page .aff-card .ddb-card-body{background:#171f2b; border-top:1px solid #21283a; padding:12px}

/* Title + pills */
.affinity-page .aff-card .ddb-title{font-weight:900;margin:2px 0 6px}
.affinity-page .pillrow{display:flex;gap:8px;flex-wrap:wrap;margin:6px 0 6px}
.affinity-page .pill{
  background:#1a1f2e; border:1px solid #2a3044; color:#dbe4ff;
  padding:.28rem .6rem; border-radius:999px; font-size:.82rem; font-weight:700;
}

/* Connection chip */
.affinity-page .conn-chip{
  display:inline-flex;align-items:center;gap:8px;
  background:#0f1b2e; border:1px solid rgba(255,255,255,.08); color:#e9f3ff;
  padding:.42rem .65rem; border-radius:999px; font-weight:800; font-size:.86rem;
}

/* Rank/Match and metrics line */
.affinity-page .kv{color:#b9c3e8; font-size:.88rem; margin:8px 0}
.affinity-page .kv b{color:#fff}

/* ER chips and brand list (like home) */
.affinity-page .er-line{display:flex;align-items:center;gap:8px;margin:6px 0 2px;flex-wrap:wrap}
.affinity-page .er-chip{padding:6px 10px;border-radius:999px;background:#0f1b2e;border:1px solid rgba(255,255,255,.08);font-weight:800;font-size:.78rem}
.affinity-page .er-strength{padding:6px 10px;border-radius:999px;background:#13263f;border:1px solid rgba(255,255,255,.08);font-weight:800;font-size:.78rem}
.affinity-page .brand-list{margin-top:8px;font-size:.86rem;line-height:1.4}
.affinity-page .brand-head{display:flex;justify-content:space-between;gap:8px;font-size:.78rem;opacity:.75;border-bottom:1px dashed rgba(255,255,255,.12);padding-bottom:2px}
.affinity-page .brand-row{display:flex;justify-content:space-between;gap:8px;margin-top:2px}
.affinity-page .brand-row .name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:70%}

/* Compact STAT grid with icons */
.affinity-page .stats{
  display:grid; grid-template-columns:1fr 1fr; gap:10px; margin:10px 0 12px;
}
.affinity-page .stat{
  display:flex; align-items:center; gap:8px; padding:10px; border-radius:12px;
  background:#101728; border:1px solid #222b3c; color:#dbe4ff; font-size:.9rem;
}
.affinity-page .stat i{width:16px; text-align:center; opacity:.9}

/* Card action */
.affinity-page .card-actions{margin-top:auto}
.affinity-page .ddb-btn.profile{
  width:100%;
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  border:none; border-radius:12px; padding:.65rem 1rem;
  background:linear-gradient(180deg, var(--brand), var(--brand2)); color:#111; font-weight:900;
  box-shadow:0 10px 24px rgba(255,122,26,.35);
}

/* Helper text */
.affinity-page .muted{color:var(--muted)}

/* Hide bios on cards */
.affinity-page .artist-bio{display:none !important}
