/* factory.css — shared styles para factory.raulsanzdesco.com
   Hereda CSS variables pattern de analisis.raulsanzdesco.com.
   Dark default + light theme toggle.
*/

*{box-sizing:border-box;margin:0;padding:0}

:root{
  /* Surfaces */
  --bg:#0f0f10;
  --surface:#1a1a1c;
  --surface-2:#1f1f22;
  --border:#2a2a2a;

  /* Text */
  --text:#e8e8e8;
  --text-strong:#fff;
  --text-soft:#bbb;
  --text-muted:#888;
  --text-faint:#666;

  /* Accents */
  --accent:#4ade80;
  --accent-bg:#1f3a2e;
  --warn:#f59e0b;
  --warn-bg:#3a2a1a;
  --err:#ef4444;
  --err-bg:#3a1a1a;
  --info:#60a5fa;
  --info-bg:#1a2a3a;

  /* Stage colors (E1→E5) */
  --stage-e1:#60a5fa;       /* azul info — exploration */
  --stage-e2:#a78bfa;       /* violeta — research */
  --stage-e3:#f59e0b;       /* ámbar — building spec */
  --stage-e4:#fb923c;       /* naranja — building MVP */
  --stage-e5:#4ade80;       /* verde — launched */

  /* Tier colors */
  --tier-s:#4ade80;         /* verde — top */
  --tier-a:#60a5fa;         /* azul */
  --tier-b:#f59e0b;         /* ámbar */
  --tier-c:#888;            /* gris */

  /* State flags */
  --state-killed:#ef4444;
  --state-launched:#4ade80;
  --state-scaled:#22d3ee;
  --state-blocked-human:#f59e0b;
  --state-blocked-budget:#fb923c;
  --state-backlog:#666;

  /* Provenance */
  --prov-wave-3:#a78bfa;
  --prov-wave-4:#60a5fa;
  --prov-wave-5-sport:#22d3ee;
  --prov-brainstorm-v2:#f59e0b;
  --prov-scout:#fb923c;
  --prov-user:#4ade80;
  --prov-wave-2-original:#ec4899;
  --prov-wave-3-promoted:#c084fc;
}

[data-theme="light"]{
  --bg:#f9fafb;
  --surface:#fff;
  --surface-2:#f3f4f6;
  --border:#e5e7eb;
  --text:#1f2937;
  --text-strong:#111827;
  --text-soft:#374151;
  --text-muted:#6b7280;
  --text-faint:#9ca3af;
  --accent:#16a34a;
  --accent-bg:#dcfce7;
  --warn:#d97706;
  --warn-bg:#fef3c7;
  --err:#dc2626;
  --err-bg:#fee2e2;
  --info:#2563eb;
  --info-bg:#dbeafe;
}

body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:var(--bg);
  color:var(--text);
  line-height:1.7;
  min-height:100vh;
}

.wrap{
  max-width:1200px;
  margin:0 auto;
  padding:2rem 1.5rem;
}

/* Theme toggle */
.theme-toggle{
  position:fixed;top:1rem;right:1rem;z-index:200;
  background:var(--surface);color:var(--text);
  border:1px solid var(--border);border-radius:50%;
  width:42px;height:42px;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:1.1rem;
  transition:all 0.15s;
}
.theme-toggle:hover{border-color:var(--accent);color:var(--accent)}

/* Nav */
.nav{
  display:flex;gap:1.2rem;font-size:0.9rem;
  margin-bottom:2rem;padding-bottom:0.8rem;
  border-bottom:1px solid var(--border);
}
.nav a{
  color:var(--text-muted);text-decoration:none;
  padding:0.3rem 0;border-bottom:2px solid transparent;
  transition:all 0.15s;
}
.nav a:hover{color:var(--text-strong)}
.nav a.active{color:var(--accent);border-bottom-color:var(--accent)}

