/* ===== CONSENSUS REPORT STYLES ===== */

/* ===== PAGE VARIABLES ===== */
:root {
  --src-claude: #e8913a;
  --src-gpt: #10a37f;
  --src-gemini: #4285f4;
  --src-grok: #ef4444;
  --src-deepseek: #06b6d4;
  --tier1: #f59e0b;
  --tier2: #a78bfa;
  --tier3: #2dd4bf;
  --tier4: #64748b;
  --accent: #c084fc;
  --accent-dim: #c084fc30;
}

/* ===== PAGE OVERRIDES ===== */
.accent-rule {
  background: linear-gradient(90deg, var(--src-claude), var(--src-gpt), var(--src-gemini), var(--src-grok), var(--src-deepseek));
  opacity: 0.45;
}
main { max-width: 1020px; }
.hero::before {
  background:
    radial-gradient(ellipse 40% 50% at 15% 45%, #e8913a12, transparent),
    radial-gradient(ellipse 30% 40% at 35% 55%, #10a37f10, transparent),
    radial-gradient(ellipse 35% 45% at 50% 40%, #4285f410, transparent),
    radial-gradient(ellipse 30% 40% at 65% 55%, #ef444410, transparent),
    radial-gradient(ellipse 40% 50% at 85% 45%, #06b6d412, transparent);
}
.hero h1 em {
  background: linear-gradient(135deg, var(--src-claude), var(--accent), var(--src-deepseek));
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.section h2 {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: -0.03em;
}
.section h3 {
  font-family: var(--sans);
  font-weight: 700;
  letter-spacing: -0.02em;
}
p { margin-bottom: 1.2rem; }
.pull-quote {
  margin: 2.5rem 0; padding: 1.8rem 0 1.8rem 2rem;
  border-left: 2px solid;
  border-image: linear-gradient(to bottom, var(--src-claude), var(--src-gpt), var(--src-gemini), var(--src-grok), var(--src-deepseek)) 1;
}
footer { letter-spacing: 0.06em; }

/* ===== HERO SOURCES ===== */
.hero-sources {
  display: flex; justify-content: center; gap: 0.8rem;
  margin-bottom: 2rem; flex-wrap: wrap;
}
.hero-source-pill {
  font-family: var(--sans); font-size: 0.68rem; font-weight: 600;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 0.3rem 0.8rem; border-radius: 20px;
  border: 1px solid; opacity: 0.8;
}

/* ===== CONSENSUS DOTS ===== */
.consensus-dots {
  display: inline-flex; gap: 4px; vertical-align: middle; margin: 0 0.3rem;
}
.c-dot {
  width: 8px; height: 8px; border-radius: 50%;
  display: inline-block;
}
.c-dot.empty { border: 1px solid var(--border-light); background: transparent; }

/* ===== CALLOUT BOXES ===== */
.callout-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 1rem; margin: 2rem 0;
}
.callout {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 1.5rem; position: relative; overflow: hidden;
}
.callout::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
}
.callout.t1::before { background: var(--tier1); }
.callout.t2::before { background: var(--tier2); }
.callout.t3::before { background: var(--tier3); }
.callout .callout-label {
  font-family: var(--sans); font-size: 0.65rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase; margin-bottom: 0.5rem;
}
.callout.t1 .callout-label { color: var(--tier1); }
.callout.t2 .callout-label { color: var(--tier2); }
.callout.t3 .callout-label { color: var(--tier3); }
.callout .callout-title {
  font-family: var(--sans); font-size: 1.05rem; font-weight: 700;
  color: var(--text-hero); margin-bottom: 0.6rem; letter-spacing: -0.01em;
}
.callout p { font-size: 0.88rem; line-height: 1.65; margin-bottom: 0.6rem; text-indent: 0 !important; }
.callout p:last-child { margin-bottom: 0; }
.callout-meta {
  display: flex; gap: 0.8rem; flex-wrap: wrap;
  margin-top: 0.8rem; padding-top: 0.8rem;
  border-top: 1px solid var(--border);
}
.callout-meta-item {
  font-family: var(--sans); font-size: 0.72rem; color: var(--text-tertiary);
}
.callout-meta-item strong { color: var(--text-secondary); font-weight: 600; }

/* ===== CATEGORY CARDS ===== */
.cat-grid {
  display: grid; grid-template-columns: repeat(3, 1fr);
  gap: 1rem; margin: 2rem 0;
}
.cat-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 1.8rem; text-align: center;
}
.cat-letter {
  font-family: var(--mono); font-size: 2.5rem; font-weight: 700;
  line-height: 1; margin-bottom: 0.3rem; opacity: 0.15;
}
.cat-card-title {
  font-family: var(--sans); font-size: 0.95rem; font-weight: 700;
  color: var(--text-hero); margin-bottom: 0.6rem;
}
.cat-card p {
  font-size: 0.82rem; color: var(--text-secondary); line-height: 1.6;
  text-indent: 0 !important; margin-bottom: 0.5rem;
}
.cat-card p:last-child { margin-bottom: 0; }
.cat-tools {
  margin-top: 0.8rem; padding-top: 0.8rem;
  border-top: 1px solid var(--border);
  font-family: var(--mono); font-size: 0.7rem;
  color: var(--accent); letter-spacing: 0.02em;
  line-height: 1.8;
}

/* ===== HEATMAP ===== */
.heatmap-wrap {
  margin: 2.5rem 0; overflow-x: auto; border: 1px solid var(--border);
  border-radius: 8px; background: var(--bg-card);
}
.heatmap {
  display: grid;
  grid-template-columns: minmax(170px, 200px) repeat(5, 56px) 50px;
  min-width: 560px;
}
.hm-header {
  font-family: var(--sans); font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  padding: 1rem 0.5rem 0.8rem; text-align: center;
  border-bottom: 1px solid var(--border); color: var(--text-tertiary);
}
.hm-header.tool-col { text-align: left; padding-left: 1.2rem; }
.hm-header.src-col-claude { color: var(--src-claude); }
.hm-header.src-col-gpt { color: var(--src-gpt); }
.hm-header.src-col-gemini { color: var(--src-gemini); }
.hm-header.src-col-grok { color: var(--src-grok); }
.hm-header.src-col-deepseek { color: var(--src-deepseek); }
.hm-cell {
  display: flex; align-items: center; justify-content: center;
  padding: 0.55rem 0.5rem;
  border-bottom: 1px solid #ffffff05;
}
.hm-cell.tool-cell {
  justify-content: flex-start; padding-left: 1.2rem;
  font-family: var(--sans); font-size: 0.78rem;
  color: var(--text-primary); font-weight: 500;
}
.hm-cell.total-cell {
  font-family: var(--mono); font-size: 0.78rem; font-weight: 700;
}
.hm-dot {
  width: 14px; height: 14px; border-radius: 50%;
  transition: transform 0.2s;
}
.hm-dot:hover { transform: scale(1.4); }
.hm-dot.filled-claude { background: var(--src-claude); box-shadow: 0 0 8px var(--src-claude)40; }
.hm-dot.filled-gpt { background: var(--src-gpt); box-shadow: 0 0 8px var(--src-gpt)40; }
.hm-dot.filled-gemini { background: var(--src-gemini); box-shadow: 0 0 8px var(--src-gemini)40; }
.hm-dot.filled-grok { background: var(--src-grok); box-shadow: 0 0 8px var(--src-grok)40; }
.hm-dot.filled-deepseek { background: var(--src-deepseek); box-shadow: 0 0 8px var(--src-deepseek)40; }
.hm-dot.empty { border: 1.5px solid var(--border-light); background: transparent; }
.hm-tier-divider {
  grid-column: 1 / -1; padding: 0.5rem 1.2rem;
  font-family: var(--sans); font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.2em; text-transform: uppercase;
  background: var(--bg-inset); border-bottom: 1px solid var(--border);
}
.hm-tier-divider.t1 { color: var(--tier1); }
.hm-tier-divider.t2 { color: var(--tier2); }
.hm-tier-divider.t3 { color: var(--tier3); }
.hm-tier-divider.t4 { color: var(--tier4); }

/* ===== VRAM CHART ===== */
.vram-chart { margin: 2.5rem 0; }
.vram-row {
  display: grid; grid-template-columns: 170px 1fr;
  gap: 1rem; align-items: center;
  margin-bottom: 0.4rem; padding: 0.5rem 0;
  border-bottom: 1px solid #ffffff05;
}
.vram-label {
  font-family: var(--sans); font-size: 0.76rem;
  color: var(--text-secondary); text-align: right;
}
.vram-track {
  height: 22px; background: #ffffff04; border-radius: 3px;
  position: relative;
}
.vram-bar {
  position: absolute; top: 0; height: 100%;
  border-radius: 3px; display: flex; align-items: center;
  justify-content: center;
  transition: opacity 0.8s, transform 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  opacity: 0; transform: scaleX(0); transform-origin: left;
}
.vram-bar.animated { opacity: 1; transform: scaleX(1); }
.vram-bar.t1-bar { background: linear-gradient(90deg, var(--tier1)30, var(--tier1)88); }
.vram-bar.t2-bar { background: linear-gradient(90deg, var(--tier2)30, var(--tier2)88); }
.vram-bar.t3-bar { background: linear-gradient(90deg, var(--tier3)30, var(--tier3)88); }
.vram-bar.t4-bar { background: linear-gradient(90deg, var(--tier4)30, var(--tier4)88); }
.vram-val {
  font-family: var(--mono); font-size: 0.62rem; font-weight: 600;
  color: var(--bg-deep); white-space: nowrap; padding: 0 6px;
}
.vram-axis {
  display: grid; grid-template-columns: 170px 1fr;
  gap: 1rem; margin-top: 0.3rem;
}
.vram-axis-labels {
  display: flex; justify-content: space-between;
  font-family: var(--mono); font-size: 0.6rem; color: var(--text-tertiary);
}

/* ===== PIPELINE DIAGRAM ===== */
.pipeline {
  margin: 2.5rem 0; padding: 2.5rem;
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px;
}
.pipeline-title {
  font-family: var(--sans); font-size: 0.65rem; font-weight: 700;
  letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--text-tertiary); margin-bottom: 2rem; text-align: center;
}
.pipeline-flow {
  display: flex; flex-direction: column; align-items: center; gap: 0;
}
.pipeline-node {
  padding: 1rem 2rem; border-radius: 6px; text-align: center;
  font-family: var(--sans); position: relative; width: 100%; max-width: 420px;
}
.pipeline-node.input-node {
  background: var(--bg-inset); border: 1px dashed var(--border-light);
}
.pipeline-node.stage-node {
  background: var(--accent-dim); border: 1px solid var(--accent)40;
}
.pipeline-node.output-node {
  background: linear-gradient(135deg, var(--tier1)15, var(--tier3)15);
  border: 1px solid var(--tier1)40;
}
.pipeline-node-label {
  font-size: 0.65rem; font-weight: 700;
  letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--text-tertiary); margin-bottom: 0.3rem;
}
.pipeline-node-title {
  font-size: 0.95rem; font-weight: 600; color: var(--text-hero);
  margin-bottom: 0.3rem;
}
.pipeline-node-tools {
  font-family: var(--mono); font-size: 0.68rem; color: var(--accent);
  line-height: 1.7;
}
.pipeline-arrow {
  width: 1px; height: 32px;
  background: linear-gradient(to bottom, var(--accent)60, var(--accent)20);
  position: relative;
}
.pipeline-arrow::after {
  content: ''; position: absolute;
  bottom: -4px; left: 50%; transform: translateX(-50%);
  border-left: 4px solid transparent; border-right: 4px solid transparent;
  border-top: 5px solid var(--accent)60;
}

/* ===== HARDWARE GRID ===== */
.hw-grid {
  display: grid; grid-template-columns: repeat(4, 1fr);
  gap: 1rem; margin: 2rem 0;
}
.hw-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 1.5rem; text-align: center;
  position: relative; overflow: hidden;
}
.hw-card::before {
  content: ''; position: absolute;
  top: 0; left: 0; right: 0; height: 2px;
}
.hw-card.hw-t1::before { background: var(--tier1); }
.hw-card.hw-t2::before { background: var(--tier2); }
.hw-card.hw-t3::before { background: var(--tier3); }
.hw-card.hw-t4::before { background: linear-gradient(90deg, var(--tier1), var(--tier3)); }
.hw-vram {
  font-family: var(--mono); font-size: 1.6rem; font-weight: 700;
  color: var(--text-hero); line-height: 1; margin-bottom: 0.2rem;
}
.hw-vram-unit {
  font-family: var(--sans); font-size: 0.65rem;
  color: var(--text-tertiary); letter-spacing: 0.1em;
  text-transform: uppercase; margin-bottom: 1rem;
}
.hw-quality {
  font-family: var(--sans); font-size: 0.72rem; font-weight: 600;
  color: var(--text-secondary); margin-bottom: 0.8rem;
}
.hw-tools-list {
  font-family: var(--mono); font-size: 0.65rem;
  color: var(--text-tertiary); line-height: 1.8;
  text-align: left;
}

