/* --- CSS VARIABLES (THEME TOKENS) --- */
:root {
  --c-color-gray-100: #F8FAFD;
  --c-color-gray-200: #EFF2F5;
  --c-color-gray-300: #CFD6E4;
  --c-color-gray-400: #A6B0C3;
  --c-color-gray-500: #808A9D;
  --c-color-gray-600: #616E85;
  --c-color-blue-500: #3861FB;
  --c-color-blue-600: #2444D4;
  --c-color-green-500: #16C784;
  --c-color-red-500: #EA3943;
  --c-color-background-1: #FCFDFE;
  --c-color-background-2: #FFFFFF;
  --c-color-surface-1: #FFFFFF;
  --c-color-surface-2: #F8FAFD;
  --c-color-text-primary: #0D1421;
  --c-color-text-secondary: #616E85;
  --c-color-text-caption: #A6B0C3;
  --c-color-text-hyperlink: #3861FB;
  --c-color-negative: #EA3943;
  --c-color-positive: #16C784;
  --c-shadow-tiny: 0px 1px 2px 0px rgba(88, 102, 126, 0.12), 0px 4px 24px 0px rgba(88, 102, 126, 0.08);
}

.NIGHT {
  --c-color-gray-100: #222531;
  --c-color-gray-200: #323546;
  --c-color-gray-300: #53596A;
  --c-color-gray-400: #646B80;
  --c-color-gray-500: #858CA2;
  --c-color-gray-600: #A1A7BB;
  --c-color-background-1: #171924;
  --c-color-background-2: #0D1421;
  --c-color-surface-1: #222531;
  --c-color-surface-2: #2B2E3D;
  --c-color-text-primary: #FFFFFF;
  --c-color-text-secondary: #A1A7BB;
  --c-color-text-caption: #646B80;
  --c-color-text-hyperlink: #6188FF;
  --c-color-negative-bg: #411F2A;
  --c-color-positive-bg: #173C37;
  --c-shadow-tiny: 0px 1px 2px 0px rgba(13, 20, 33, 0.24), 0px 4px 24px 0px rgba(13, 20, 33, 0.12);
}

/* --- BASE RESET --- */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
body, html {
  font-family: Inter, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Helvetica, Arial, sans-serif;
  background: var(--c-color-background-1);
  color: var(--c-color-text-primary);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
a { color: var(--c-color-text-hyperlink); text-decoration: none; }
a:hover { text-decoration: underline; }
button { cursor: pointer; font-family: inherit; }
ul { list-style: none; }

/* --- HEADER --- */
.cmc-header {
  position: sticky; top: 0; z-index: 100;
  background: var(--c-color-background-2);
  border-bottom: 1px solid var(--c-color-gray-200);
}
.cmc-header__inner {
  max-width: 1400px; margin: 0 auto;
  padding: 0 24px; height: 64px;
  display: flex; align-items: center; justify-content: space-between; gap: 20px;
}
.cmc-header__left { display: flex; align-items: center; gap: 24px; flex: 1; min-width: 0; }
.cmc-logo { display: flex; align-items: center; flex-shrink: 0; }
.cmc-logo svg { height: 26px; width: auto; }
.cmc-nav { display: flex; align-items: center; gap: 16px; white-space: nowrap; overflow-x: auto; }
.cmc-nav__link {
  color: var(--c-color-text-primary); font-size: 14px; font-weight: 600;
  text-decoration: none; padding: 8px 0;
}
.cmc-nav__link:hover { color: var(--c-color-blue-500); text-decoration: none; }

.cmc-header__right { display: flex; align-items: center; gap: 12px; flex-shrink: 0; }
.cmc-plain-btn {
  height: 36px; padding: 0 12px; border-radius: 10px;
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--c-color-text-primary); text-decoration: none; font-size: 14px; font-weight: 600;
}
.cmc-plain-btn:hover { background: var(--c-color-gray-100); text-decoration: none; }
.cmc-plain-btn svg { color: var(--c-color-text-secondary); }

.cmc-search-trigger {
  height: 36px; width: 200px; padding: 0 12px; border-radius: 999px; border: 0;
  background: var(--c-color-gray-100); color: var(--c-color-text-secondary);
  display: inline-flex; align-items: center; gap: 8px; font-size: 14px; font-weight: 600;
}
.cmc-search-trigger__kbd {
  margin-left: auto; height: 22px; min-width: 22px; padding: 0 6px; border-radius: 6px;
  background: var(--c-color-background-2); border: 1px solid var(--c-color-gray-200);
  color: var(--c-color-text-caption); font-size: 12px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
}

