/* ============================================================
   APEX ARENA — ARK Survival Ascended template
   LOOK & FEEL: bold, competitive unofficial-cluster site with a
   tournament-grade feel. Near-black, crimson PvP accent, Oswald
   condensed display, battlefield hero, live cluster-stats bar,
   season/wipe strip, ranked tribe leaderboard, skewed accents.
   Shared class vocabulary kept so the form pages still render.
   ============================================================ */

:root {
    --bg-0:#08090c; --bg-1:#0d0f14; --bg-2:#12151c; --bg-3:#171b24; --panel:#11141a; --panel-2:#161a22;
    --line:rgba(255,255,255,0.07); --line-2:rgba(255,255,255,0.14);
    --paper:#f3f5fa; --text:#c4cad6; --text-muted:#828a9b; --muted-2:#5f6779;
    /* accent overridden per-customer by header theme vars */
    --accent-fire:#ec2b3b; --accent-fire-2:#ff5d68; --accent-fire-dk:#b11626; --accent:var(--accent-fire);
    --live:#33d27a; --warn:#ffb02e; --down:#ff5151;
    --f-display:'Oswald','Arial Narrow',sans-serif; --f-body:'Inter',system-ui,sans-serif;
    --maxw:1220px;
}
* { 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; }
h1,h2,h3,h4,h5 { font-family:var(--f-display); color:var(--paper); font-weight:600; text-transform:uppercase; letter-spacing:.01em; line-height:1.04; margin:0 0 .4em; }
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 28px; }
.skip-link { position:absolute; left:-999px; top:0; z-index:9999; background:var(--accent-fire); color:#fff; padding:10px 16px; font-weight:700; } .skip-link:focus { left:12px; top:12px; }
@keyframes apxPulse { 0%{box-shadow:0 0 0 0 rgba(51,210,122,.5);} 70%{box-shadow:0 0 0 7px rgba(51,210,122,0);} 100%{box-shadow:0 0 0 0 rgba(51,210,122,0);} }

/* ============================================================
   NAVBAR (dark, bold, crimson)
   ============================================================ */
.site-navbar { position:sticky; top:0; z-index:50; background:rgba(8,9,12,.86); backdrop-filter:blur(12px); border-bottom:1px solid var(--line); padding:14px 0; transition:border-color .2s,background .2s; }
.site-navbar.scrolled { background:rgba(6,7,10,.97); border-bottom-color:var(--accent-fire-dk); }
.site-navbar .container { display:flex; align-items:center; justify-content:space-between; }
.brand-wordmark { display:inline-flex; align-items:center; gap:11px; font-family:var(--f-display); font-weight:700; font-size:1.45rem; color:var(--paper); text-transform:uppercase; letter-spacing:.04em; }
.brand-wordmark:hover { color:var(--paper); }
.brand-mark { width:38px; height:38px; display:inline-flex; align-items:center; justify-content:center; background:var(--accent-fire); color:#fff; font-size:1.05rem; transform:skewX(-10deg); box-shadow:0 0 22px rgba(236,43,59,.45); }
.brand-mark i { transform:skewX(10deg); }
.navbar-nav { display:flex; align-items:center; gap:4px; list-style:none; margin:0; padding:0; }
.nav-link { color:var(--text-muted); font-family:var(--f-display); font-weight:500; font-size:.95rem; text-transform:uppercase; letter-spacing:.06em; padding:8px 14px; transition:color .15s; }
.nav-link:hover { color:var(--paper); } .nav-link.active { color:var(--accent-fire); }
.btn-connect { margin-left:8px; }
.navbar-toggler { display:none; background:none; border:1px solid var(--line-2); color:var(--paper); padding:7px 10px; 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:flex-start; padding-top:12px;} .nav-link{padding:11px 4px; width:100%;} }

/* ============================================================
   BUTTONS (skewed, aggressive)
   ============================================================ */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:var(--f-display); font-weight:600; font-size:.95rem; text-transform:uppercase; letter-spacing:.05em; padding:12px 26px; border:2px solid transparent; cursor:pointer; transition:all .15s; text-decoration:none; transform:skewX(-8deg); }