/* ===== LICENSE GRID ===== */
.license-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 1rem; margin: 2rem 0;
}
.license-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: 8px; padding: 1.5rem;
}
.license-type {
  font-family: var(--mono); font-size: 0.82rem; font-weight: 700;
  margin-bottom: 0.3rem;
}
.license-type.lic-mit { color: var(--tier3); }
.license-type.lic-apache { color: var(--src-gemini); }
.license-type.lic-research { color: var(--src-grok); }
.license-type.lic-restricted { color: var(--tier1); }
.license-commercial {
  font-family: var(--sans); font-size: 0.7rem;
  color: var(--text-tertiary); margin-bottom: 0.8rem;
}
.license-tools {
  font-family: var(--sans); font-size: 0.8rem;
  color: var(--text-secondary); line-height: 1.7;
}

/* ===== DISAGREE TABLE ===== */
.disagree-table {
  width: 100%; border-collapse: collapse; margin: 2rem 0;
  font-size: 0.85rem;
}
.disagree-table th {
  font-family: var(--sans); font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--text-tertiary); text-align: left;
  padding: 0.8rem 1rem; border-bottom: 1px solid var(--border);
  background: var(--bg-card);
}
.disagree-table td {
  padding: 0.8rem 1rem; border-bottom: 1px solid #ffffff06;
  vertical-align: top; line-height: 1.6;
}
.disagree-table td:first-child {
  font-family: var(--sans); font-weight: 600;
  color: var(--text-hero); font-size: 0.82rem; white-space: nowrap;
}

