/* ═══════════════════════════════════════════════════════════
   Engines of Growth — Game-specific styles
   Extends /styles.css (shared civic.games base)
   ═══════════════════════════════════════════════════════════ */

/* ── Pillar colour tokens ── */
:root {
  --pillar-finance:      #C87A20;
  --pillar-workforce:    #4A8C72;
  --pillar-infra:        #4D696D;
  --pillar-innovation:   #7B6FB0;
  --pillar-entrep:       #B85C3A;
  --pillar-finance-bg:   #FEF6EC;
  --pillar-workforce-bg: #EBF5F0;
  --pillar-infra-bg:     #EBF4F4;
  --pillar-innovation-bg:#F2F0FA;
  --pillar-entrep-bg:    #FDF2EF;
  --green:               #2E7D5A;
  --green-bg:            #E8F5EE;
}

/* ── Brand bar (ink top strip with logo + game counter) ── */
.brand-bar {
  background: var(--ink);
  padding: 12px 24px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.brand-bar svg { display: block; }
.game-counter {
  font-size: 9px; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase;
  color: rgba(234,229,208,.3);
}

/* ── Round header strip ── */
.round-strip {
  background: var(--ink);
  padding: 10px 24px;
  display: flex; justify-content: space-between; align-items: center;
}
.round-strip-left {
  font-size: 9px; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--amber);
}
.round-strip-right {
  font-size: 9px; color: rgba(234,229,208,.35);
  letter-spacing: .06em;
}

/* ── Economy strip (4-cell summary row) ── */
.economy-strip {
  border-bottom: 1px solid var(--border);
  display: grid; grid-template-columns: repeat(4,1fr);
}
.econ-cell {
  padding: 10px 12px; text-align: center;
  border-right: 1px solid var(--border);
}
.econ-cell:last-child { border-right: none; }
.econ-label {
  font-size: 7px; font-weight: 800;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-faint); margin-bottom: 3px;
}
.econ-val {
  font-family: 'EB Garamond', serif;
  font-size: 18px; font-weight: 400; line-height: 1;
  color: var(--ink);
}
.econ-val.amber  { color: var(--amber); }
.econ-val.danger { color: var(--rust); }
.econ-val.green  { color: var(--green); }
.econ-val em { font-size: 11px; color: var(--ink-faint); font-style: normal; }

/* ── Pillar bar strip ── */
.pillar-strip {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 10px 16px;
  display: flex; gap: 8px;
}
.p-unit { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.p-label {
  font-size: 7px; font-weight: 800;
  letter-spacing: .1em; text-transform: uppercase;
  color: var(--ink-faint);
}
.p-track { height: 4px; background: var(--bar-bg); border-radius: 2px; overflow: hidden; }
.p-fill  { height: 100%; border-radius: 2px; }
.p-row   { display: flex; justify-content: space-between; }
.p-val   { font-size: 9px; font-weight: 700; color: var(--ink-muted); }
.p-val.low { color: var(--rust); font-weight: 800; }
.p-delta { font-size: 8px; font-weight: 700; }
.p-delta.up   { color: var(--green); }
.p-delta.down { color: var(--rust); }

/* ── Policy market header ── */
.market-header {
  background: var(--white);
  border-bottom: 1px solid var(--border);
  padding: 10px 16px;
  display: flex; justify-content: space-between; align-items: center;
}
.market-header-left {}
.market-title {
  font-size: 9px; font-weight: 800;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--ink);
}
.market-sub {
  font-family: 'EB Garamond', serif; font-style: italic;
  font-size: 12px; color: var(--ink-muted); margin-top: 1px;
}
.pushes-counter { display: flex; align-items: baseline; gap: 2px; }
.pushes-num {
  font-family: 'EB Garamond', serif;
  font-size: 28px; line-height: 1; color: var(--amber);
}
.pushes-denom {
  font-family: 'EB Garamond', serif;
  font-size: 17px; color: var(--ink-faint);
}
.pushes-label {
  font-size: 7px; font-weight: 800;
  letter-spacing: .14em; text-transform: uppercase;
  color: var(--ink-faint); margin-top: 2px;
}

/* ── Filter tabs ── */
.filter-tabs {
  background: var(--white);
  border-bottom: 2px solid var(--border);
  display: flex; overflow-x: auto; scrollbar-width: none;
  padding: 0 12px;
}
.filter-tabs::-webkit-scrollbar { display: none; }
.ftab {
  padding: 7px 10px;
  font-size: 9px; font-weight: 800; letter-spacing: .1em;
  text-transform: uppercase; color: var(--ink-faint);
  white-space: nowrap; flex-shrink: 0; cursor: pointer;
  border-bottom: 2px solid transparent; margin-bottom: -2px;
}
.ftab.active         { color: var(--ink); border-bottom-color: var(--amber); }
.ftab.active-suite   { color: var(--teal); border-bottom-color: var(--teal); }

