@import url('https://fonts.googleapis.com/css2?family=Bangers&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500;9..40,600&display=swap');

:root {
    --bg: #FAF8F5;
    --white: #FFFFFF;
    --text: #1A1A1A;
    --text2: #555;
    --text3: #999;
    --border: #E8E5E0;
    --gold: #D4A020;
    --gold-light: #FEF7E0;
    --silver: #8A8A8A;
    --silver-light: #F0F0F0;
    --bronze: #B5722A;
    --bronze-light: #FDF2E8;
    --green: #1B8F5A;
    --green-bg: #EDFBF3;
    --red: #D1344B;
    --red-bg: #FDF0F2;
    --blue: #2B6CB0;
    --blue-bg: #EBF4FF;
    --orange: #C77A1A;
    --orange-bg: #FFF7EB;
    --purple: #6B46C1;
    --purple-bg: #F3EEFF;
    --radius: 14px;
}

*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body {
    font-family: 'DM Sans', system-ui, sans-serif;
    background: var(--bg);
    color: var(--text);
    font-weight: 400;
    font-size: 15px;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
}
a { color:inherit; text-decoration:none; }
button { cursor:pointer; font-family:inherit; }
img { display:block; max-width:100%; }

/* ===== NAV ===== */
.nav {
    position: fixed; top:0; left:0; right:0; z-index:100;
    display: flex; justify-content: space-between; align-items: center;
    padding: 12px 32px;
    background: rgba(250,248,245,0.9);
    backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border);
}
.brand {
    font-family: 'Bangers', cursive;
    font-size: 1.4rem;
    letter-spacing: 2px;
    color: var(--text);
}
.brand span { color: var(--gold); }
.nav-r { display:flex; align-items:center; gap:20px; }
.nav-link { font-size:.8rem; color:var(--text3); transition:color .2s; }
.nav-link:hover { color:var(--text); }
.nav-token {
    font-family: 'Bangers', cursive;
    font-size: .9rem;
    letter-spacing: 1.5px;
    padding: 4px 14px;
    border-radius: 8px;
    background: var(--gold-light);
    color: var(--gold);
}

