/* ============================================================
   FRONTIER — ARK Survival Ascended template
   LOOK & FEEL: warm, welcoming PvE-community cluster. Warm-black
   base, amber/gold accent, friendly rounded cards, Outfit type.
   Events-forward (event calendar), "why play here" highlights,
   live servers, rates, mods, tribe recruitment. Real data only.
   ============================================================ */

:root {
    --bg-0:#100d09; --bg-1:#15110b; --bg-2:#1b150d; --panel:#181308; --panel-2:#1e1810;
    --line:rgba(255,255,255,0.07); --line-2:rgba(224,169,58,0.20);
    --paper:#f6f1e7; --text:#c6bca9; --text-muted:#90856f; --muted-2:#6b614f;
    --accent-fire:#e0a93a; --accent-fire-2:#f5c45e; --accent-fire-dk:#b07e1f; --accent:var(--accent-fire);
    --live:#5fc488; --warn:#e0a93a; --down:#e06a4a;
    --f-display:'Outfit','Inter',sans-serif; --f-body:'Inter',system-ui,sans-serif;
    --maxw:1200px; --r:16px; --r-sm:11px;
}
* { 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.66; -webkit-font-smoothing:antialiased; overflow-x:hidden;
    background-image:radial-gradient(circle at 50% -10%, rgba(224,169,58,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.01em; line-height:1.08; 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:#1a1206; padding:10px 16px; font-weight:700; } .skip-link:focus { left:12px; top:12px; }
@keyframes frPulse { 0%{box-shadow:0 0 0 0 rgba(95,196,136,.5);} 70%{box-shadow:0 0 0 7px rgba(95,196,136,0);} 100%{box-shadow:0 0 0 0 rgba(95,196,136,0);} }

/* nav */
.site-navbar { position:sticky; top:0; z-index:50; background:rgba(16,13,9,.84); backdrop-filter:blur(14px); border-bottom:1px solid var(--line); padding:13px 0; }
.site-navbar.scrolled { background:rgba(12,10,6,.97); }
.site-navbar .container { display:flex; align-items:center; justify-content:space-between; gap:16px; }
.brand-wordmark { display:inline-flex; align-items:center; gap:11px; font-family:var(--f-display); font-weight:700; font-size:1.3rem; color:var(--paper); }
.brand-wordmark:hover { color:var(--paper); }
.brand-mark { width:34px; height:34px; display:inline-flex; align-items:center; justify-content:center; background:var(--accent-fire); color:#1a1206; border-radius:10px; font-size:1rem; box-shadow:0 0 18px rgba(224,169,58,.4); }
.navbar-nav { display:flex; align-items:center; gap:2px; list-style:none; margin:0; padding:0; }
.nav-link { color:var(--text-muted); font-family:var(--f-display); font-weight:500; font-size:.94rem; 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(224,169,58,.12); }
.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:9px; 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 */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:9px; font-family:var(--f-display); font-weight:600; font-size:.95rem; padding:12px 24px; border:1px solid transparent; cursor:pointer; border-radius:999px; transition:all .15s; text-decoration:none; }
.btn-primary { background:var(--accent-fire); color:#1a1206; box-shadow:0 6px 22px rgba(224,169,58,.26); }
.btn-primary:hover { background:var(--accent-fire-2); color:#1a1206; 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; }

/* hero */
.fr-hero { position:relative; padding:80px 0 64px; overflow:hidden;
    background:linear-gradient(180deg, rgba(16,13,9,.55), rgba(16,13,9,.84) 60%, var(--bg-0)), var(--ark-hero-image,none); background-size:cover; background-position:center; }
.fr-statline { display:inline-flex; align-items:center; gap:10px; font-family:var(--f-display); font-size:.95rem; color:var(--text-muted); margin-bottom:16px; padding:6px 14px; border:1px solid var(--line-2); border-radius:999px; background:rgba(0,0,0,.3); }
.fr-statline .dot { width:8px; height:8px; border-radius:50%; background:var(--live); box-shadow:0 0 10px var(--live); animation:frPulse 2s infinite; }
.fr-statline b { color:var(--paper); }
.fr-hero h1 { font-size:clamp(2.6rem,6.5vw,4.8rem); color:var(--paper); line-height:1.0; margin-bottom:18px; letter-spacing:-0.02em; }
.fr-hero h1 .torch { color:var(--accent-fire); }
.fr-hero-sub { font-size:1.22rem; color:var(--text); max-width:600px; margin-bottom:26px; }
.fr-hero-actions { display:flex; flex-wrap:wrap; gap:13px; }
.torch { color:var(--accent-fire); }

/* sections */
.section { padding:64px 0; }
.section-elev { background:var(--bg-1); 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:.76rem; 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.01em; }
.section-lead { color:var(--text-muted); font-size:1.05rem; max-width:660px; }
.fr-head { display:flex; flex-wrap:wrap; align-items:flex-end; justify-content:space-between; gap:16px; margin-bottom:28px; }

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

/* stat tiles */
.fr-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; }
@media (max-width:680px){ .fr-stats { grid-template-columns:repeat(2,1fr); } }
.fr-stat { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:22px; text-align:center; }
.fr-stat .n { font-family:var(--f-display); font-size:2.4rem; font-weight:700; color:var(--accent-fire-2); line-height:1; }
.fr-stat .l { font-family:var(--f-display); font-size:.78rem; text-transform:uppercase; letter-spacing:.08em; color:var(--text-muted); margin-top:9px; }

/* server cards (warm, friendly) */
.fr-server-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(310px,1fr)); gap:18px; }
.fr-server { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:22px; transition:transform .16s,border-color .16s; }
.fr-server:hover { transform:translateY(-3px); border-color:var(--line-2); }
.fr-server-top { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:14px; }
.fr-badge { display:inline-flex; align-items:center; gap:8px; font-family:var(--f-display); font-size:.78rem; font-weight:600; padding:5px 12px; border-radius:999px; }
.fr-badge.online { color:var(--live); background:rgba(95,196,136,.12); } .fr-badge.online .d { width:8px; height:8px; border-radius:50%; background:var(--live); box-shadow:0 0 8px var(--live); }
.fr-badge.offline { color:var(--muted-2); background:rgba(255,255,255,.05); } .fr-badge.offline .d { width:8px; height:8px; border-radius:50%; background:var(--muted-2); }
.fr-badge.stale { color:var(--warn); background:rgba(224,169,58,.12); } .fr-badge.stale .d { width:8px; height:8px; border-radius:50%; background:var(--warn); }
.fr-server-tag { font-family:var(--f-display); font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; color:var(--muted-2); }
.fr-server-name { font-family:var(--f-display); font-size:1.4rem; color:var(--paper); margin-bottom:3px; }
.fr-server-map { color:var(--accent-fire-2); font-size:.92rem; margin-bottom:16px; }
.fr-server-pop { display:flex; align-items:baseline; gap:8px; margin-bottom:8px; } .fr-server-pop .num { font-family:var(--f-display); font-size:1.9rem; font-weight:700; color:var(--paper); line-height:1; } .fr-server-pop .max { color:var(--text-muted); } .fr-server-pop .cap { margin-left:auto; font-size:.78rem; color:var(--text-muted); align-self:center; }
.fr-bar { height:8px; background:rgba(255,255,255,.06); border-radius:6px; overflow:hidden; margin-bottom:16px; } .fr-bar > span { display:block; height:100%; background:linear-gradient(90deg,var(--accent-fire-dk),var(--accent-fire-2)); border-radius:6px; }
.fr-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,.3); border:1px solid var(--line); border-radius:var(--r-sm); padding:10px 13px; cursor:pointer; } .fr-server-ip i { color:var(--accent-fire-2); } .fr-server-ip:hover { border-color:var(--line-2); }

