/* ============================================================
   EIGHT47 — DIRECTION IV · OPERATOR  ·  MODULE PAGES
   Shared additions for the three module pages.
   Inherits all tokens + base components from styles.css.
   ============================================================ */

/* nav: module label retired — kept hidden to avoid crowding the brand */
.nav-mod{display:none!important}

/* hero: module variant — slightly tighter, artifact-led */
.hero .eyebrow .mi{color:var(--txt-2);font-weight:400}

/* ---- generic chips row ---- */
.chips{display:flex;gap:6px;flex-wrap:wrap;margin-top:13px}
.chips span{font-family:var(--mono);font-size:9.5px;letter-spacing:0.05em;text-transform:uppercase;color:var(--txt-3);border:1px solid var(--line-2);border-radius:3px;padding:4px 8px;display:inline-flex;align-items:center;gap:6px;white-space:nowrap}
.chips span.src{color:var(--txt-2)}
.chips span.on{color:var(--sage);border-color:var(--sage-dim)}
.chips span .pip{width:4px;height:4px;border-radius:50%;background:var(--gold);flex:none}
.chips span.on .pip{background:var(--sage)}

/* ============================================================
   ARTIFACT CARD SHELL (hero interface artifact)
   ============================================================ */
.acard{background:linear-gradient(180deg,var(--surf-2),var(--surf));border:1px solid var(--line-2);border-radius:10px;box-shadow:0 30px 70px -30px rgba(0,0,0,0.7),inset 0 1px 0 rgba(236,231,219,0.05);overflow:hidden}
.acard-top{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.acard-top .tt{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold)}
.acard-top .rt{font-family:var(--mono);font-size:10px;letter-spacing:0.06em;text-transform:uppercase;color:var(--txt-3)}
.acard-body{padding:20px}
.acard-foot{display:flex;align-items:center;gap:9px;padding:13px 20px;border-top:1px solid var(--line);background:rgba(0,0,0,0.18);font-family:var(--mono);font-size:9.5px;letter-spacing:0.05em;text-transform:uppercase;color:var(--txt-3);flex-wrap:wrap}
.acard-foot .sp{color:var(--line-3)}

/* card action row */
.acts{display:flex;align-items:center;gap:10px;margin-top:18px;flex-wrap:wrap}
.acts .primary{background:var(--gold);color:var(--bg);font-size:13px;font-weight:600;padding:9px 18px;border-radius:4px;border:1px solid var(--gold)}
.acts .ghost{background:transparent;border:1px solid var(--line-3);color:var(--txt);font-size:13px;font-weight:600;padding:9px 18px;border-radius:4px}
.acts .spacer{flex:1}

/* ---- support conversation (customer service) ---- */
.msg{margin-bottom:13px}
.msg .lbl{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:9px;letter-spacing:0.08em;text-transform:uppercase;color:var(--txt-3);margin-bottom:7px}
.msg .bubble{background:var(--surf-3);border-radius:11px;border-top-left-radius:3px;padding:13px 15px;font-size:14.5px;color:var(--txt);line-height:1.45}
.msg.draft .lbl{color:var(--gold)}
.msg.draft .bubble{background:transparent;border:1px solid var(--gold-line);border-top-left-radius:11px;border-bottom-left-radius:3px;font-family:var(--serif);font-style:italic}

/* ---- voice-match meter (marketing) ---- */
.vmatch{display:inline-flex;align-items:center;gap:9px;font-family:var(--mono);font-size:10px;letter-spacing:0.04em;color:var(--sage);text-transform:none}
.vmatch .track{width:46px;height:4px;background:var(--line-2);border-radius:2px;overflow:hidden}
.vmatch .fill{height:100%;background:var(--sage);border-radius:2px}

/* marketing draft post body */
.post{font-family:var(--serif);font-size:16px;line-height:1.5;color:var(--txt);letter-spacing:-0.005em}
.post .muted{color:var(--txt-2)}
.post .cursor{display:inline-block;width:8px;height:18px;background:var(--gold);vertical-align:-3px;margin-left:2px;animation:blink 1.1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
@media(prefers-reduced-motion:reduce){.post .cursor{animation:none}}

/* ---- build card rows (bespoke) reuse .onepg from styles.css ---- */
.acard-body .onepg .row .k{min-width:88px}
.statline{display:flex;align-items:center;gap:9px;margin-top:16px;padding-top:14px;border-top:1px solid var(--line);font-family:var(--mono);font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--sage)}

