/* ============================================================
   VANGUARD — ARK Survival Ascended template
   LOOK & FEEL: modern competitive-cluster dashboard —
   near-black base, electric indigo accent,
   rounded cards, clean bold sans (Space Grotesk), announcement
   banner, wipe countdown, live cluster pulse, stat tiles, tribe
   leaderboard, grouped server grid. Driven by our real data.
   ============================================================ */

:root {
    --bg-0:#08070e; --bg-1:#0b0a12; --bg-2:#100e1a; --panel:#0f0d18; --panel-2:#14121f;
    --line:rgba(255,255,255,0.07); --line-2:rgba(124,108,255,0.18);
    --paper:#eef3f0; --text:#b2bcb6; --text-muted:#7c877f; --muted-2:#5c665e;
    /* accent overridden per-customer by header theme vars */
    --accent-fire:#6a5cff; --accent-fire-2:#8e84ff; --accent-fire-dk:#4b3fd6; --accent:var(--accent-fire);
    --live:#8e84ff; --warn:#ffc24b; --down:#ff5d6c;
    --f-display:'Space Grotesk','Inter',sans-serif; --f-body:'Inter',system-ui,sans-serif;
    --maxw:1200px; --r:14px; --r-sm:10px;
}
* { box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { margin:0; font-family:var(--f-body); background:var(--bg-0); color:var(--text); line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden;
    background-image:radial-gradient(circle at 50% -8%, rgba(106,92,255,0.10), transparent 55%); background-attachment:fixed; }
h1,h2,h3,h4,h5 { font-family:var(--f-display); color:var(--paper); font-weight:600; letter-spacing:-0.02em; line-height:1.06; margin:0 0 .5em; }
a { color:var(--accent-fire-2); text-decoration:none; } a:hover { color:var(--accent-fire); }
code,.mono { font-family:'JetBrains Mono',ui-monospace,monospace; }
.container { width:100%; max-width:var(--maxw); margin:0 auto; padding:0 26px; }
.skip-link { position:absolute; left:-999px; top:0; z-index:9999; background:var(--accent-fire); color:#ffffff; padding:10px 16px; font-weight:700; } .skip-link:focus { left:12px; top:12px; }
@keyframes vgPulse { 0%{box-shadow:0 0 0 0 rgba(142,132,255,.5);} 70%{box-shadow:0 0 0 7px rgba(142,132,255,0);} 100%{box-shadow:0 0 0 0 rgba(142,132,255,0);} }
@keyframes vgBar { from { transform:scaleY(.4);} to { transform:scaleY(1);} }

/* ============================================================
   NAV (slim, pill links)
   ============================================================ */
.site-navbar { position:sticky; top:0; z-index:50; background:rgba(8,7,14,.82); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); padding:12px 0; }
.site-navbar.scrolled { background:rgba(6,5,11,.96); }
.site-navbar .container { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand-wordmark { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-weight:700; font-size:1.2rem; color:var(--paper); letter-spacing:-0.01em; }
.brand-wordmark:hover { color:var(--paper); }
.brand-mark { width:32px; height:32px; display:inline-flex; align-items:center; justify-content:center; background:var(--accent-fire); color:#ffffff; border-radius:9px; font-size:.95rem; box-shadow:0 0 18px rgba(106,92,255,.45); }
.navbar-nav { display:flex; align-items:center; gap:2px; list-style:none; margin:0; padding:0; }
.nav-link { color:var(--text-muted); font-weight:500; font-size:.9rem; padding:8px 14px; border-radius:999px; transition:all .15s; }
.nav-link:hover { color:var(--paper); background:rgba(255,255,255,.04); }
.nav-link.active { color:var(--accent-fire-2); background:rgba(106,92,255,.1); }
.btn-connect { margin-left:6px; }
.navbar-toggler { display:none; background:none; border:1px solid var(--line-2); color:var(--paper); padding:7px 10px; border-radius:8px; cursor:pointer; }
@media (max-width:900px){ .navbar-toggler{display:inline-flex;} .navbar-collapse{display:none; width:100%;} .navbar-collapse.show{display:block;} .navbar-nav{flex-direction:column; align-items:stretch; padding-top:10px; gap:2px;} .nav-link{padding:11px 14px;} }

/* ============================================================
   BUTTONS (pill)
   ============================================================ */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:var(--f-display); font-weight:600; font-size:.92rem; padding:11px 22px; border:1px solid transparent; cursor:pointer; border-radius:999px; transition:all .15s; text-decoration:none; }
.btn-primary { background:var(--accent-fire); color:#ffffff; box-shadow:0 6px 22px rgba(106,92,255,.28); }
.btn-primary:hover { background:var(--accent-fire-2); color:#ffffff; transform:translateY(-1px); }
.btn-outline-light { background:rgba(255,255,255,.03); border-color:var(--line-2); color:var(--paper); }
.btn-outline-light:hover { border-color:var(--accent-fire); color:var(--accent-fire-2); }
.btn.disabled,.btn:disabled { opacity:.45; cursor:not-allowed; }
.px-5 { padding-left:38px !important; padding-right:38px !important; }

/* ============================================================
   ANNOUNCEMENT BANNER
   ============================================================ */
.vg-ann { background:linear-gradient(120deg, rgba(106,92,255,.12), rgba(106,92,255,.03)); border:1px solid var(--line-2); border-radius:var(--r); padding:18px 22px; display:flex; align-items:center; gap:18px; flex-wrap:wrap; margin-top:26px; }
.vg-ann .tag { font-family:var(--f-display); font-size:.68rem; font-weight:600; text-transform:uppercase; letter-spacing:.14em; color:var(--accent-fire-2); }
.vg-ann h3 { font-size:1.25rem; margin:2px 0 2px; color:var(--paper); }
.vg-ann p { margin:0; color:var(--text-muted); font-size:.92rem; }
.vg-ann .spacer { flex:1; }

/* ============================================================
   HERO
   ============================================================ */
.vg-hero { position:relative; padding:54px 0 40px; overflow:hidden;
    background:linear-gradient(180deg, rgba(8,7,14,.5), rgba(8,7,14,.85) 60%, var(--bg-0)), var(--ark-hero-image,none); background-size:cover; background-position:center; }
.vg-statline { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-size:.92rem; color:var(--text-muted); margin-bottom:14px; }
.vg-statline .dot { width:8px; height:8px; border-radius:50%; background:var(--live); box-shadow:0 0 10px var(--live); animation:vgPulse 2s infinite; }
.vg-statline b { color:var(--paper); }
.vg-kicker { font-family:var(--f-display); font-size:.74rem; font-weight:600; text-transform:uppercase; letter-spacing:.2em; color:var(--accent-fire-2); margin-bottom:14px; display:block; }
.vg-hero h1 { font-size:clamp(2.8rem,8vw,6rem); color:var(--paper); line-height:.95; margin-bottom:22px; letter-spacing:-0.03em; }
.vg-hero-actions { display:flex; flex-wrap:wrap; gap:12px; }

/* ============================================================
   CARDS / GRID
   ============================================================ */
.vg-card { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:24px; }
.vg-card.glow { border-color:var(--line-2); box-shadow:0 0 0 1px rgba(106,92,255,.05), 0 24px 60px rgba(0,0,0,.4); }
.vg-card-label { display:flex; align-items:center; justify-content:space-between; gap:10px; font-family:var(--f-display); font-size:.72rem; font-weight:600; text-transform:uppercase; letter-spacing:.14em; color:var(--text-muted); margin-bottom:14px; }
.vg-live-badge { display:inline-flex; align-items:center; gap:7px; color:var(--live); font-size:.72rem; } .vg-live-badge .dot { width:7px; height:7px; border-radius:50%; background:var(--live); box-shadow:0 0 8px var(--live); animation:vgPulse 2s infinite; }
.vg-grid2 { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
@media (max-width:820px){ .vg-grid2 { grid-template-columns:1fr; } }

/* countdown */
.vg-count-title { font-family:var(--f-display); font-size:1.4rem; color:var(--paper); margin:2px 0 4px; }
.vg-count-sub { font-size:.82rem; color:var(--text-muted); margin-bottom:18px; }
.vg-count { display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.vg-count-box { background:rgba(0,0,0,.35); border:1px solid var(--line); border-radius:var(--r-sm); padding:14px 8px; text-align:center; }
.vg-count-box .n { font-family:var(--f-display); font-size:2rem; font-weight:700; color:var(--paper); line-height:1; }
.vg-count-box .u { font-size:.62rem; text-transform:uppercase; letter-spacing:.12em; color:var(--muted-2); margin-top:7px; }
.vg-count-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:16px; }
.vg-tag { font-family:var(--f-display); font-size:.68rem; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); border:1px solid var(--line); border-radius:999px; padding:4px 12px; }

/* cluster pulse bars */
.vg-pulse-top { display:flex; align-items:baseline; gap:10px; margin-bottom:16px; }
.vg-pulse-top .big { font-family:var(--f-display); font-size:2.2rem; font-weight:700; color:var(--paper); line-height:1; }
.vg-pulse-top .lbl { color:var(--text-muted); font-size:.85rem; }
.vg-pulse-bars { display:flex; align-items:flex-end; gap:6px; height:96px; }
.vg-pulse-bar { flex:1; min-width:6px; background:linear-gradient(180deg,var(--accent-fire-2),var(--accent-fire-dk)); border-radius:4px 4px 0 0; transform-origin:bottom; animation:vgBar .8s ease-out; opacity:.9; }
.vg-pulse-bar.off { background:rgba(255,255,255,.08); }
.vg-pulse-foot { display:flex; justify-content:space-between; margin-top:12px; font-size:.78rem; color:var(--text-muted); }

/* ============================================================
   STAT TILES
   ============================================================ */
.vg-stats { display:grid; grid-template-columns:repeat(5,1fr); gap:14px; }
@media (max-width:900px){ .vg-stats { grid-template-columns:repeat(2,1fr); } }
.vg-stat { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:22px; }
.vg-stat .l { font-family:var(--f-display); font-size:.68rem; text-transform:uppercase; letter-spacing:.12em; color:var(--text-muted); margin-bottom:12px; }
.vg-stat .n { font-family:var(--f-display); font-size:2.4rem; font-weight:700; color:var(--paper); line-height:1; }
.vg-stat .n .live { color:var(--accent-fire-2); }

/* ============================================================
   SECTIONS
   ============================================================ */
.section { padding:60px 0; }
.section-eyebrow { display:inline-block; font-family:var(--f-display); font-size:.74rem; font-weight:600; text-transform:uppercase; letter-spacing:.16em; color:var(--accent-fire-2); margin-bottom:12px; }
.section-title { font-size:clamp(1.8rem,3.6vw,2.7rem); color:var(--paper); margin-bottom:14px; letter-spacing:-0.02em; }
.section-lead { color:var(--text-muted); font-size:1.04rem; max-width:640px; }
.section-elev { background:var(--bg-1); border-top:1px solid var(--line); }
.section-dark { background:var(--bg-0); border-top:1px solid var(--line); }
.torch { color:var(--accent-fire-2); }
.vg-head { display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:26px; }

/* sub-page hero (cloned pages) */
.hero { padding:54px 0 0; background:linear-gradient(180deg,rgba(8,7,14,.5),rgba(8,7,14,.85) 60%,var(--bg-0)), var(--ark-hero-image,none); background-size:cover; background-position:center; }
.subpage-hero { padding-bottom:44px; border-bottom:1px solid var(--line); }
.hero-eyebrow { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-size:.74rem; font-weight:600; text-transform:uppercase; letter-spacing:.18em; color:var(--accent-fire-2); margin-bottom:16px; }
.pulse { width:8px; height:8px; border-radius:50%; background:var(--live); animation:vgPulse 2s infinite; }
.hero h1 { font-size:clamp(2.4rem,5.5vw,4rem); color:var(--paper); margin-bottom:14px; letter-spacing:-0.02em; }
.hero-sub { font-size:1.12rem; color:var(--text); max-width:640px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:12px; margin-top:24px; }

/* ============================================================
   TRIBE LEADERBOARD
   ============================================================ */
.vg-board { display:flex; flex-direction:column; gap:10px; }
.vg-board-row { display:grid; grid-template-columns:54px 1fr auto; align-items:center; gap:16px; background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:16px 20px; transition:border-color .15s,transform .12s; }
.vg-board-row:hover { border-color:var(--line-2); transform:translateX(3px); }
.vg-rank { font-family:var(--f-display); font-size:1.5rem; font-weight:700; color:var(--muted-2); text-align:center; }
.vg-board-row:nth-child(1) .vg-rank { color:var(--accent-fire-2); }
.vg-tribe-name { font-family:var(--f-display); font-size:1.2rem; color:var(--paper); font-weight:600; }
.vg-tribe-tag { font-size:.84rem; color:var(--text-muted); margin-top:2px; }
.vg-board-meta { display:flex; gap:24px; text-align:right; }
.vg-board-meta .v { font-family:var(--f-display); font-size:1.15rem; font-weight:600; color:var(--paper); }
.vg-board-meta .k { font-size:.66rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted-2); margin-top:3px; }
@media (max-width:560px){ .vg-board-meta { display:none; } }

/* ============================================================
   SERVER GRID (grouped)
   ============================================================ */
.vg-group { margin-bottom:14px; }
.vg-group-head { display:flex; align-items:center; gap:12px; padding:12px 4px; }
.vg-group-head h3 { font-family:var(--f-display); font-size:1.05rem; color:var(--paper); margin:0; text-transform:capitalize; }
.vg-group-head .meta { font-family:var(--f-display); font-size:.8rem; color:var(--text-muted); }
.vg-group-head .meta b { color:var(--accent-fire-2); }
.vg-group-head .rule { flex:1; height:1px; background:var(--line); }
.vg-srv-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:8px; }
.vg-srv { display:flex; align-items:center; justify-content:space-between; gap:10px; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-sm); padding:11px 14px; transition:border-color .15s; }
.vg-srv:hover { border-color:var(--line-2); }
.vg-srv .nm { display:flex; align-items:center; gap:9px; font-size:.9rem; color:var(--paper); font-weight:500; min-width:0; }
.vg-srv .nm .dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; background:var(--live); box-shadow:0 0 7px var(--live); }
.vg-srv.off .nm .dot { background:var(--muted-2); box-shadow:none; }
.vg-srv .nm span { overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.vg-srv .pc { font-family:var(--f-display); font-size:.82rem; color:var(--text-muted); white-space:nowrap; } .vg-srv .pc b { color:var(--paper); }

/* rates + mods */
.vg-rates { display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:14px; }
.vg-rate { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:22px; text-align:center; }
.vg-rate .x { font-family:var(--f-display); font-size:2.2rem; font-weight:700; color:var(--accent-fire-2); } .vg-rate .x small { color:var(--text-muted); font-size:1rem; }
.vg-rate .l { font-family:var(--f-display); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-muted); margin-top:4px; }
.vg-mods { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:10px; }
.vg-mod { display:flex; align-items:center; gap:12px; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-sm); padding:10px 12px; transition:border-color .15s,transform .15s; }
.vg-mod:hover { border-color:var(--line-2); transform:translateY(-2px); }
.vg-mod-logo { width:44px; height:44px; flex-shrink:0; border-radius:9px; overflow:hidden; background:rgba(0,0,0,.4); border:1px solid var(--line); display:inline-flex; align-items:center; justify-content:center; }
.vg-mod-logo img { width:100%; height:100%; object-fit:cover; } .vg-mod-logo i { color:var(--muted-2); }
.vg-mod-name { font-weight:600; font-size:.9rem; color:var(--paper); line-height:1.25; }
.vg-cat { display:flex; align-items:center; gap:12px; margin:30px 0 14px; }
.vg-cat h2 { font-family:var(--f-display); font-size:1.2rem; color:var(--paper); margin:0; } .vg-cat .count { font-family:var(--f-display); color:var(--accent-fire-2); font-size:.85rem; } .vg-cat .rule { flex:1; height:1px; background:var(--line); }

