/* ============================================================
   TokenProp — DAO Governance Styles
   ============================================================ */

.dao-page { padding-top: calc(var(--nav-height) + 32px); }

/* ---------- Header ---------- */
.dao-header {
  padding: 48px 0 32px;
  background: radial-gradient(ellipse at top center, rgba(245,166,35,0.06) 0%, transparent 60%);
}
.dao-header h1 { font-size: 2.4rem; margin-bottom: 8px; }
.dao-header p  { color: var(--text-secondary); font-size: 1.05rem; max-width: 650px; }

/* ---------- Layout ---------- */
.dao-layout {
  display: grid; grid-template-columns: 1fr 360px; gap: 36px;
  padding-bottom: 80px;
}

/* ---------- Proposals ---------- */
.proposals-section {}
.proposals-header {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 24px;
}
.proposals-header h2 { font-size: 1.5rem; }
.proposals-tabs { display: flex; gap: 4px; background: rgba(255,255,255,0.04); border-radius: 100px; padding: 4px; }
.proposals-tabs button {
  padding: 7px 18px; border-radius: 100px; border: none;
  background: transparent; color: var(--text-muted); font-size: 0.82rem; font-weight: 600;
  transition: all 0.2s; cursor: pointer;
}
.proposals-tabs button.active { background: var(--accent-blue); color: #fff; }

.proposal-card {
  padding: 24px; margin-bottom: 16px;
}

.proposal-top {
  display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 12px;
}
.proposal-id { font-size: 0.78rem; color: var(--text-muted); font-family: monospace; }
.proposal-card h3 { font-size: 1.1rem; margin: 8px 0 8px; }
.proposal-card .proposal-desc { font-size: 0.9rem; color: var(--text-secondary); margin-bottom: 16px; line-height: 1.6; }

.proposal-meta {
  display: flex; gap: 20px; flex-wrap: wrap; font-size: 0.82rem; margin-bottom: 20px;
}
.proposal-meta-item { display: flex; align-items: center; gap: 6px; color: var(--text-muted); }
.proposal-meta-item span { font-weight: 600; color: var(--text-primary); }

/* Voting bars */
.vote-bars { margin-bottom: 16px; }
.vote-bar-row { margin-bottom: 10px; }
.vote-bar-label {
  display: flex; justify-content: space-between; font-size: 0.82rem; margin-bottom: 4px;
}
.vote-bar-label .vl-text { color: var(--text-secondary); }
.vote-bar-label .vl-pct  { font-weight: 600; }
.vote-bar-track {
  width: 100%; height: 8px; border-radius: 4px; background: rgba(255,255,255,0.06); overflow: hidden;
}
.vote-bar-fill { height: 100%; border-radius: 4px; transition: width 1.2s var(--ease); }
.vote-bar-fill.for     { background: var(--gradient-green); }
.vote-bar-fill.against { background: linear-gradient(135deg, var(--accent-red), #ef6f6f); }
.vote-bar-fill.abstain { background: linear-gradient(135deg, #64748b, #94a3b8); }

.proposal-actions {
  display: flex; gap: 10px; padding-top: 16px; border-top: 1px solid rgba(255,255,255,0.06);
}
.vote-btn {
  flex: 1; padding: 10px; border-radius: var(--radius-sm); border: 1px solid rgba(255,255,255,0.1);
  background: rgba(255,255,255,0.04); color: var(--text-secondary); font-weight: 600;
  font-size: 0.85rem; cursor: pointer; transition: all 0.2s;
}
.vote-btn:hover { border-color: rgba(79,142,247,0.3); color: var(--accent-blue); }
.vote-btn.voted { border-color: rgba(0,212,161,0.4); color: var(--accent-green); background: rgba(0,212,161,0.08); pointer-events: none; }
.vote-btn.for-btn:hover { border-color: rgba(0,212,161,0.4); color: var(--accent-green); background: rgba(0,212,161,0.08); }
.vote-btn.against-btn:hover { border-color: rgba(239,68,68,0.4); color: var(--accent-red); background: rgba(239,68,68,0.08); }
.vote-btn.abstain-btn:hover { border-color: rgba(148,163,184,0.4); color: var(--text-secondary); background: rgba(148,163,184,0.08); }

/* ---------- Sidebar ---------- */
.dao-sidebar { position: sticky; top: calc(var(--nav-height) + 24px); }

/* POI Score Card */
.poi-card {
  padding: 24px; margin-bottom: 20px;
}
.poi-card h3 { font-size: 1.15rem; margin-bottom: 6px; }
.poi-card .poi-subtitle { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 20px; }

.poi-score-display {
  text-align: center; margin-bottom: 24px;
}
.poi-ring {
  position: relative; width: 140px; height: 140px; margin: 0 auto 12px;
}
.poi-ring svg { width: 100%; height: 100%; transform: rotate(-90deg); }
.poi-ring circle {
  fill: none; stroke-width: 8; stroke-linecap: round;
}
.poi-ring .ring-bg { stroke: rgba(255,255,255,0.06); }
.poi-ring .ring-fill {
  stroke: url(#poiGradient);
  stroke-dasharray: 408;
  stroke-dashoffset: 408;
  transition: stroke-dashoffset 1.5s var(--ease);
}
.poi-score-num {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-family: 'Space Grotesk'; font-size: 2rem; font-weight: 700;
}
.poi-score-label { font-size: 0.82rem; color: var(--text-muted); }

/* POI Breakdown */
.poi-breakdown { display: flex; flex-direction: column; gap: 12px; margin-bottom: 20px; }
.poi-factor {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px; border-radius: var(--radius-sm); background: rgba(255,255,255,0.03);
}
.poi-factor-left { display: flex; align-items: center; gap: 10px; }
.poi-factor-icon {
  width: 32px; height: 32px; border-radius: 8px; display: flex; align-items: center; justify-content: center;
  font-size: 0.9rem;
}
.poi-factor-name { font-size: 0.85rem; font-weight: 500; }
.poi-factor-weight { font-size: 0.75rem; color: var(--text-muted); }
.poi-factor-score { font-size: 1rem; font-weight: 700; }

/* Governance vs Financial */
.poi-comparison {
  padding: 16px; border-radius: var(--radius-sm); background: rgba(255,255,255,0.03);
  margin-bottom: 20px;
}
.poi-comparison h4 { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 12px; }
.comparison-row {
  display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px;
}
.comparison-row:last-child { margin-bottom: 0; }
.comparison-label { font-size: 0.85rem; }
.comparison-value { font-size: 0.95rem; font-weight: 700; }

/* Formula */
.poi-formula {
  padding: 16px; border-radius: var(--radius-sm);
  background: rgba(79,142,247,0.06); border: 1px dashed rgba(79,142,247,0.2);
}
.poi-formula h4 { font-size: 0.82rem; color: var(--accent-blue); margin-bottom: 8px; }
.poi-formula code {
  display: block; font-family: 'Space Grotesk', monospace; font-size: 0.82rem;
  color: var(--text-secondary); line-height: 1.6;
}

/* DAO Stats */
.dao-stats-card { padding: 24px; }
.dao-stats-card h3 { font-size: 1.15rem; margin-bottom: 16px; }
.dao-stat-row {
  display: flex; justify-content: space-between; padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.04); font-size: 0.88rem;
}
.dao-stat-row:last-child { border: none; }
.dao-stat-row .ds-label { color: var(--text-muted); }
.dao-stat-row .ds-value { font-weight: 600; }

/* Vote Success Toast */
.vote-toast {
  position: fixed; bottom: 32px; right: 32px; z-index: 3000;
  padding: 16px 24px; border-radius: var(--radius-md);
  background: var(--bg-secondary); border: 1px solid rgba(0,212,161,0.3);
  box-shadow: var(--shadow-lg), var(--shadow-glow-green);
  display: flex; align-items: center; gap: 12px;
  transform: translateY(100px); opacity: 0;
  transition: all 0.4s var(--ease); pointer-events: none;
}
.vote-toast.show { transform: translateY(0); opacity: 1; pointer-events: auto; }
.vote-toast .toast-icon { font-size: 1.3rem; }
.vote-toast .toast-text { font-size: 0.9rem; font-weight: 500; }

/* ---------- Responsive ---------- */
@media (max-width: 1024px) {
  .dao-layout { grid-template-columns: 1fr; }
  .dao-sidebar { position: static; display: grid; grid-template-columns: 1fr 1fr; gap: 20px; }
}
@media (max-width: 640px) {
  .dao-sidebar { grid-template-columns: 1fr; }
  .proposal-actions { flex-wrap: wrap; }
}