/* ============================================================
   "WHAT IT DOES" — capability list
   ============================================================ */
.caps{list-style:none;margin-top:8px;border-top:1px solid var(--line-2)}
.caps li{display:grid;grid-template-columns:auto 1fr;gap:18px;padding:20px 0;border-bottom:1px solid var(--line);font-size:16.5px;color:var(--txt);align-items:baseline;line-height:1.45}
.caps li .k{font-family:var(--mono);font-size:11px;color:var(--gold);letter-spacing:0.04em;padding-top:3px}
.caps li em{font-style:italic;color:var(--gold-soft);font-family:var(--serif)}

/* ============================================================
   "HOW IT COMPOUNDS" — statement + cross links
   ============================================================ */
.compound{display:grid;grid-template-columns:1.05fr 0.95fr;gap:clamp(30px,5vw,64px);align-items:center}
.xlinks{display:flex;flex-direction:column;border-top:1px solid var(--line-2)}
.xlink{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:18px 2px;border-bottom:1px solid var(--line);transition:padding-left .18s,background .18s}
.xlink:hover{padding-left:10px;background:rgba(236,231,219,0.02)}
.xlink .xl{display:flex;flex-direction:column;gap:5px}
.xlink .xt{font-size:17.5px;color:var(--txt);font-weight:600}
.xlink .xs{font-family:var(--mono);font-size:10px;letter-spacing:0.06em;text-transform:uppercase;color:var(--txt-3)}
.xlink .arr{color:var(--gold);font-size:17px;transition:transform .2s;flex:none}
.xlink:hover .arr{transform:translateX(5px)}

/* CTA closing band */
.close-cta{text-align:center}
.close-cta .kicker{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);margin-bottom:18px}
.close-cta h2{font-family:var(--serif);font-weight:400;font-size:clamp(30px,4.6vw,54px);letter-spacing:-0.02em;max-width:20ch;margin:0 auto}
.close-cta h2 em{font-style:italic;color:var(--gold-soft)}
.close-cta .sub{font-size:17px;color:var(--txt-2);max-width:46ch;margin:22px auto 0}
.close-cta .row{display:flex;gap:14px;justify-content:center;align-items:center;margin-top:34px;flex-wrap:wrap}
.close-cta .note{font-family:var(--mono);font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--txt-3);display:flex;align-items:center;gap:8px;margin-top:24px;justify-content:center}

/* ============================================================
   ORIGIN PAGE — "Who's behind Eight47"
   ============================================================ */

/* hero "operating" panel — our own usage, labelled */
.ops{background:var(--surf);border:1px solid var(--line-2);border-radius:10px;overflow:hidden;box-shadow:0 30px 70px -40px rgba(0,0,0,0.7)}
.ops-top{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.ops-top .lt{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold)}
.ops-top .lv{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:9.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--sage)}
.ops-row{display:grid;grid-template-columns:128px 1fr auto;gap:16px;padding:16px 20px;border-bottom:1px solid var(--line);align-items:center}
.ops-row:last-of-type{border-bottom:0}
.ops-row .pn{font-family:var(--mono);font-size:11.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--gold-soft)}
.ops-row .pd{font-size:13.5px;color:var(--txt-2);line-height:1.4}
.ops-row .pt{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:9.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--sage);white-space:nowrap}
.ops-foot{display:flex;align-items:center;gap:9px;padding:13px 20px;border-top:1px solid var(--line);background:rgba(0,0,0,0.18);font-family:var(--mono);font-size:9.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--txt-3)}

/* coordination proof band */
.coord{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}
.coordcell{background:var(--surf);border:1px solid var(--line-2);border-radius:9px;padding:26px 24px;display:flex;flex-direction:column;gap:10px}
.coordcell .cfig{display:flex;align-items:baseline;gap:12px}
.coordcell .cnum{font-family:var(--serif);font-size:clamp(40px,5.4vw,62px);line-height:0.9;color:var(--gold-soft);letter-spacing:-0.02em}
.coordcell .cunit{font-family:var(--mono);font-size:10.5px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);max-width:11ch;line-height:1.4}
.coordcell .cdesc{font-size:15px;line-height:1.5;color:var(--txt-2)}
.coordcell .cdesc em{font-style:normal;color:var(--txt)}
.coordcell .ctag{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:9.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--sage);border-top:1px solid var(--line);padding-top:13px;margin-top:4px}

