/* ============================================================
   lyncc.io — Desktop platform mock (shared: home + platform)
   B2B desktop dashboard frame + views for the product demo.
   ============================================================ */

/* ---------- browser frame ---------- */
.browser { background: var(--bg-ink-2); border: 1px solid var(--border-ink); border-radius: 14px;
  box-shadow: 0 -2px 0 rgba(255,255,255,.03), 0 40px 90px rgba(0,0,0,.5); overflow: hidden; }
.browser.flush-bottom { border-radius: 14px 14px 0 0; }
.browser-bar { display: flex; align-items: center; gap: 14px; padding: 13px 16px; border-bottom: 1px solid var(--border-ink); background: var(--bg-ink-2); }
.browser-dots { display: flex; gap: 7px; }
.browser-dots span { width: 11px; height: 11px; border-radius: 50%; background: #4A463F; }
.browser-url { flex: 1; max-width: 380px; margin: 0 auto; display: flex; align-items: center; gap: 8px;
  font-family: var(--font-mono); font-size: 12px; color: var(--fg-on-ink-2);
  background: var(--lyncc-ink); border: 1px solid var(--border-ink); border-radius: var(--r-pill); padding: 6px 14px; }
.browser-url svg { width: 12px; height: 12px; color: var(--lyncc-yellow); }
.browser-body { background: var(--bg-paper); color: var(--fg-1); }

/* ---------- dashboard layout ---------- */
.dash { display: grid; grid-template-columns: 214px 1fr; min-height: 470px; }
.dash-side { background: var(--lyncc-ink); padding: 22px 16px; display: flex; flex-direction: column; gap: 4px; }
.dash-side .brand { display: flex; align-items: center; gap: 9px; margin: 2px 6px 22px; }
.dash-side .brand img { height: 22px; }
.dash-nav-item { display: flex; align-items: center; gap: 11px; padding: 9px 11px; border-radius: var(--r-sm); font-size: 13.5px; color: var(--fg-on-ink-2); font-weight: 500; cursor: default; transition: background var(--dur) var(--ease-out), color var(--dur) var(--ease-out); }
.dash-nav-item svg { width: 17px; height: 17px; }
.dash-nav-item.active { background: var(--bg-ink-2); color: var(--fg-on-ink); }
.dash-nav-item.active svg { color: var(--lyncc-yellow); }
.dash-side .spacer { flex: 1; }
.dash-mgr { display: flex; align-items: center; gap: 10px; padding: 11px; border-radius: var(--r-md); background: var(--bg-ink-2); border: 1px solid var(--border-ink); }
.dash-mgr .avatar { width: 30px; height: 30px; border-radius: 50%; background: var(--lyncc-yellow); color: var(--lyncc-ink); display: grid; place-items: center; font-weight: 700; font-size: 12px; }
.dash-mgr .meta { line-height: 1.3; }
.dash-mgr .meta b { font-size: 12.5px; color: var(--fg-on-ink); display: block; }
.dash-mgr .meta span { font-size: 11px; color: var(--fg-on-ink-2); }

.dash-main { padding: 24px 26px; background: var(--bg-paper); position: relative; }
.dash-head { display: flex; align-items: center; margin-bottom: 18px; }
.dash-head h4 { font-family: var(--font-display); font-weight: 600; font-size: 18px; margin: 0; letter-spacing: -.01em; }
.dash-head .sub { font-size: 12.5px; color: var(--fg-3); margin-top: 2px; }
.dash-head .pill { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-mono); font-size: 11px; color: var(--ok); background: rgba(46,125,91,.1); border: 1px solid rgba(46,125,91,.25); padding: 5px 11px; border-radius: var(--r-pill); }
.dash-head .pill .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--ok); }

.dash-cards { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; margin-bottom: 18px; }
.dash-stat { background: var(--bg-card); border: 1px solid var(--border-1); border-radius: var(--r-md); padding: 14px; }
.dash-stat .k { font-family: var(--font-mono); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--fg-3); }
.dash-stat .v { font-family: var(--font-display); font-weight: 600; font-size: 24px; letter-spacing: -.02em; margin-top: 6px; }
.dash-stat .v small { font-size: 13px; color: var(--fg-3); font-weight: 500; }

/* ---------- lot tracker timeline ---------- */
.tracker { background: var(--bg-card); border: 1px solid var(--border-1); border-radius: var(--r-md); padding: 18px 18px 20px; }
.tracker-top { display: flex; align-items: center; margin-bottom: 22px; }
.tracker-top .lot { font-family: var(--font-mono); font-size: 12px; color: var(--fg-2); }
.tracker-top .lot b { color: var(--fg-1); }
.tracker-top .tag { margin-left: auto; font-size: 11px; font-weight: 600; color: var(--lyncc-ink); background: var(--lyncc-yellow); padding: 4px 10px; border-radius: var(--r-pill); }
.steps { display: grid; grid-template-columns: repeat(5,1fr); position: relative; }
.steps::before { content: ""; position: absolute; left: 6%; right: 6%; top: 11px; height: 2px; background: var(--border-2); }
.steps .bar-fill { position: absolute; left: 6%; top: 11px; height: 2px; background: var(--lyncc-yellow); width: 0; transition: width 1.1s var(--ease-out); }
.step { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; gap: 9px; text-align: center; }
.step .node { width: 24px; height: 24px; border-radius: 50%; background: var(--bg-card); border: 2px solid var(--border-2); display: grid; place-items: center; color: var(--fg-4); transition: all var(--dur) var(--ease-out); }
.step .node svg { width: 12px; height: 12px; }
.step.done .node { background: var(--lyncc-yellow); border-color: var(--lyncc-yellow); color: var(--lyncc-ink); }
.step.current .node { background: var(--lyncc-ink); border-color: var(--lyncc-ink); color: var(--lyncc-yellow); box-shadow: 0 0 0 4px rgba(26,26,26,.08); }
.step .lbl { font-size: 11px; font-weight: 600; color: var(--fg-2); line-height: 1.25; }
.step .when { font-family: var(--font-mono); font-size: 9.5px; color: var(--fg-4); }
.step.done .lbl, .step.current .lbl { color: var(--fg-1); }

/* ---------- mini list rows (used in feature visuals) ---------- */
.mini-dash { width: 100%; background: var(--lyncc-ink); border-radius: var(--r-md); padding: 16px; box-shadow: var(--sh-lg); }
.mini-row { display: flex; align-items: center; gap: 10px; padding: 11px 12px; border-radius: var(--r-sm); background: var(--bg-ink-2); margin-bottom: 8px; border: 1px solid var(--border-ink); }
.mini-row:last-child { margin-bottom: 0; }
.mini-row .mi { width: 30px; height: 30px; border-radius: 8px; background: rgba(255,213,0,.12); color: var(--lyncc-yellow); display: grid; place-items: center; flex: none; }
.mini-row .mi svg { width: 15px; height: 15px; }
.mini-row .mt { flex: 1; }
.mini-row .mt b { display: block; font-size: 12.5px; color: var(--fg-on-ink); font-weight: 600; }
.mini-row .mt span { font-family: var(--font-mono); font-size: 10px; color: var(--fg-on-ink-2); }
.mini-row .badge { font-size: 10px; font-weight: 600; padding: 3px 9px; border-radius: var(--r-pill); }
.badge-ok { background: rgba(46,125,91,.16); color: #6BD6A6; }
.badge-go { background: var(--lyncc-yellow); color: var(--lyncc-ink); }
.badge-wait { background: var(--bg-ink); color: var(--fg-on-ink-2); border: 1px solid var(--border-ink); }
