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

:root {
  --bg:#0a0a1a;
  --bg2:#0f0f28;
  --card-bg:rgba(15,15,40,0.85);
  --cyan:#00f0ff;
  --magenta:#ff00e4;
  --purple:#7b2ff7;
  --text:#ffffff;
  --text2:#8888bb;
  --green:#00ff88;
  --orange:#ff8800;
  --radius:16px;
  --transition:0.3s cubic-bezier(0.4,0,0.2,1);
}

html{scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  overflow-x:hidden;
  line-height:1.6;
}

::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--cyan),var(--purple));border-radius:4px}
::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,var(--magenta),var(--cyan))}

::selection{background:var(--cyan);color:var(--bg)}

#particle-canvas{
  position:fixed;top:0;left:0;width:100%;height:100%;
  z-index:0;pointer-events:none;
}

.scanlines{
  position:fixed;top:0;left:0;width:100%;height:100%;
  z-index:0;pointer-events:none;
  background:repeating-linear-gradient(
    0deg,
    transparent,
    transparent 2px,
    rgba(0,240,255,0.015) 2px,
    rgba(0,240,255,0.015) 4px
  );
}

.container{
  max-width:1280px;margin:0 auto;padding:0 20px;
  position:relative;z-index:1;
}

/* ── Header ── */
.header{
  padding:30px 0 20px;
  position:relative;z-index:2;
}
.header-inner{
  display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:16px;
}
.logo-area{display:flex;align-items:center;gap:18px}
.logo-icon{flex-shrink:0;filter:drop-shadow(0 0 20px rgba(0,240,255,0.3))}
.logo-title{
  font-family:'Orbitron',sans-serif;
  font-size:28px;font-weight:700;
  background:linear-gradient(135deg,var(--cyan),var(--purple),var(--magenta));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  text-shadow:none;
  letter-spacing:-0.5px;
}
.logo-tagline{
  font-size:12px;color:var(--text2);letter-spacing:1px;text-transform:uppercase;margin-top:2px;
}
.domain-badge{
  font-family:'Orbitron',sans-serif;
  font-size:13px;font-weight:500;
  padding:8px 18px;
  border:1px solid var(--purple);
  border-radius:20px;
  color:var(--purple);
  letter-spacing:2px;
  text-transform:uppercase;
  background:rgba(123,47,247,0.1);
  position:relative;
  overflow:hidden;
}
.domain-badge::before{
  content:'';position:absolute;top:-50%;left:-50%;
  width:200%;height:200%;
  background:conic-gradient(transparent,var(--purple),transparent,var(--cyan),transparent);
  animation:spin 4s linear infinite;
  opacity:0.3;
}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Stats Bar ── */
.stats-bar{
  display:flex;align-items:center;justify-content:center;
  gap:24px;padding:24px 32px;
  background:var(--card-bg);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border:1px solid rgba(0,240,255,0.15);
  border-radius:var(--radius);
  margin-bottom:28px;
  position:relative;
}
.stats-bar::after{
  content:'';position:absolute;inset:-1px;
  border-radius:var(--radius);
  background:linear-gradient(135deg,var(--cyan),var(--purple),var(--magenta));
  z-index:-1;opacity:0.3;
}

.top-voted-container{
  margin-bottom: 32px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.top-section {
  background: rgba(15, 15, 40, 0.4);
  border: 1px solid rgba(0, 240, 255, 0.1);
  border-radius: var(--radius);
  padding: 20px;
  backdrop-filter: blur(10px);
}
.top-title {
  font-family: 'Orbitron', sans-serif;
  font-size: 16px;
  color: var(--cyan);
  text-transform: uppercase;
  letter-spacing: 1.5px;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.top-title::before {
  content: '★';
  color: var(--magenta);
}
.top-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 12px;
}
.top-card {
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.05);
  border-radius: 12px;
  padding: 12px;
  cursor: pointer;
  transition: var(--transition);
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: inherit;
}
.top-card:hover {
  background: rgba(0, 240, 255, 0.05);
  border-color: var(--cyan);
  transform: translateY(-2px);
}
.top-card .rank {
  font-family: 'Orbitron', sans-serif;
  font-size: 14px;
  color: var(--magenta);
  font-weight: 700;
  width: 20px;
}
.top-card .p-name {
  font-size: 13px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  flex: 1;
}
.top-card .p-score {
  font-size: 12px;
  color: var(--cyan);
  font-weight: 600;
}
.top-loading {
  grid-column: 1/-1;
  text-align: center;
  font-size: 12px;
  color: var(--text2);
  padding: 10px;
}

