/* layerSVD shared styles */

:root {
  --bg: #0f1115;
  --panel: #161a22;
  --panel-2: #1c2230;
  --border: #2a3344;
  --text: #d8e1ee;
  --text-dim: #8a96aa;
  --accent: #6ab0ff;
  --accent-warm: #ffa057;
  --swa: #2c5d8f;
  --global: #8f4f2c;
  --moe: #6b4f8a;
  --dense: #3a6b4f;
  --good: #57c98a;
  --warn: #ffcb47;
  --bad: #ff6f6f;
  --mono: ui-monospace, "SF Mono", "Cascadia Code", Menlo, Consolas, monospace;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text);
  font-family: system-ui, -apple-system, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  font-size: 14px;
  line-height: 1.45;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar {
  display: flex;
  align-items: baseline;
  gap: 24px;
  padding: 14px 22px;
  background: var(--panel);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 10;
}
.topbar h1 {
  margin: 0;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.02em;
}
.topbar h1 span.muted {
  color: var(--text-dim);
  font-weight: 400;
  margin-left: 8px;
}
.topbar nav a {
  margin-right: 16px;
  font-size: 13px;
  color: var(--text-dim);
}
.topbar nav a.active { color: var(--text); border-bottom: 2px solid var(--accent); padding-bottom: 4px; }

main {
  padding: 22px;
  max-width: 1400px;
  margin: 0 auto;
}

/* ----- one-line model summary at the top of the architecture page ----- */
#model-line {
  font-family: var(--mono);
  font-size: 12px;
  color: var(--text-dim);
  margin: 6px 0 22px 0;
}
#model-line strong { color: var(--text); font-weight: 500; }
#model-line .sep { color: var(--border); margin: 0 8px; }

.section-title {
  font-size: 11px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--text-dim);
  font-weight: 500;
  margin: 32px 0 4px 0;
  border-bottom: 1px solid var(--border);
  padding-bottom: 4px;
}
.section-sub {
  font-size: 11px;
  color: var(--text-dim);
  margin: 0 0 14px 0;
  max-width: 880px;
}

#flow-wrap, #ribbon-wrap {
  background: transparent;
}

#flow {
  display: block;
  width: 100%;
  height: auto;
}
#ribbon {
  display: block;
  width: 100%;
  height: auto;
}

/* SVG style hooks */
svg .rail        { stroke: var(--border); stroke-width: 1; }
svg .tee         { stroke: var(--border); stroke-width: 1; }
svg .block-bg    { fill: transparent; stroke: var(--border); stroke-width: 0.5; }
svg .block-bg.hover { fill: var(--panel); }
svg .block-mark.swa    { fill: var(--accent); }
svg .block-mark.global { fill: var(--accent-warm); }
svg .block-label {
  fill: var(--text);
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
}
svg .block-sub {
  fill: var(--text-dim);
  font-family: var(--mono);
  font-size: 9.5px;
}
svg .spark-line {
  fill: none;
  stroke: var(--accent);
  stroke-width: 1.6;
  stroke-linejoin: round;
  stroke-linecap: round;
}
svg .spark-line.global { stroke: var(--accent-warm); }
svg .spark-fill {
  fill: var(--accent);
  fill-opacity: 0.12;
  stroke: none;
}
svg .spark-fill.global { fill: var(--accent-warm); }
svg .spark-base {
  stroke: var(--border);
  stroke-width: 0.6;
}
svg .spark-base.dotted {
  stroke-dasharray: 1 3;
}
svg .spark-final-dot {
  fill: var(--text);
  stroke: var(--bg);
  stroke-width: 0.5;
}
svg .spark-final-text {
  fill: var(--text-dim);
  font-family: var(--mono);
  font-size: 9px;
}
svg .spark-label {
  fill: var(--text-dim);
  font-family: var(--mono);
  font-size: 8.5px;
  text-transform: lowercase;
  letter-spacing: 0.04em;
}
svg .axis-text {
  fill: var(--text-dim);
  font-family: var(--mono);
  font-size: 9px;
}
svg .panel-title {
  fill: var(--text);
  font-family: var(--mono);
  font-size: 12px;
  font-weight: 500;
}
svg .panel-sub {
  fill: var(--text-dim);
  font-family: var(--mono);
  font-size: 10px;
}

svg g.block { cursor: pointer; }
svg g.block:hover .block-bg { fill: var(--panel); }
svg g.block:hover .spark-line { stroke: var(--accent); stroke-width: 1.25; }

/* ----- floating tooltip overlay ----- */
.tooltip {
  position: fixed;
  pointer-events: none;
  background: var(--panel-2);
  border: 1px solid var(--border);
  padding: 10px 12px;
  font-family: var(--mono);
  font-size: 11px;
  border-radius: 4px;
  z-index: 100;
  max-width: 360px;
  box-shadow: 0 4px 16px rgba(0,0,0,.35);
}
.tooltip .tt-head {
  font-weight: 600;
  font-size: 12px;
  color: var(--text);
  margin-bottom: 6px;
}
.tooltip .tt-line {
  color: var(--text-dim);
  margin: 1px 0;
}
.tooltip .tt-line strong { color: var(--text); font-weight: 500; }
.tooltip table.tt-tensors {
  width: 100%;
  border-collapse: collapse;
  margin-top: 8px;
  font-size: 10px;
}
.tooltip table.tt-tensors td {
  padding: 1px 6px 1px 0;
  white-space: nowrap;
}
.tooltip table.tt-tensors td.role { color: var(--text-dim); }
.tooltip table.tt-tensors td.shape { color: var(--accent); }
.tooltip table.tt-tensors td.type  { color: var(--accent-warm); }
.tooltip table.tt-tensors td.params { text-align: right; color: var(--text); }

footer {
  padding: 22px;
  text-align: center;
  color: var(--text-dim);
  font-size: 12px;
}
footer a { color: var(--text-dim); }