/* Headers */
h1{
  font-size:clamp(2rem,5.5vw,3rem);font-weight:300;
  letter-spacing:-0.02em;margin-bottom:0.7rem;
  color:var(--text-strong);
}
h2{
  font-size:1.15rem;font-weight:500;
  color:var(--text-strong);margin-bottom:1rem;
  padding-bottom:0.5rem;border-bottom:1px solid var(--border);
}
.section-title{
  font-size:0.85rem;font-weight:500;color:var(--text-muted);
  text-transform:uppercase;letter-spacing:0.08em;
  margin:2.5rem 0 1.2rem;
}

/* Cards */
.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:1.4rem 1.5rem;
}
.section-card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:1.5rem;margin-bottom:1.5rem;
}

/* Buttons */
.btn{
  background:var(--accent);color:#0a0a0a;
  border:none;padding:0.5rem 1rem;border-radius:6px;
  font-size:0.88rem;font-weight:600;cursor:pointer;
  font-family:inherit;text-decoration:none;display:inline-block;
}
.btn:hover{filter:brightness(1.1)}
.btn.ghost{background:transparent;color:var(--text-muted);border:1px solid var(--border);font-weight:500}
.btn.ghost:hover{border-color:var(--accent);color:var(--accent)}
.btn.danger{background:transparent;color:var(--err);border:1px solid var(--err)}
.btn.danger:hover{background:var(--err);color:#fff}
.btn-mini{
  padding:0.25rem 0.65rem;font-size:0.78rem;
  background:transparent;color:var(--text-muted);
  border:1px solid var(--border);border-radius:5px;
  cursor:pointer;font-family:inherit;
}
.btn-mini:hover{border-color:var(--accent);color:var(--accent)}

/* Stage badge (E1-E5 + states) */
.stage-badge{
  display:inline-block;padding:0.2rem 0.6rem;
  border-radius:10px;font-size:0.72rem;font-weight:600;
  text-transform:uppercase;letter-spacing:0.04em;
}
.stage-e1{background:rgba(96,165,250,0.15);color:var(--stage-e1)}
.stage-e2{background:rgba(167,139,250,0.15);color:var(--stage-e2)}
.stage-e3{background:rgba(245,158,11,0.15);color:var(--stage-e3)}
.stage-e4{background:rgba(251,146,60,0.15);color:var(--stage-e4)}
.stage-e5{background:rgba(74,222,128,0.15);color:var(--stage-e5)}
.stage-killed{background:rgba(239,68,68,0.15);color:var(--state-killed)}
.stage-launched{background:rgba(74,222,128,0.2);color:var(--state-launched);font-weight:700}
.stage-blocked_human{background:rgba(245,158,11,0.15);color:var(--state-blocked-human)}
.stage-blocked_budget{background:rgba(251,146,60,0.15);color:var(--state-blocked-budget)}
.stage-backlog{background:var(--surface-2);color:var(--text-faint)}

/* Tier badge */
.tier-badge{
  display:inline-block;padding:0.15rem 0.55rem;
  border-radius:6px;font-size:0.7rem;font-weight:700;
  text-transform:uppercase;color:#fff;
  min-width:24px;text-align:center;
}
.tier-s{background:var(--tier-s);color:#0a0a0a}
.tier-a{background:var(--tier-a);color:#0a0a0a}
.tier-b{background:var(--tier-b);color:#0a0a0a}
.tier-c{background:var(--tier-c);color:#fff}

/* Provenance pill */
.prov-pill{
  display:inline-block;padding:0.1rem 0.45rem;
  border-radius:4px;font-size:0.65rem;font-weight:600;
  text-transform:uppercase;letter-spacing:0.04em;
  color:#fff;
}
.prov-wave-3{background:var(--prov-wave-3)}
.prov-wave-4{background:var(--prov-wave-4)}
.prov-wave-5-sport{background:var(--prov-wave-5-sport);color:#0a0a0a}
.prov-brainstorm-v2{background:var(--prov-brainstorm-v2);color:#0a0a0a}
.prov-scout{background:var(--prov-scout)}
.prov-user{background:var(--prov-user);color:#0a0a0a}
.prov-wave-2-original{background:var(--prov-wave-2-original)}
.prov-wave-3-promoted{background:var(--prov-wave-3-promoted)}

/* Pipeline funnel viz */
.pipeline-strip{
  display:flex;align-items:stretch;gap:0.5rem;
  margin:1.5rem 0;flex-wrap:wrap;
}
.pipeline-step{
  flex:1;min-width:140px;padding:0.9rem 1rem;
  background:var(--surface);border:1px solid var(--border);
  border-radius:8px;text-align:center;cursor:pointer;
  transition:all 0.15s;text-decoration:none;color:inherit;
  position:relative;
}
.pipeline-step:hover{border-color:var(--accent);transform:translateY(-1px)}
.pipeline-step .label{font-size:0.72rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.04em}
.pipeline-step .count{font-size:1.8rem;font-weight:600;color:var(--text-strong);margin:0.3rem 0;font-family:'SF Mono','Consolas',monospace}
.pipeline-step .desc{font-size:0.72rem;color:var(--text-faint)}
.pipeline-step.active{border-color:var(--accent);background:linear-gradient(135deg,var(--surface) 0%,var(--accent-bg) 100%)}
.pipeline-step.bottleneck{border-color:var(--warn);background:linear-gradient(135deg,var(--surface) 0%,var(--warn-bg) 100%)}

/* Score breakdown */
.score-breakdown{
  display:grid;grid-template-columns:1fr auto;gap:0.4rem;
  font-size:0.82rem;font-family:'SF Mono','Consolas',monospace;
}
.score-breakdown .row{display:contents}
.score-breakdown .row > span:first-child{color:var(--text-muted)}
.score-breakdown .row > span:last-child{color:var(--text-strong);text-align:right;font-weight:600}
.score-bar{
  display:inline-block;width:60px;height:6px;
  background:var(--surface-2);border-radius:3px;overflow:hidden;
  vertical-align:middle;margin-right:0.4rem;
}
.score-bar-fill{height:100%;border-radius:3px}
.score-bar-fill.s{background:var(--tier-s)}
.score-bar-fill.a{background:var(--tier-a)}
.score-bar-fill.b{background:var(--tier-b)}
.score-bar-fill.c{background:var(--tier-c)}

/* Idea card (portfolio activo) */
.idea-card{
  display:grid;grid-template-columns:1fr auto;gap:1rem;
  padding:1.2rem 1.3rem;background:var(--surface);
  border:1px solid var(--border);border-radius:10px;
  transition:all 0.15s;text-decoration:none;color:inherit;
  margin-bottom:0.8rem;
}
.idea-card:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 4px 16px rgba(0,0,0,0.25)}
.idea-card .header{display:flex;align-items:center;gap:0.6rem;flex-wrap:wrap;margin-bottom:0.4rem}
.idea-card .title{font-size:1rem;font-weight:600;color:var(--text-strong)}
.idea-card .thesis{font-size:0.88rem;color:var(--text-soft);line-height:1.5;margin-top:0.3rem}
.idea-card .meta{display:flex;gap:0.8rem;margin-top:0.6rem;font-size:0.78rem;color:var(--text-muted);flex-wrap:wrap}
.idea-card .next-action{font-size:0.78rem;color:var(--warn);margin-top:0.5rem;padding:0.4rem 0.7rem;background:var(--warn-bg);border-radius:5px}
.idea-card .scores{font-family:'SF Mono','Consolas',monospace;font-size:0.85rem;text-align:right}
.idea-card .score-total{font-size:1.5rem;font-weight:600;color:var(--text-strong)}
.idea-card .score-split{font-size:0.72rem;color:var(--text-muted);margin-top:0.2rem}

/* Idea row (funnel ranking table) */
.idea-table{width:100%;border-collapse:collapse;font-size:0.88rem}
.idea-table thead{position:sticky;top:0;background:var(--surface-2);z-index:1}
.idea-table th{
  text-align:left;padding:0.6rem 0.8rem;
  color:var(--text-muted);font-weight:600;
  font-size:0.72rem;text-transform:uppercase;letter-spacing:0.04em;
  border-bottom:2px solid var(--border);cursor:pointer;user-select:none;
}
.idea-table th:hover{color:var(--text-strong)}
.idea-table th.sort-asc::after{content:' ▲';font-size:0.7em}
.idea-table th.sort-desc::after{content:' ▼';font-size:0.7em}
.idea-table td{padding:0.55rem 0.8rem;border-bottom:1px solid var(--border);vertical-align:middle}
.idea-table tr{transition:background 0.1s;cursor:pointer}
.idea-table tr:hover td{background:var(--surface-2)}
.idea-table .rank{font-weight:700;color:var(--text-muted);text-align:center;width:40px;font-family:'SF Mono','Consolas',monospace}
.idea-table .slug{font-weight:500;color:var(--text-strong)}
.idea-table .thesis-cell{font-size:0.82rem;color:var(--text-muted);max-width:340px;line-height:1.5}

/* Filters / controls */
.filters{
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:1rem;margin-bottom:1.2rem;
  display:flex;gap:0.8rem;flex-wrap:wrap;align-items:center;
}
.filters input.search{
  flex:1;min-width:200px;
  background:var(--bg);color:var(--text);
  border:1px solid var(--border);border-radius:6px;
  padding:0.5rem 0.8rem;font-size:0.88rem;font-family:inherit;
}
.filters input.search:focus{outline:none;border-color:var(--accent)}
.filters select{
  background:var(--bg);color:var(--text);
  border:1px solid var(--border);border-radius:6px;
  padding:0.5rem 0.7rem;font-size:0.85rem;cursor:pointer;
}
.filter-pill{
  padding:0.4rem 0.8rem;background:var(--surface-2);
  border:1px solid var(--border);border-radius:6px;
  font-size:0.78rem;font-weight:600;cursor:pointer;
  text-transform:uppercase;letter-spacing:0.04em;color:var(--text-muted);
  transition:all 0.15s;font-family:inherit;
}
.filter-pill:hover{color:var(--text-strong)}
.filter-pill.active{background:var(--accent);color:#0a0a0a;border-color:var(--accent)}

/* KPI strip */
.kpi-strip{
  display:flex;flex-wrap:wrap;gap:1.5rem;
  margin-top:1rem;font-size:0.85rem;color:var(--text-muted);
}
.kpi-strip strong{color:var(--accent);font-size:1.1rem;font-weight:600;font-family:'SF Mono','Consolas',monospace}

/* Footer */
footer{
  margin-top:5rem;padding:2rem 0;
  border-top:1px solid var(--border);
  font-size:0.82rem;color:var(--text-faint);text-align:center;
}
footer a{color:var(--text-muted);text-decoration:none;border-bottom:1px solid var(--border)}
footer a:hover{color:var(--accent);border-color:var(--accent)}

/* Decisions pending block (cockpit) */
.decisions-pending{
  background:var(--warn-bg);border:1px solid var(--warn);
  border-radius:10px;padding:1.2rem 1.4rem;margin-bottom:1.5rem;
}
.decisions-pending h2{color:var(--warn);border-bottom-color:var(--warn);padding-bottom:0.5rem;margin-bottom:0.8rem}
.decisions-pending ul{list-style:none;padding:0;font-size:0.9rem}
.decisions-pending li{padding:0.4rem 0;border-bottom:1px solid rgba(245,158,11,0.2)}
.decisions-pending li:last-child{border-bottom:none}
.decisions-pending .sla{font-size:0.74rem;color:var(--err);font-weight:600;margin-left:0.5rem}

/* Matrix BCG view */
.matrix-container{
  background:var(--surface);border:1px solid var(--border);
  border-radius:10px;padding:1.5rem;position:relative;
}
.matrix-canvas-wrap{position:relative;height:480px}

/* Mobile */
@media(max-width:720px){
  .wrap{padding:1.2rem 0.9rem}
  .pipeline-strip{gap:0.3rem}
  .pipeline-step{min-width:auto;padding:0.6rem 0.5rem;flex:1}
  .pipeline-step .count{font-size:1.3rem}
  .pipeline-step .desc{display:none}
  .idea-card{grid-template-columns:1fr;gap:0.5rem}
  .idea-card .scores{text-align:left}
  .filters{padding:0.7rem}
  .idea-table{font-size:0.8rem}
  .idea-table th,.idea-table td{padding:0.4rem 0.5rem}
  .idea-table .thesis-cell{max-width:180px;font-size:0.74rem}
}