.stat-item{text-align:center}
.stat-number{
  display:block;
  font-family:'Orbitron',sans-serif;
  font-size:26px;font-weight:700;
  background:linear-gradient(135deg,var(--cyan),var(--magenta));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  background-clip:text;
  line-height:1.2;
}
.stat-label{font-size:12px;color:var(--text2);text-transform:uppercase;letter-spacing:1.5px}
.stat-divider{width:1px;height:36px;background:rgba(0,240,255,0.2)}

/* ── Controls ── */
.controls{margin-bottom:28px}
.search-wrapper{
  position:relative;margin-bottom:16px;
}
.search-icon{
  position:absolute;left:16px;top:50%;transform:translateY(-50%);
  pointer-events:none;
}
.search-input{
  width:100%;padding:16px 16px 16px 48px;
  background:rgba(15,15,40,0.6);
  border:1px solid rgba(0,240,255,0.2);
  border-radius:12px;
  color:var(--text);font-size:15px;font-family:'Inter',sans-serif;
  outline:none;transition:var(--transition);
}
.search-input:focus{
  border-color:var(--cyan);
  box-shadow:0 0 30px rgba(0,240,255,0.15),inset 0 0 30px rgba(0,240,255,0.05);
}
.search-input::placeholder{color:var(--text2)}
.search-suggestions{
  position:absolute;top:100%;left:0;right:0;
  background:rgba(10,10,26,0.95);
  backdrop-filter:blur(20px);
  border:1px solid rgba(0,240,255,0.15);
  border-top:none;
  border-radius:0 0 12px 12px;
  max-height:240px;overflow-y:auto;
  display:none;z-index:100;
}
.search-suggestions.show{display:block}
.suggestion-item{
  padding:10px 16px;cursor:pointer;
  color:var(--text2);font-size:14px;
  transition:var(--transition);
}
.suggestion-item:hover,.suggestion-item.active{
  background:rgba(0,240,255,0.1);color:var(--text);
}
.suggestion-item mark{background:transparent;color:var(--cyan);font-weight:600}

.filter-row{
  display:flex;align-items:flex-end;gap:14px;flex-wrap:wrap;
}
.filter-group{display:flex;flex-direction:column;gap:6px}
.filter-label{
  font-size:11px;text-transform:uppercase;letter-spacing:1.2px;color:var(--text2);
}
.select-wrap{position:relative}
.select-wrap::after{
  content:'▾';position:absolute;right:14px;top:50%;transform:translateY(-50%);
  color:var(--text2);font-size:12px;pointer-events:none;
}
.filter-select{
  appearance:none;-webkit-appearance:none;
  padding:10px 38px 10px 14px;
  background:rgba(15,15,40,0.6);
  border:1px solid rgba(0,240,255,0.15);
  border-radius:10px;
  color:var(--text);font-size:13px;font-family:'Inter',sans-serif;
  cursor:pointer;outline:none;transition:var(--transition);
  min-width:160px;
}
.filter-select:focus{
  border-color:var(--purple);
  box-shadow:0 0 20px rgba(123,47,247,0.15);
}
.results-count{margin-left:auto;text-align:right}
.results-number{
  font-family:'Orbitron',sans-serif;
  font-size:22px;font-weight:600;
  color:var(--cyan);display:block;line-height:1;
}
.results-label{font-size:11px;color:var(--text2);text-transform:uppercase;letter-spacing:1px}

/* ── Loading ── */
.loading-section{
  display:flex;justify-content:center;align-items:center;
  min-height:300px;
}
.loader{position:relative;text-align:center}
.loader-ring{
  position:absolute;top:50%;left:50%;
  width:60px;height:60px;
  margin:-30px 0 0 -30px;
  border:3px solid transparent;
  border-top-color:var(--cyan);
  border-radius:50%;
  animation:spin 0.8s linear infinite;
}
.loader-ring:nth-child(2){
  width:44px;height:44px;
  margin:-22px 0 0 -22px;
  border-top-color:var(--magenta);
  animation-duration:0.6s;animation-direction:reverse;
}
.loader-ring:nth-child(3){
  width:28px;height:28px;
  margin:-14px 0 0 -14px;
  border-top-color:var(--purple);
  animation-duration:0.5s;
}
.loader-text{
  margin-top:72px;color:var(--text2);
  font-size:13px;letter-spacing:2px;text-transform:uppercase;
}

