/* ═══════════════════════════════════════════════════════════════
   HERO ASSETS — shared animated right-rail visuals
   Place <div class="hero-asset" data-asset="partner"></div> inside
   a .pg-hero. Positioned absolutely in the top-right.
   ═══════════════════════════════════════════════════════════════ */

.hero-asset{
  position:absolute;
  top:72px;
  right:40px;
  width:min(40vw, 440px);
  height:clamp(320px, 44vh, 460px);
  pointer-events:none;
  z-index:1;
  font-family:var(--mono, 'JetBrains Mono', monospace);
  color:var(--fg, #fff);
}
@media (max-width:1100px){
  .hero-asset{ width:min(42vw, 360px); height:340px; right:24px; opacity:.9; }
}
@media (max-width:900px){
  .hero-asset{ display:none; }
}

.ha-box{
  position:absolute; inset:0;
  border:1px solid var(--rule, rgba(255,255,255,.12));
  background:var(--bg, #0a0a0a);
  overflow:hidden;
}
.ha-chrome{
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 14px;
  border-bottom:1px solid var(--rule, rgba(255,255,255,.12));
  font-size:10px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--fg-dim, rgba(255,255,255,.5));
  background:rgba(255,255,255,.02);
}
.ha-chrome .dot{
  display:inline-block; width:6px; height:6px; border-radius:50%;
  background:var(--accent, #fff); margin-right:6px; vertical-align:middle;
  animation: haPulse 1.8s ease-in-out infinite;
}
@keyframes haPulse{ 0%,100%{ opacity:.4; } 50%{ opacity:1; } }

.ha-body{ padding:14px; height:calc(100% - 36px); position:relative; }

/* ─── 1. Partner With Me — operator console ─────────────────── */
.ha-partner .op-grid{ display:grid; grid-template-columns:1fr 1fr; gap:8px; margin-bottom:12px; }
.ha-partner .op-cell{ border:1px solid var(--rule); padding:10px 12px; background:rgba(255,255,255,.01); }
.ha-partner .op-lbl{ font-size:9px; letter-spacing:.18em; color:var(--fg-dim); margin-bottom:4px; text-transform:uppercase; }
.ha-partner .op-val{ font-family:var(--display, 'Anton'); font-size:22px; line-height:1; color:var(--fg); }
.ha-partner .op-val .acc{ color:var(--accent); }
.ha-partner .op-delta{ font-size:10px; color:var(--accent); margin-top:3px; font-family:var(--mono); }
.ha-partner .op-feed{ border-top:1px solid var(--rule); padding-top:10px; }
.ha-partner .op-feed-ttl{ font-size:9px; letter-spacing:.2em; color:var(--fg-dim); margin-bottom:8px; }
.ha-partner .op-line{ display:flex; gap:8px; font-size:10px; line-height:1.5; color:var(--fg-dim); margin-bottom:4px; opacity:0; animation: feedIn .4s forwards; }
.ha-partner .op-line .ts{ color:var(--accent); flex-shrink:0; }
.ha-partner .op-line .ch{ color:var(--fg); }
@keyframes feedIn{ to{ opacity:1; } }

/* ─── 2. AI Infrastructure — workflow machine ──────────────── */
.ha-ai{ overflow:visible; }
.ha-ai .wf-title{ font-size:10px; letter-spacing:.2em; color:var(--fg-dim); margin-bottom:14px; }
.ha-ai .wf-svg{ width:100%; height:calc(100% - 20px); }
.ha-ai .wf-node{ fill:var(--bg-2, #141414); stroke:var(--rule); stroke-width:1; }
.ha-ai .wf-node.active{ stroke:var(--accent); stroke-width:1.5; }
.ha-ai .wf-txt{ font-family:var(--mono); font-size:9px; fill:var(--fg); letter-spacing:.12em; }
.ha-ai .wf-txt-sub{ font-size:7px; fill:var(--fg-dim); letter-spacing:.15em; }
.ha-ai .wf-line{ stroke:var(--rule); stroke-width:1; fill:none; }
.ha-ai .wf-packet{ fill:var(--accent); r:3; }

/* ─── 3. ARCOS Install — install progress ──────────────────── */
.ha-install .inst-row{ display:flex; align-items:center; gap:10px; margin-bottom:12px; font-size:10px; }
.ha-install .inst-idx{ color:var(--accent); width:24px; font-family:var(--mono); }
.ha-install .inst-lbl{ flex:1; color:var(--fg); text-transform:uppercase; letter-spacing:.1em; font-size:10px; }
.ha-install .inst-pct{ color:var(--fg-dim); font-family:var(--mono); width:40px; text-align:right; font-size:10px; }
.ha-install .inst-bar{ position:relative; height:4px; background:var(--rule); margin-bottom:14px; overflow:hidden; }
.ha-install .inst-fill{ position:absolute; left:0; top:0; height:100%; background:var(--accent); width:0; transition: width 2s cubic-bezier(.3,0,.2,1); }
.ha-install .inst-footer{ position:absolute; bottom:14px; left:14px; right:14px; padding-top:10px; border-top:1px solid var(--rule); display:flex; justify-content:space-between; font-size:9px; color:var(--fg-dim); letter-spacing:.15em; text-transform:uppercase; }
.ha-install .inst-footer .val{ color:var(--accent); font-family:var(--mono); }

/* ─── 4. ARCOS Sovereign — moat/vault ──────────────────────── */
.ha-sov .moat-svg{ width:100%; height:100%; }
.ha-sov .m-ring{ fill:none; stroke:var(--rule); stroke-width:1; }
.ha-sov .m-ring.active{ stroke:var(--accent); stroke-width:1.5; }
.ha-sov .m-lbl{ font-family:var(--mono); font-size:8px; fill:var(--fg); letter-spacing:.22em; }
.ha-sov .m-lbl-acc{ fill:var(--accent); }
.ha-sov .m-center{ font-family:var(--display); font-size:22px; fill:var(--accent); text-anchor:middle; dominant-baseline:middle; }
@keyframes ringPulse{ 0%,100%{ opacity:.3; } 50%{ opacity:1; } }
.ha-sov .m-ring{ animation: ringPulse 3s ease-in-out infinite; }
.ha-sov .m-ring:nth-child(2){ animation-delay:.5s; }
.ha-sov .m-ring:nth-child(3){ animation-delay:1s; }
.ha-sov .m-ring:nth-child(4){ animation-delay:1.5s; }

/* ─── 5. Book a Call — application slots ───────────────────── */
.ha-book .slot{ display:flex; justify-content:space-between; align-items:center; padding:14px 0; border-bottom:1px dashed var(--rule); font-size:11px; }
.ha-book .slot .sn{ font-family:var(--mono); color:var(--fg-dim); letter-spacing:.18em; font-size:9px; }
.ha-book .slot .sv{ font-family:var(--mono); letter-spacing:.15em; font-size:10px; }
.ha-book .slot.claimed .sv{ color:var(--accent); }
.ha-book .slot.claimed .sn{ color:var(--fg); }
.ha-book .slot.open .sv{ color:var(--fg-dim); }
.ha-book .slot.open .sv::before{ content:""; display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--accent); margin-right:8px; vertical-align:middle; animation: haPulse 1.6s ease-in-out infinite; }
.ha-book .slot-foot{ margin-top:16px; font-size:9px; letter-spacing:.2em; color:var(--fg-dim); text-transform:uppercase; }
.ha-book .slot-foot .val{ color:var(--accent); }

/* ─── 6. Agency — services stack ───────────────────────────── */
.ha-agency .svc-row{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:12px; padding:10px 0; border-bottom:1px solid var(--rule); font-size:10px; }
.ha-agency .svc-row:last-of-type{ border-bottom:0; }
.ha-agency .svc-ic{ width:22px; height:22px; border:1px solid var(--accent); display:flex; align-items:center; justify-content:center; font-family:var(--mono); color:var(--accent); font-size:10px; }
.ha-agency .svc-lbl{ font-family:var(--display); font-size:15px; letter-spacing:.02em; text-transform:uppercase; }
.ha-agency .svc-lbl .sub{ display:block; font-family:var(--mono); font-size:8px; color:var(--fg-dim); letter-spacing:.18em; font-weight:400; margin-top:2px; }
.ha-agency .svc-val{ font-family:var(--mono); font-size:10px; color:var(--accent); }
.ha-agency .svc-total{ margin-top:14px; padding-top:12px; border-top:1px solid var(--accent); display:flex; justify-content:space-between; font-family:var(--mono); font-size:10px; letter-spacing:.12em; text-transform:uppercase; }
.ha-agency .svc-total .val{ color:var(--accent); font-family:var(--display); font-size:18px; letter-spacing:0; }

/* ─── 7. Challenges — live cohort ──────────────────────────── */
.ha-challenge .ch-day{ font-family:var(--display); font-size:72px; line-height:.9; margin-bottom:4px; color:var(--accent); }
.ha-challenge .ch-day-lbl{ font-size:10px; letter-spacing:.22em; color:var(--fg-dim); text-transform:uppercase; margin-bottom:18px; }
.ha-challenge .ch-agenda{ display:flex; flex-direction:column; gap:6px; }
.ha-challenge .ch-item{ display:flex; gap:10px; align-items:center; font-size:10px; padding:6px 0; border-bottom:1px dashed var(--rule); }
.ha-challenge .ch-item .d{ color:var(--accent); font-family:var(--mono); width:32px; font-size:9px; letter-spacing:.15em; }
.ha-challenge .ch-item .t{ flex:1; letter-spacing:.02em; text-transform:uppercase; font-family:var(--display); font-size:13px; }
.ha-challenge .ch-item.done{ opacity:.4; }
.ha-challenge .ch-item.done .t{ text-decoration:line-through; }
.ha-challenge .ch-item.active .d::before{ content:""; display:inline-block; width:6px; height:6px; border-radius:50%; background:var(--accent); margin-right:6px; animation: haPulse 1.4s infinite; vertical-align:middle; }
.ha-challenge .ch-footer{ position:absolute; bottom:14px; left:14px; right:14px; padding-top:10px; border-top:1px solid var(--rule); display:flex; justify-content:space-between; font-size:9px; letter-spacing:.2em; color:var(--fg-dim); text-transform:uppercase; }
.ha-challenge .ch-footer .v{ color:var(--accent); font-family:var(--mono); }

/* ─── 8. Million Dollar Challenge — book ───────────────────── */
.ha-book3d{ perspective:1200px; display:flex; align-items:center; justify-content:center; }
.ha-book3d .ha-box{ background:transparent; border:0; }
.ha-book3d .book{ position:relative; width:220px; height:310px; transform-style:preserve-3d; transform:rotateY(-18deg) rotateX(6deg); animation: bookFloat 6s ease-in-out infinite; }
@keyframes bookFloat{ 0%,100%{ transform:rotateY(-18deg) rotateX(6deg) translateY(0); } 50%{ transform:rotateY(-22deg) rotateX(4deg) translateY(-10px); } }
.ha-book3d .book-front{ position:absolute; inset:0; background:linear-gradient(135deg, var(--accent) 0%, #111 100%); border:1px solid var(--accent); padding:22px 20px; display:flex; flex-direction:column; justify-content:space-between; box-shadow: -10px 10px 40px rgba(0,0,0,.6); }
.ha-book3d .book-side{ position:absolute; top:0; left:-14px; width:14px; height:100%; background:#1a1a1a; transform:rotateY(-90deg); transform-origin:right; border:1px solid var(--rule); }
.ha-book3d .book-top{ font-family:var(--mono); font-size:9px; letter-spacing:.22em; color:rgba(255,255,255,.6); text-transform:uppercase; }
.ha-book3d .book-title{ font-family:var(--display); font-size:32px; line-height:.9; color:#fff; }
.ha-book3d .book-title .it{ font-family:var(--serif, 'Instrument Serif', serif); font-style:italic; font-size:.9em; color:rgba(255,255,255,.85); }
.ha-book3d .book-author{ font-family:var(--mono); font-size:9px; letter-spacing:.22em; color:rgba(255,255,255,.7); }
.ha-book3d .book-pages{ position:absolute; top:4px; right:-4px; width:4px; height:calc(100% - 8px); background:repeating-linear-gradient(to bottom, #ddd 0 1px, #f5f5f5 1px 2px); }

/* ─── 9. Digital Hustlers — 12 systems matrix ──────────────── */
.ha-dh .dh-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:4px; height:calc(100% - 48px); }
.ha-dh .dh-cell{ border:1px solid var(--rule); display:flex; flex-direction:column; justify-content:center; align-items:center; text-align:center; padding:6px; position:relative; transition: all .3s; font-size:8px; letter-spacing:.08em; color:var(--fg-dim); text-transform:uppercase; font-family:var(--mono); }
.ha-dh .dh-cell.on{ border-color:var(--accent); background:rgba(0,255,128,.04); color:var(--accent); }
.ha-dh .dh-cell .n{ font-family:var(--display); font-size:14px; color:inherit; margin-bottom:2px; line-height:1; }
.ha-dh .dh-head{ display:flex; justify-content:space-between; margin-bottom:8px; font-size:9px; letter-spacing:.2em; color:var(--fg-dim); text-transform:uppercase; }
.ha-dh .dh-head .v{ color:var(--accent); }
.ha-dh .dh-foot{ position:absolute; bottom:14px; left:14px; right:14px; font-size:9px; letter-spacing:.2em; color:var(--fg-dim); text-transform:uppercase; display:flex; justify-content:space-between; padding-top:8px; border-top:1px solid var(--rule); }
.ha-dh .dh-foot .v{ color:var(--accent); font-family:var(--mono); }

/* ─── 10. Invisible Rich — newsletter envelope ─────────────── */
.ha-news .env{ position:relative; border:1px solid var(--rule); padding:18px; background:rgba(255,255,255,.015); margin-bottom:12px; }
.ha-news .env-hdr{ display:flex; justify-content:space-between; margin-bottom:14px; font-size:9px; letter-spacing:.18em; color:var(--fg-dim); text-transform:uppercase; }
.ha-news .env-hdr .from{ color:var(--accent); }
.ha-news .env-subj{ font-family:var(--display); font-size:22px; line-height:1; margin-bottom:10px; min-height:44px; }
.ha-news .env-subj .cursor{ display:inline-block; width:2px; height:20px; background:var(--accent); animation: blink 1s step-end infinite; vertical-align:middle; margin-left:2px; }
@keyframes blink{ 50%{ opacity:0; } }
.ha-news .env-meta{ font-family:var(--mono); font-size:9px; color:var(--fg-dim); letter-spacing:.12em; }
.ha-news .news-stats{ display:grid; grid-template-columns:1fr 1fr; gap:8px; }
.ha-news .news-stat{ border:1px solid var(--rule); padding:10px; }
.ha-news .news-stat .k{ font-size:8px; letter-spacing:.2em; color:var(--fg-dim); text-transform:uppercase; margin-bottom:4px; }
.ha-news .news-stat .v{ font-family:var(--display); font-size:22px; line-height:1; color:var(--accent); }

/* prevent hero grid background from fighting the asset */
.pg-hero.has-hero-asset::before,
.ir-hero.has-hero-asset::before{ opacity:.2 !important; }

/* constrain headline + lede width when a hero asset is present, so they don't overlap */
.pg-hero.has-hero-asset .pg-headline,
.pg-hero.has-hero-asset h1,
.ir-hero.has-hero-asset .ir-headline,
.ir-hero.has-hero-asset h1{
  max-width: min(55%, 16ch);
}
/* Larger override only when the page opts in via .hero-asset-big */
.pg-hero.has-hero-asset.hero-asset-big .pg-headline,
.pg-hero.has-hero-asset.hero-asset-big h1,
.ir-hero.has-hero-asset.hero-asset-big .ir-headline,
.ir-hero.has-hero-asset.hero-asset-big h1{
  font-size: clamp(40px, 6.2vw, 96px) !important;
}
.pg-hero.has-hero-asset .pg-lede-grid,
.pg-hero.has-hero-asset .lede,
.ir-hero.has-hero-asset .ir-lede-grid,
.ir-hero.has-hero-asset .lede{
  grid-template-columns: minmax(0, 1fr);
  max-width: 55%;
}
@media (max-width:1100px){
  .pg-hero.has-hero-asset .pg-headline,
  .pg-hero.has-hero-asset h1,
  .ir-hero.has-hero-asset .ir-headline,
  .ir-hero.has-hero-asset h1,
  .pg-hero.has-hero-asset .pg-lede-grid,
  .ir-hero.has-hero-asset .ir-lede-grid,
  .pg-hero.has-hero-asset .lede,
  .ir-hero.has-hero-asset .lede{ max-width: 58%; }
}
@media (max-width:900px){
  .pg-hero.has-hero-asset .pg-headline,
  .pg-hero.has-hero-asset h1,
  .ir-hero.has-hero-asset .ir-headline,
  .ir-hero.has-hero-asset h1,
  .pg-hero.has-hero-asset .pg-lede-grid,
  .ir-hero.has-hero-asset .ir-lede-grid,
  .pg-hero.has-hero-asset .lede,
  .ir-hero.has-hero-asset .lede{ max-width: 100%; }
}