/* ===== HERO ===== */
.hero {
    position: relative;
    padding: 72px 32px 0;
    background: var(--white);
    border-bottom: 1px solid var(--border);
    overflow: hidden;
}
.hero::before {
    content: '';
    position: absolute;
    top: -120px; right: -120px;
    width: 500px; height: 500px;
    background: radial-gradient(circle, rgba(212,160,32,.08) 0%, transparent 70%);
    pointer-events: none;
}
.hero-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 340px 1fr;
    gap: 32px;
    align-items: end;
}
.hero-left {
    padding-bottom: 48px;
    position: relative;
    z-index: 2;
}
.hero-title {
    font-family: 'Bangers', cursive;
    font-size: 5.5rem;
    line-height: .82;
    letter-spacing: 4px;
    color: var(--text);
    text-shadow: 3px 3px 0 var(--border);
}
.hero-gold { color: var(--gold); text-shadow: 3px 3px 0 rgba(212,160,32,.15); }
.hero-subtitle {
    font-family: 'Bangers', cursive;
    font-size: 1.2rem;
    letter-spacing: 8px;
    color: var(--gold);
    margin-top: 8px;
}
/* Hero CA */
.hero-ca {
    margin-top: 20px;
}
.hero-ca-label {
    display: block;
    font-size: .6rem;
    font-weight: 700;
    letter-spacing: 2px;
    color: var(--text3);
    margin-bottom: 6px;
}
.hero-ca-row {
    display: flex;
    align-items: center;
    gap: 0;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    max-width: 320px;
}
.hero-ca-code {
    flex: 1;
    padding: 9px 12px;
    font-size: .72rem;
    font-family: 'DM Sans', monospace;
    color: var(--text);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    user-select: all;
}
.hero-ca-copy {
    background: var(--gold);
    border: none;
    color: var(--white);
    padding: 9px 14px;
    font-size: .9rem;
    cursor: pointer;
    transition: background .15s;
    flex-shrink: 0;
}
.hero-ca-copy:hover { background: #c99418; }

/* Hero external links */
.hero-links {
    display: flex;
    gap: 8px;
    margin-top: 14px;
}
.hero-link {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 38px; height: 38px;
    border-radius: 10px;
    background: var(--white);
    border: 1px solid var(--border);
    color: var(--text2);
    transition: all .2s;
}
.hero-link img {
    width: 24px; height: 24px;
    border-radius: 6px;
    object-fit: cover;
}
.hero-link:hover {
    border-color: var(--gold);
    color: var(--gold);
    background: var(--gold-light);
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(212,160,32,.15);
}

/* ===== PODIUM ===== */
.podium {
    display: flex;
    align-items: flex-end;
    justify-content: center;
    gap: 6px;
    position: relative;
    z-index: 2;
}
.podium-slot {
    display: flex;
    flex-direction: column;
    align-items: center;
    transition: transform .25s ease;
}
.podium-slot:hover { transform: translateY(-6px); }
.podium-slot:hover .podium-card { box-shadow: 0 12px 40px rgba(0,0,0,.1); }

.podium-card {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 16px 18px 14px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 16px;
    position: relative;
    transition: box-shadow .25s;
    box-shadow: 0 4px 20px rgba(0,0,0,.04);
}
.slot-1 .podium-card {
    border-color: rgba(212,160,32,.25);
    background: linear-gradient(180deg, #FFFDF5 0%, var(--white) 100%);
    box-shadow: 0 8px 32px rgba(212,160,32,.12);
}
.slot-2 .podium-card {
    border-color: rgba(0,0,0,.06);
    background: linear-gradient(180deg, #FAFAFA 0%, var(--white) 100%);
}
.slot-3 .podium-card {
    border-color: rgba(181,114,42,.12);
    background: linear-gradient(180deg, #FDF8F3 0%, var(--white) 100%);
}

.podium-rank-badge {
    position: absolute;
    top: -10px; right: -8px;
    width: 28px; height: 28px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Bangers', cursive;
    font-size: .85rem;
    letter-spacing: 0;
    z-index: 5;
}
.rank-1 { background: linear-gradient(135deg, #FFD700, #F0A500); color: #fff; box-shadow: 0 2px 10px rgba(212,160,32,.4); }
.rank-2 { background: linear-gradient(135deg, #C0C0C0, #9A9A9A); color: #fff; box-shadow: 0 2px 8px rgba(0,0,0,.1); }
.rank-3 { background: linear-gradient(135deg, #E8A04A, #CD7F32); color: #fff; box-shadow: 0 2px 8px rgba(181,114,42,.3); }

.podium-crown { font-size: 1.4rem; margin-bottom: -2px; z-index: 5; position: relative; }
.slot-1 .podium-crown { font-size: 2rem; }
.crown-1 { animation: bounce 2s ease-in-out infinite; }
@keyframes bounce { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-5px)} }

.podium-avatar { border-radius: 50%; padding: 3px; margin-bottom: 10px; }
.slot-1 .podium-avatar { width: 100px; height: 100px; }
.slot-2 .podium-avatar, .slot-3 .podium-avatar { width: 76px; height: 76px; }
.ring-gold { background: linear-gradient(135deg, #FFD700, #FFA500); box-shadow: 0 6px 24px rgba(212,160,32,.3); }
.ring-silver { background: linear-gradient(135deg, #D4D4D4, #F0F0F0); box-shadow: 0 4px 16px rgba(0,0,0,.06); }
.ring-bronze { background: linear-gradient(135deg, #CD7F32, #E8A04A); box-shadow: 0 4px 16px rgba(181,114,42,.2); }
.podium-avatar img { width: 100%; height: 100%; border-radius: 50%; object-fit: cover; border: 3px solid var(--white); background: var(--bg); }

.podium-name { font-family: 'Bangers', cursive; font-size: 1rem; letter-spacing: 1.5px; margin-top: 2px; }
.slot-1 .podium-name { font-size: 1.15rem; }
.podium-ticker { font-size: .72rem; color: var(--text3); margin-bottom: 6px; }
.podium-mcap { font-size: 1.05rem; font-weight: 600; }
.slot-1 .podium-mcap { font-size: 1.2rem; }
.podium-change { font-size: .7rem; font-weight: 500; padding: 2px 8px; border-radius: 4px; margin: 4px 0; }
.up { color: var(--green); }
.down { color: var(--red); }
.podium-change.up { background: var(--green-bg); }
.podium-change.down { background: var(--red-bg); }
.podium-st { font-size: .6rem; font-weight: 600; letter-spacing: .5px; padding: 3px 10px; border-radius: 5px; }

/* Pedestals */
.pedestal {
    width: 100%;
    display: flex;
    align-items: flex-end;
    justify-content: center;
    border-radius: 12px 12px 0 0;
    font-family: 'Bangers', cursive;
    font-size: 2rem;
    letter-spacing: 2px;
    margin-top: 8px;
    position: relative;
    overflow: hidden;
}
.pedestal span { position: relative; z-index: 1; }
.pedestal::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    opacity: .5;
}
.ped-1 {
    width: 190px;
    height: 110px;
    background: linear-gradient(180deg, #FEF3C7 0%, #FDE68A 40%, #D4A020 100%);
    border: 2px solid rgba(212,160,32,.2);
    border-bottom: none;
    color: rgba(255,255,255,.5);
    box-shadow: inset 0 2px 20px rgba(212,160,32,.15), 0 -4px 24px rgba(212,160,32,.1);
}
.ped-1::before {
    background: linear-gradient(135deg, transparent 30%, rgba(255,255,255,.3) 50%, transparent 70%);
}
.ped-2 {
    width: 160px;
    height: 72px;
    background: linear-gradient(180deg, #F5F5F5 0%, #E0E0E0 40%, #B0B0B0 100%);
    border: 2px solid rgba(0,0,0,.06);
    border-bottom: none;
    color: rgba(255,255,255,.4);
    box-shadow: inset 0 2px 16px rgba(0,0,0,.03);
}
.ped-2::before {
    background: linear-gradient(135deg, transparent 30%, rgba(255,255,255,.4) 50%, transparent 70%);
}
.ped-3 {
    width: 160px;
    height: 50px;
    background: linear-gradient(180deg, #FDE8CD 0%, #E8B878 40%, #CD7F32 100%);
    border: 2px solid rgba(181,114,42,.1);
    border-bottom: none;
    color: rgba(255,255,255,.4);
    box-shadow: inset 0 2px 16px rgba(181,114,42,.1);
}
.ped-3::before {
    background: linear-gradient(135deg, transparent 30%, rgba(255,255,255,.3) 50%, transparent 70%);
}

/* ===== STATUS BADGES ===== */
.st-hold { background:var(--green-bg); color:var(--green); }
.st-air  { background:var(--blue-bg); color:var(--blue); }
.st-sell { background:var(--orange-bg); color:var(--orange); }
.st-dump { background:var(--red-bg); color:var(--red); }
.st-dist { background:var(--purple-bg); color:var(--purple); }
.stb { display:inline-flex; align-items:center; gap:3px; font-size:.66rem; font-weight:600; letter-spacing:.3px; padding:3px 9px; border-radius:5px; }
.stb-lg { font-size:.78rem; padding:6px 14px; }

/* ===== LEADERBOARD ===== */
.board { padding:48px 24px 80px; background:var(--bg); }
.board-wrap { max-width:1060px; margin:0 auto; }
.board-head { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:12px; margin-bottom:20px; }
.board-title { font-family:'Bangers',cursive; font-size:1.8rem; letter-spacing:3px; }
.filters { display:flex; flex-wrap:wrap; gap:4px; }
.fbtn { background:transparent; border:1px solid var(--border); color:var(--text3); padding:5px 12px; border-radius:7px; font-size:.72rem; font-weight:500; transition:all .15s; }
.fbtn:hover { border-color:var(--text3); color:var(--text); }
.fbtn.active { background:var(--text); border-color:var(--text); color:var(--white); }

.board-table { background:var(--white); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.board-row { display:grid; grid-template-columns:44px 2fr 1fr 1fr 1fr 1.4fr 1.1fr 1.2fr; align-items:center; padding:11px 18px; gap:8px; border-bottom:1px solid var(--border); transition:background .1s; }
.board-row:last-child { border-bottom:none; }
.board-row:not(.board-header-row):hover { background:rgba(0,0,0,.015); }
.board-header-row { background:var(--bg); font-size:.66rem; font-weight:600; letter-spacing:.8px; color:var(--text3); text-transform:uppercase; position:sticky; top:0; z-index:3; }
.sort-col { cursor:pointer; user-select:none; }
.sort-col:hover { color:var(--text); }
.sort-col.active { color:var(--text); }
.col-rank { font-family:'Bangers',cursive; font-size:1.1rem; color:var(--text3); text-align:center; }
.col-kol { display:flex; align-items:center; gap:10px; }
.row-av { width:30px; height:30px; border-radius:50%; border:1px solid var(--border); background:var(--bg); flex-shrink:0; }
.col-kol strong { display:block; font-size:.84rem; font-weight:500; }
.col-kol small { color:var(--text3); font-size:.72rem; }
.col-ticker { font-weight:500; color:var(--text2); font-size:.8rem; }
.col-mcap { font-weight:500; font-size:.88rem; }
.col-change { font-weight:500; font-size:.8rem; }
.col-supply { display:flex; align-items:center; gap:8px; }
.supply-bar-wrap { flex:1; height:4px; background:var(--border); border-radius:4px; overflow:hidden; }
.supply-bar-fill { height:100%; background:var(--text); border-radius:4px; transition:width .6s ease-out; }
.supply-bar-lg { height:8px; }
.col-supply span { font-size:.76rem; color:var(--text2); min-width:40px; text-align:right; }
.col-addr { display:flex; align-items:center; gap:5px; }
.col-addr code { font-size:.72rem; color:var(--text3); background:var(--bg); padding:2px 7px; border-radius:4px; font-family:'DM Sans',monospace; }
.cpb { background:transparent; border:1px solid var(--border); color:var(--text3); font-size:.72rem; padding:2px 5px; border-radius:4px; transition:all .15s; }
.cpb:hover { border-color:var(--text2); color:var(--text); }

/* ===== PAGE HERO (tokens.php) ===== */
.page-hero {
    padding: 90px 24px 32px;
    text-align: center;
    background: var(--white);
    border-bottom: 1px solid var(--border);
}
.page-title {
    font-family: 'Bangers', cursive;
    font-size: clamp(2rem, 6vw, 3.5rem);
    letter-spacing: 4px;
    text-shadow: 3px 3px 0 var(--border);
}
.page-sub { font-size:.9rem; color:var(--text3); margin-top:6px; }
.page-sub a { color:var(--gold); }
.page-sub a:hover { text-decoration:underline; }

/* ===== TOKENS GRID (tokens.php) ===== */
.tokens-grid-section { padding:40px 24px 80px; }
.tokens-wrap { max-width:1100px; margin:0 auto; }
.tokens-toolbar { margin-bottom:24px; }
.tokens-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 16px;
}
.token-card {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    position: relative;
    transition: transform .15s, box-shadow .15s;
    display: block;
}
.token-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.06);
}
.tc-rank {
    position: absolute;
    top: 12px; right: 14px;
    font-family: 'Bangers', cursive;
    font-size: .95rem;
    color: var(--text3);
}
.tc-top { display:flex; align-items:center; gap:12px; margin-bottom:16px; }
.tc-av { width:42px; height:42px; border-radius:50%; border:2px solid var(--border); background:var(--bg); flex-shrink:0; }
.tc-name { font-family:'Bangers',cursive; font-size:1rem; letter-spacing:1px; }
.tc-handle { font-size:.72rem; color:var(--text3); }
.tc-top .stb { margin-left:auto; }
.tc-stats { display:grid; grid-template-columns:1fr 1fr 1fr; gap:8px; margin-bottom:14px; }
.tc-stats div { text-align:center; }
.tc-stats small { display:block; font-size:.65rem; color:var(--text3); text-transform:uppercase; letter-spacing:.5px; }
.tc-stats strong { font-size:.88rem; }
.tc-supply { }
.tc-supply-label { display:block; font-size:.7rem; color:var(--text3); margin-top:6px; text-align:right; }

/* ===== TOKEN PAGE (token.php) ===== */
.token-page { padding:70px 24px 40px; }
.token-page-full {
    max-width: 1000px;
    margin: 0 auto;
}
.back-link { display:inline-block; font-size:.8rem; color:var(--text3); margin-bottom:16px; transition:color .15s; }
.back-link:hover { color:var(--text); }

.token-header { margin-bottom:24px; }
.token-hero-row { display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap; }
.token-hero-left { display:flex; align-items:center; gap:16px; }
.token-hero-av { width:64px; height:64px; flex-shrink:0; }
.token-hero-av img { width:100%; height:100%; border-radius:50%; border:2px solid var(--border); background:var(--bg); }
.token-hero-name { font-family:'Bangers',cursive; font-size:1.8rem; letter-spacing:2px; }
.token-hero-meta { display:flex; align-items:center; gap:10px; margin-top:2px; }
.token-hero-ticker { font-weight:600; color:var(--gold); font-size:.9rem; }
.token-hero-handle { font-size:.8rem; color:var(--text3); }
.token-hero-rank { font-family:'Bangers',cursive; font-size:.85rem; color:var(--text3); background:var(--bg); padding:2px 8px; border-radius:4px; }

.token-stats-row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 12px;
    margin-bottom: 20px;
}
.token-stat-box {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 14px 16px;
}
.token-stat-box small { display:block; font-size:.68rem; color:var(--text3); text-transform:uppercase; letter-spacing:.5px; margin-bottom:4px; }
.token-stat-box strong { font-size:1rem; }
.token-addr-row { display:flex; align-items:center; gap:4px; }
.token-addr-row code { font-size:.75rem; color:var(--text2); }

.token-supply-section {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 16px;
    margin-bottom: 24px;
}
.token-supply-label { display:flex; justify-content:space-between; font-size:.8rem; color:var(--text2); margin-bottom:8px; }

/* Holdings chart */
.holdings-chart-section {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 24px;
}
.holdings-chart-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
    flex-wrap: wrap;
    gap: 8px;
}
.holdings-range-btns { display:flex; gap:4px; }
.hrange-btn {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text3);
    padding: 4px 12px;
    border-radius: 6px;
    font-size: .72rem;
    font-weight: 600;
    transition: all .15s;
}
.hrange-btn:hover { border-color: var(--text3); color: var(--text); }
.hrange-btn.active { background: var(--text); border-color: var(--text); color: var(--white); }
.holdings-chart-wrap {
    position: relative;
    width: 100%;
    background: var(--bg);
    border-radius: 10px;
    overflow: hidden;
}
.holdings-chart-wrap canvas {
    display: block;
    width: 100%;
    height: 280px;
}
.holdings-empty {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    color: var(--text3);
    font-size: .85rem;
    text-align: center;
}
.holdings-chart-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-top: 12px;
    font-size: .8rem;
    color: var(--text2);
    flex-wrap: wrap;
    gap: 8px;
}
.holdings-chart-footer strong { color: var(--text); }

/* DexScreener embed */
.chart-section { margin-bottom:24px; }
.chart-title { font-family:'Bangers',cursive; font-size:1.3rem; letter-spacing:2px; margin-bottom:12px; }
.dex-embed {
    position: relative;
    width: 100%;
    padding-bottom: 65%;
    border-radius: var(--radius);
    overflow: hidden;
    border: 1px solid var(--border);
    background: #131722;
}
.dex-embed iframe {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0; left: 0;
    border: 0;
}

/* ===== CHAT ===== */
.chat {
    position: fixed;
    bottom: 0;
    right: 24px;
    width: 340px;
    z-index: 90;
    display: flex;
    flex-direction: column;
    border-radius: 14px 14px 0 0;
    border: 1px solid var(--border);
    border-bottom: none;
    background: var(--white);
    box-shadow: 0 -4px 24px rgba(0,0,0,.06);
    overflow: hidden;
    transition: transform .25s ease;
}
.chat.collapsed { transform: translateY(calc(100% - 46px)); }

.chat-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 16px;
    background: var(--text);
    color: var(--white);
    cursor: pointer;
    user-select: none;
    flex-shrink: 0;
}
.chat-title {
    font-family: 'Bangers', cursive;
    font-size: .95rem;
    letter-spacing: 1.5px;
    flex: 1;
}
.chat-live {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: .6rem;
    font-weight: 600;
    letter-spacing: 1px;
    color: var(--green);
}
.chat-dot {
    width: 5px; height: 5px;
    border-radius: 50%;
    background: var(--green);
    animation: blink 1.4s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:.3} }
.chat-collapse {
    background: none; border: none;
    color: var(--white);
    font-size: 1.2rem;
    line-height: 1;
    opacity: .6;
    transition: opacity .15s;
}
.chat-collapse:hover { opacity:1; }

.chat-body {
    display: flex;
    flex-direction: column;
    height: 360px;
}
.chat-messages {
    flex: 1;
    overflow-y: auto;
    padding: 12px 14px;
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.chat-messages::-webkit-scrollbar { width:4px; }
.chat-messages::-webkit-scrollbar-thumb { background:var(--border); border-radius:4px; }

.chat-msg {
    max-width: 92%;
    padding: 8px 12px;
    border-radius: 10px;
    font-size: .82rem;
    line-height: 1.4;
    animation: msgIn .2s ease;
}
@keyframes msgIn { from { opacity:0; transform:translateY(6px); } to { opacity:1; transform:translateY(0); } }
.chat-msg-user {
    display: block;
    font-size: .65rem;
    font-weight: 600;
    margin-bottom: 2px;
}
.chat-msg-time {
    display: block;
    font-size: .58rem;
    margin-top: 2px;
    opacity: .5;
}
.chat-msg.self {
    align-self: flex-end;
    background: var(--gold-light);
    color: var(--text);
}
.chat-msg.self .chat-msg-user { color: var(--gold); }
.chat-msg.other {
    align-self: flex-start;
    background: var(--bg);
    color: var(--text);
}
.chat-msg.other .chat-msg-user { color: var(--purple); }
.chat-msg.system {
    align-self: center;
    background: transparent;
    color: var(--text3);
    font-size: .72rem;
    font-style: italic;
    text-align: center;
    padding: 4px;
}

.chat-form {
    display: flex;
    gap: 0;
    border-top: 1px solid var(--border);
    flex-shrink: 0;
}
.chat-input {
    flex: 1;
    border: none;
    outline: none;
    padding: 12px 14px;
    font-size: .82rem;
    font-family: inherit;
    background: transparent;
}
.chat-input::placeholder { color:var(--text3); }
.chat-send {
    border: none;
    background: var(--text);
    color: var(--white);
    padding: 12px 18px;
    font-size: 1rem;
    font-weight: 600;
    transition: background .15s;
}
.chat-send:hover { background: var(--gold); color: var(--text); }

/* ===== NOTIFICATION FEED ===== */
.notif-feed {
    position: fixed;
    bottom: 0;
    left: 24px;
    width: 320px;
    z-index: 90;
    display: flex;
    flex-direction: column;
    border-radius: 14px 14px 0 0;
    border: 1px solid var(--border);
    border-bottom: none;
    background: var(--white);
    box-shadow: 0 -4px 24px rgba(0,0,0,.06);
    overflow: hidden;
    transition: transform .25s ease;
}
.notif-feed.collapsed { transform: translateY(calc(100% - 42px)); }

.notif-header {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 9px 14px;
    background: var(--text);
    color: var(--white);
    cursor: pointer;
    user-select: none;
    flex-shrink: 0;
}
.notif-title {
    font-family: 'Bangers', cursive;
    font-size: .9rem;
    letter-spacing: 1.5px;
    flex: 1;
}
.notif-live {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: .58rem;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: var(--green);
}
.notif-dot {
    width: 5px; height: 5px;
    border-radius: 50%;
    background: var(--green);
    animation: blink 1.4s ease-in-out infinite;
}
.notif-collapse {
    background: none; border: none;
    color: var(--white);
    font-size: 1.2rem;
    line-height: 1;
    opacity: .6;
    transition: opacity .15s;
}
.notif-collapse:hover { opacity: 1; }

.notif-body {
    max-height: 340px;
    overflow-y: auto;
}
.notif-body::-webkit-scrollbar { width: 3px; }
.notif-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

.notif-list { display: flex; flex-direction: column; max-height: 400px; overflow-y: auto; }

.notif-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-bottom: 1px solid var(--border);
    transition: background .15s;
    cursor: pointer;
    text-decoration: none;
    color: inherit;
    animation: notifSlide .3s ease;
}
.notif-item:last-child { border-bottom: none; }
.notif-item:hover { background: var(--bg); }
@keyframes notifSlide {
    from { opacity: 0; transform: translateX(-12px); }
    to   { opacity: 1; transform: translateX(0); }
}

.notif-icon {
    width: 32px; height: 32px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
}
.notif-icon-sell     { background: var(--red-bg); }
.notif-icon-buy      { background: var(--green-bg); }
.notif-icon-transfer { background: var(--blue-bg); }
.notif-icon-burn     { background: var(--orange-bg); }
.notif-icon-receive  { background: var(--purple-bg); }
.notif-icon-swap     { background: var(--gold-light); }
.notif-icon-activity { background: var(--bg); }

.notif-content { flex: 1; min-width: 0; }
.notif-text {
    font-size: .78rem;
    font-weight: 500;
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.notif-time {
    font-size: .62rem;
    color: var(--text3);
    margin-top: 1px;
}
.notif-badge {
    font-size: .6rem;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 4px;
    letter-spacing: .3px;
    flex-shrink: 0;
}
.notif-badge-sell     { background: var(--red-bg); color: var(--red); }
.notif-badge-buy      { background: var(--green-bg); color: var(--green); }
.notif-badge-transfer { background: var(--blue-bg); color: var(--blue); }
.notif-badge-burn     { background: var(--orange-bg); color: var(--orange); }
.notif-badge-receive  { background: var(--purple-bg); color: var(--purple); }
.notif-badge-swap     { background: var(--gold-light); color: var(--gold); }
.notif-badge-activity { background: var(--bg); color: var(--text2); }

.notif-avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1px solid var(--border);
    flex-shrink: 0;
    object-fit: cover;
}
.notif-tx {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px; height: 24px;
    border-radius: 6px;
    background: var(--bg);
    font-size: .85rem;
    color: var(--text3);
    flex-shrink: 0;
    transition: all .15s;
    text-decoration: none;
}
.notif-tx:hover { background: var(--gold-light); color: var(--gold); }

.notif-empty {
    padding: 24px 14px;
    text-align: center;
    color: var(--text3);
    font-size: .8rem;
}

/* Notification toast popup */
.notif-toast {
    position: fixed;
    bottom: 60px;
    left: 24px;
    width: 320px;
    padding: 12px 16px;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: 12px;
    box-shadow: 0 8px 32px rgba(0,0,0,.12);
    z-index: 95;
    display: flex;
    align-items: center;
    gap: 10px;
    transform: translateY(20px);
    opacity: 0;
    transition: all .3s ease;
    pointer-events: none;
}
.notif-toast.show {
    transform: translateY(0);
    opacity: 1;
    pointer-events: auto;
}
.notif-toast .notif-text { font-size: .82rem; }
.notif-toast .notif-time { font-size: .65rem; }
.notif-toast .notif-avatar { width: 36px; height: 36px; }

@media (max-width:600px) {
    .notif-feed { width: calc(100% - 24px); left: 12px; }
    .notif-toast { width: calc(100% - 24px); left: 12px; }
}

/* ===== EVENTS SECTION (token page) ===== */
.events-section {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 24px;
}
.events-section-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 16px;
}
.events-section-header .chart-title { margin-bottom: 0; }
.events-viewall {
    font-size: .78rem;
    color: var(--gold);
    font-weight: 500;
    transition: opacity .15s;
}
.events-viewall:hover { opacity: .7; }
.events-list .ev-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 0;
    border-bottom: 1px solid var(--border);
    text-decoration: none;
    color: inherit;
}
.events-list .ev-item:last-child { border-bottom: none; }
.ev-item-icon {
    width: 32px; height: 32px;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem;
    flex-shrink: 0;
}
.ev-item-content { flex: 1; min-width: 0; }
.ev-item-desc {
    font-size: .8rem;
    font-weight: 500;
    line-height: 1.3;
}
.ev-item-amount {
    font-size: .85rem;
    font-weight: 700;
    color: var(--gold);
    margin-top: 2px;
}
.ev-item-time {
    font-size: .62rem;
    color: var(--text3);
    margin-top: 1px;
}
.ev-item-badge {
    font-size: .6rem;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 4px;
    letter-spacing: .3px;
    flex-shrink: 0;
}
.ev-item-avatar {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1px solid var(--border);
    flex-shrink: 0;
    object-fit: cover;
}
.ev-item-tx {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px; height: 24px;
    border-radius: 6px;
    background: var(--bg);
    font-size: .85rem;
    color: var(--text3);
    cursor: pointer;
    transition: all .15s;
    flex-shrink: 0;
    text-decoration: none;
}
.ev-item-tx:hover { background: var(--gold-light); color: var(--gold); }

/* ===== EVENTS PAGE ===== */
.events-page { padding: 0 24px 80px; }
.events-page-wrap { max-width: 1100px; margin: 0 auto; }
.events-toolbar { margin-bottom: 20px; }
.events-empty-page {
    padding: 60px 20px;
    text-align: center;
    color: var(--text3);
    font-size: .9rem;
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}
.events-table {
    background: var(--white);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    overflow: hidden;
}
.ev-row {
    display: grid;
    grid-template-columns: 120px 1.5fr 2fr 1.2fr 80px 40px;
    align-items: center;
    padding: 12px 18px;
    gap: 12px;
    border-bottom: 1px solid var(--border);
    text-decoration: none;
    color: inherit;
    transition: background .1s;
}
.ev-row:last-child { border-bottom: none; }
.ev-data:hover { background: rgba(0,0,0,.015); }
.ev-header {
    background: var(--bg);
    font-size: .66rem;
    font-weight: 600;
    letter-spacing: .8px;
    color: var(--text3);
    text-transform: uppercase;
}
.ev-type-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .68rem;
    font-weight: 700;
    padding: 4px 10px;
    border-radius: 6px;
    letter-spacing: .3px;
}
.ev-badge-sell     { background: var(--red-bg); color: var(--red); }
.ev-badge-buy      { background: var(--green-bg); color: var(--green); }
.ev-badge-transfer { background: var(--blue-bg); color: var(--blue); }
.ev-badge-burn     { background: var(--orange-bg); color: var(--orange); }
.ev-badge-receive  { background: var(--purple-bg); color: var(--purple); }
.ev-badge-swap     { background: var(--gold-light); color: var(--gold); }
.ev-badge-activity { background: var(--bg); color: var(--text2); }

.ev-col-kol {
    display: flex;
    align-items: center;
    gap: 8px;
}
.ev-avatar {
    width: 28px; height: 28px;
    border-radius: 50%;
    border: 1px solid var(--border);
    flex-shrink: 0;
}
.ev-col-kol strong { font-size: .82rem; display: block; }
.ev-col-kol small { font-size: .68rem; color: var(--text3); }
.ev-col-desc {
    font-size: .8rem;
    color: var(--text2);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.ev-col-amount {
    font-size: .9rem;
    font-weight: 700;
    color: var(--gold);
}
.ev-col-amount small {
    font-weight: 500;
    font-size: .7rem;
    color: var(--text3);
}
.ev-col-time {
    font-size: .72rem;
    color: var(--text3);
}
.ev-tx-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 24px; height: 24px;
    border-radius: 6px;
    background: var(--bg);
    font-size: .85rem;
    color: var(--text3);
    cursor: pointer;
    transition: all .15s;
}
.ev-tx-link:hover { background: var(--gold-light); color: var(--gold); }

.events-pagination {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    padding: 20px;
}
.ev-page-btn {
    font-size: .8rem;
    color: var(--gold);
    font-weight: 500;
    transition: opacity .15s;
}
.ev-page-btn:hover { opacity: .7; }
.ev-page-info {
    font-size: .75rem;
    color: var(--text3);
}

@media (max-width:900px) {
    .ev-row { grid-template-columns: 90px 1.2fr 1.5fr 1fr 60px 30px; padding: 10px 12px; gap: 8px; }
    .ev-col-desc { display: none; }
}
@media (max-width:600px) {
    .ev-row { grid-template-columns: 80px 1fr 1fr 30px; }
    .ev-col-desc, .ev-col-time { display: none; }
    .ev-header .ev-col-desc, .ev-header .ev-col-time { display: none; }
}

/* Token external links */
.token-links { margin-bottom:24px; }
.token-ext-link {
    display: inline-block;
    font-size: .82rem;
    color: var(--gold);
    font-weight: 500;
    transition: opacity .15s;
}
.token-ext-link:hover { opacity:.7; }

/* ===== FOOTER ===== */
.foot {
    border-top: 1px solid var(--border);
    padding: 20px 32px;
    display: flex; align-items: center; justify-content: space-between;
    background: var(--white);
}
.foot .brand { font-size:1rem; }
.foot-txt { color:var(--text3); font-size:.75rem; }

/* ===== TOAST ===== */
.toast {
    position:fixed; bottom:24px; left:50%;
    transform:translateX(-50%) translateY(12px);
    background:var(--text); color:var(--white);
    font-weight:500; font-size:.8rem;
    padding:8px 22px; border-radius:8px;
    opacity:0; pointer-events:none;
    transition:all .2s; z-index:999;
}
.toast.show { opacity:1; transform:translateX(-50%) translateY(0); }

/* ===== RESPONSIVE ===== */
@media (max-width:1024px) {
    .token-page-full { max-width:100%; }
    .hero-inner { grid-template-columns:1fr; text-align:center; }
    .hero-left { padding-bottom:16px; }
    .hero-ca-row { margin-left:auto; margin-right:auto; }
    .hero-links { justify-content:center; }
}
@media (max-width:900px) {
    .board-row { grid-template-columns:36px 1.5fr 1fr 1fr 1fr; }
    .col-supply, .col-status, .col-addr { display:none; }
    .podium { gap:4px; }
    .ped-1 { width:150px !important; height:90px; }
    .ped-2 { width:130px !important; height:60px; }
    .ped-3 { width:130px !important; height:42px; }
    .slot-1 .podium-avatar { width:80px !important; height:80px !important; }
    .slot-2 .podium-avatar, .slot-3 .podium-avatar { width:64px !important; height:64px !important; }
    .podium-card { padding:12px 14px 10px; }
    .token-stats-row { grid-template-columns:1fr 1fr; }
    .dex-embed { padding-bottom:80%; }
    .chat { width:300px; right:12px; }
}
@media (max-width:600px) {
    .nav { padding:10px 16px; }
    .nav-link { display:none; }
    .hero { padding:64px 16px 0; }
    .hero-title { font-size:3.5rem; }
    .podium { flex-direction:column; align-items:center; gap:12px; }
    .podium-slot { width:80%; max-width:240px; }
    .pedestal { display:none; }
    .podium-card { flex-direction:row; gap:12px; padding:14px 16px; }
    .podium-card .podium-crown { position:absolute; top:-8px; left:-4px; font-size:1.2rem !important; }
    .podium-card .podium-avatar { width:50px !important; height:50px !important; margin-bottom:0; }
    .slot-2 { order:2; } .slot-1 { order:1; } .slot-3 { order:3; }
    .board-head { flex-direction:column; align-items:flex-start; }
    .board-row { grid-template-columns:30px 2fr 1fr 1fr; }
    .col-change { display:none; }
    .chat { width:calc(100% - 24px); right:12px; }
    .tokens-grid { grid-template-columns:1fr; }
    .token-stats-row { grid-template-columns:1fr; }
    .dex-embed { padding-bottom:125%; }
}
