/* =============================================================================
   AffiliationHub — ah2.css : outcome-driven, dropship-style component library
   Load AFTER ah.css (depends on its :root tokens). Dark apex brand kept.
   Compose mockups from these primitives so every page stays consistent.
   ========================================================================== */

/* ---- big benefit hero (outcome-first) ---- */
.hero2{position:relative;padding:64px 0 40px}
.hero2::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(900px 480px at 82% -10%,rgba(138,43,230,.20),transparent 60%),
             radial-gradient(680px 420px at 6% 0,rgba(46,107,255,.16),transparent 62%)}
.hero2 .grid{display:grid;grid-template-columns:1fr;gap:44px;align-items:center}
@media(min-width:920px){.hero2 .grid{grid-template-columns:1.05fr .95fr}}
.hero2 h1{font-family:var(--ah-font-display);font-weight:700;line-height:1.03;letter-spacing:-.03em;
  font-size:clamp(2.5rem,6vw,4rem);margin-top:18px}
.hero2 .sub{font-size:clamp(1.1rem,2.1vw,1.4rem);color:var(--ah-grey-300);max-width:30ch;margin-top:20px;line-height:1.45}
.hero2 .cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero2 .trust{margin-top:22px;color:var(--ah-grey-500);font-size:.86rem}

/* ---- product mockup frame (the "app window") ---- */
.mockup{position:relative;background:var(--ah-navy-700);border:1px solid var(--ah-navy-500);border-radius:var(--ah-radius-lg);
  overflow:hidden;box-shadow:0 30px 80px rgba(10,17,48,.5)}