/* ── Error ── */
.error-section{
  display:flex;justify-content:center;align-items:center;min-height:300px;
}
.error-card{
  text-align:center;padding:48px;
  background:var(--card-bg);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,136,0,0.3);
  border-radius:var(--radius);
  max-width:420px;
}
.error-title{
  font-family:'Orbitron',sans-serif;
  font-size:20px;margin:16px 0 8px;
  color:var(--orange);
}
.error-message{font-size:14px;color:var(--text2);margin-bottom:20px}
.error-retry{
  padding:10px 32px;
  background:linear-gradient(135deg,var(--orange),var(--magenta));
  border:none;border-radius:8px;
  color:#fff;font-size:14px;font-weight:600;
  cursor:pointer;transition:var(--transition);
  font-family:'Inter',sans-serif;
}
.error-retry:hover{transform:scale(1.05);box-shadow:0 0 30px rgba(255,136,0,0.4)}

/* ── Projects Grid ── */
.projects-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(300px,1fr));
  gap:20px;
  padding-bottom:40px;
}

/* ── Project Card ── */
.project-card{
  background:var(--card-bg);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-radius:var(--radius);
  padding:24px;
  cursor:pointer;
  position:relative;
  transition:var(--transition);
  border:1px solid rgba(0,240,255,0.08);
  overflow:hidden;
}
.project-card::before{
  content:'';position:absolute;inset:-1px;
  border-radius:var(--radius);
  background:linear-gradient(135deg,var(--cyan),var(--purple),var(--magenta),var(--cyan));
  background-size:300% 300%;
  z-index:-1;
  opacity:0;
  transition:opacity 0.5s ease;
  animation:gradMove 4s ease infinite;
}
@keyframes gradMove{
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
.project-card:hover::before{opacity:0.6}
.project-card:hover{
  transform:translateY(-4px);
  box-shadow:0 12px 48px rgba(0,240,255,0.12),0 0 60px rgba(123,47,247,0.08);
}
.project-card-inner{position:relative;z-index:1}
.project-card-header{
  display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;
}
.project-name{
  font-family:'Orbitron',sans-serif;
  font-size:16px;font-weight:600;
  color:var(--text);
  line-height:1.3;
  transition:var(--transition);
}
.project-card:hover .project-name{color:var(--cyan)}
.chain-badge{
  font-size:10px;font-weight:600;text-transform:uppercase;
  padding:4px 10px;
  border-radius:20px;
  white-space:nowrap;flex-shrink:0;
  letter-spacing:0.5px;
}
.chain-badge.default{
  background:rgba(123,47,247,0.2);
  color:var(--purple);
  border:1px solid rgba(123,47,247,0.3);
}

.project-desc{
  font-size:13px;color:var(--text2);
  line-height:1.5;margin-bottom:16px;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;
}
.project-card-footer{
  display:flex;align-items:center;justify-content:space-between;
}
.project-logo-placeholder{
  width:32px;height:32px;
  border-radius:8px;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;font-weight:700;
  flex-shrink:0;
}
.project-link{
  font-size:12px;color:var(--cyan);
  text-decoration:none;
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 14px;
  border:1px solid rgba(0,240,255,0.25);
  border-radius:8px;
  transition:var(--transition);
  font-weight:500;
}
.project-link:hover{
  background:rgba(0,240,255,0.1);
  box-shadow:0 0 20px rgba(0,240,255,0.2);
}
.project-link svg{width:14px;height:14px}

.project-card .card-glow{
  position:absolute;
  width:120px;height:120px;
  border-radius:50%;
  filter:blur(60px);
  opacity:0;
  transition:opacity 0.5s ease;
  pointer-events:none;
}
.project-card:hover .card-glow{opacity:0.3}

/* ── Modal ── */
.modal-overlay{
  display:none;
  position:fixed;inset:0;z-index:1000;
  background:rgba(0,0,0,0.7);
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
  align-items:center;justify-content:center;
  padding:20px;
}
.modal-overlay.show{display:flex}
.modal{
  background:rgba(10,10,26,0.96);
  backdrop-filter:blur(24px);
  border:1px solid rgba(0,240,255,0.2);
  border-radius:20px;
  max-width:560px;width:100%;
  max-height:90vh;overflow-y:auto;
  position:relative;
  animation:modalIn 0.3s ease;
}
@keyframes modalIn{
  from{opacity:0;transform:scale(0.92) translateY(20px)}
  to{opacity:1;transform:scale(1) translateY(0)}
}
.modal-close{
  position:absolute;top:16px;right:16px;
  background:rgba(255,255,255,0.06);
  border:none;color:var(--text2);
  width:36px;height:36px;border-radius:50%;
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  transition:var(--transition);z-index:2;
}
.modal-close:hover{background:rgba(255,0,228,0.15);color:var(--magenta)}
.modal-body{padding:36px 32px 32px}
.modal-header{
  display:flex;align-items:flex-start;gap:16px;margin-bottom:18px;
}
.modal-logo{
  width:56px;height:56px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;font-weight:700;flex-shrink:0;
}
.modal-name{
  font-family:'Orbitron',sans-serif;
  font-size:22px;font-weight:700;
  margin-bottom:4px;
}
.modal-chain{
  font-size:12px;font-weight:600;text-transform:uppercase;
  padding:4px 12px;border-radius:20px;
  letter-spacing:0.5px;
  display:inline-block;
}
.modal-desc{
  font-size:14px;color:var(--text2);
  line-height:1.7;margin-bottom:20px;
}
.modal-meta{
  display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:20px;
}
.modal-meta-item{
  background:rgba(0,240,255,0.04);
  border:1px solid rgba(0,240,255,0.08);
  border-radius:10px;padding:12px 14px;
}
.modal-meta-label{
  font-size:10px;text-transform:uppercase;letter-spacing:1px;
  color:var(--text2);margin-bottom:2px;
}
.modal-meta-value{
  font-size:14px;font-weight:600;color:var(--text);
}
.modal-link-btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:12px 28px;
  background:linear-gradient(135deg,var(--cyan),var(--purple));
  color:#fff;text-decoration:none;
  border-radius:10px;font-weight:600;font-size:14px;
  transition:var(--transition);
}
.modal-link-btn:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 30px rgba(0,240,255,0.3);
}