/* CTA card */
.vg-cta { background:linear-gradient(120deg, rgba(106,92,255,.14), rgba(106,92,255,.03)); border:1px solid var(--line-2); border-radius:18px; padding:44px; display:flex; flex-wrap:wrap; align-items:center; gap:22px; }
.vg-cta h2 { font-size:clamp(1.6rem,3vw,2.3rem); color:var(--paper); margin:0 0 6px; } .vg-cta p { margin:0; color:var(--text-muted); }
.vg-cta .spacer { flex:1; } .vg-cta .acts { display:flex; flex-wrap:wrap; gap:12px; }

/* ============================================================
   SHARED (feature/tribe/rules/forms/join/footer)
   ============================================================ */
.feature-card { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:26px; height:100%; }
.feature-card h3 { font-size:1.15rem; margin-bottom:8px; } .feature-card p { color:var(--text-muted); margin:0; font-size:.95rem; }
.feature-icon { width:46px; height:46px; display:inline-flex; align-items:center; justify-content:center; background:rgba(106,92,255,.12); color:var(--accent-fire-2); font-size:1.2rem; margin-bottom:15px; border-radius:12px; }
.hero-server-card { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line-2); border-radius:var(--r); padding:22px; max-width:380px; }
.hero-server-card > .label { font-family:var(--f-display); font-size:.74rem; text-transform:uppercase; letter-spacing:.12em; color:var(--accent-fire-2); margin-bottom:14px; display:block; }
.info-row { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:10px 0; border-bottom:1px solid var(--line); } .info-row:last-child { border-bottom:0; }
.info-row .label { font-size:.8rem; text-transform:uppercase; letter-spacing:.06em; color:var(--text-muted); } .info-row .value { font-family:var(--f-display); font-weight:600; color:var(--paper); }
.rules-list { list-style:none; margin:0; padding:0; }
.rules-list li { display:flex; gap:18px; padding:16px 0; border-bottom:1px solid var(--line); }
.rules-list li strong { font-family:var(--f-display); font-size:1.3rem; color:var(--accent-fire-2); flex-shrink:0; width:40px; }
.rules-list li div { color:var(--text); }
.cta-strip { margin-top:40px; padding:38px; text-align:center; background:linear-gradient(120deg, rgba(106,92,255,.12), rgba(106,92,255,.02)); border:1px solid var(--line-2); border-radius:18px; }
.tribe-card { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:24px; height:100%; } .tribe-card:hover { border-color:var(--line-2); }
.tribe-tag { font-family:var(--f-display); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--accent-fire-2); margin-bottom:8px; }
.tribe-name { font-size:1.3rem; margin-bottom:8px; } .tribe-card p { color:var(--text-muted); font-size:.95rem; }
.tribe-meta { display:flex; flex-wrap:wrap; gap:14px; margin-top:14px; }
.tribe-meta span { display:inline-flex; align-items:center; gap:6px; font-size:.82rem; color:var(--text-muted); } .tribe-meta i { color:var(--accent-fire-2); }
.ark-join-panel { display:flex; flex-direction:column; }
.ark-join-count { font-family:var(--f-display); font-size:.8rem; color:var(--accent-fire-2); border:1px solid var(--line-2); border-radius:999px; padding:5px 12px; height:fit-content; white-space:nowrap; }
.ark-join-server-list { display:flex; flex-direction:column; gap:10px; margin-top:8px; }
.ark-join-server-row { display:flex; align-items:center; justify-content:space-between; gap:14px; padding:13px 16px; background:var(--panel); border:1px solid var(--line); border-radius:var(--r-sm); }
.ark-join-server-title { display:flex; align-items:center; gap:9px; font-family:var(--f-display); font-weight:600; color:var(--paper); flex-wrap:wrap; }
.ark-connect-dot { width:9px; height:9px; border-radius:50%; flex-shrink:0; box-shadow:0 0 8px currentColor; }
.ark-connect-badge { font-family:var(--f-display); font-size:.64rem; text-transform:uppercase; color:var(--accent-fire-2); border:1px solid var(--line-2); border-radius:999px; padding:2px 9px; }
.ark-join-flag { font-size:.72rem; color:var(--warn); }
.ark-join-search-name { font-family:'JetBrains Mono',monospace; font-size:.78rem; color:var(--text-muted); margin-top:5px; }
.ark-join-meta { font-size:.78rem; color:var(--muted-2); margin-top:3px; }
.ark-join-ip { white-space:nowrap; font-family:'JetBrains Mono',monospace; } .ark-join-note { font-size:.88rem; color:var(--text-muted); }
.ark-join-checklist { display:flex; flex-direction:column; gap:11px; } .ark-join-checklist > div { display:flex; gap:11px; align-items:flex-start; color:var(--text); } .ark-join-checklist i { color:var(--live); margin-top:5px; }
.ark-join-actions { display:flex; flex-wrap:wrap; gap:12px; }
.ark-form-card { background:var(--panel); border:1px solid var(--line-2); border-radius:var(--r); padding:32px; margin-top:8px; }
.ark-contact-choice { text-align:center; margin-bottom:20px; }
.ark-discord-contact-card { background:var(--panel); border:1px solid var(--line-2); border-radius:var(--r); padding:40px; text-align:center; }
.form-label { font-family:var(--f-display); font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); margin-bottom:7px; display:block; }
.form-control { width:100%; background:rgba(0,0,0,.35); border:1px solid var(--line-2); color:var(--paper); padding:12px 14px; font-family:var(--f-body); font-size:.98rem; border-radius:var(--r-sm); }
.form-control:focus { outline:none; border-color:var(--accent-fire); box-shadow:0 0 0 3px rgba(106,92,255,.16); }
.was-validated .form-control:invalid { border-color:var(--down); }