.cmc-theme-toggle {
  width: 36px; height: 36px; border-radius: 999px; border: 0;
  background: var(--c-color-gray-100); color: var(--c-color-text-secondary);
  display: inline-flex; align-items: center; justify-content: center;
}
.cmc-theme-toggle:hover { background: var(--c-color-gray-200); color: var(--c-color-text-primary); }
.NIGHT .icon-sun { display: block; }
.NIGHT .icon-moon { display: none; }
.icon-sun { display: none; }
.icon-moon { display: block; }

.cmc-login-btn {
  height: 36px; padding: 0 16px; border-radius: 999px; border: 0;
  background: var(--c-color-blue-500); color: #fff; font-size: 14px; font-weight: 700;
}
.cmc-login-btn:hover { background: var(--c-color-blue-600); }

.cmc-user__avatar {
  width: 36px; height: 36px; border-radius: 999px; border: 0;
  background: transparent; color: var(--c-color-text-secondary);
  display: inline-flex; align-items: center; justify-content: center;
}
.cmc-user__avatar:hover { background: var(--c-color-gray-100); color: var(--c-color-text-primary); }

.cmc-mobile-menu-btn {
  display: none; width: 36px; height: 36px; border: 0; background: transparent;
  color: var(--c-color-text-primary); align-items: center; justify-content: center;
}

/* Mobile Menu Overlay */
.mobile-menu-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.5); z-index: 200;
  opacity: 0; visibility: hidden; transition: all 0.3s ease;
}
.mobile-menu-drawer {
  position: absolute; left: 0; top: 0; bottom: 0; width: 280px;
  background: var(--c-color-background-2); padding: 24px;
  display: flex; flex-direction: column; gap: 16px;
  transform: translateX(-100%); transition: transform 0.3s ease;
}
.mobile-menu-drawer a {
  color: var(--c-color-text-primary); font-size: 16px; font-weight: 600; text-decoration: none;
}
body.mobile-menu-open .mobile-menu-overlay { opacity: 1; visibility: visible; }
body.mobile-menu-open .mobile-menu-drawer { transform: translateX(0); }

/* --- MAIN VOTE APP --- */
.cmc-main { min-height: calc(100vh - 64px - 200px); padding: 24px 0; }
.page-grid {
  max-width: 1200px; margin: 0 auto; padding: 0 24px;
  display: grid; grid-template-columns: minmax(0, 1fr) 360px;
  grid-template-areas: "header sidebar" "about sidebar" "links sidebar";
  gap: 24px; align-items: start;
}
.token-header-section { grid-area: header; }
.voting-sidebar-section { grid-area: sidebar; position: sticky; top: 88px; }
.about-section { grid-area: about; }
.links-section { grid-area: links; }

.back-link {
  display: inline-flex; align-items: center; gap: 8px;
  color: var(--c-color-text-secondary); font-weight: 600; font-size: 14px;
  margin-bottom: 16px; text-decoration: none;
}
.back-link:hover { color: var(--c-color-text-primary); text-decoration: none; }