/* ===== TAKEAWAY LIST ===== */
.takeaway-list {
  list-style: none; margin: 2rem 0;
  counter-reset: takeaway;
}
.takeaway-item {
  counter-increment: takeaway;
  display: grid; grid-template-columns: 48px 1fr;
  gap: 1rem; padding: 1.5rem 0;
  border-bottom: 1px solid var(--border);
}
.takeaway-item::before {
  content: counter(takeaway);
  font-family: var(--mono); font-size: 1.8rem; font-weight: 700;
  color: var(--accent); opacity: 0.4; line-height: 1;
  text-align: center; padding-top: 0.1rem;
}
.takeaway-item p { margin-bottom: 0; font-size: 0.95rem; text-indent: 0 !important; }
.takeaway-item strong { color: var(--text-hero); }

/* ===== INLINE ===== */
.hl { color: var(--accent); font-weight: 600; }
.tag {
  display: inline-block; font-family: var(--sans);
  font-size: 0.62rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  padding: 0.2rem 0.55rem; border-radius: 3px; margin-bottom: 0.5rem;
}
.tag.tag-t1 { background: var(--tier1)20; color: var(--tier1); }
.tag.tag-t2 { background: var(--tier2)20; color: var(--tier2); }
.tag.tag-t3 { background: var(--tier3)20; color: var(--tier3); }

/* ===== RESPONSIVE ===== */
@media (max-width: 860px) {
  .cat-grid { grid-template-columns: 1fr; }
  .hw-grid { grid-template-columns: 1fr 1fr; }
  .vram-row { grid-template-columns: 120px 1fr; }
  .vram-label { font-size: 0.68rem; }
  .heatmap { min-width: 520px; }
}
@media (max-width: 560px) {
  body { font-size: 15.5px; }
  .hw-grid { grid-template-columns: 1fr; }
  .vram-row { grid-template-columns: 90px 1fr; }
  .pipeline { padding: 1.5rem; }
  .hero h1 { font-size: 2.2rem; }
  .hm-cell.tool-cell { font-size: 0.68rem; }
  .heatmap { grid-template-columns: minmax(130px, 160px) repeat(5, 44px) 40px; }
}