.site-footer { background:var(--bg-1); border-top:1px solid var(--line); padding:56px 0 28px; }
.footer-brand { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-weight:700; font-size:1.2rem; color:var(--paper); }
.site-footer p { color:var(--text-muted); font-size:.92rem; }
.site-footer h5 { font-family:var(--f-display); font-size:.8rem; text-transform:uppercase; letter-spacing:.12em; color:var(--accent-fire-2); margin-bottom:14px; }
.footer-info { font-size:.9rem; color:var(--text-muted); } .footer-info strong { display:block; color:var(--paper); font-size:.7rem; text-transform:uppercase; letter-spacing:.08em; margin-bottom:4px; }
.footer-links { list-style:none; margin:0; padding:0; } .footer-links li { margin-bottom:9px; } .footer-links a { color:var(--text-muted); font-size:.92rem; } .footer-links a:hover { color:var(--accent-fire-2); }
.social-link { display:inline-flex; align-items:center; justify-content:center; width:40px; height:40px; border:1px solid var(--line-2); color:var(--text-muted); margin-right:8px; border-radius:10px; } .social-link:hover { border-color:var(--accent-fire); color:var(--accent-fire-2); }
.footer-bottom { margin-top:40px; padding-top:22px; border-top:1px solid var(--line); font-size:.8rem; color:var(--muted-2); }
.server-ip { color:var(--accent-fire-2); cursor:pointer; font-family:'JetBrains Mono',monospace; }
.back-to-top { position:fixed; right:24px; bottom:24px; z-index:50; width:44px; height:44px; border:none; background:var(--accent-fire); color:#ffffff; cursor:pointer; opacity:0; pointer-events:none; transition:opacity .2s; border-radius:12px; }
.back-to-top.visible { opacity:1; pointer-events:auto; }

[data-aos] { opacity:0; transform:translateY(16px); transition:opacity .55s,transform .55s; }
[data-aos].aos-animate { opacity:1; transform:none; }

/* nav contrast — override Bootstrap navbar defaults (dark active text / invisible brand) */
.site-navbar { --bs-navbar-color:var(--text-muted); --bs-navbar-hover-color:var(--paper); --bs-navbar-active-color:var(--accent-fire-2); --bs-navbar-brand-color:var(--paper); --bs-navbar-brand-hover-color:var(--paper); }
.site-navbar .brand-wordmark, .site-navbar .brand-wordmark:hover { color:var(--paper); }
.site-navbar .nav-link { color:var(--text-muted); }
.site-navbar .nav-link:hover { color:var(--paper); }
.site-navbar .nav-link.active { color:var(--accent-fire-2); background:rgba(106,92,255,.14); }