/* ── Market grid (2-col policy cards) ── */
.market-grid {
  background: #F0EDE4;
  padding: 10px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}

/* ── Policy card ── */
.pcard {
  background: var(--white);
  border: 1.5px solid var(--border);
  cursor: pointer;
  display: flex; flex-direction: column;
  transition: border-color .12s;
}
.pcard:hover            { border-color: var(--amber); }
.pcard.selected         { border-color: var(--amber); border-width: 2px; }
.pcard.suite            { border-color: #C4DDE0; }
.pcard.suite.selected   { border-color: var(--teal); }

.pcard-band { height: 3px; flex-shrink: 0; }

.pcard-body { padding: 9px 10px 8px; flex: 1; display: flex; flex-direction: column; gap: 5px; }
.pcard-top  { display: flex; align-items: center; justify-content: space-between; gap: 4px; }
.pcard-pillar { font-size: 8px; font-weight: 800; letter-spacing: .09em; text-transform: uppercase; }
.pcard-stage  { font-size: 8px; font-weight: 700; color: var(--ink-faint); background: #F0EDE4; padding: 1px 5px; }
.pcard-suite-pip { font-size: 8px; font-weight: 800; color: var(--teal); background: #EBF4F4; padding: 1px 5px; }
.pcard-name {
  font-family: 'EB Garamond', serif;
  font-size: 13.5px; font-weight: 500;
  line-height: 1.2; color: var(--ink); flex: 1;
}

/* benefit row */
.pcard-benefit {
  border-top: 1px solid var(--border);
  padding: 6px 10px; background: #F4FAF7;
  display: flex; justify-content: space-between; align-items: center;
}
.pcard.selected .pcard-benefit { background: #D8EFE3; }
.pb-label { font-size: 7px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--green); }
.pb-val   { font-size: 11px; font-weight: 800; color: var(--green); }
.pb-passive { font-size: 9px; font-weight: 700; color: #4A9B72; }

/* ── Detail tray ── */
.detail-tray {
  background: var(--white);
  border-top: 2px solid var(--amber);
  padding: 14px 16px 16px;
}
.tray-meta { display: flex; gap: 6px; align-items: center; flex-wrap: wrap; margin-bottom: 6px; }
.tray-pillar-label { font-size: 8px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.tray-suite-tag { font-size: 8px; font-weight: 800; color: var(--teal); background: #EBF4F4; padding: 2px 6px; }
.tray-name {
  font-family: 'EB Garamond', serif;
  font-size: 17px; font-weight: 500; color: var(--ink);
  margin-bottom: 6px; line-height: 1.2;
}
.tray-desc {
  font-family: 'EB Garamond', serif; font-style: italic;
  font-size: 13px; line-height: 1.6; color: var(--ink-mid);
  margin-bottom: 10px;
}
.tray-benefit-block {
  background: #F4FAF7; border: 1px solid #9DD4B8;
  padding: 10px 12px; margin-bottom: 10px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
}
.tbb { display: flex; flex-direction: column; gap: 2px; }
.tbb + .tbb { border-left: 1px solid #C8E8D8; padding-left: 10px; }
.tbb-label { font-size: 7px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: var(--green); }
.tbb-val   { font-size: 14px; font-weight: 800; color: var(--green); }
.tbb-sub   { font-size: 9px; color: var(--ink-muted); line-height: 1.35; }
.tray-suite-hint {
  background: #EBF4F4; border: 1px solid #9ECCD4;
  padding: 7px 10px; margin-bottom: 10px;
  display: flex; gap: 6px; align-items: flex-start;
}
.tsh-icon { color: var(--teal); flex-shrink: 0; font-size: 12px; }
.tsh-text  { font-size: 10px; font-weight: 600; color: var(--teal); line-height: 1.4; }

/* ── Enterprise cards ── */
.enterprise-grid { background: #F0EDE4; padding: 10px; display: flex; flex-direction: column; gap: 8px; }
.ecard { background: var(--white); border: 1.5px solid var(--border); }
.ecard.affordable { border-color: #9DD4B8; }
.ecard-head { padding: 10px 12px 8px; display: flex; gap: 10px; align-items: flex-start; }
.ecard-stage-badge {
  font-size: 8px; font-weight: 800; letter-spacing: .12em; text-transform: uppercase;
  color: var(--white); padding: 3px 7px; flex-shrink: 0; margin-top: 2px;
}
.ecard-stage-badge.micro  { background: var(--pillar-entrep); }
.ecard-stage-badge.small  { background: var(--teal); }
.ecard-stage-badge.medium { background: var(--ink); }
.ecard-info {}
.ecard-sector { font-size: 8px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--amber); margin-bottom: 3px; }
.ecard-name { font-family: 'EB Garamond', serif; font-size: 16px; font-weight: 500; color: var(--ink); line-height: 1.2; }
.ecard-employees { font-size: 10px; color: var(--ink-muted); margin-top: 3px; }

.ecard-costs {
  border-top: 1px solid var(--border);
  padding: 8px 12px; background: #FAFAF6;
  display: grid; grid-template-columns: repeat(5,1fr); gap: 4px;
}
.ecost { display: flex; flex-direction: column; gap: 2px; align-items: center; }
.ecost-track { width: 100%; height: 4px; background: var(--bar-bg); overflow: hidden; }
.ecost-fill  { height: 100%; }
.ecost-val   { font-size: 9px; font-weight: 700; text-align: center; }
.ecost-name  { font-size: 6px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; text-align: center; color: var(--ink-faint); }
.ecost.met   .ecost-val { color: var(--green); }
.ecost.unmet .ecost-val { color: var(--rust); }

.ecard-foot {
  border-top: 1px solid var(--border); padding: 8px 12px;
  display: flex; justify-content: space-between; align-items: center;
}
.ecard-status-ok   { font-size: 9px; font-weight: 700; color: var(--green); }
.ecard-status-need { font-size: 9px; font-weight: 600; color: var(--rust); }
.btn-attract {
  background: var(--green); color: var(--white); border: none;
  padding: 7px 14px; font-family: 'Inter', sans-serif;
  font-size: 9px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase;
  cursor: pointer;
}
.btn-attract:disabled { background: var(--bar-bg); color: var(--ink-faint); cursor: not-allowed; }

/* ── Policy ecosystem screen ── */
.eco-passive-summary {
  border-bottom: 1px solid var(--border);
  padding: 12px 16px; background: var(--white);
  display: grid; grid-template-columns: repeat(5,1fr); gap: 4px;
}
.eps-cell { background: #F5F2EC; border: 1px solid var(--border); padding: 6px 4px; text-align: center; }
.eps-val  { font-family: 'EB Garamond', serif; font-size: 15px; font-weight: 500; }
.eps-val.has-income { color: var(--green); }
.eps-val.zero       { color: var(--ink-faint); }
.eps-label { font-size: 7px; font-weight: 800; letter-spacing: .08em; text-transform: uppercase; color: var(--ink-faint); margin-top: 1px; }

.eco-section-head {
  padding: 8px 16px 4px;
  font-size: 8px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase;
  color: var(--ink-faint); background: #F0EDE4;
}

.pushed-policy {
  background: var(--white); border-bottom: 1px solid var(--border);
  display: flex; flex-direction: column;
}
.pp-band { height: 3px; flex-shrink: 0; }
.pp-body { padding: 9px 16px 8px; display: flex; gap: 10px; align-items: flex-start; }
.pp-round { font-size: 8px; font-weight: 700; color: var(--ink-faint); padding-top: 2px; flex-shrink: 0; }
.pp-pillar { font-size: 8px; font-weight: 800; letter-spacing: .09em; text-transform: uppercase; margin-bottom: 2px; }
.pp-name { font-family: 'EB Garamond', serif; font-size: 14px; font-weight: 500; color: var(--ink); line-height: 1.2; }
.pp-suite-tag { font-size: 8px; font-weight: 800; color: var(--teal); background: #EBF4F4; padding: 1px 5px; display: inline-block; margin-top: 3px; }
.pp-passive {
  border-top: 1px solid var(--border); padding: 5px 16px;
  background: #F4FAF7;
  display: flex; justify-content: space-between; align-items: center;
}
.pp-passive-label { font-size: 8px; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; color: var(--green); }
.pp-passive-val   { font-size: 10px; font-weight: 800; color: var(--green); }

.suite-progress-card {
  background: var(--white); border-bottom: 1px solid var(--border);
  padding: 12px 16px;
}
.spc-top { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.spc-name { font-size: 12px; font-weight: 700; color: var(--ink); }
.spc-bonus { font-size: 9px; font-weight: 700; color: var(--teal); }
.spc-dots { display: flex; gap: 4px; }
.sp-dot { width: 9px; height: 9px; border-radius: 50%; border: 1.5px solid var(--bar-bg); }
.sp-dot.done    { background: var(--amber); border-color: var(--amber); }
.sp-dot.current { background: var(--teal);  border-color: var(--teal); }
.spc-rows { display: flex; flex-direction: column; gap: 0; }
.spc-row { display: flex; align-items: center; gap: 8px; padding: 5px 0; border-bottom: 1px solid var(--border); font-size: 11px; }
.spc-row:last-child { border-bottom: none; }
.spc-status { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.spc-status.done    { background: var(--amber); }
.spc-status.next    { background: var(--teal); }
.spc-status.locked  { background: var(--bar-bg); }
.spc-card-name { flex: 1; color: var(--ink); }
.spc-stage { font-size: 8px; color: var(--ink-faint); font-weight: 700; }

/* ── Intro / opening ── */
.stats-table { border: 1px solid var(--border); margin: 0 24px; }
.stats-head {
  background: var(--ink); padding: 7px 14px;
  font-size: 8px; font-weight: 800; letter-spacing: .2em;
  text-transform: uppercase; color: rgba(234,229,208,.4);
}
.stat-row { display: flex; justify-content: space-between; align-items: center; padding: 9px 14px; border-bottom: 1px solid var(--border); }
.stat-row:last-child { border-bottom: none; }
.stat-row:nth-child(even) { background: #FAFAF6; }
.stat-label { font-size: 12px; color: var(--ink-muted); }
.stat-val { font-family: 'EB Garamond', serif; font-size: 16px; font-weight: 500; color: var(--ink); }
.stat-val.amber  { color: var(--amber); }
.stat-val.danger { color: var(--rust); }

.pillar-table { border: 1px solid var(--border); border-top: none; margin: 0 24px; }
.pillar-table-head { background: #F5F2EC; padding: 6px 14px; font-size: 8px; font-weight: 800; letter-spacing: .18em; text-transform: uppercase; color: var(--ink-faint); border-bottom: 1px solid var(--border); border-top: 1px solid var(--border); }
.pillar-table-row { display: flex; align-items: center; padding: 8px 14px; gap: 12px; border-bottom: 1px solid var(--border); }
.pillar-table-row:last-child { border-bottom: none; }
.pillar-table-row:nth-child(even) { background: #FAFAF6; }
.ptr-name { font-size: 11px; color: var(--ink-muted); width: 120px; flex-shrink: 0; }
.ptr-track { flex: 1; height: 3px; background: var(--bar-bg); overflow: hidden; }
.ptr-fill  { height: 100%; }
.ptr-val   { font-size: 10px; font-weight: 800; width: 36px; text-align: right; flex-shrink: 0; }
.ptr-val.ok  { color: var(--ink-muted); }
.ptr-val.low { color: var(--rust); }

.objectives { padding: 0 24px; display: flex; flex-direction: column; gap: 8px; }
.obj-card { border: 1px solid var(--border); padding: 13px 15px; display: flex; gap: 14px; align-items: flex-start; background: var(--white); }
.obj-n { font-family: 'EB Garamond', serif; font-size: 26px; line-height: 1; color: var(--amber); opacity: .7; flex-shrink: 0; margin-top: 1px; }
.obj-title { font-size: 12px; font-weight: 700; color: var(--ink); margin-bottom: 3px; }
.obj-desc  { font-family: 'EB Garamond', serif; font-style: italic; font-size: 13.5px; line-height: 1.55; color: var(--ink-mid); }

.section-gap { padding: 28px 24px 0; }
.section-label-line { font-size: 8px; font-weight: 800; letter-spacing: .22em; text-transform: uppercase; color: var(--ink-faint); display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.section-label-line::after { content: ''; flex: 1; height: 1px; background: var(--border); }

.cta-wrap { padding: 24px; }
.cta-wrap .btn { margin-bottom: 10px; }
.giz-line { text-align: center; font-size: 10px; color: var(--ink-faint); letter-spacing: .06em; margin-top: 14px; line-height: 1.8; }
.giz-line strong { color: var(--amber); font-weight: 700; }

/* ── Responsive — desktop gets a card layout ── */
@media (min-width: 700px) {
  .market-grid { grid-template-columns: repeat(3, 1fr); }
  .pillar-strip { padding: 12px 24px; gap: 12px; }
  .economy-strip { }
}
