/* ============================================================
   BINOBAN — Product mockups & architecture diagrams
   Conceptual, brand-aligned representations of the platform.
   Stylized illustrations of how the system works, not claims
   of literal product UI. Loaded after binoban-pages.css.
   ============================================================ */

/* ---- shared app-window frame ---- */
.mk{ --mk-line:var(--hairline-dark2); --mk-soft:var(--on-dark-soft); --mk-mute:var(--on-dark-mute);
  position:relative; border:1px solid var(--hairline-dark); border-radius:14px; overflow:hidden;
  background:linear-gradient(180deg,#0c1a33,#091428);
  box-shadow:0 40px 90px -40px rgba(0,0,0,.75); font-size:13px; color:var(--on-dark); }
.bg-paper .mk,.bg-paper-2 .mk{ background:linear-gradient(180deg,#0c1a33,#091428); color:var(--on-dark); border-color:rgba(0,0,0,.18); }
.mk-bar{ display:flex; align-items:center; gap:8px; padding:12px 16px; border-bottom:1px solid var(--mk-line);
  background:rgba(255,255,255,.02); }
.mk-dots{ display:flex; gap:6px; }
.mk-dots i{ width:9px; height:9px; border-radius:50%; background:rgba(243,241,234,.18); }
.mk-title{ font-size:11px; font-weight:700; letter-spacing:.14em; text-transform:uppercase; color:var(--mk-mute); margin-left:6px; }
.mk-chip-live{ margin-left:auto; display:inline-flex; align-items:center; gap:6px; font-size:10px; font-weight:700;
  letter-spacing:.1em; text-transform:uppercase; color:var(--gold-bright); }
.mk-chip-live::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--gold); box-shadow:0 0 0 3px rgba(205,163,102,.18); }
.mk-body{ padding:22px; }
.mk-cap{ margin-top:14px; font-size:12.5px; line-height:1.5; color:var(--ink-mute); text-align:center; }
.bg-deep .mk-cap,.bg-navy .mk-cap{ color:var(--on-dark-mute); }

/* ============================================================
   1. CUSTOMER PROFILE
   ============================================================ */
.mk-profile .mk-body{ display:grid; gap:18px; }
.mk-id{ display:flex; align-items:center; gap:14px; }
.mk-avatar{ width:52px; height:52px; border-radius:50%; flex:none;
  background:radial-gradient(circle at 35% 30%, #c8924e, #6f4a1f);
  display:flex; align-items:center; justify-content:center; font-weight:900; font-size:18px; color:#1a1205; }
.mk-id h4{ margin:0; font-size:17px; font-weight:900; letter-spacing:-.01em; }
.mk-id .mk-sub{ font-size:11.5px; color:var(--mk-mute); letter-spacing:.02em; margin-top:2px; }
.mk-badges{ display:flex; flex-wrap:wrap; gap:6px; }
.mk-badge{ display:inline-flex; align-items:center; gap:5px; font-size:10.5px; font-weight:600; letter-spacing:.02em;
  padding:4px 9px; border:1px solid var(--mk-line); border-radius:100px; color:var(--mk-soft); }
.mk-badge::before{ content:""; width:5px; height:5px; border-radius:50%; background:var(--gold); }
.mk-stats{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--mk-line);
  border:1px solid var(--mk-line); border-radius:10px; overflow:hidden; }
.mk-stat{ background:#0b1830; padding:13px 14px; }
.mk-stat .v{ font-size:18px; font-weight:900; letter-spacing:-.02em; color:var(--on-dark); }
.mk-stat .v .gold{ color:var(--gold-bright); }
.mk-stat .l{ font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--mk-mute); margin-top:3px; }
.mk-tabs{ display:flex; gap:22px; border-bottom:1px solid var(--mk-line); padding-bottom:2px; }
.mk-tabs span{ font-size:12px; font-weight:600; color:var(--mk-mute); padding-bottom:10px; position:relative; }
.mk-tabs span.on{ color:var(--on-dark); }
.mk-tabs span.on::after{ content:""; position:absolute; left:0; right:0; bottom:-1px; height:2px; background:var(--gold); }
.mk-events{ display:flex; flex-direction:column; gap:0; }
.mk-event{ display:grid; grid-template-columns:78px 1fr auto; align-items:center; gap:14px;
  padding:11px 0; border-top:1px solid var(--mk-line); }
.mk-event:first-child{ border-top:0; }
.mk-event .t{ font-size:10.5px; color:var(--mk-mute); letter-spacing:.02em; }
.mk-event .d{ font-size:12.5px; color:var(--mk-soft); }
.mk-event .d b{ color:var(--on-dark); font-weight:700; }
.mk-event .tag{ font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
  padding:3px 8px; border-radius:5px; }
.mk-event .tag.buy{ color:#8fd6a8; background:rgba(95,180,130,.12); }
.mk-event .tag.view{ color:var(--gold-bright); background:rgba(205,163,102,.12); }
.mk-event .tag.eng{ color:#9db8e0; background:rgba(120,150,210,.14); }
.mk-segs{ display:flex; flex-wrap:wrap; gap:7px; }
.mk-seg{ font-size:11px; font-weight:600; padding:5px 11px; border-radius:100px;
  border:1px solid rgba(205,163,102,.35); color:var(--gold-bright); background:rgba(205,163,102,.07); }

/* ============================================================
   2. IDENTITY GRAPH
   ============================================================ */
.mk-graph .mk-body{ position:relative; min-height:300px; }
.mk-graph svg{ position:absolute; inset:0; width:100%; height:100%; pointer-events:none; }
.mk-graph svg line{ stroke:rgba(205,163,102,.4); stroke-width:1.2; }
.mk-graph svg line.prob{ stroke-dasharray:4 4; stroke:rgba(157,184,224,.4); }
.mk-node{ position:absolute; transform:translate(-50%,-50%); display:flex; flex-direction:column; align-items:center;
  gap:5px; width:104px; text-align:center; }
.mk-node .chip{ width:100%; padding:8px 6px; border:1px solid var(--mk-line); border-radius:9px;
  background:#0b1830; font-size:11px; font-weight:700; color:var(--on-dark); }
.mk-node .meta{ font-size:9.5px; letter-spacing:.04em; color:var(--mk-mute); }
.mk-node .meta b{ color:var(--gold-bright); font-weight:700; }
.mk-node.center .chip{ border-color:var(--gold); background:linear-gradient(180deg,rgba(205,163,102,.16),rgba(205,163,102,.06));
  box-shadow:0 0 0 4px rgba(205,163,102,.08); padding:13px 8px; font-size:12px; }
.mk-legend{ display:flex; gap:18px; justify-content:center; margin-top:6px; padding-top:14px; border-top:1px solid var(--mk-line); }
.mk-legend span{ display:inline-flex; align-items:center; gap:7px; font-size:10.5px; color:var(--mk-mute); letter-spacing:.03em; }
.mk-legend span i{ width:16px; height:0; border-top:1.4px solid var(--gold); }
.mk-legend span i.prob{ border-top-style:dashed; border-color:#9db8e0; }

/* ============================================================
   3. JOURNEY FLOW
   ============================================================ */
.mk-journey .mk-body{ overflow-x:auto; }
.mk-flow{ display:flex; align-items:stretch; gap:0; min-width:560px; }
.mk-step{ display:flex; align-items:center; }
.mk-fnode{ width:150px; border:1px solid var(--mk-line); border-radius:11px; background:#0b1830; padding:14px; }
.mk-fnode .ftype{ font-size:9.5px; font-weight:800; letter-spacing:.12em; text-transform:uppercase; margin-bottom:8px; }
.mk-fnode .fname{ font-size:13px; font-weight:700; color:var(--on-dark); line-height:1.3; }
.mk-fnode .fmeta{ font-size:11px; color:var(--mk-mute); margin-top:6px; line-height:1.4; }
.mk-fnode.trigger{ border-color:rgba(205,163,102,.4); }
.mk-fnode.trigger .ftype{ color:var(--gold-bright); }
.mk-fnode.cond .ftype{ color:#9db8e0; }
.mk-fnode.action .ftype{ color:#8fd6a8; }
.mk-branch{ display:flex; flex-direction:column; gap:12px; }
.mk-conn{ width:34px; flex:none; align-self:center; display:flex; align-items:center; justify-content:center; color:rgba(205,163,102,.55); }
.mk-conn svg{ width:34px; height:14px; }

/* ============================================================
   4. RETAIL MEDIA CAMPAIGN
   ============================================================ */
.mk-rmp .mk-body{ display:grid; grid-template-columns:1.1fr 1fr; gap:18px; }
.mk-placement{ border:1px solid var(--mk-line); border-radius:10px; overflow:hidden; background:#0b1830; }
.mk-placement .ph-top{ display:flex; align-items:center; justify-content:space-between; padding:9px 12px; border-bottom:1px solid var(--mk-line); }
.mk-placement .ph-top .lbl{ font-size:10px; letter-spacing:.1em; text-transform:uppercase; color:var(--mk-mute); }
.mk-spons{ font-size:9px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--gold-bright);
  border:1px solid rgba(205,163,102,.4); border-radius:4px; padding:2px 6px; }
.mk-products{ display:grid; grid-template-columns:repeat(3,1fr); gap:8px; padding:12px; }
.mk-prod{ border:1px solid var(--mk-line); border-radius:7px; padding:8px; }
.mk-prod .sw{ height:42px; border-radius:5px; background:linear-gradient(135deg,#16294a,#0e1d38); margin-bottom:7px;
  position:relative; }
.mk-prod.feat .sw{ background:linear-gradient(135deg,rgba(205,163,102,.32),rgba(205,163,102,.1)); }
.mk-prod .pn{ font-size:9.5px; color:var(--mk-soft); line-height:1.3; }
.mk-prod .pp{ font-size:10px; font-weight:800; color:var(--on-dark); margin-top:3px; }
.mk-rmp-side{ display:grid; gap:14px; align-content:start; }
.mk-rmp-side .blk-label{ font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--mk-mute); margin-bottom:9px; }
.mk-metrics{ display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--mk-line); border:1px solid var(--mk-line); border-radius:9px; overflow:hidden; }
.mk-metric{ background:#0b1830; padding:11px 13px; }
.mk-metric .v{ font-size:17px; font-weight:900; letter-spacing:-.02em; color:var(--gold-bright); }
.mk-metric .l{ font-size:9.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--mk-mute); margin-top:2px; }
.mk-bars{ display:flex; align-items:flex-end; gap:6px; height:60px; padding-top:4px; }
.mk-bars i{ flex:1; background:linear-gradient(180deg,var(--gold),rgba(205,163,102,.25)); border-radius:3px 3px 0 0; }

/* ============================================================
   5. DEPLOYMENT ARCHITECTURE  +  6. EVENT PIPELINE
   ============================================================ */
.mk-arch .mk-body{ display:grid; gap:0; }
.mk-boundary{ border:1.5px dashed rgba(205,163,102,.5); border-radius:12px; padding:16px; position:relative; margin-top:14px; }
.mk-boundary .bnd-tag{ position:absolute; top:-10px; left:18px; background:#091428; padding:0 10px;
  font-size:10px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--gold-bright); }
.mk-tier{ display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.mk-tier + .mk-tier{ margin-top:10px; }
.mk-tierlabel{ width:96px; flex:none; font-size:10px; font-weight:700; letter-spacing:.08em; text-transform:uppercase; color:var(--mk-mute); }
.mk-mod{ flex:1; min-width:96px; border:1px solid var(--mk-line); border-radius:8px; background:#0b1830;
  padding:11px 12px; font-size:12px; font-weight:700; color:var(--on-dark); text-align:center; }
.mk-mod.core{ border-color:rgba(205,163,102,.4); background:linear-gradient(180deg,rgba(205,163,102,.12),rgba(205,163,102,.04)); }
.mk-mod small{ display:block; font-size:9.5px; font-weight:500; letter-spacing:.02em; color:var(--mk-mute); margin-top:3px; }
.mk-ext{ display:flex; gap:10px; flex-wrap:wrap; justify-content:center; margin-bottom:6px; }
.mk-ext .x{ border:1px dashed var(--mk-line); border-radius:7px; padding:9px 13px; font-size:11px; color:var(--mk-soft); }

/* pipeline */
.mk-pipe .mk-body{ overflow-x:auto; }
.mk-pipeline{ display:flex; align-items:center; gap:0; min-width:640px; }
.mk-pstage{ flex:1; min-width:96px; text-align:center; }
.mk-pstage .pn{ width:46px; height:46px; margin:0 auto 9px; border-radius:11px; border:1px solid var(--mk-line);
  background:#0b1830; display:flex; align-items:center; justify-content:center; color:var(--gold-bright); }
.mk-pstage .pn svg{ width:22px; height:22px; }
.mk-pstage .ps{ font-size:11.5px; font-weight:700; color:var(--on-dark); line-height:1.25; }
.mk-pstage .pd{ font-size:10px; color:var(--mk-mute); margin-top:4px; line-height:1.35; }
.mk-parrow{ flex:none; width:30px; color:rgba(205,163,102,.5); display:flex; justify-content:center; }
.mk-parrow svg{ width:26px; height:12px; }

@media (max-width:820px){
  .mk-rmp .mk-body{ grid-template-columns:1fr; }
  .mk-stats{ grid-template-columns:repeat(2,1fr); }
  .mk-tierlabel{ width:100%; }
}

/* showcase wrapper: centers a mockup with breathing room */
.mk-showcase{ margin-top:clamp(40px,5vw,64px); max-width:820px; margin-left:auto; margin-right:auto; }
.mk-showcase--wide{ max-width:960px; }
