/* ============================================================
   DOCKHAVEN LABS — Centered hero with LIVE dashboard backdrop
   (loaded after styles.css + detail.css so it wins)
   ============================================================ */

.hero {
  position: relative; min-height: 100svh;
  display: grid; place-items: center;
  padding: 132px 0 92px; overflow: hidden;
}

/* ---------- background layers ---------- */
.hero-bg { position: absolute; inset: 0; z-index: 0; pointer-events: none; overflow: hidden; }

/* faint ambient freight field */
.hero-freight {
  position: absolute; top: 50%; right: -8%; transform: translateY(-50%);
  width: min(860px, 92vh); height: min(860px, 92vh); opacity: .16;
}

/* floating live dashboard panels */
.hpanel {
  position: absolute; border: 1px solid var(--line-2); border-radius: 14px;
  background: linear-gradient(180deg, color-mix(in oklab, var(--card) 96%, black), var(--bg-2));
  box-shadow: 0 40px 90px -50px rgba(0,0,0,.9);
  opacity: .5; filter: blur(.5px); overflow: hidden;
  will-change: transform;
}
.hp-ops {
  width: 560px; top: 5.5%; right: -7%;
  transform: perspective(1400px) rotateY(-17deg) rotateX(7deg) rotate(-1deg);
  animation: floatA 13s ease-in-out infinite;
}
.hp-leads {
  width: 432px; bottom: 5.5%; left: -6%;
  transform: perspective(1400px) rotateY(15deg) rotateX(6deg) rotate(1deg);
  animation: floatB 16s ease-in-out infinite;
}
@keyframes floatA {
  0%,100% { transform: perspective(1400px) rotateY(-17deg) rotateX(7deg) rotate(-1deg) translateY(0); }
  50%     { transform: perspective(1400px) rotateY(-17deg) rotateX(7deg) rotate(-1deg) translateY(-16px); }
}
@keyframes floatB {
  0%,100% { transform: perspective(1400px) rotateY(15deg) rotateX(6deg) rotate(1deg) translateY(0); }
  50%     { transform: perspective(1400px) rotateY(15deg) rotateX(6deg) rotate(1deg) translateY(14px); }
}
body.motion-off .hpanel { animation: none; }
body.motion-off .hero-freight { opacity: .12; }

/* panel chrome */
.hp-top { display: flex; align-items: center; gap: 12px; padding: 11px 14px; border-bottom: 1px solid var(--line); }
.hp-brand { display: inline-flex; align-items: center; gap: 8px; font-family: var(--serif); font-size: 16px; color: var(--ink); }
.hp-brand .dot { width: 8px; height: 8px; border-radius: 50%; }
.hp-brand .dot.ds { background: var(--cobalt); box-shadow: 0 0 8px var(--cobalt); }
.hp-brand .dot.lsd { background: var(--amber); box-shadow: 0 0 8px var(--amber); }
.hp-tabs { display: flex; gap: 3px; margin-left: 6px; }
.hp-tabs b { font-family: var(--mono); font-weight: 400; font-size: 10.5px; letter-spacing: .03em;
  color: var(--ink-4); padding: 4px 8px; border-radius: 6px; transition: color .3s, background .3s; white-space: nowrap; }
.hp-tabs b.on { color: var(--cobalt); background: var(--cobalt-soft); }
.hp-live { margin-left: auto; display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--mono); font-size: 9.5px; letter-spacing: .12em; color: var(--ink-3); }
.hp-live i { width: 6px; height: 6px; border-radius: 50%; background: var(--teal); animation: livePulse 2s infinite; }
.hp-meta { margin-left: auto; font-family: var(--mono); font-size: 10px; color: var(--ink-3); letter-spacing: .04em; }
.hp-meta b { color: var(--amber); font-weight: 500; }

.hp-stage { padding: 14px; }

/* KPI tiles */
.hp-kpis { display: grid; grid-template-columns: repeat(2, 1fr); gap: 8px; }
.hp-kpi { border: 1px solid var(--line); border-radius: 9px; padding: 10px 12px; background: rgba(255,255,255,.012); }
.hp-kpi .l { font-family: var(--mono); font-size: 8.5px; letter-spacing: .1em; text-transform: uppercase; color: var(--ink-4);
  display: flex; justify-content: space-between; }
.hp-kpi .v { font-family: var(--serif); font-size: 23px; line-height: 1; margin-top: 7px; color: var(--ink); }
.hp-kpi .v .u { font-family: var(--mono); font-size: 11px; color: var(--ink-3); }
.hp-alert { margin-top: 10px; display: flex; align-items: center; gap: 8px; padding: 8px 10px; border-radius: 8px;
  border: 1px solid color-mix(in oklab, var(--red) 35%, transparent); background: color-mix(in oklab, var(--red) 9%, transparent);
  font-family: var(--mono); font-size: 10.5px; color: color-mix(in oklab, var(--red) 60%, var(--ink)); }

