:root{--bg:#070b14;--panel:#0f172a;--panel-2:#111b30;--border:#1e2a44;--border-2:#27375a;--text:#e6ecf5;--muted:#94a3b8;--gold:#22d3ee;--gold2:#67e8f9;--red:#ef4444;--red2:#fb7185;--green:#10b981;--purple:#a78bfa;--blue:#60a5fa;--accent:#22d3ee;--accent2:#818cf8}
*{box-sizing:border-box}html,body{margin:0;padding:0}
body{background:radial-gradient(1200px 600px at 30% -100px,#152042 0%,transparent 60%),radial-gradient(900px 500px at 85% 20%,#0a1632 0%,transparent 55%),var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;min-height:100vh;line-height:1.5}
a{color:var(--blue);text-decoration:none}a:hover{color:var(--gold)}
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.muted{color:var(--muted)}
.site-header{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.04);position:sticky;top:0;background:rgba(20,10,6,.85);backdrop-filter:blur(10px);z-index:10}
.header-inner{display:flex;align-items:center;justify-content:space-between}
.header-actions{display:flex;gap:10px}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{width:56px;height:56px;border-radius:12px;background:linear-gradient(135deg,var(--red),var(--gold));display:grid;place-items:center;font-size:30px;color:#0a1024;box-shadow:0 8px 24px rgba(201,56,56,.35)}
.brand-text{display:flex;flex-direction:column}
.brand-tag{font-size:10.5px;color:var(--muted);letter-spacing:.16em}
.brand-title{font-size:18px;font-weight:700;color:var(--gold2)}
.chart-btn{border:1px solid var(--border);padding:8px 18px;border-radius:999px;color:var(--text);font-size:13px;background:rgba(255,255,255,.02);transition:all .2s}
.chart-btn:hover{background:rgba(34,211,238,.10);border-color:var(--gold)}
.hero{display:grid;grid-template-columns:1fr 340px;gap:36px;padding:56px 0 40px;align-items:start}
.hero-pitch{font-size:16px;margin:0 0 16px;max-width:520px}.hero-pitch strong{color:var(--gold2)}
.ticker-badge{display:inline-flex;align-items:center;background:linear-gradient(90deg,rgba(96,165,250,.18),rgba(34,211,238,.05));border:1px solid rgba(96,165,250,.3);padding:6px 14px;border-radius:6px;font-size:12px;font-weight:700;color:var(--red2);margin-bottom:22px}
.ticker-badge .addr{color:var(--muted);font-weight:400;margin-left:8px}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;max-width:520px}
.stat{background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:10px;padding:12px 14px;display:flex;flex-direction:column;gap:4px}
.stat-label{font-size:10px;color:var(--muted);letter-spacing:.12em}
.stat-value{font-size:16px;font-weight:700}.up{color:var(--green)}.down{color:var(--red2)}
.hero-right{display:flex;flex-direction:column;gap:16px}
.mascot{border-radius:14px;overflow:hidden;border:1px solid var(--border);height:240px;background:radial-gradient(circle at 30% 30%,rgba(34,211,238,.16),transparent 60%),linear-gradient(180deg,#172037,#0a1024);position:relative}
.mascot-frame{position:absolute;inset:0;display:grid;place-items:center}
.mascot-card{font-size:96px;color:var(--gold);text-shadow:0 6px 30px rgba(34,211,238,.5);filter:drop-shadow(0 4px 12px rgba(0,0,0,.6))}
.pack-progress{background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:12px}
.pack-progress-top{display:flex;justify-content:space-between;margin-bottom:8px;color:var(--muted)}
.pack-sol{color:var(--text)}
.bar{width:100%;height:4px;background:rgba(255,255,255,.06);border-radius:4px;overflow:hidden;margin:4px 0}.bar.small{height:3px}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--red),var(--gold));border-radius:inherit;transition:width .4s}
.bar-fill.purple{background:linear-gradient(90deg,var(--purple),var(--blue))}
.pack-meta{color:var(--muted);margin-top:10px;font-size:11px}
.section-heading{margin:40px 0 20px}
.section-heading.flex-row{display:flex;justify-content:space-between;align-items:flex-end}
.kicker{display:block;font-size:11px;letter-spacing:.18em;color:var(--red2);text-transform:uppercase;margin-bottom:6px}
.section-heading h2{margin:0;font-size:28px;font-weight:700}
.section-sub{color:var(--muted);margin:6px 0 0;font-size:14px}
.slabs-count{font-size:12px;color:var(--muted);background:rgba(255,255,255,.04);padding:4px 10px;border-radius:999px;margin-left:10px;vertical-align:middle}
.grail-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;max-width:380px;margin:0 auto;overflow:hidden;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.grail-header{background:linear-gradient(135deg,#8a2020,#1e3a6b);padding:14px 16px;display:flex;justify-content:space-between;gap:10px}
.grader-tag{display:inline-block;background:rgba(0,0,0,.3);color:#fff;font-weight:800;font-size:12px;padding:2px 8px;border-radius:3px;margin-bottom:6px;letter-spacing:.06em}
.grail-title{font-size:13px;font-weight:700;line-height:1.3}
.grail-sub{font-size:11px;color:rgba(255,255,255,.7);margin-top:4px}
.mint-link{color:rgba(255,255,255,.85)}
.rarity-tag{font-size:10px;background:rgba(0,0,0,.35);padding:4px 8px;border-radius:3px;letter-spacing:.1em;white-space:nowrap;align-self:flex-start}
.grail-img-wrap{padding:18px;background:linear-gradient(180deg,#152033,#0a1024);display:grid;place-items:center;min-height:340px}
.real-card-img{max-width:240px;max-height:340px;border-radius:8px;box-shadow:0 14px 30px rgba(0,0,0,.6)}
.real-card-img.big{max-width:280px;max-height:380px}
.placeholder-card{width:220px;height:310px;border-radius:10px;background:linear-gradient(160deg,#ef4444,#22d3ee,#4a2818);border:3px solid #22d3ee;display:grid;place-items:center;padding:12px;text-align:center;color:#fff;font-weight:700;text-shadow:0 2px 4px rgba(0,0,0,.5)}
.placeholder-card.big{width:260px;height:360px}
.grail-footer{padding:14px 16px;border-top:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.insured-amt{font-size:24px;font-weight:800;color:var(--gold);display:block}
.grail-meta{display:flex;flex-direction:column;gap:4px;align-items:flex-end}
.pill{background:rgba(255,255,255,.05);border:1px solid var(--border);padding:3px 8px;border-radius:4px;font-size:10px;color:var(--muted)}
.sent-block{padding:12px 16px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:6px}
.recipient{font-family:ui-monospace,monospace;font-size:12px}
.pack-tag{display:inline-block;background:rgba(67,209,138,.15);color:var(--green);border:1px solid rgba(67,209,138,.3);padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600;width:fit-content}
.time{font-size:11px;color:var(--muted)}
.onchain{padding:12px 16px;border-top:1px solid var(--border)}
.onchain ul{list-style:none;margin:8px 0 0;padding:0}
.onchain li{display:flex;justify-content:space-between;padding:4px 0;font-size:12px}
.onchain li span{color:var(--muted)}
.empty-grail,.empty-state{background:var(--panel);border:1px dashed var(--border);border-radius:10px;padding:30px;text-align:center;color:var(--muted)}
.filters{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;background:rgba(255,255,255,.02);padding:16px;border-radius:10px;border:1px solid var(--border);margin-bottom:12px}
.filters label{display:flex;flex-direction:column;gap:4px;font-size:10px;color:var(--muted);letter-spacing:.12em}
.filters select,.filters input{background:rgba(0,0,0,.3);border:1px solid var(--border);color:var(--text);padding:8px 10px;border-radius:6px;font-size:13px;outline:none}
.filters select:focus,.filters input:focus{border-color:var(--gold)}
.filter-summary{color:var(--muted);font-size:13px;margin-bottom:22px}
.card-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:14px}
.market-card{background:var(--panel);border:1px solid var(--border);border-radius:8px;overflow:hidden;display:flex;flex-direction:column}
.market-card-top{background:linear-gradient(135deg,#8a2020,#1e3a6b);padding:5px 10px;display:flex;justify-content:space-between;font-size:10px;font-weight:700;letter-spacing:.06em}
.market-img{height:200px;background:linear-gradient(180deg,#152033,#0a1024);display:grid;place-items:center;padding:10px;overflow:hidden}
.market-img .real-card-img{max-height:180px;max-width:100%}
.market-img .placeholder-card{width:100%;height:100%;border-width:2px}
.market-card-info{padding:10px 12px}
.market-card-title{font-size:12px;font-weight:700;line-height:1.3;margin-bottom:8px;min-height:32px}
.market-card-row{display:flex;justify-content:space-between;align-items:center;font-size:11px}
.market-price{color:var(--gold);font-weight:800;font-size:14px}
.market-rarity{font-size:10px;color:var(--muted);letter-spacing:.08em}
.market-addr{font-family:ui-monospace,monospace;font-size:10px;margin-top:4px}
.market-time{font-size:10px;color:var(--muted)}
.market-onchain{border-top:1px solid var(--border);padding:8px 12px;font-size:10px}
.market-onchain .kicker{font-size:9px;margin-bottom:6px}
.market-onchain ul{list-style:none;margin:0;padding:0}
.market-onchain li{display:flex;justify-content:space-between;padding:2px 0}
.market-onchain li span{color:var(--muted)}
.pagination{display:flex;justify-content:center;gap:6px;margin-top:28px;flex-wrap:wrap}
.pagination button{background:rgba(255,255,255,.03);border:1px solid var(--border);color:var(--text);padding:6px 12px;border-radius:6px;font-size:13px;cursor:pointer}
.pagination button:hover:not(:disabled){border-color:var(--gold)}
.pagination button:disabled{opacity:.4;cursor:not-allowed}
.pagination button.active{background:var(--gold);color:#0a1024;border-color:var(--gold);font-weight:700}
.page-meta{text-align:center;color:var(--muted);font-size:12px;margin-top:10px}
.ticket-board{margin:60px 0}.pool{text-align:right}.pool-amt{font-size:36px;color:var(--gold);font-weight:800}
.holders{list-style:none;margin:0;padding:0}
.holders li{display:grid;grid-template-columns:60px 1fr auto auto;gap:16px;align-items:center;padding:14px 18px;background:rgba(255,255,255,.02);border-bottom:1px solid var(--border);font-size:14px}
.holders li:first-child{border-radius:10px 10px 0 0}.holders li:last-child{border-radius:0 0 10px 10px}
.rank{color:var(--red2);font-weight:700}
.addr-mono{font-family:ui-monospace,monospace}
.holdings{color:var(--muted);font-size:13px}
.tickets{color:var(--gold);font-weight:700}
.holders-note{text-align:right;color:var(--muted);font-size:11px;margin-top:8px}
.site-footer{text-align:center;padding:40px 0;color:var(--muted);font-size:13px;border-top:1px solid var(--border);margin-top:60px}
/* Admin panel */
.admin-wrap{max-width:1200px;margin:0 auto;padding:30px 24px}
.admin-tabs{display:flex;gap:4px;border-bottom:1px solid var(--border);margin-bottom:24px;flex-wrap:wrap}
.admin-tabs button{background:transparent;border:none;color:var(--muted);padding:10px 18px;font-size:14px;cursor:pointer;border-bottom:2px solid transparent;font-weight:600}
.admin-tabs button.active{color:var(--gold);border-bottom-color:var(--gold)}
.admin-section{display:none}.admin-section.active{display:block}
.card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:20px;margin-bottom:18px}
.card h3{margin-top:0;color:var(--gold2)}
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.form-grid.cols-3{grid-template-columns:repeat(3,1fr)}
.form-grid label{display:flex;flex-direction:column;gap:4px;font-size:11px;color:var(--muted);letter-spacing:.1em}
.form-grid input,.form-grid select,.form-grid textarea{background:rgba(0,0,0,.3);border:1px solid var(--border);color:var(--text);padding:9px 12px;border-radius:6px;font-size:13px;outline:none;font-family:inherit}
.form-grid input:focus,.form-grid select:focus,.form-grid textarea:focus{border-color:var(--gold)}
.form-grid textarea{min-height:80px;resize:vertical}
.full-row{grid-column:1/-1}
.btn{background:var(--gold);color:#0a1024;border:none;padding:10px 18px;border-radius:6px;font-weight:700;cursor:pointer;font-size:13px}
.btn:hover{background:var(--gold2)}
.btn.secondary{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn.secondary:hover{border-color:var(--gold)}
.btn.danger{background:var(--red);color:#fff}
.btn-row{display:flex;gap:10px;margin-top:14px;flex-wrap:wrap}
.login-wrap{max-width:380px;margin:80px auto;padding:30px;background:var(--panel);border:1px solid var(--border);border-radius:12px}
.login-wrap h1{margin-top:0;text-align:center}
table.admin-table{width:100%;border-collapse:collapse;font-size:13px}
.admin-table th,.admin-table td{padding:8px 10px;text-align:left;border-bottom:1px solid var(--border);vertical-align:top}
.admin-table th{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.1em;font-weight:600}
.admin-table tr:hover{background:rgba(255,255,255,.02)}
.status-badge{display:inline-block;padding:2px 8px;border-radius:4px;font-size:10px;font-weight:700;letter-spacing:.06em}
.status-vault{background:rgba(78,163,224,.15);color:var(--blue)}
.status-allocated{background:rgba(245,185,66,.15);color:var(--gold)}
.status-delivered{background:rgba(67,209,138,.15);color:var(--green)}
.toast{position:fixed;bottom:20px;right:20px;background:var(--panel);border:1px solid var(--gold);padding:14px 20px;border-radius:8px;color:var(--text);font-size:13px;z-index:100;box-shadow:0 8px 24px rgba(0,0,0,.5)}
.toast.error{border-color:var(--red)}
.tiny{font-size:11px;color:var(--muted)}
.code{font-family:ui-monospace,monospace;font-size:11px;color:var(--blue)}
@media (max-width:900px){.hero{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.card-grid{grid-template-columns:repeat(2,1fr)}.filters{grid-template-columns:repeat(2,1fr)}.form-grid,.form-grid.cols-3{grid-template-columns:1fr}}

/* admin extras */
.stat-card{background:var(--panel);border:1px solid var(--border);border-radius:10px;padding:14px}
.stat-card .stat-k{color:var(--muted);font-size:11px;text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.stat-card .stat-v{font-size:1.25rem;font-weight:600}
.cols-3{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.thumb{width:48px;height:48px;object-fit:cover;border-radius:6px;border:1px solid var(--border)}
.mono{font-family:ui-monospace,monospace}
.tiny{font-size:11px}
.muted{color:var(--muted)}
.btn.tiny{padding:4px 8px;font-size:11px;border-radius:6px}
.btn.danger{background:var(--red2);border-color:var(--red2);color:#fff}
.pill.grail,.pill.gold{background:rgba(255,200,80,.15);color:#ffc850;border-color:rgba(255,200,80,.35)}
.pill.vault{background:rgba(160,160,255,.12);color:#aab8ff;border-color:rgba(160,160,255,.3)}
.pill.allocated{background:rgba(255,170,80,.12);color:#ffaa50;border-color:rgba(255,170,80,.3)}
.pill.delivered{background:rgba(120,220,140,.12);color:#78dc8c;border-color:rgba(120,220,140,.3)}
.modal-back{position:fixed;inset:0;background:rgba(0,0,0,.65);z-index:200;display:flex;align-items:center;justify-content:center;padding:24px}
.modal{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:22px;max-width:640px;width:100%;max-height:90vh;overflow:auto;box-shadow:0 24px 64px rgba(0,0,0,.6)}
.modal h3{margin:0 0 14px}
.winner{background:linear-gradient(135deg,rgba(255,200,80,.15),rgba(255,80,80,.15));border:1px solid rgba(255,200,80,.4);border-radius:10px;padding:18px;text-align:center}
.toast{margin-top:8px;animation:slideIn .25s ease}
.toast.ok{border-color:#78dc8c;color:#78dc8c}
.toast.err{border-color:var(--red2);color:#ff9090}
.toast.fade{opacity:0;transition:opacity .4s}
@keyframes slideIn{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
#toastSlot{position:fixed;right:20px;bottom:20px;z-index:300;display:flex;flex-direction:column;align-items:flex-end}
.full-row{grid-column:1/-1}

/* ---------- Vault grid ---------- */
.card-grid#vaultGrid, .card-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(220px,1fr)); gap:18px; margin-top:14px; }
.slab-card { background:#1c0f0a; border:1px solid #3b1f12; border-radius:12px; overflow:hidden; display:flex; flex-direction:column; transition:transform .15s ease, border-color .15s ease; }
.slab-card:hover { transform:translateY(-2px); border-color:#7a3a1d; }
.slab-img { aspect-ratio:3/4; background:linear-gradient(135deg,#11203a,#180a05); display:flex; align-items:center; justify-content:center; overflow:hidden; }
.slab-img img { width:100%; height:100%; object-fit:cover; display:block; }
.slab-body { padding:10px 12px 12px; display:flex; flex-direction:column; gap:6px; }
.slab-row { display:flex; justify-content:space-between; align-items:center; gap:8px; }
.slab-name { font-weight:600; font-size:14px; color:#f1e2c9; line-height:1.2; }
.slab-meta { font-size:11px; color:#a98a6a; text-transform:uppercase; letter-spacing:.04em; }
.slab-foot { display:flex; justify-content:space-between; font-size:12px; margin-top:4px; }
.slab-status { color:#caa57c; text-transform:uppercase; letter-spacing:.06em; font-size:10px; padding:2px 6px; border:1px solid #5a341c; border-radius:6px; }
.slab-val { color:#ffb066; font-weight:600; }
.tier-pill { font-size:10px; padding:2px 6px; border-radius:6px; text-transform:uppercase; letter-spacing:.06em; background:#3a1d0e; color:#ffcf99; }
.tier-pill.tier-grail { background:#4a1313; color:#ffb3b3; border:1px solid #7a2424; }
.tier-pill.tier-rare { background:#2a1a3a; color:#cbb3ff; }
.empty-card { padding:28px; text-align:center; color:#a98a6a; border:1px dashed #3b1f12; border-radius:12px; }

/* Featured prize lives inside the hero mascot frame */
.mascot:has(#grailSlot){
  height:auto;
  min-height:320px;
  padding:18px;
  background:radial-gradient(circle at 30% 30%,rgba(34,211,238,.12),transparent 60%),linear-gradient(180deg,#172037,#0a1024);
}
.mascot:has(#grailSlot) .mascot-frame{
  position:relative;
  inset:auto;
}
#grailSlot{
  font-size:initial;
  color:inherit;
  text-shadow:none;
  filter:none;
  width:100%;
}
#grailSlot .grail-card{
  max-width:100%;
  margin:0;
  box-shadow:0 12px 40px rgba(0,0,0,.55);
}
#grailSlot .empty-grail{
  font-size:14px;
  color:#a98a6a;
  text-align:center;
  padding:40px 16px;
}


/* ---------------- Polish layer (cool palette + layout) ---------------- */
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.hero{display:grid;grid-template-columns:1.05fr .95fr;gap:36px;padding:36px 0 12px;align-items:start}
.hero-left{display:flex;flex-direction:column;gap:18px}
.hero-right{display:flex;flex-direction:column;gap:14px}
.hero-pitch{font-size:15px;color:var(--muted);margin:0;max-width:520px;line-height:1.55}
.hero-pitch strong{color:var(--text);font-weight:600}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0}
.stat{background:rgba(255,255,255,.025);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:6px;transition:border-color .2s ease, transform .2s ease}
.stat:hover{border-color:var(--border-2);transform:translateY(-1px)}
.stat-label{font-size:10px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.stat-value{font-size:18px;font-weight:700;color:var(--text);font-variant-numeric:tabular-nums}
.stat-value.up{color:var(--green)}
.stat-value.down{color:var(--red2)}

/* Header polish */
.site-header{padding:18px 0;border-bottom:1px solid rgba(255,255,255,.03)}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:14px}
.brand-logo{width:48px;height:48px;border-radius:12px;background:linear-gradient(135deg,#22d3ee,#818cf8) !important;display:grid;place-items:center;font-size:24px;color:#0a1024;font-weight:700;box-shadow:0 6px 20px rgba(34,211,238,.25)}
.brand-tag{font-size:10px;color:var(--muted);letter-spacing:.16em;text-transform:uppercase;font-weight:600}
.brand-title{font-size:18px;font-weight:700;color:var(--text)}
.header-actions{display:flex;gap:8px}
.chart-btn{padding:8px 18px;border-radius:999px;border:1px solid var(--border);background:rgba(255,255,255,.02);color:var(--text);font-size:13px;font-weight:600;text-decoration:none;transition:all .2s ease}
.chart-btn:hover{background:rgba(34,211,238,.08);border-color:var(--accent);color:var(--accent)}

/* Ticker badge polish */
.ticker-badge{display:inline-flex;align-items:center;gap:10px;background:rgba(34,211,238,.08);border:1px solid rgba(34,211,238,.22);padding:6px 14px;border-radius:999px;color:var(--accent);font-weight:700;font-size:13px;width:fit-content;margin:0}
.ticker-badge .addr{color:var(--muted);font-weight:500;font-family:ui-monospace,monospace;font-size:12px}

/* Mascot / featured slot */
.mascot:has(#grailSlot){border-radius:16px;border:1px solid var(--border);background:radial-gradient(circle at 30% 20%,rgba(34,211,238,.10),transparent 60%),linear-gradient(180deg,#0f172a,#0a1024);padding:18px;height:auto;min-height:360px}
.mascot:has(#grailSlot) .mascot-frame{position:relative;inset:auto;display:block}
#grailSlot{font-size:initial;color:inherit;text-shadow:none;filter:none;width:100%}
#grailSlot .grail-card{max-width:100%;margin:0;border-radius:12px;border:1px solid var(--border);background:linear-gradient(180deg,#0c1426,#091022);box-shadow:0 16px 50px rgba(0,0,0,.55), 0 0 0 1px rgba(34,211,238,.04)}
#grailSlot .grail-header{background:linear-gradient(135deg,#1e3a6b,#0e2046);padding:14px 16px;border-bottom:1px solid var(--border)}
#grailSlot .empty-grail{font-size:14px;color:var(--muted);text-align:center;padding:48px 16px}

/* Pack progress card */
.pack-progress{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:14px 16px;display:flex;flex-direction:column;gap:8px}
.pack-progress-top{display:flex;justify-content:space-between;font-size:13px;color:var(--text);font-weight:500;margin:0}
.pack-sol{color:var(--accent);font-weight:700;font-variant-numeric:tabular-nums}
.pack-progress .bar{height:8px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:999px;overflow:hidden}
.pack-progress .bar.small{height:5px}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--accent),var(--accent2));border-radius:inherit;transition:width .4s ease}
.bar-fill.purple{background:linear-gradient(90deg,var(--accent2),#c084fc)}
.pack-meta{color:var(--muted);font-size:11px;margin-top:2px}
.pack-meta .kicker{display:inline-block;font-size:10px;color:var(--accent2);text-transform:uppercase;letter-spacing:.14em;margin-right:4px}

/* Section heading */
.section-heading{margin:48px 0 18px;display:flex;flex-direction:column;gap:6px}
.section-heading .kicker{font-size:11px;color:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-weight:700}
.section-heading h2{margin:0;font-size:28px;font-weight:800;letter-spacing:-.01em;color:var(--text);display:flex;align-items:center;gap:10px}
.section-heading .section-sub{margin:0;color:var(--muted);font-size:13px}
.section-heading.flex-row{flex-direction:row;justify-content:space-between;align-items:flex-end}
.slabs-count{font-size:11px;color:var(--accent);background:rgba(34,211,238,.10);border:1px solid rgba(34,211,238,.22);padding:4px 10px;border-radius:999px;letter-spacing:.06em;font-weight:600}

/* Filters polish */
.filters{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:18px;margin-bottom:18px;display:grid;grid-template-columns:repeat(6,1fr);gap:14px}
.filters label{display:flex;flex-direction:column;gap:6px;font-size:10px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.filters select,.filters input{background:rgba(0,0,0,.25);border:1px solid var(--border);color:var(--text);padding:9px 12px;border-radius:8px;font-size:13px;outline:none;transition:border-color .15s ease}
.filters select:focus,.filters input:focus{border-color:var(--accent)}
.filter-summary{font-size:12px;color:var(--muted);margin-bottom:14px}

/* Marketplace cards */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px}
.market-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;overflow:hidden;display:flex;flex-direction:column;transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease}
.market-card:hover{transform:translateY(-3px);border-color:var(--border-2);box-shadow:0 12px 32px rgba(0,0,0,.4)}
.market-card-top{background:linear-gradient(135deg,#1e3a6b,#0e2046);padding:8px 12px;font-size:10px;font-weight:700;letter-spacing:.08em;color:var(--text);display:flex;justify-content:space-between;align-items:center;text-transform:uppercase}
.market-img{aspect-ratio:3/4;height:auto;background:linear-gradient(135deg,#1a2540,#0a1024);display:grid;place-items:center;padding:12px;overflow:hidden}
.market-img .real-card-img{max-width:100%;max-height:100%;border-radius:6px;display:block;object-fit:contain}
.market-img .placeholder-card{width:100%;height:100%;border:2px dashed var(--border-2);border-radius:6px;display:grid;place-items:center;color:var(--muted);font-size:11px;text-align:center;padding:8px}
.market-card-info{padding:12px 14px;display:flex;flex-direction:column;gap:6px}
.market-card-title{font-size:12px;font-weight:600;line-height:1.35;color:var(--text);margin:0;min-height:34px}
.market-card-row{display:flex;justify-content:space-between;align-items:center;font-size:11px}
.market-price{font-size:15px;font-weight:700;color:var(--accent)}
.market-rarity{font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.market-addr{font-family:ui-monospace,monospace;font-size:10px;color:var(--blue)}
.market-time{font-size:10px;color:var(--muted)}
.market-onchain{border-top:1px solid var(--border);padding:10px 14px;font-size:10px}
.market-onchain .kicker{font-size:9px;letter-spacing:.14em;color:var(--muted);margin-bottom:6px;text-transform:uppercase;font-weight:600}
.market-onchain ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:3px}
.market-onchain li{display:flex;justify-content:space-between;padding:2px 0;color:var(--muted)}
.market-onchain li span:first-child{color:var(--muted)}
.market-onchain li a{color:var(--blue);font-family:ui-monospace,monospace}

/* Pagination */
.pagination{display:flex;justify-content:center;gap:6px;margin:24px 0;flex-wrap:wrap}
.pagination button{background:rgba(255,255,255,.025);border:1px solid var(--border);color:var(--text);padding:7px 13px;border-radius:8px;font-size:13px;cursor:pointer;transition:all .15s ease}
.pagination button:hover:not(:disabled){border-color:var(--accent);color:var(--accent)}
.pagination button.active{background:var(--accent);color:#0a1024;border-color:var(--accent);font-weight:700}
.pagination button:disabled{opacity:.4;cursor:not-allowed}
.page-meta{text-align:center;color:var(--muted);font-size:12px;margin-top:12px}

/* Ticket board */
.ticket-board{margin:64px 0}
.ticket-board .section-heading{margin-bottom:18px}
.pool{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:2px}
.pool .kicker{font-size:11px;color:var(--muted);letter-spacing:.16em}
.pool-amt{font-size:36px;color:var(--accent);font-weight:800;font-variant-numeric:tabular-nums;line-height:1}
.holders{list-style:none;margin:0;padding:0;background:var(--panel);border:1px solid var(--border);border-radius:14px;overflow:hidden}
.holders li{display:grid;grid-template-columns:60px 1fr auto auto;gap:18px;align-items:center;padding:14px 20px;background:transparent;border-bottom:1px solid var(--border);font-size:14px;transition:background .15s ease}
.holders li:last-child{border-bottom:none}
.holders li:hover{background:rgba(34,211,238,.03)}
.rank{color:var(--accent);font-weight:700;font-size:13px}
.addr-mono{font-family:ui-monospace,monospace;color:var(--text);font-size:13px}
.holdings{color:var(--muted);font-size:12px;font-variant-numeric:tabular-nums}
.tickets{color:var(--accent2);font-weight:700;font-size:13px;font-variant-numeric:tabular-nums}
.holders-note{text-align:right;color:var(--muted);font-size:11px;margin-top:10px}

/* Footer */
.site-footer{text-align:center;padding:48px 0;color:var(--muted);font-size:12px;border-top:1px solid var(--border);margin-top:60px}

/* Empty / pending state */
.empty-state{text-align:center;color:var(--muted);padding:48px 16px;background:var(--panel);border:1px dashed var(--border);border-radius:12px}

/* Pill */
.pill{background:rgba(255,255,255,.04);border:1px solid var(--border);padding:3px 9px;border-radius:6px;font-size:10px;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}

/* Pack tag */
.pack-tag{display:inline-block;background:rgba(34,211,238,.12);color:var(--accent);border:1px solid rgba(34,211,238,.3);padding:3px 9px;border-radius:6px;font-size:11px;font-weight:700;width:fit-content}

/* Grail card internals (when in mascot) */
#grailSlot .grail-img-wrap{padding:14px;background:linear-gradient(180deg,#0a1226,#091022)}
#grailSlot .grail-footer{padding:14px 16px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;gap:14px;background:var(--panel)}
#grailSlot .insured-amt{font-size:24px;color:var(--accent);font-weight:800;display:block;margin-top:2px}
#grailSlot .sent-block{padding:12px 16px;border-top:1px solid var(--border);background:var(--panel)}
#grailSlot .recipient{font-family:ui-monospace,monospace;font-size:12px;color:var(--blue);margin:4px 0}
#grailSlot .onchain{padding:12px 16px;border-top:1px solid var(--border);background:var(--panel)}
#grailSlot .onchain .kicker{font-size:10px;color:var(--muted);letter-spacing:.14em;display:block;margin-bottom:8px;font-weight:600}
#grailSlot .onchain ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
#grailSlot .onchain li{display:flex;justify-content:space-between;font-size:11px;padding:2px 0}
#grailSlot .onchain li span:first-child{color:var(--muted)}
#grailSlot .onchain li a{color:var(--blue);font-family:ui-monospace,monospace;text-decoration:none}
#grailSlot .grail-title{font-size:14px;font-weight:700;color:var(--text);margin-top:2px;line-height:1.35}
#grailSlot .grail-sub{font-size:11px;color:var(--muted);margin-top:4px;letter-spacing:.04em}
#grailSlot .mint-link{color:var(--blue);font-family:ui-monospace,monospace;text-decoration:none}
#grailSlot .grader-tag{display:inline-block;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);padding:3px 9px;border-radius:6px;font-size:10px;font-weight:700;color:var(--text);letter-spacing:.06em}
#grailSlot .rarity-tag{display:inline-block;background:rgba(34,211,238,.12);border:1px solid rgba(34,211,238,.28);padding:3px 9px;border-radius:6px;font-size:10px;font-weight:700;color:var(--accent);letter-spacing:.06em;float:right;margin-top:-22px}
#grailSlot .stat-label{font-size:10px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;display:block}

/* Real card image inside grail */
.real-card-img.big{width:100%;height:auto;border-radius:8px;display:block;background:transparent}

/* Mobile */
@media (max-width:880px){
  .hero{grid-template-columns:1fr;gap:24px;padding:24px 0 12px}
  .stats-grid{grid-template-columns:repeat(2,1fr)}
  .filters{grid-template-columns:repeat(2,1fr)}
  .section-heading h2{font-size:22px}
  .holders li{grid-template-columns:48px 1fr auto;gap:10px;padding:12px 14px;font-size:12px}
  .holders li .holdings{display:none}
  .pool-amt{font-size:26px}
  .container{padding:0 16px}
}

/* Holders empty state should span the row */
.holders li.empty-state{display:block;grid-template-columns:none;padding:48px 16px;text-align:center;background:transparent;border-bottom:none}


/* How-it-works panel */
.how-it-works{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:20px;margin-top:6px}
.how-it-works .kicker{font-size:11px;color:var(--accent);letter-spacing:.18em;text-transform:uppercase;font-weight:700}
.how-it-works .how-head{margin-bottom:14px}
.how-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}
.how-list li{display:flex;gap:14px;align-items:flex-start;font-size:13px;color:var(--muted);line-height:1.5}
.how-list li strong{color:var(--text);font-weight:600}
.how-num{flex-shrink:0;width:30px;height:30px;border-radius:8px;background:rgba(34,211,238,.10);border:1px solid rgba(34,211,238,.22);color:var(--accent);font-weight:700;font-size:12px;display:grid;place-items:center;font-variant-numeric:tabular-nums}

/* Subdue — (em-dash) values on grail onchain rows */
#grailSlot .onchain li:has(span:last-child:not(a)){opacity:.55}


/* --- logo image override --- */
.brand-logo{background:transparent !important;box-shadow:none !important;color:transparent !important;font-size:0 !important;padding:0 !important;overflow:hidden;}
.brand-logo img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit;}