/* pull line — large brass italic */
.pull{text-align:center;padding:clamp(40px,7vh,80px) 0}
.pull p{font-family:var(--serif);font-style:italic;font-size:clamp(28px,4.6vw,52px);letter-spacing:-0.02em;color:var(--txt);max-width:20ch;margin:0 auto;line-height:1.1}
.pull p em{color:var(--gold-soft);font-style:italic}

/* portfolio cards */
.pf{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-top:8px}
.pfcard{background:var(--surf);border:1px solid var(--line-2);border-radius:9px;padding:24px 22px;display:flex;flex-direction:column;gap:11px;transition:transform .2s,border-color .2s}
.pfcard:hover{transform:translateY(-3px);border-color:var(--line-3)}
.pfcard .pfn{font-family:var(--serif);font-size:24px;color:var(--txt);letter-spacing:-0.01em}
.pfcard .pfk{font-family:var(--mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold)}
.pfcard .pfd{font-size:14.5px;color:var(--txt-2);line-height:1.5;flex:1}
.pfcard .pfs{display:flex;align-items:center;gap:8px;font-family:var(--mono);font-size:9.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--sage);border-top:1px solid var(--line);padding-top:13px;margin-top:4px}

/* founder */
.founder{display:grid;grid-template-columns:300px 1fr;gap:clamp(30px,5vw,60px);align-items:center}
.fphoto{position:relative;border:1px solid var(--line-2);border-radius:10px;overflow:hidden;background:var(--surf);box-shadow:0 30px 70px -38px rgba(0,0,0,0.8)}
.fphoto img{display:block;width:100%;height:auto;filter:grayscale(0.32) contrast(1.02)}
.fphoto figcaption{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:13px 16px;border-top:1px solid var(--line);font-family:var(--mono);font-size:10px;letter-spacing:0.06em;text-transform:uppercase;color:var(--txt-3)}
.fphoto figcaption .nm{color:var(--gold)}
.fname{font-family:var(--serif);font-size:clamp(26px,3.4vw,38px);font-weight:400;letter-spacing:-0.015em;color:var(--txt)}
.frole{font-family:var(--mono);font-size:11px;letter-spacing:0.1em;text-transform:uppercase;color:var(--txt-3);margin-top:8px}
.fquote{border-left:1px solid var(--gold-line);padding-left:24px;margin-top:26px}
.fquote p{font-family:var(--serif);font-style:italic;font-size:clamp(19px,2.2vw,25px);line-height:1.32;color:var(--txt);letter-spacing:-0.01em}
.fquote .attr{font-family:var(--mono);font-style:normal;font-size:10.5px;letter-spacing:0.08em;text-transform:uppercase;color:var(--gold);margin-top:16px;display:block}

/* two-entity split */
.entity{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--line-2);margin-top:8px}
.ecol{padding:28px 28px 4px 0;border-right:1px solid var(--line)}
.ecol:last-child{border-right:0;padding-right:0;padding-left:28px}
.ecol .eh{font-family:var(--serif);font-size:24px;color:var(--txt);margin-bottom:6px}
.ecol .ek{font-family:var(--mono);font-size:10px;letter-spacing:0.1em;text-transform:uppercase;color:var(--gold);margin-bottom:13px}
.ecol p{font-size:15px;line-height:1.55;color:var(--txt-2)}

/* homepage origin section (on index) */
.origin-hp{display:grid;grid-template-columns:88px 1fr;gap:26px;align-items:center;margin-top:8px}
.origin-hp .oface{width:88px;height:88px;border-radius:50%;overflow:hidden;border:1px solid var(--gold-line)}
.origin-hp .oface img{width:100%;height:100%;object-fit:cover;filter:grayscale(0.3)}
.origin-hp .attr{font-family:var(--mono);font-size:10.5px;letter-spacing:0.06em;text-transform:uppercase;color:var(--txt-3);margin-top:20px;display:flex;align-items:center;gap:9px;flex-wrap:wrap}

@media(max-width:920px){
  .compound{grid-template-columns:1fr;gap:34px}
  .pf{grid-template-columns:1fr}
  .founder{grid-template-columns:1fr;gap:28px}
  .fphoto{max-width:300px}
  .entity{grid-template-columns:1fr}
  .ecol{border-right:0;border-bottom:1px solid var(--line);padding:24px 0}
  .ecol:last-child{padding-left:0}
}