/* bars */
.hp-bars { display: flex; align-items: flex-end; gap: 7px; height: 64px; margin-top: 12px; }
.hp-bars .g { flex: 1; display: flex; gap: 2px; align-items: flex-end; height: 100%; }
.hp-bars .g i { flex: 1; border-radius: 2px 2px 0 0; transition: height .7s var(--ease); }
.hp-bars .g .rev { background: var(--cobalt); opacity: .8; }
.hp-bars .g .cost { background: var(--red); opacity: .65; }

/* lanes / accounts rows */
.hp-rows { display: flex; flex-direction: column; gap: 9px; }
.hp-row { display: flex; align-items: center; gap: 10px; font-size: 11.5px; color: var(--ink-2); }
.hp-row .nm { width: 116px; font-family: var(--mono); font-size: 10.5px; color: var(--ink-2); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hp-row .track { flex: 1; height: 5px; border-radius: 4px; background: var(--line-2); overflow: hidden; }
.hp-row .track i { display: block; height: 100%; background: var(--cobalt); border-radius: 4px; transition: width .8s var(--ease); }
.hp-row .track i.warn { background: var(--red); }
.hp-row .vv { font-family: var(--mono); font-size: 10.5px; color: var(--ink); width: 46px; text-align: right; }

/* leadsense stream */
.hp-leadlist { padding: 12px 14px; display: flex; flex-direction: column; gap: 8px; min-height: 220px; }
.hp-lead { display: flex; align-items: center; gap: 10px; border: 1px solid var(--line); border-radius: 9px;
  padding: 9px 11px; background: rgba(255,255,255,.012); }
.hp-lead.enter { animation: leadIn .55s var(--ease); }
@keyframes leadIn { from { opacity: 0; transform: translateY(-12px); } to { opacity: 1; transform: none; } }
.hp-lead .co { flex: 1; min-width: 0; }
.hp-lead .co b { display: block; font-size: 12px; color: var(--ink); font-weight: 450; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.hp-lead .co small { font-family: var(--mono); font-size: 9px; color: var(--ink-4); letter-spacing: .04em; }
.hp-lead .src { font-family: var(--mono); font-size: 8.5px; color: var(--ink-3); border: 1px solid var(--line-2); border-radius: 5px; padding: 3px 6px; white-space: nowrap; }
.hp-lead .sc { font-family: var(--mono); font-size: 13px; color: var(--amber); width: 24px; text-align: right; font-weight: 500; }

/* ---------- scrim for readability ---------- */
.hero-scrim {
  position: absolute; inset: 0; z-index: 2; pointer-events: none;
  background:
    radial-gradient(ellipse 70% 62% at 50% 46%,
      var(--bg) 0%,
      var(--bg) 24%,
      color-mix(in oklab, var(--bg) 82%, transparent) 46%,
      color-mix(in oklab, var(--bg) 30%, transparent) 70%,
      transparent 86%),
    linear-gradient(180deg, color-mix(in oklab, var(--bg) 80%, transparent), transparent 18%, transparent 78%, color-mix(in oklab, var(--bg) 92%, transparent));
}

/* ---------- centered copy ---------- */
.hero-center {
  position: relative; z-index: 3; text-align: center;
  width: 100%; max-width: 860px; padding-inline: var(--gut);
  display: flex; flex-direction: column; align-items: center;
}
.hero-center .hero-kicker { margin-bottom: 26px; }
.hero-center .marker::before { display: none; }
.hero-center h1 {
  font-family: var(--serif); font-weight: 400;
  font-size: clamp(44px, 6.4vw, 84px); line-height: 1.08; letter-spacing: -0.022em;
  margin: 0 0 26px; padding-bottom: .06em; text-shadow: 0 2px 40px rgba(4,5,10,.6);
}
.hero-center h1 .lit { color: var(--cobalt); }
.hero-center .hero-sub {
  font-size: clamp(16px, 1.6vw, 19px); color: var(--ink-2); max-width: 30em;
  margin: 0 auto 36px; line-height: 1.62; text-shadow: 0 1px 20px rgba(4,5,10,.7);
}
.hero-center .hero-cta { display: flex; gap: 14px; flex-wrap: wrap; align-items: center; justify-content: center; }
.hero-center .hero-meta {
  margin-top: 38px; display: flex; gap: 14px 30px; flex-wrap: wrap; justify-content: center;
  font-family: var(--mono); font-size: 11.5px; letter-spacing: .06em; color: var(--ink-3);
}
.hero-center .hero-meta span { position: relative; }
.hero-center .hero-meta span + span::before {
  content: ""; position: absolute; left: -16px; top: 50%; width: 1px; height: 12px;
  background: var(--line-2); transform: translateY(-50%);
}
.hero-center .hero-meta b { color: var(--ink); font-weight: 500; }
.hero-center .hero-meta b#statMotion { color: var(--teal); }

/* hide heavy panels on small screens (mobile pass handles layout) */
@media (max-width: 860px) {
  .hpanel { display: none; }
  .hero-freight { opacity: .1; right: -30%; }
  .hero-scrim { background: radial-gradient(ellipse 90% 70% at 50% 45%, var(--bg) 0%, color-mix(in oklab, var(--bg) 60%, transparent) 60%, transparent 100%); }
}
