/* ==========================================================================
   Adlytiq — App dashboard mockup (the hero "screenshot")
   A believable, static product shot. Mock data per PRD §7.
   ========================================================================== */

.appshot {
  --side-w: 196px;
  position: relative;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-xl);
  overflow: hidden;
  text-align: left;
}

/* window top chrome */
.appshot-chrome {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 38px;
  padding-inline: 16px;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
}
.appshot-chrome .dots { display: flex; gap: 7px; }
.appshot-chrome .dots i { width: 11px; height: 11px; border-radius: 50%; background: #d7dee7; }
.appshot-chrome .addr {
  margin-inline: auto;
  display: inline-flex; align-items: center; gap: 7px;
  height: 23px; padding-inline: 12px;
  border-radius: 999px;
  background: #fff; border: 1px solid var(--line);
  font-family: var(--font-mono); font-size: 11px; color: var(--muted);
}
.appshot-chrome .addr svg { width: 11px; height: 11px; color: var(--positive); }

.appshot-body { display: grid; grid-template-columns: var(--side-w) 1fr; min-height: 540px; }

/* sidebar */
.app-side {
  border-right: 1px solid var(--line);
  background: var(--bg-2);
  padding: 16px 12px;
  display: flex; flex-direction: column; gap: 4px;
}
.app-ws {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 9px; margin-bottom: 10px;
  border-radius: var(--r-sm);
  border: 1px solid var(--line);
  background: #fff;
}
.app-ws .mark { width: 22px; height: 22px; border-radius: 6px; display:grid; place-items:center; background: var(--primary-soft); }
.app-ws .mark svg { width: 14px; height: 14px; }
.app-ws .nm { font-size: 13px; font-weight: 600; color: var(--ink); letter-spacing: -.01em; }
.app-ws .cv { margin-left: auto; color: var(--faint); }
.app-nav-label {
  font-family: var(--font-mono); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase;
  color: var(--faint); padding: 12px 9px 6px;
}
.app-nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 9px; border-radius: var(--r-xs);
  font-size: 13px; font-weight: 500; color: var(--ink-2);
}
.app-nav-item svg { width: 16px; height: 16px; color: var(--faint); }
.app-nav-item.active { background: #fff; color: var(--ink); box-shadow: var(--sh-xs); border: 1px solid var(--line); }
.app-nav-item.active svg { color: var(--primary); }
.app-side .spacer { flex: 1; }
.app-user {
  display: flex; align-items: center; gap: 9px;
  padding: 8px; border-radius: var(--r-sm); border: 1px solid var(--line); background: #fff;
}
.app-user .av { width: 26px; height: 26px; border-radius: 50%; background: linear-gradient(135deg, var(--primary), color-mix(in oklab, var(--primary) 50%, var(--positive))); }
.app-user .nm { font-size: 12px; font-weight: 600; color: var(--ink); }
.app-user .em { font-size: 10.5px; color: var(--faint); }

/* main */
.app-main { padding: 18px 20px 22px; min-width: 0; }
.app-topbar { display: flex; align-items: center; gap: 12px; margin-bottom: 18px; }
.app-topbar h3 { font-size: 17px; letter-spacing: -.02em; }
.app-topbar .sub { font-size: 11.5px; color: var(--muted); }
.app-topbar .right { margin-left: auto; display: flex; align-items: center; gap: 8px; }
.app-chip {
  display: inline-flex; align-items: center; gap: 7px;
  height: 30px; padding-inline: 11px;
  border-radius: var(--r-xs); border: 1px solid var(--line); background: #fff;
  font-size: 12px; font-weight: 500; color: var(--ink-2);
}
.app-chip svg { width: 13px; height: 13px; color: var(--muted); }
.app-chip .sync-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--positive); box-shadow: 0 0 0 3px var(--positive-soft); }

/* KPI row */
.kpi-row { display: grid; grid-template-columns: repeat(5, 1fr); gap: 10px; margin-bottom: 14px; }
.kpi {
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: #fff;
}
.kpi.hl { background: var(--primary-soft); border-color: color-mix(in oklab, var(--primary) 26%, var(--line)); }
.kpi .lab { font-size: 11px; color: var(--muted); font-weight: 500; }
.kpi .val { font-size: 21px; font-weight: 680; color: var(--ink); letter-spacing: -.02em; margin-top: 6px; font-variant-numeric: tabular-nums; }
.kpi.hl .val { color: var(--primary); }
.kpi .delta { display: inline-flex; align-items: center; gap: 3px; margin-top: 7px; font-size: 11px; font-weight: 600; font-variant-numeric: tabular-nums; }
.kpi .delta svg { width: 11px; height: 11px; }
.delta.up { color: var(--positive); }
.delta.down { color: var(--negative); }
.delta.good-down { color: var(--positive); }

/* charts area */
.app-charts { display: grid; grid-template-columns: 1.55fr 1fr; gap: 12px; }
.panel {
  border: 1px solid var(--line);
  border-radius: var(--r-sm);
  background: #fff;
  padding: 14px 16px 12px;
}
.panel-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 10px; }
.panel-head .t { font-size: 13px; font-weight: 600; color: var(--ink); }
.panel-legend { display: flex; gap: 12px; }
.panel-legend span { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--muted); }
.panel-legend i { width: 9px; height: 9px; border-radius: 2px; }
.panel-legend i.bar { background: color-mix(in oklab, var(--primary) 70%, white); }
.panel-legend i.line { background: var(--ink); border-radius: 50%; width: 8px; height: 8px; }

.chart-svg { width: 100%; height: 168px; display: block; }
.chart-mini { width: 100%; height: 168px; display: block; }

/* top campaigns mini table */
.app-table-wrap { margin-top: 12px; border: 1px solid var(--line); border-radius: var(--r-sm); background: #fff; overflow: hidden; }
.app-tt-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--line); }
.app-tt-head .t { font-size: 13px; font-weight: 600; color: var(--ink); }
.app-tt-head .lk { font-size: 11.5px; color: var(--primary); font-weight: 540; }
table.app-table { width: 100%; border-collapse: collapse; font-size: 12px; }
table.app-table th {
  text-align: right; font-weight: 500; color: var(--faint);
  font-size: 10.5px; text-transform: uppercase; letter-spacing: .04em;
  padding: 9px 16px; border-bottom: 1px solid var(--line-2);
}
table.app-table th:first-child { text-align: left; }
table.app-table td { padding: 9px 16px; text-align: right; color: var(--ink-2); font-variant-numeric: tabular-nums; border-bottom: 1px solid var(--line-2); }
table.app-table tr:last-child td { border-bottom: 0; }
table.app-table td:first-child { text-align: left; font-weight: 540; color: var(--ink); }
table.app-table .cname { display: flex; align-items: center; gap: 9px; }
table.app-table .swatch { width: 8px; height: 8px; border-radius: 2px; flex-shrink: 0; }
.roas-tag { font-weight: 650; color: var(--positive); }
.spark { width: 56px; height: 18px; display: block; }

/* size variant used inside hero (slightly denser) */
.appshot.compact .kpi .val { font-size: 19px; }

@media (max-width: 760px) {
  .appshot { --side-w: 0px; }
  .app-side { display: none; }
  .appshot-body { grid-template-columns: 1fr; }
  .kpi-row { grid-template-columns: repeat(2, 1fr); }
  .kpi:nth-child(5) { grid-column: 1 / -1; }
  .app-charts { grid-template-columns: 1fr; }
  .chart-svg, .chart-mini { height: 150px; }
  .app-table .col-opt { display: none; }
}