.mockup::after{content:"";position:absolute;inset:-1px;border-radius:inherit;pointer-events:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
.mockup .bar{display:flex;align-items:center;gap:7px;padding:11px 14px;border-bottom:1px solid var(--ah-navy-500);background:rgba(255,255,255,.02)}
.mockup .bar i{width:10px;height:10px;border-radius:50%;background:var(--ah-navy-500);display:block}
.mockup .bar i:nth-child(1){background:#F0436A4d}.mockup .bar i:nth-child(2){background:#F5A5244d}.mockup .bar i:nth-child(3){background:#12B9814d}
.mockup .bar .ttl{margin-left:8px;font-family:var(--ah-font-mono);font-size:.72rem;color:var(--ah-grey-500);letter-spacing:.04em}
.mockup .body{padding:18px}
.mockup-glow{position:relative}
.mockup-glow::before{content:"";position:absolute;inset:auto 0 -30px 0;height:120px;z-index:-1;filter:blur(48px);
  background:var(--ah-gradient-apex-diag);opacity:.28;border-radius:50%}

/* ---- opportunity card (core Prediction visual) ---- */
.opp{display:grid;grid-template-columns:auto 1fr auto;gap:14px;align-items:center;
  background:var(--ah-ink);border:1px solid var(--ah-navy-500);border-radius:var(--ah-radius-md);padding:14px}
.opp + .opp{margin-top:10px}
.opp .thumb{width:46px;height:46px;border-radius:10px;background:var(--ah-gradient-apex-diag);position:relative;flex:0 0 auto}
.opp .thumb.alt{background:linear-gradient(135deg,#2E6BFF,#12B981)}
.opp .thumb.alt2{background:linear-gradient(135deg,#8A2BE6,#F5A524)}
.opp .info .name{font-weight:600;font-size:.95rem}
.opp .info .tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.opp .chip{font-family:var(--ah-font-mono);font-size:.66rem;letter-spacing:.04em;color:var(--ah-grey-300);
  border:1px solid var(--ah-navy-500);border-radius:999px;padding:2px 8px;white-space:nowrap}
.opp .chip.up{color:var(--ah-success);border-color:rgba(18,185,129,.4)}
.opp .chip.hot{color:var(--ah-grad-4);border-color:rgba(224,33,138,.4)}
.opp .score{text-align:right}
.opp .score .n{font-family:var(--ah-font-display);font-weight:700;font-size:1.5rem;line-height:1}
.opp .score .l{font-family:var(--ah-font-mono);font-size:.6rem;letter-spacing:.1em;color:var(--ah-grey-500);text-transform:uppercase}

/* ---- meter bars (demand / satisfaction / commission / match) ---- */
.meters{display:flex;flex-direction:column;gap:12px}
.meter .top{display:flex;justify-content:space-between;font-size:.8rem;color:var(--ah-grey-300);margin-bottom:5px}
.meter .top b{color:var(--ah-grey-100);font-weight:600}
.meter .track{height:8px;border-radius:999px;background:var(--ah-navy-500);overflow:hidden}
.meter .fill{height:100%;border-radius:999px;background:var(--ah-gradient-apex-diag)}
.meter .fill.good{background:linear-gradient(90deg,#2E6BFF,#12B981)}
.meter .fill.warn{background:linear-gradient(90deg,#8A2BE6,#F5A524)}

/* ---- score ring (conic) ---- */
.ring{--v:78;width:96px;height:96px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  background:conic-gradient(var(--ah-grad-4) calc(var(--v)*1%),var(--ah-navy-500) 0)}
.ring .hole{width:74px;height:74px;border-radius:50%;background:var(--ah-navy-700);display:grid;place-items:center;text-align:center}
.ring .hole b{font-family:var(--ah-font-display);font-weight:700;font-size:1.4rem;line-height:1}
.ring .hole span{font-family:var(--ah-font-mono);font-size:.56rem;letter-spacing:.1em;color:var(--ah-grey-500);text-transform:uppercase}

/* ---- AI-influencer avatar card ---- */
.avatars{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(min-width:480px){.avatars{grid-template-columns:repeat(3,1fr)}}
.avatar{text-align:center;background:var(--ah-ink);border:1px solid var(--ah-navy-500);border-radius:var(--ah-radius-md);padding:16px 12px}
.avatar .face{width:56px;height:56px;border-radius:50%;margin:0 auto 10px;display:grid;place-items:center;
  font-family:var(--ah-font-display);font-weight:600;color:#fff;font-size:1.1rem;background:var(--ah-gradient-apex-diag)}
.avatar .face.b{background:linear-gradient(135deg,#2E6BFF,#8A2BE6)}
.avatar .face.c{background:linear-gradient(135deg,#E0218A,#F5A524)}
.avatar .nm{font-weight:600;font-size:.9rem}
.avatar .ni{font-family:var(--ah-font-mono);font-size:.66rem;color:var(--ah-grey-500);letter-spacing:.04em;margin-top:3px}
.avatar .fol{margin-top:8px;font-size:.82rem;color:var(--ah-grad-3);font-weight:600}

/* ---- phone / app mockup ---- */
.phone{width:200px;max-width:100%;margin:0 auto;background:var(--ah-ink);border:6px solid var(--ah-navy-500);
  border-radius:28px;padding:14px 12px;box-shadow:0 30px 70px rgba(10,17,48,.5)}
.phone .notch{width:46px;height:5px;border-radius:999px;background:var(--ah-navy-500);margin:0 auto 14px}
.phone .row{height:34px;border-radius:8px;background:var(--ah-navy-700);margin-bottom:10px;border:1px solid var(--ah-navy-500)}
.phone .row.tall{height:70px;background:var(--ah-gradient-apex-diag);opacity:.85;border:0}

/* ---- 3-step flow (opportunity → content → commission) ---- */
.flow3{display:grid;grid-template-columns:1fr;gap:14px;margin-top:36px}
@media(min-width:740px){.flow3{grid-template-columns:1fr auto 1fr auto 1fr;align-items:stretch}}
.flow3 .step{background:var(--ah-navy-700);border:1px solid var(--ah-navy-500);border-radius:var(--ah-radius-lg);padding:22px}
.flow3 .step .n{font-family:var(--ah-font-mono);font-size:.7rem;letter-spacing:.12em;color:var(--ah-grad-3)}
.flow3 .step h4{font-family:var(--ah-font-display);font-weight:600;font-size:1.05rem;margin:8px 0}
.flow3 .step p{color:var(--ah-grey-500);font-size:.9rem}
.flow3 .arrow{display:none;align-self:center;color:var(--ah-grad-4);font-size:1.4rem}
@media(min-width:740px){.flow3 .arrow{display:block}}

/* ---- big outcome stats ---- */
.bigstats{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:36px}
@media(min-width:760px){.bigstats{grid-template-columns:repeat(4,1fr)}}
.bigstat .n{font-family:var(--ah-font-display);font-weight:700;font-size:clamp(2rem,4vw,2.8rem);line-height:1;letter-spacing:-.02em}
.bigstat .l{color:var(--ah-grey-500);font-size:.86rem;margin-top:8px}

/* ---- feature-split (alternating text + mockup, dropship-style) ---- */
.split{display:grid;grid-template-columns:1fr;gap:40px;align-items:center}
@media(min-width:900px){.split{grid-template-columns:1fr 1fr}.split.flip .copy{order:2}}
.split .copy .eyebrow{display:block;margin-bottom:14px}
.split .copy h2{font-family:var(--ah-font-display);font-weight:700;letter-spacing:-.02em;line-height:1.1;font-size:clamp(1.8rem,3.6vw,2.6rem)}
.split .copy .lead{color:var(--ah-grey-300);font-size:1.1rem;margin-top:16px;line-height:1.6;max-width:46ch}
.split .copy ul{list-style:none;margin-top:20px;display:flex;flex-direction:column;gap:12px}
.split .copy li{display:flex;gap:11px;align-items:flex-start;color:var(--ah-grey-100);font-size:.98rem}
.split .copy li::before{content:"";flex:0 0 auto;width:20px;height:20px;border-radius:50%;margin-top:1px;
  background:var(--ah-gradient-apex-diag);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/14px no-repeat;
          mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M9 16.2 4.8 12l-1.4 1.4L9 19 21 7l-1.4-1.4z'/%3E%3C/svg%3E") center/14px no-repeat}
.split .copy .more{margin-top:24px}

/* ---- pillar showcase card (homepage) ---- */
.pillar-show{padding:64px 0;border-bottom:1px solid var(--ah-navy-500)}

/* ---- powered-by-ageni ---- */
.poweredby{display:inline-flex;align-items:center;gap:7px;color:var(--ah-grey-500);font-size:.82rem}
.poweredby a{color:var(--ah-grey-100);font-weight:600}
.poweredby a:hover{color:var(--ah-grad-3)}

/* ---- hero button row (avoids collision with .cta section rule) ---- */
.hero2 .hero-btns{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}

/* ---- stats label (intro label above bigstats, surface-navy) ---- */
.stats-label{font-family:var(--ah-font-mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--ah-grey-500);display:block;margin-bottom:18px;padding-top:4px}
.stats-label + .bigstats{margin-top:0}

/* ---- pillars intro header (above first split, inside pillar-show) ---- */
.pillars-intro{margin-bottom:0}
.pillars-intro .eyebrow{display:block;margin-top:14px;margin-bottom:10px}
.pillars-intro .pillars-title{font-family:var(--ah-font-display);font-weight:700;letter-spacing:-.02em;
  line-height:1.1;font-size:clamp(1.7rem,3.2vw,2.4rem);max-width:32ch}

/* ---- real-face avatar images (circular crop, clips watermark) ---- */
.avatar img.face{width:56px;height:56px;border-radius:50%;object-fit:cover;object-position:center top;display:block;margin:0 auto 10px}

/* ---- community face strip (real people, real audiences) ---- */
.face-strip{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:28px}
.face-strip .fs-faces{display:flex}
.face-strip .fs-faces img{width:38px;height:38px;border-radius:50%;object-fit:cover;object-position:center top;border:2px solid var(--ah-navy-700);margin-left:-10px}
.face-strip .fs-faces img:first-child{margin-left:0}
.face-strip .fs-label{font-size:.82rem;color:var(--ah-grey-400);margin-left:4px}

/* ---- real product photo inside .opp thumb ---- */
.opp .thumb img{width:100%;height:100%;border-radius:10px;object-fit:cover;object-position:center;display:block}

/* ---- opportunity-detected callout (inside .mockup .body, after .meters) ---- */
.opp-alert{margin-top:18px;padding:14px;background:rgba(224,33,138,.08);border:1px solid rgba(224,33,138,.25);border-radius:10px}
.opp-alert-label{font-family:var(--ah-font-mono);font-size:.7rem;letter-spacing:.08em;color:var(--ah-grad-4);text-transform:uppercase;margin-bottom:6px}
.opp-alert-msg{font-size:.95rem;font-weight:600}

/* ---- filter count note (inside .mockup .body, below opp rows) ---- */
.opp-filter-note{display:flex;align-items:center;gap:8px;margin-top:14px;color:var(--ah-grey-500);font-size:.82rem;font-family:var(--ah-font-mono)}
.opp-filter-dot{width:8px;height:8px;border-radius:50%;background:var(--ah-success);flex:0 0 auto}

/* ---- audience niche face strip (lease audiences: face circles with niche labels) ---- */
.niche-faces{display:flex;flex-wrap:wrap;gap:18px;margin:28px 0 4px;justify-content:flex-start}
.niche-face{display:flex;flex-direction:column;align-items:center;gap:7px}
.niche-face img{width:52px;height:52px;border-radius:50%;object-fit:cover;object-position:center top;border:2px solid var(--ah-navy-500)}
.niche-face .nf-label{font-family:var(--ah-font-mono);font-size:.62rem;letter-spacing:.07em;color:var(--ah-grey-400);text-align:center;white-space:nowrap}

/* ---- distribution page: product index strip ---- */
.dist-index{display:flex;flex-wrap:wrap;align-items:center;gap:0;padding:20px 0}
.dist-index-item{display:flex;flex-direction:column;gap:3px;padding:12px 20px;border-radius:var(--ah-radius-md);
  transition:background .18s var(--ah-ease);text-decoration:none;min-width:0}
.dist-index-item:hover{background:rgba(46,107,255,.08)}
.dist-index-num{font-family:var(--ah-font-mono);font-size:.66rem;letter-spacing:.14em;color:var(--ah-grey-500);text-transform:uppercase}
.dist-index-name{font-family:var(--ah-font-display);font-weight:600;font-size:1rem;color:var(--ah-grey-100)}
.dist-index-desc{font-family:var(--ah-font-mono);font-size:.7rem;color:var(--ah-grey-500)}
.dist-index-sep{color:var(--ah-navy-500);font-size:1.2rem;padding:0 4px;flex:0 0 auto;align-self:center}
@media(max-width:639px){.dist-index{flex-direction:column;align-items:flex-start}.dist-index-sep{transform:rotate(90deg)}}

/* ---- distribution page: platforms mockup row (phone + site side by side) ---- */
.platforms-mockup-row{display:flex;gap:16px;align-items:center;justify-content:center}
.platforms-site-mockup{flex:1;min-width:0}
.platforms-hero-bar{height:16px;border-radius:6px;background:var(--ah-gradient-apex-diag);opacity:.75;margin-bottom:12px}
.platforms-text-line{height:8px;border-radius:999px;background:var(--ah-navy-500);margin-bottom:8px}
.platforms-text-line-long{width:84%}
.platforms-text-line-med{width:60%;margin-bottom:14px}
.platforms-card-row{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.platforms-card{display:flex;align-items:center;gap:8px;background:var(--ah-ink);border:1px solid var(--ah-navy-500);border-radius:var(--ah-radius-sm);padding:8px 10px}
.platforms-card-face{width:32px;height:32px;border-radius:50%;object-fit:cover;object-position:center top;flex:0 0 auto;border:2px solid var(--ah-navy-500)}
.platforms-card-meta{display:flex;flex-direction:column;gap:4px;min-width:0;flex:1}
.platforms-card-name{height:7px;border-radius:999px;background:var(--ah-navy-500);width:70%}
.platforms-card-sub{height:5px;border-radius:999px;background:var(--ah-navy-500);width:45%}

/* ---- distribution page: lease audiences chip row ---- */
.lease-niche-row{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:16px}

/* ---- distribution page: lease auto-approved row ---- */
.lease-approved-row{display:flex;align-items:center;gap:8px;margin-top:14px;padding:10px 14px;
  border-radius:8px;background:rgba(18,185,129,.08);border:1px solid rgba(18,185,129,.3);
  font-size:.82rem;color:var(--ah-success)}

/* ---- ai-influencer: scheduled content row (face + platform + copy) ---- */
.ai-sched-row{display:flex;align-items:flex-start;gap:12px;padding:10px 0;border-bottom:1px solid var(--ah-navy-500)}
.ai-sched-row:last-of-type{border-bottom:none;margin-bottom:4px}
.ai-sched-face{flex:0 0 auto}
.ai-sched-face img{width:32px;height:32px;border-radius:50%;object-fit:cover;object-position:center top;display:block;border:2px solid var(--ah-navy-500)}
.ai-sched-meta{flex:1;min-width:0}
.ai-sched-platform{font-family:var(--ah-font-mono);font-size:.7rem;letter-spacing:.04em;margin-bottom:4px}
.ai-sched-ig{color:var(--ah-grad-4)}
.ai-sched-tt{color:var(--ah-grad-3)}
.ai-sched-nl{color:var(--ah-grad-2)}
.ai-sched-copy{font-size:.85rem;color:var(--ah-grey-100);line-height:1.4}

/* ---- card icon (emoji / svg anchor above card heading) ---- */
.card-icon{font-size:1.6rem;display:block;margin-bottom:10px;line-height:1}

/* ---- media-engine: channel output list (hero mockup) ---- */
.me-channel-list{display:flex;flex-direction:column;gap:7px;margin-top:14px}
.me-channel-row{display:flex;justify-content:space-between;align-items:center;
  padding:9px 12px;border-radius:var(--ah-radius-md);border:1px solid var(--ah-navy-500);
  background:var(--ah-ink)}
.me-done{border-color:rgba(18,185,129,.30)}
.me-writing{border-color:rgba(245,165,36,.25)}
.me-queued{opacity:.55}
.me-channel-name{font-family:var(--ah-font-mono);font-size:.62rem;color:var(--ah-grey-300);letter-spacing:.02em}
.me-channel-status{font-family:var(--ah-font-mono);font-size:.62rem;color:var(--ah-success);white-space:nowrap}
.me-status-writing{color:var(--ah-warn)}
.me-status-queued{color:var(--ah-grey-500)}
.me-publish-bar{margin-top:11px;text-align:center;
  font-family:var(--ah-font-mono);font-size:.66rem;color:var(--ah-grad-3)}
/* hero opp: tighten spacing when inside hero mockup */
.me-hero-opp{margin-bottom:14px}

/* ---- media-engine: content format cards (split 2 mockup) ---- */
.me-format-list{display:flex;flex-direction:column;gap:10px}
.me-format-card{background:var(--ah-ink);border:1px solid var(--ah-navy-500);border-radius:var(--ah-radius-md);padding:12px 14px}
.me-format-label{font-family:var(--ah-font-mono);font-size:.6rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--ah-grad-3);margin-bottom:6px}
.me-format-copy{font-size:.84rem;color:var(--ah-grey-100);line-height:1.5;margin:0}

/* ---- media-engine: publish speed stat (split 3 mockup) ---- */
.me-publish-stat{text-align:center;margin-bottom:16px;padding-bottom:14px;border-bottom:1px solid var(--ah-navy-500)}
.me-publish-num{font-family:var(--ah-font-display);font-weight:700;font-size:2.4rem;
  line-height:1;background:var(--ah-gradient-apex-up);-webkit-background-clip:text;background-clip:text;color:transparent}
.me-publish-unit{font-family:var(--ah-font-mono);font-size:.62rem;letter-spacing:.1em;
  color:var(--ah-grey-500);text-transform:uppercase;margin-top:4px}