/* EVENTS calendar (signature section) */
.fr-events { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:16px; }
.fr-event { display:flex; gap:16px; background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:20px; }
.fr-event-date { flex-shrink:0; width:62px; text-align:center; background:rgba(224,169,58,.1); border:1px solid var(--line-2); border-radius:var(--r-sm); padding:10px 6px; }
.fr-event-date .d { font-family:var(--f-display); font-size:1.7rem; font-weight:700; color:var(--accent-fire-2); line-height:1; }
.fr-event-date .m { font-family:var(--f-display); font-size:.68rem; text-transform:uppercase; letter-spacing:.1em; color:var(--text-muted); margin-top:4px; }
.fr-event-body h3 { font-size:1.15rem; margin:0 0 5px; color:var(--paper); }
.fr-event-body p { margin:0; color:var(--text-muted); font-size:.92rem; }

/* why-join features */
.fr-feats { display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:16px; }
.fr-feat { background:linear-gradient(160deg,var(--panel-2),var(--panel)); border:1px solid var(--line); border-radius:var(--r); padding:26px; }
.fr-feat .ic { width:48px; height:48px; display:inline-flex; align-items:center; justify-content:center; background:rgba(224,169,58,.12); color:var(--accent-fire-2); font-size:1.3rem; border-radius:14px; margin-bottom:16px; }
.fr-feat h3 { font-size:1.15rem; margin-bottom:7px; } .fr-feat p { margin:0; color:var(--text-muted); font-size:.94rem; }

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

/* cta */
.fr-cta { background:linear-gradient(120deg, rgba(224,169,58,.16), rgba(224,169,58,.03)); border:1px solid var(--line-2); border-radius:20px; padding:46px; text-align:center; }
.fr-cta h2 { font-size:clamp(1.7rem,3.2vw,2.5rem); color:var(--paper); margin:0 0 8px; } .fr-cta p { color:var(--text-muted); margin:0 0 22px; } .fr-cta .acts { display:flex; flex-wrap:wrap; gap:12px; justify-content:center; }

/* 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:48px; height:48px; display:inline-flex; align-items:center; justify-content:center; background:rgba(224,169,58,.12); color:var(--accent-fire-2); font-size:1.25rem; margin-bottom:16px; border-radius:14px; }
.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(224,169,58,.14), rgba(224,169,58,.02)); border:1px solid var(--line-2); border-radius:20px; }
.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:.74rem; 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:.84rem; 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,.3); 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(224,169,58,.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.3rem; 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:11px; } .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:#1a1206; cursor:pointer; opacity:0; pointer-events:none; transition:opacity .2s; border-radius:13px; }
.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 */
.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(224,169,58,.14); }