.modal-category-tag{
  display:inline-block;
  padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;
  margin-bottom:8px;text-transform:uppercase;letter-spacing:0.5px;
}

.chain-badge.ethereum{background:rgba(130,155,255,0.2);color:#829bff;border-color:rgba(130,155,255,0.3)}
.chain-badge.solana{background:rgba(0,240,255,0.2);color:var(--cyan);border-color:rgba(0,240,255,0.3)}
.chain-badge.polygon{background:rgba(130,71,229,0.2);color:#8247e5;border-color:rgba(130,71,229,0.3)}
.chain-badge.bsc{background:rgba(240,185,11,0.2);color:#f0b90b;border-color:rgba(240,185,11,0.3)}
.chain-badge.avalanche{background:rgba(232,65,66,0.2);color:#e84142;border-color:rgba(232,65,66,0.3)}
.chain-badge.arbitrum{background:rgba(40,160,240,0.2);color:#28a0f0;border-color:rgba(40,160,240,0.3)}
.chain-badge.optimism{background:rgba(255,4,32,0.2);color:#ff0420;border-color:rgba(255,4,32,0.3)}
.chain-badge.base{background:rgba(0,82,255,0.2);color:#0052ff;border-color:rgba(0,82,255,0.3)}
.chain-badge.cosmos{background:rgba(46,49,72,0.3);color:#2e2f49;border-color:rgba(46,49,72,0.4)}

.category-1{background:rgba(0,255,136,0.15);color:var(--green);border:1px solid rgba(0,255,136,0.25)}
.category-2{background:rgba(255,0,228,0.15);color:var(--magenta);border:1px solid rgba(255,0,228,0.25)}
.category-3{background:rgba(0,240,255,0.15);color:var(--cyan);border:1px solid rgba(0,240,255,0.25)}
.category-4{background:rgba(255,136,0,0.15);color:var(--orange);border:1px solid rgba(255,136,0,0.25)}
.category-5{background:rgba(123,47,247,0.15);color:var(--purple);border:1px solid rgba(123,47,247,0.25)}
.category-6{background:rgba(255,255,255,0.1);color:#aaa;border:1px solid rgba(255,255,255,0.15)}

/* ── Footer ── */
.footer{
  text-align:center;padding:32px 0;
  border-top:1px solid rgba(0,240,255,0.06);
  margin-top:20px;
}
.footer-text{
  font-size:13px;color:var(--text2);letter-spacing:0.5px;
}
.footer-sub{font-size:11px;color:rgba(136,136,187,0.5);margin-top:4px}

/* ── Responsive ── */
@media(max-width:768px){
  .header-inner{flex-direction:column;align-items:flex-start}
  .logo-title{font-size:22px}
  .stats-bar{gap:12px;padding:16px 20px}
  .stat-number{font-size:20px}
  .filter-row{flex-direction:column;align-items:stretch}
  .select-wrap{width:100%}
  .filter-select{width:100%;min-width:unset}
  .results-count{margin-left:0;text-align:left}
  .modal{padding:0}
  .modal-body{padding:24px 20px 20px}
  .modal-meta{grid-template-columns:1fr}
  .projects-grid{grid-template-columns:1fr}
}
@media(min-width:769px)and(max-width:1024px){
  .projects-grid{grid-template-columns:repeat(2,1fr)}
}

/* ── Utility ── */
.fade-in{animation:fadeIn 0.4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