.btn > * { transform:skewX(8deg); }
.btn span, .btn i { display:inline-block; transform:skewX(8deg); }
.btn-primary { background:var(--accent-fire); color:#fff; box-shadow:0 0 24px rgba(236,43,59,.32); }
.btn-primary:hover { background:var(--accent-fire-dk); color:#fff; box-shadow:0 0 34px rgba(236,43,59,.5); }
.btn-outline-light { background:transparent; border-color:var(--line-2); color:var(--paper); }
.btn-outline-light:hover { border-color:var(--accent-fire); color:var(--accent-fire); }
.btn.disabled,.btn:disabled { opacity:.45; cursor:not-allowed; }
.px-5 { padding-left:42px !important; padding-right:42px !important; }

/* ============================================================
   HERO (full-bleed battlefield)
   ============================================================ */
.apx-hero { position:relative; padding:120px 0 0; overflow:hidden;
    background:linear-gradient(180deg, rgba(8,9,12,.55) 0%, rgba(8,9,12,.82) 55%, var(--bg-0) 100%), var(--ark-hero-image,none);
    background-size:cover; background-position:center; }
.apx-hero::before { content:''; position:absolute; left:0; right:0; top:0; height:4px; background:linear-gradient(90deg,transparent,var(--accent-fire),transparent); }
.apx-hero-inner { max-width:840px; padding-bottom:60px; }
.apx-eyebrow { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-size:.9rem; font-weight:600; text-transform:uppercase; letter-spacing:.18em; color:var(--accent-fire-2); margin-bottom:18px; }
.apx-eyebrow .pulse { width:9px; height:9px; border-radius:50%; background:var(--live); animation:apxPulse 2s infinite; }
.apx-hero h1 { font-size:clamp(2.8rem,7vw,5.6rem); color:var(--paper); line-height:.96; margin-bottom:18px; text-shadow:0 6px 40px rgba(0,0,0,.6); }
.apx-hero h1 em { color:var(--accent-fire); font-style:normal; }
.apx-hero-sub { font-size:1.2rem; color:var(--text); max-width:620px; margin-bottom:28px; }
.apx-actions { display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
.apx-ip { display:inline-flex; align-items:center; gap:12px; transform:skewX(-8deg); background:rgba(0,0,0,.4); border:1px solid var(--line-2); padding:11px 18px; cursor:pointer; }
.apx-ip > * { transform:skewX(8deg); }
.apx-ip .lbl { font-family:var(--f-display); font-size:.7rem; text-transform:uppercase; letter-spacing:.14em; color:var(--text-muted); }
.apx-ip .val { font-family:'JetBrains Mono',monospace; color:var(--paper); font-weight:600; }
.apx-ip i { color:var(--accent-fire); }

/* season / wipe strip */
.apx-season { background:var(--accent-fire-dk); color:#fff; }
.apx-season .container { display:flex; flex-wrap:wrap; align-items:center; gap:10px 22px; padding:12px 28px; font-family:var(--f-display); text-transform:uppercase; letter-spacing:.06em; font-size:.9rem; }
.apx-season .badge { background:#fff; color:var(--accent-fire-dk); padding:3px 12px; font-weight:700; transform:skewX(-10deg); } .apx-season .badge span { display:inline-block; transform:skewX(10deg); }
.apx-season .item { color:rgba(255,255,255,.85); } .apx-season .item b { color:#fff; }

/* live cluster stats bar */
.apx-statbar { background:var(--bg-1); border-top:1px solid var(--accent-fire-dk); border-bottom:1px solid var(--line); }
.apx-stats { display:grid; grid-template-columns:repeat(4,1fr); }
@media (max-width:680px){ .apx-stats { grid-template-columns:repeat(2,1fr); } }
.apx-stat { padding:26px 22px; text-align:center; border-right:1px solid var(--line); position:relative; }
.apx-stat:last-child { border-right:0; }
.apx-stat .n { font-family:var(--f-display); font-size:2.8rem; font-weight:700; color:var(--paper); line-height:1; }
.apx-stat .n .live { color:var(--live); }
.apx-stat .l { font-family:var(--f-display); font-size:.82rem; text-transform:uppercase; letter-spacing:.14em; color:var(--text-muted); margin-top:9px; }

/* ============================================================
   SECTIONS
   ============================================================ */
.section { padding:80px 0; }
.section-elev { background:linear-gradient(180deg,var(--bg-1),var(--bg-0)); border-top:1px solid var(--line); }
.section-dark { background:var(--bg-0); border-top:1px solid var(--line); }
.section-eyebrow { display:inline-block; font-family:var(--f-display); font-size:.85rem; font-weight:600; text-transform:uppercase; letter-spacing:.18em; color:var(--accent-fire); margin-bottom:12px; }
.section-title { font-size:clamp(1.9rem,3.6vw,2.9rem); color:var(--paper); margin-bottom:14px; }
.section-lead { color:var(--text-muted); font-size:1.05rem; max-width:660px; }
.torch { color:var(--accent-fire); font-style:normal; }
.apx-head { display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:30px; }

/* sub-page hero (cloned rules/tribes/contact) */
.hero { padding:120px 0 0; background:linear-gradient(180deg,rgba(8,9,12,.55),rgba(8,9,12,.86) 60%,var(--bg-0)), var(--ark-hero-image,none); background-size:cover; background-position:center; }
.subpage-hero { padding-bottom:50px; border-bottom:1px solid var(--line); }
.hero-eyebrow { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-size:.88rem; font-weight:600; text-transform:uppercase; letter-spacing:.16em; color:var(--accent-fire-2); margin-bottom:18px; }
.pulse { width:9px; height:9px; border-radius:50%; background:var(--live); }
.hero h1 { font-size:clamp(2.4rem,5.5vw,4.2rem); color:var(--paper); margin-bottom:16px; }
.hero-sub { font-size:1.15rem; color:var(--text); max-width:640px; }
.hero-actions { display:flex; flex-wrap:wrap; gap:14px; margin-top:26px; }

/* ============================================================
   SERVER CARDS (bold competitive)
   ============================================================ */
.apx-server-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:20px; }
.apx-server { position:relative; background:linear-gradient(165deg,var(--panel-2),var(--panel)); border:1px solid var(--line-2); overflow:hidden; transition:transform .16s,border-color .16s,box-shadow .16s; }
.apx-server::before { content:''; position:absolute; top:0; left:0; right:0; height:3px; background:var(--accent-fire); }
.apx-server.is-offline::before { background:var(--muted-2); } .apx-server.is-stale::before { background:var(--warn); }
.apx-server:hover { transform:translateY(-4px); border-color:var(--accent-fire); box-shadow:0 22px 50px rgba(0,0,0,.55); }
.apx-server-top { display:flex; align-items:center; justify-content:space-between; gap:10px; padding:16px 18px 0; }
.apx-live { display:inline-flex; align-items:center; gap:8px; font-family:var(--f-display); font-size:.82rem; font-weight:600; text-transform:uppercase; letter-spacing:.1em; }
.apx-live .led { width:9px; height:9px; border-radius:50%; background:var(--live); box-shadow:0 0 10px var(--live); animation:apxPulse 2s infinite; }
.apx-live.online { color:var(--live); } .apx-live.offline { color:var(--muted-2); } .apx-live.offline .led { background:var(--muted-2); box-shadow:none; animation:none; } .apx-live.stale { color:var(--warn); } .apx-live.stale .led { background:var(--warn); box-shadow:0 0 10px var(--warn); }
.apx-server-tag { font-family:var(--f-display); font-size:.74rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted-2); }
.apx-server-body { padding:10px 18px 20px; }
.apx-server-name { font-family:var(--f-display); font-size:1.5rem; color:var(--paper); margin-bottom:2px; }
.apx-server-map { font-family:var(--f-display); font-size:.85rem; text-transform:uppercase; letter-spacing:.06em; color:var(--accent-fire-2); margin-bottom:16px; }
.apx-pop { display:flex; align-items:baseline; gap:8px; margin-bottom:4px; }
.apx-pop .num { font-family:var(--f-display); font-size:2.6rem; font-weight:700; color:var(--paper); line-height:1; }
.apx-pop .max { font-family:var(--f-display); font-size:1.1rem; color:var(--text-muted); }
.apx-pop .cap { margin-left:auto; font-family:var(--f-display); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-muted); align-self:flex-end; }
.apx-bar { height:6px; background:rgba(255,255,255,.06); overflow:hidden; margin-bottom:16px; }
.apx-bar > span { display:block; height:100%; background:linear-gradient(90deg,var(--accent-fire-dk),var(--accent-fire)); box-shadow:0 0 12px rgba(236,43,59,.5); }
.apx-server-ip { display:flex; align-items:center; gap:9px; font-family:'JetBrains Mono',monospace; font-size:.82rem; color:var(--paper); background:rgba(0,0,0,.35); border:1px solid var(--line); padding:9px 12px; cursor:pointer; }
.apx-server-ip i { color:var(--accent-fire); } .apx-server-ip:hover { border-color:var(--accent-fire); }
.apx-chiprow { display:flex; flex-wrap:wrap; gap:6px; margin-top:12px; }
.apx-chip { font-family:var(--f-display); font-size:.72rem; text-transform:uppercase; letter-spacing:.05em; color:var(--text-muted); border:1px solid var(--line); padding:4px 10px; } .apx-chip i { color:var(--accent-fire-2); margin-right:5px; }

/* ============================================================
   TRIBE LEADERBOARD (ranked standings)
   ============================================================ */
.apx-board { border:1px solid var(--line); }
.apx-board-row { display:grid; grid-template-columns:64px 1fr auto; align-items:center; gap:18px; padding:16px 20px; background:var(--panel); border-bottom:1px solid var(--line); transition:background .15s; }
.apx-board-row:last-child { border-bottom:0; }
.apx-board-row:hover { background:var(--panel-2); }
.apx-rank { font-family:var(--f-display); font-size:2rem; font-weight:700; color:var(--muted-2); text-align:center; line-height:1; }
.apx-board-row:nth-child(1) .apx-rank { color:var(--accent-fire); }
.apx-board-row:nth-child(2) .apx-rank { color:var(--accent-fire-2); }
.apx-tribe-name { font-family:var(--f-display); font-size:1.25rem; color:var(--paper); }
.apx-tribe-tag { font-family:var(--f-display); font-size:.74rem; text-transform:uppercase; letter-spacing:.08em; color:var(--accent-fire-2); margin-top:2px; }
.apx-board-meta { display:flex; gap:22px; text-align:right; }
.apx-board-meta div { font-family:var(--f-display); }
.apx-board-meta .v { font-size:1.2rem; font-weight:600; color:var(--paper); }
.apx-board-meta .k { font-size:.66rem; text-transform:uppercase; letter-spacing:.1em; color:var(--muted-2); }
@media (max-width:620px){ .apx-board-meta { display:none; } }

/* mods grid */
.apx-mods { display:grid; grid-template-columns:repeat(auto-fill,minmax(210px,1fr)); gap:12px; }
.apx-mod { display:flex; align-items:center; gap:12px; padding:11px 13px; background:var(--panel); border:1px solid var(--line); transition:border-color .15s,transform .15s; }
.apx-mod:hover { border-color:var(--accent-fire); transform:translateY(-2px); }
.apx-mod-logo { width:46px; height:46px; flex-shrink:0; background:rgba(0,0,0,.4); border:1px solid var(--line-2); overflow:hidden; display:inline-flex; align-items:center; justify-content:center; }
.apx-mod-logo img { width:100%; height:100%; object-fit:cover; } .apx-mod-logo i { color:var(--muted-2); }
.apx-mod-name { font-weight:600; font-size:.9rem; color:var(--paper); line-height:1.25; }
.apx-cat { display:flex; align-items:center; gap:14px; margin:34px 0 14px; }
.apx-cat h2 { font-family:var(--f-display); font-size:1.3rem; color:var(--paper); margin:0; } .apx-cat .count { font-family:var(--f-display); color:var(--accent-fire); } .apx-cat .rule { flex:1; height:1px; background:linear-gradient(90deg,var(--accent-fire-dk),transparent); }

/* rates */
.apx-rates { display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:14px; }
.apx-rate { background:var(--panel); border:1px solid var(--line); border-bottom:3px solid var(--accent-fire); padding:22px; text-align:center; }
.apx-rate .x { font-family:var(--f-display); font-size:2.4rem; font-weight:700; color:var(--paper); } .apx-rate .x small { font-size:1.1rem; color:var(--accent-fire); }
.apx-rate .l { font-family:var(--f-display); font-size:.82rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-muted); margin-top:4px; }

/* ============================================================
   SHARED (feature/tribe/rules/forms/join/footer)
   ============================================================ */
.feature-card { background:var(--panel); border:1px solid var(--line); padding:26px; height:100%; }
.feature-card h3 { font-size:1.2rem; margin-bottom:8px; } .feature-card p { color:var(--text-muted); margin:0; font-size:.95rem; }
.feature-icon { width:48px; height:48px; display:inline-flex; align-items:center; justify-content:center; background:rgba(236,43,59,.12); color:var(--accent-fire); font-size:1.2rem; margin-bottom:16px; transform:skewX(-8deg); } .feature-icon i { transform:skewX(8deg); }
.hero-server-card { background:linear-gradient(165deg,var(--panel-2),var(--panel)); border:1px solid var(--line-2); padding:22px; max-width:380px; }
.hero-server-card > .label { font-family:var(--f-display); font-size:.78rem; text-transform:uppercase; letter-spacing:.14em; color:var(--accent-fire); 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-family:var(--f-display); font-size:.78rem; 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:17px 0; border-bottom:1px solid var(--line); }
.rules-list li strong { font-family:var(--f-display); font-size:1.4rem; color:var(--accent-fire); 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(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line-2); border-top:3px solid var(--accent-fire); }
.tribe-card { background:var(--panel); border:1px solid var(--line); padding:24px; height:100%; } .tribe-card:hover { border-color:var(--accent-fire); }
.tribe-tag { font-family:var(--f-display); font-size:.74rem; text-transform:uppercase; letter-spacing:.1em; color:var(--accent-fire); margin-bottom:8px; }
.tribe-name { font-size:1.4rem; margin-bottom:8px; } .tribe-card p { color:var(--text-muted); font-size:.95rem; }
.tribe-meta { display:flex; flex-wrap:wrap; gap:16px; margin-top:14px; }
.tribe-meta span { display:inline-flex; align-items:center; gap:6px; font-family:var(--f-display); font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; 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); border:1px solid var(--line-2); padding:5px 11px; 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 15px; background:rgba(0,0,0,.3); border:1px solid var(--line); }
.ark-join-server-title { display:flex; align-items:center; gap:9px; font-family:var(--f-display); font-weight:600; font-size:1.1rem; color:var(--paper); flex-wrap:wrap; }
.ark-connect-dot { width:9px; height:9px; border-radius:50%; flex-shrink:0; box-shadow:0 0 9px currentColor; }
.ark-connect-badge { font-family:var(--f-display); font-size:.64rem; text-transform:uppercase; color:var(--accent-fire); border:1px solid var(--line-2); padding:2px 8px; }
.ark-join-flag { font-family:var(--f-display); font-size:.7rem; 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-family:var(--f-display); font-size:.74rem; text-transform:uppercase; 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); 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); 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,.4); border:1px solid var(--line-2); color:var(--paper); padding:12px 14px; font-family:var(--f-body); font-size:.98rem; }
.form-control:focus { outline:none; border-color:var(--accent-fire); box-shadow:0 0 0 3px rgba(236,43,59,.16); }
.was-validated .form-control:invalid { border-color:var(--down); }

.site-footer { background:var(--bg-1); border-top:1px solid var(--line-2); padding:60px 0 28px; }
.footer-brand { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-weight:700; font-size:1.45rem; color:var(--paper); text-transform:uppercase; letter-spacing:.04em; }
.site-footer p { color:var(--text-muted); font-size:.92rem; }
.site-footer h5 { font-family:var(--f-display); font-size:.85rem; text-transform:uppercase; letter-spacing:.14em; color:var(--accent-fire); margin-bottom:14px; }
.footer-info { font-size:.9rem; color:var(--text-muted); } .footer-info strong { display:block; color:var(--paper); font-family:var(--f-display); font-size:.72rem; 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); }
.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; transform:skewX(-8deg); } .social-link i { transform:skewX(8deg); } .social-link:hover { border-color:var(--accent-fire); color:var(--accent-fire); }
.footer-bottom { margin-top:40px; padding-top:22px; border-top:1px solid var(--line); font-family:var(--f-display); font-size:.78rem; text-transform:uppercase; letter-spacing:.05em; 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:#fff; cursor:pointer; opacity:0; pointer-events:none; transition:opacity .2s; transform:skewX(-8deg); } .back-to-top i { transform:skewX(8deg); }
.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); --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); }