.token-header-card {
  border-radius: 16px; overflow: hidden;
  background: var(--c-color-surface-1); border: 1px solid var(--c-color-gray-200);
  box-shadow: var(--c-shadow-tiny);
}
.token-header-bg {
  width: 100%; aspect-ratio: 3/1;
  background: radial-gradient(1000px 120px at 10% 0, rgba(56,97,251,.22), rgba(56,97,251,0)), 
              radial-gradient(900px 200px at 70% 0, rgba(22,199,132,.16), rgba(22,199,132,0));
  background-color: var(--c-color-surface-2);
}
.token-header-content { padding: 0 24px 24px; }
.token-logo-large {
  width: 84px; height: 84px; border-radius: 50%;
  background: var(--c-color-surface-1); border: 4px solid var(--c-color-surface-1);
  display: flex; align-items: center; justify-content: center; overflow: hidden;
  margin-top: -42px; box-shadow: 0 8px 24px rgba(0,0,0,.08);
}
.token-logo-large img { width: 100%; height: 100%; object-fit: cover; }
.token-title-row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin-top: 16px; }
.token-title { font-size: 28px; font-weight: 800; color: var(--c-color-text-primary); }
.token-symbol-badge {
  height: 28px; padding: 0 12px; border-radius: 999px;
  background: var(--c-color-gray-100); color: var(--c-color-text-secondary);
  font-weight: 700; font-size: 14px; display: inline-flex; align-items: center;
}
.token-badges { display: flex; gap: 8px; margin-left: auto; }
.badge {
  display: inline-flex; align-items: center; gap: 6px; height: 28px; padding: 0 12px;
  border-radius: 999px; font-size: 13px; font-weight: 700; white-space: nowrap;
}
.badge svg { width: 14px; height: 14px; }
.badge-trending { background: rgba(22,199,132,.12); color: var(--c-color-positive); }
.badge-rank { background: rgba(240,185,11,.22); color: #c58f00; }
.NIGHT .badge-rank { color: #f3b55a; }

.token-meta-row { margin-top: 16px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.network-badge, .contract-badge {
  display: inline-flex; align-items: center; gap: 10px; height: 36px; padding: 0 14px;
  border-radius: 999px; border: 1px solid var(--c-color-gray-200);
  background: var(--c-color-surface-1); color: var(--c-color-text-primary);
  font-weight: 600; font-size: 14px;
}
.contract-badge button {
  width: 28px; height: 28px; border-radius: 8px; border: 0;
  background: var(--c-color-gray-100); display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-color-text-secondary);
}
.contract-badge button:hover { color: var(--c-color-text-primary); }
.contract-badge button svg { width: 16px; height: 16px; }

.section-card {
  margin-top: 24px; border-radius: 16px;
  background: var(--c-color-surface-1); border: 1px solid var(--c-color-gray-200);
  padding: 24px; box-shadow: var(--c-shadow-tiny);
}
.section-title {
  margin: 0 0 16px; color: var(--c-color-text-primary); font-size: 18px; font-weight: 800;
  display: flex; align-items: center; gap: 10px;
}
.section-title svg { width: 20px; height: 20px; color: var(--c-color-text-secondary); }
.description-text { color: var(--c-color-text-secondary); font-size: 15px; line-height: 1.6; }
.description-text p { margin: 0 0 12px; }

.links-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 12px; }
.link-item {
  height: 48px; padding: 0 16px; border-radius: 12px;
  border: 1px solid var(--c-color-gray-200); background: var(--c-color-surface-1);
  text-decoration: none; color: var(--c-color-text-primary); font-weight: 700; font-size: 14px;
  display: flex; align-items: center; gap: 10px;
}
.link-item:hover { background: var(--c-color-gray-100); text-decoration: none; }
.link-icon {
  width: 32px; height: 32px; border-radius: 999px;
  display: flex; align-items: center; justify-content: center; color: #fff; flex-shrink: 0;
}
.link-icon svg { width: 18px; height: 18px; }
.link-icon.website { background: var(--c-color-blue-500); }
.link-icon.twitter { background: #000; }
.link-icon.telegram { background: #229ed9; }
.link-icon.dexscreener { background: var(--c-color-positive); }

/* Voting Sidebar */
.voting-card {
  border-radius: 16px; border: 1px solid var(--c-color-gray-200);
  background: var(--c-color-surface-1); padding: 24px; box-shadow: var(--c-shadow-tiny);
}
.voting-header { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.voting-title { font-size: 18px; font-weight: 800; color: var(--c-color-text-primary); }
.live-badge {
  display: inline-flex; align-items: center; gap: 6px; height: 26px; padding: 0 10px;
  border-radius: 999px; background: rgba(22,199,132,.12); color: var(--c-color-positive);
  font-weight: 700; font-size: 12px;
}
.live-dot { width: 8px; height: 8px; border-radius: 999px; background: var(--c-color-positive); box-shadow: 0 0 0 4px rgba(22,199,132,.15); }

.vote-stats {
  border-radius: 12px; border: 1px solid var(--c-color-gray-200);
  display: grid; grid-template-columns: 1fr auto 1fr; overflow: hidden; margin-bottom: 20px;
}
.vote-stat { padding: 16px; text-align: center; }
.vote-stat-value { font-size: 24px; font-weight: 800; color: var(--c-color-text-primary); }
.vote-stat-label { font-size: 13px; font-weight: 600; color: var(--c-color-text-caption); margin-top: 4px; }
.vote-divider { width: 1px; background: var(--c-color-gray-200); }

.progress-section { margin-bottom: 20px; }
.progress-header { display: flex; justify-content: space-between; color: var(--c-color-text-secondary); font-size: 14px; font-weight: 600; margin-bottom: 8px; }
.progress-bar { height: 8px; border-radius: 999px; background: var(--c-color-gray-200); overflow: hidden; }
.progress-fill { height: 100%; background: linear-gradient(90deg, var(--c-color-blue-500), var(--c-color-positive)); border-radius: 999px; transition: width 0.5s ease; }
.progress-info { margin-top: 8px; display: flex; justify-content: space-between; color: var(--c-color-text-caption); font-size: 13px; font-weight: 600; }

.vote-btn {
  width: 100%; height: 48px; border-radius: 12px; border: 0;
  background: var(--c-color-blue-500); color: #fff; font-weight: 700; font-size: 15px;
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
}
.vote-btn:hover { background: var(--c-color-blue-600); }
.vote-hint { margin-top: 12px; color: var(--c-color-text-caption); font-size: 13px; font-weight: 600; text-align: center; }

.recent-section { margin-top: 24px; border-top: 1px solid var(--c-color-gray-200); padding-top: 20px; }
.recent-title { color: var(--c-color-text-secondary); font-size: 14px; font-weight: 700; margin-bottom: 12px; display: block;}
.voters-list { display: grid; gap: 10px; max-height: 300px; overflow-y: auto; }
.voter-item {
  display: flex; align-items: center; gap: 12px; padding: 10px;
  border-radius: 12px; border: 1px solid var(--c-color-gray-200);
}
.voter-item.is-new { border-color: rgba(22,199,132,.35); background: rgba(22,199,132,.06); }
.voter-avatar {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--c-color-surface-2); border: 1px solid var(--c-color-gray-200);
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.voter-logo { width: 20px; height: 20px; object-fit: contain; }
.voter-info { min-width: 0; }
.voter-address { font-weight: 700; font-size: 14px; color: var(--c-color-text-primary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.voter-time { font-size: 12px; font-weight: 600; color: var(--c-color-text-caption); margin-top: 2px; }

.fetch-error {
  margin-top: 16px; padding: 12px; background: rgba(234,57,67,.08);
  border: 1px solid rgba(234,57,67,.25); color: var(--c-color-negative);
  border-radius: 12px; font-weight: 600; font-size: 14px;
}

/* --- FOOTER --- */
.cmc-footer {
  background: var(--c-color-background-2); border-top: 1px solid var(--c-color-gray-200);
  padding: 48px 0 24px; margin-top: 48px;
}
.footer-container { max-width: 1400px; margin: 0 auto; padding: 0 24px; }
.footer-navigation { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; margin-bottom: 32px; }
.footer-row { display: grid; grid-template-columns: 1fr 1fr; gap: 32px; }
.footer-list-wrapper span {
  display: block; color: var(--c-color-text-caption); font-size: 14px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 16px;
}
.footer-list-wrapper ul { display: flex; flex-direction: column; gap: 12px; }
.footer-list-wrapper a { color: var(--c-color-text-secondary); font-size: 14px; font-weight: 500; }
.footer-list-wrapper a:hover { color: var(--c-color-text-primary); text-decoration: none; }
.footer-meta { border-top: 1px solid var(--c-color-gray-200); padding-top: 24px; text-align: center; }
.footer-copyright { color: var(--c-color-text-caption); font-size: 13px; font-weight: 500; }

/* --- RESPONSIVE --- */
@media (max-width: 1100px) {
  .cmc-nav, .cmc-plain-btn, .cmc-search-trigger { display: none; }
  .cmc-mobile-menu-btn { display: flex; }

  .page-grid {
    grid-template-columns: 1fr;
    grid-template-areas: "header" "sidebar" "about" "links";
    gap: 16px; padding: 0 16px;
  }
  .voting-sidebar-section { position: static; }
  .cmc-main { padding: 16px 0; }
}

@media (max-width: 768px) {
  .cmc-header__inner { padding: 0 16px; height: 56px; }
  .cmc-login-btn { display: none; }
  .token-title { font-size: 22px; }
  .token-logo-large { width: 64px; height: 64px; margin-top: -32px; }
  .token-badges { margin-left: 0; margin-top: 8px; width: 100%; }
  .links-grid { grid-template-columns: 1fr; }
  .footer-navigation { grid-template-columns: 1fr; gap: 24px; }
  .footer-row { grid-template-columns: 1fr 1fr; gap: 24px; }
}