/* ================================================================
   Ironhorde Online - Landing Page
   Cinematic MMORPG Fantasy Theme
   (shared_base.css provides reset, variables, body, scrollbar, ember canvas)
   ================================================================ */

/* ---- Page-specific overrides ---- */
html{scroll-padding-top:80px}
:root{--nav-h:70px}

.container{max-width:1200px;margin:0 auto;padding:0 24px}
.text-gold{color:var(--gold)}

/* ================================================================
   NAVBAR
   ================================================================ */
.navbar{
    position:fixed;top:0;left:0;right:0;z-index:1000;
    height:var(--nav-h);
    background:rgba(6,7,11,0.7);
    backdrop-filter:blur(16px);
    -webkit-backdrop-filter:blur(16px);
    transition:background .4s,box-shadow .4s;
}
.navbar.scrolled{
    background:rgba(6,7,11,0.95);
    box-shadow:0 2px 40px rgba(0,0,0,0.6);
}
.nav-border-glow{
    position:absolute;bottom:0;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,var(--gold),transparent);
    opacity:0.25;
}
.nav-inner{
    max-width:1200px;margin:0 auto;padding:0 24px;
    height:100%;display:flex;align-items:center;justify-content:space-between;
}

/* Logo */
.nav-logo{display:flex;align-items:center;gap:10px}
.logo-emblem{
    width:40px;height:40px;display:flex;align-items:center;justify-content:center;
    border:1px solid rgba(201,164,74,0.2);border-radius:50%;
    background:radial-gradient(circle,rgba(201,164,74,0.06) 0%,transparent 70%);
}
.logo-text-wrap{display:flex;flex-direction:column;line-height:1}
.logo-main{
    font-family:var(--font-d);font-size:15px;font-weight:700;
    letter-spacing:3px;color:var(--white);
}
.logo-accent{color:var(--gold)}
.logo-sub{font-size:8px;letter-spacing:4px;color:var(--gray);margin-top:1px}

/* Nav links */
.nav-links{display:flex;gap:6px}
.nav-link{
    font-size:11px;font-weight:600;letter-spacing:2px;
    padding:8px 14px;border-radius:4px;
    color:var(--gray);transition:color .25s,background .25s;
    position:relative;
}
.nav-link:hover,.nav-link.active{color:var(--gold)}
.nav-link.active::after{
    content:'';position:absolute;bottom:2px;left:50%;transform:translateX(-50%);
    width:16px;height:2px;background:var(--gold);border-radius:2px;
}

/* Nav right */
.nav-right{display:flex;align-items:center;gap:16px}

/* Server pill */
.server-pill{
    display:flex;align-items:center;gap:8px;
    padding:6px 14px;border-radius:20px;
    background:rgba(68,204,102,0.06);
    border:1px solid rgba(68,204,102,0.15);
}
.pulse-dot{
    width:8px;height:8px;border-radius:50%;background:var(--green);
    box-shadow:0 0 8px var(--green);
    animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.85)}}
.pill-text{display:flex;flex-direction:column;line-height:1}
.pill-label{font-size:8px;letter-spacing:1.5px;color:rgba(68,204,102,0.7);font-weight:600}
.pill-count{font-size:11px;font-weight:600;color:var(--green)}

/* CTA button */
.nav-cta{
    display:flex;align-items:center;gap:6px;
    padding:8px 18px;border-radius:6px;
    background:linear-gradient(135deg,var(--gold-d),var(--gold));
    color:#0a0a0a;font-size:11px;font-weight:700;letter-spacing:1.5px;
    transition:transform .2s,box-shadow .2s;
}
.nav-cta:hover{
    transform:translateY(-1px);
    box-shadow:0 6px 24px rgba(201,164,74,0.3);
}

/* Hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:6px}
.hamburger span{display:block;width:22px;height:2px;background:var(--white);border-radius:2px;transition:.3s}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ================================================================
   HERO
   ================================================================ */
.hero{
    position:relative;
    min-height:100vh;
    display:flex;align-items:center;justify-content:center;
    overflow:hidden;
    width:100%;max-width:100vw;
    background:
        radial-gradient(ellipse 80% 50% at 50% 30%, rgba(201,164,74,0.04) 0%, transparent 60%),
        radial-gradient(ellipse 60% 60% at 20% 80%, rgba(255,106,0,0.03) 0%, transparent 50%),
        radial-gradient(ellipse 60% 60% at 80% 80%, rgba(139,0,0,0.03) 0%, transparent 50%),
        var(--bg);
}

/* Background layers */
.hero-darkness{
    position:absolute;inset:0;
    background:linear-gradient(to bottom,rgba(6,7,11,0.3) 0%,rgba(6,7,11,0) 30%,
               rgba(6,7,11,0) 60%,rgba(6,7,11,0.9) 100%);
    z-index:2;
}
.hero-vignette{
    position:absolute;inset:0;
    background:radial-gradient(ellipse 50% 50% at 50% 50%,transparent 0%,rgba(6,7,11,0.7) 100%);
    z-index:2;
}
.hero-fog{
    position:absolute;bottom:0;left:0;width:100%;height:40%;
    background:linear-gradient(to top,rgba(201,164,74,0.02),transparent);
    opacity:0.6;z-index:2;
}
.hero-fog-1{animation:fogDrift 20s ease-in-out infinite}
.hero-fog-2{animation:fogDrift 25s ease-in-out infinite reverse;opacity:0.3}
@keyframes fogDrift{0%,100%{transform:translateX(0)}50%{transform:translateX(3%)}}

.hero-radial{position:absolute;border-radius:50%;z-index:1;pointer-events:none}
.hero-radial-1{
    width:600px;height:600px;top:-10%;left:-5%;
    background:radial-gradient(circle,rgba(201,164,74,0.03) 0%,transparent 70%);
    animation:floatSlow 15s ease-in-out infinite;
}
.hero-radial-2{
    width:400px;height:400px;bottom:10%;right:-5%;
    background:radial-gradient(circle,rgba(255,106,0,0.025) 0%,transparent 70%);
    animation:floatSlow 18s ease-in-out infinite reverse;
}
.hero-radial-3{
    width:300px;height:300px;top:40%;left:50%;transform:translateX(-50%);
    background:radial-gradient(circle,rgba(201,164,74,0.05) 0%,transparent 60%);
}
@keyframes floatSlow{0%,100%{transform:translate(0,0)}50%{transform:translate(20px,-20px)}}

/* Ornamental corners */
.hero-corner{position:absolute;width:80px;height:80px;z-index:5}
.hero-corner::before,.hero-corner::after{
    content:'';position:absolute;background:var(--gold);opacity:0.15;
}
.hero-corner-tl{top:30px;left:30px}
.hero-corner-tl::before{top:0;left:0;width:40px;height:1px}
.hero-corner-tl::after{top:0;left:0;width:1px;height:40px}
.hero-corner-tr{top:30px;right:30px}
.hero-corner-tr::before{top:0;right:0;width:40px;height:1px}
.hero-corner-tr::after{top:0;right:0;width:1px;height:40px}
.hero-corner-bl{bottom:30px;left:30px}
.hero-corner-bl::before{bottom:0;left:0;width:40px;height:1px}
.hero-corner-bl::after{bottom:0;left:0;width:1px;height:40px}
.hero-corner-br{bottom:30px;right:30px}
.hero-corner-br::before{bottom:0;right:0;width:40px;height:1px}
.hero-corner-br::after{bottom:0;right:0;width:1px;height:40px}

/* Hero content */
.hero-content{
    position:relative;z-index:10;text-align:center;
    padding:var(--nav-h) 24px 60px;
}

.hero-emblem{
    margin:0 auto 16px;
    position:relative;
    display:block;
    width:fit-content;
    animation:emblemFloat 4s ease-in-out infinite;
}

.emblem-img{
    display:block;
    width:clamp(150px,21vw,270px);
    height:auto;
    filter:drop-shadow(0 0 30px rgba(201,164,74,0.25)) drop-shadow(0 0 60px rgba(255,106,0,0.12));
    animation:emblemPulse 3s ease-in-out infinite;
}

/* Floating animation */
@keyframes emblemFloat{
    0%,100%{transform:translateY(0)}
    50%{transform:translateY(-10px)}
}

/* Subtle brightness pulse */
@keyframes emblemPulse{
    0%,100%{filter:drop-shadow(0 0 30px rgba(201,164,74,0.25)) drop-shadow(0 0 60px rgba(255,106,0,0.12)) brightness(1)}
    50%{filter:drop-shadow(0 0 40px rgba(201,164,74,0.4)) drop-shadow(0 0 80px rgba(255,106,0,0.2)) brightness(1.08)}
}

/* Fire eyes — positioned on the warrior helmet eyes */
.emblem-eye{
    position:absolute;
    width:3.5%;height:2.5%;
    border-radius:50%;
    background:radial-gradient(ellipse,#fff 0%,#ffcc00 25%,#ff6a00 55%,transparent 70%);
    box-shadow:
        0 0 8px 3px rgba(255,106,0,0.8),
        0 0 20px 6px rgba(255,106,0,0.4),
        0 0 40px 10px rgba(255,68,0,0.2);
    animation:eyeFlicker 2.5s ease-in-out infinite;
    pointer-events:none;
    z-index:2;
}

.emblem-eye-l{top:31.8%;left:44.6%}
.emblem-eye-r{top:31.0%;left:52.4%}

/* Eye intensity variation */
@keyframes eyeFlicker{
    0%,100%{
        box-shadow:0 0 8px 3px rgba(255,106,0,0.8),0 0 20px 6px rgba(255,106,0,0.4),0 0 40px 10px rgba(255,68,0,0.2);
    }
    30%{
        box-shadow:0 0 12px 5px rgba(255,140,0,0.9),0 0 28px 10px rgba(255,106,0,0.5),0 0 50px 14px rgba(255,68,0,0.3);
    }
    60%{
        box-shadow:0 0 6px 2px rgba(255,80,0,0.7),0 0 16px 5px rgba(255,106,0,0.3),0 0 30px 8px rgba(255,68,0,0.15);
    }
}

/* Ambient glow behind entire emblem */
.emblem-glow{
    position:absolute;
    top:25%;left:50%;
    width:60%;height:30%;
    transform:translate(-50%,-50%);
    background:radial-gradient(ellipse,rgba(255,106,0,0.15) 0%,rgba(255,152,0,0.08) 40%,transparent 70%);
    pointer-events:none;
    animation:glowPulse 3s ease-in-out infinite;
    z-index:1;
}

@keyframes glowPulse{
    0%,100%{opacity:0.6;transform:translate(-50%,-50%) scale(1)}
    50%{opacity:1;transform:translate(-50%,-50%) scale(1.15)}
}

@keyframes spinSlow{from{transform:rotate(0)}to{transform:rotate(360deg)}}

/* Badge */
.hero-badge{
    display:inline-flex;align-items:center;gap:8px;
    padding:6px 18px;border-radius:20px;
    background:linear-gradient(135deg,rgba(255,106,0,0.1),rgba(255,152,0,0.05));
    border:1px solid rgba(255,106,0,0.25);
    font-size:11px;font-weight:700;letter-spacing:2px;
    color:var(--fire2);margin-bottom:28px;
}
.badge-fire{
    display:block;width:6px;height:6px;border-radius:50%;
    background:var(--fire1);box-shadow:0 0 10px var(--fire1);
    animation:pulse 1.5s ease-in-out infinite;
}

/* Title */
.hero-title{margin-bottom:20px}
.title-top{
    display:block;font-family:var(--font-h);
    font-size:clamp(13px,1.5vw,16px);font-weight:400;
    letter-spacing:8px;color:var(--gray);margin-bottom:8px;
}
.title-main{
    display:block;font-family:var(--font-d);
    font-size:clamp(48px,8vw,110px);font-weight:900;
    line-height:0.95;letter-spacing:4px;
    background:linear-gradient(180deg,
        #f5ecd5 0%,
        #c9a44a 40%,
        #9a7420 70%,
        #7a5a15 100%);
    -webkit-background-clip:text;-webkit-text-fill-color:transparent;
    background-clip:text;
    filter:drop-shadow(0 4px 12px rgba(201,164,74,0.2));
}

/* Divider */
.hero-divider{
    display:flex;align-items:center;justify-content:center;gap:12px;
    margin-bottom:24px;
}
.div-line{width:60px;height:1px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0.3}
.div-diamond{
    width:8px;height:8px;background:var(--gold);opacity:0.5;
    transform:rotate(45deg);
}

/* Description */
.hero-desc{
    font-size:16px;line-height:1.7;color:var(--gray);
    max-width:520px;margin:0 auto 36px;
}
.hero-desc strong{color:var(--gold);font-weight:600}

/* Buttons */
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-bottom:48px}

.btn-fire{
    position:relative;display:inline-flex;align-items:center;
    padding:14px 32px;border-radius:8px;overflow:hidden;
    font-size:13px;font-weight:700;letter-spacing:2px;color:#fff;
    cursor:pointer;transition:transform .2s,box-shadow .2s;
}
.btn-fire-bg{
    position:absolute;inset:0;
    background:linear-gradient(135deg,#b8860b,#c9a44a,#daa520);
    transition:opacity .3s;
}
.btn-fire::before{
    content:'';position:absolute;inset:0;
    background:linear-gradient(135deg,var(--fire1),var(--fire2),#c9a44a);
    opacity:0;transition:opacity .4s;
}
.btn-fire:hover::before{opacity:1}
.btn-fire:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 32px rgba(201,164,74,0.4),0 0 60px rgba(255,106,0,0.15);
}
.btn-fire-content{position:relative;z-index:1;display:flex;align-items:center;gap:8px}
.btn-fire-lg{padding:16px 40px;font-size:14px}

/* Ripple effect for button clicks */
@keyframes rippleOut{to{transform:scale(1);opacity:0}}

.btn-outline{
    display:inline-flex;align-items:center;
    padding:14px 32px;border-radius:8px;
    border:1px solid rgba(201,164,74,0.3);
    font-size:13px;font-weight:600;letter-spacing:2px;color:var(--gold);
    transition:border-color .25s,background .25s,transform .2s;
}
.btn-outline:hover{
    border-color:var(--gold);
    background:rgba(201,164,74,0.06);
    transform:translateY(-2px);
}

/* Hero counters */
.hero-counters{display:flex;align-items:center;justify-content:center;gap:32px}
.hc-item{display:flex;flex-direction:column;align-items:center}
.hc-num{
    font-family:var(--font-h);font-size:28px;font-weight:700;
    color:var(--gold);line-height:1;margin-bottom:4px;
}
.hc-zero{color:var(--green)}
.hc-label{font-size:10px;letter-spacing:2px;color:var(--gray)}
.hc-sep{width:1px;height:36px;background:rgba(201,164,74,0.15)}

/* Scroll indicator */
.hero-scroll{
    position:absolute;bottom:30px;left:50%;transform:translateX(-50%);
    z-index:10;
}
.scroll-arrow{
    width:24px;height:24px;border-right:2px solid var(--gold);border-bottom:2px solid var(--gold);
    transform:rotate(45deg);opacity:0.3;
    animation:scrollBounce 2s ease-in-out infinite;
}
@keyframes scrollBounce{0%,100%{transform:rotate(45deg) translateY(0);opacity:0.3}50%{transform:rotate(45deg) translateY(8px);opacity:0.6}}

/* ================================================================
   ORNAMENT DIVIDER
   ================================================================ */
.ornament-divider{
    padding:20px 0;text-align:center;
    background:var(--bg);
}
.orn-svg{width:100%;max-width:600px;height:30px}

/* ================================================================
   SECTION COMMON
   ================================================================ */
.section{
    position:relative;
    padding:100px 0;
}
.sec-bg-pattern{
    position:absolute;inset:0;
    background-image:
        radial-gradient(circle at 20% 30%,rgba(201,164,74,0.02) 0%,transparent 50%),
        radial-gradient(circle at 80% 70%,rgba(201,164,74,0.015) 0%,transparent 50%);
    pointer-events:none;
}

.sec-head{text-align:center;margin-bottom:60px}
.sec-label{
    display:inline-block;font-size:11px;font-weight:700;letter-spacing:4px;
    color:var(--gold);margin-bottom:12px;
    padding:4px 16px;border-radius:4px;
    background:rgba(201,164,74,0.06);
    border:1px solid rgba(201,164,74,0.1);
}
.sec-title{
    font-family:var(--font-d);
    font-size:clamp(28px,4vw,44px);font-weight:700;
    letter-spacing:2px;line-height:1.2;margin-bottom:12px;
}
.sec-sub{font-size:15px;color:var(--gray);max-width:500px;margin:0 auto}

/* ================================================================
   FEATURES
   ================================================================ */
.feat-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:24px;
}
.feat-card{
    position:relative;padding:36px 28px;
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:12px;
    overflow:hidden;
    transition:border-color .4s,transform .3s,box-shadow .3s;
}
.feat-card:hover{
    border-color:var(--border-h);
    transform:translateY(-4px);
    box-shadow:0 12px 40px rgba(0,0,0,0.4),0 0 60px rgba(201,164,74,0.05);
}

.feat-icon-ring{
    width:64px;height:64px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    background:radial-gradient(circle,rgba(201,164,74,0.08) 0%,transparent 70%);
    border:1px solid rgba(201,164,74,0.15);
    margin-bottom:20px;
    transition:border-color .3s,box-shadow .3s;
}
.feat-card:hover .feat-icon-ring{
    border-color:rgba(201,164,74,0.4);
    box-shadow:0 0 20px rgba(201,164,74,0.1);
}

.feat-card h3{
    font-family:var(--font-h);font-size:15px;font-weight:700;
    letter-spacing:2px;margin-bottom:10px;color:var(--white);
}
.feat-card p{font-size:13px;line-height:1.7;color:var(--gray)}

.feat-shine{
    position:absolute;top:0;left:-100%;
    width:100%;height:100%;
    background:linear-gradient(120deg,transparent 30%,rgba(201,164,74,0.04) 50%,transparent 70%);
    transition:left .6s ease;
    pointer-events:none;
}
.feat-card:hover .feat-shine{left:100%}

/* ================================================================
   NEWS
   ================================================================ */
.news-row{
    display:grid;
    grid-template-columns:1.3fr 1fr;
    gap:24px;
    align-items:stretch;
}
.news-stack{display:flex;flex-direction:column;gap:24px}

.ncard{
    background:var(--bg-card);border:1px solid var(--border);
    border-radius:12px;overflow:hidden;
    display:flex;flex-direction:column;
    transition:border-color .3s,transform .3s,box-shadow .3s;
}
.ncard:hover{
    border-color:var(--border-h);
    transform:translateY(-3px);
    box-shadow:0 8px 30px rgba(0,0,0,0.3);
}
.ncard-big{display:flex;flex-direction:column}

/* Visual area */
.ncard-visual{position:relative;width:100%;height:220px;overflow:hidden}
.ncard-visual-sm{height:120px}
.ncard-bg{
    width:100%;height:100%;
    background-size:cover;background-position:center;
    transition:transform .6s;
}
.ncard:hover .ncard-bg{transform:scale(1.05)}
.ncard-overlay{
    position:absolute;inset:0;
    background:linear-gradient(to top,rgba(6,7,11,0.9) 0%,rgba(6,7,11,0.2) 100%);
}
.ncard-bg-1{background:linear-gradient(135deg,rgba(201,164,74,0.15),rgba(139,0,0,0.15),rgba(6,7,11,0.9))}
.ncard-bg-2{background:linear-gradient(135deg,rgba(68,136,255,0.1),rgba(6,7,11,0.8))}
.ncard-bg-3{background:linear-gradient(135deg,rgba(255,106,0,0.1),rgba(6,7,11,0.8))}

.ncard-pin{
    position:absolute;top:12px;left:12px;
    padding:4px 12px;border-radius:4px;
    background:linear-gradient(135deg,var(--fire1),var(--fire2));
    font-size:10px;font-weight:700;letter-spacing:1px;color:#fff;
    z-index:1;
}

.ncard-body{padding:24px}
.ncard-meta{display:flex;align-items:center;gap:12px;margin-bottom:10px;font-size:11px}
.ncard-meta time{color:var(--gray);letter-spacing:1px}
.ncard-cat{
    padding:2px 8px;border-radius:3px;
    background:rgba(201,164,74,0.08);
    border:1px solid rgba(201,164,74,0.12);
    color:var(--gold);font-weight:600;letter-spacing:1px;
}
.ncard h3{
    font-family:var(--font-h);font-size:17px;font-weight:700;
    margin-bottom:8px;line-height:1.3;
}
.ncard p{font-size:13px;line-height:1.6;color:var(--gray);margin-bottom:12px}
.ncard-link{
    font-size:12px;font-weight:600;letter-spacing:1.5px;
    color:var(--gold);display:inline-flex;align-items:center;gap:6px;
    transition:gap .25s;
}
.ncard-link:hover{gap:10px}
.ncard-link .arrow{transition:transform .25s}
.ncard-link:hover .arrow{transform:translateX(3px)}

/* Big card special sizing */
.ncard-big .ncard-visual{height:260px}
.ncard-big .ncard-body{flex:1}
.ncard-big h3{font-size:20px}

/* ================================================================
   RANKINGS
   ================================================================ */
.rank-panel{
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:12px;
    overflow:hidden;
}

/* Tabs */
.rank-tabs{
    display:flex;border-bottom:1px solid var(--border);
    background:rgba(255,255,255,0.01);
}
.rank-tab{
    flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
    padding:14px;font-size:12px;font-weight:600;letter-spacing:2px;
    color:var(--gray);
    border-bottom:2px solid transparent;
    transition:color .25s,border-color .25s,background .25s;
}
.rank-tab:hover{color:var(--white);background:rgba(201,164,74,0.03)}
.rank-tab.active{color:var(--gold);border-bottom-color:var(--gold);background:rgba(201,164,74,0.04)}

/* Podium */
.podium{
    display:flex;justify-content:center;align-items:flex-end;
    gap:40px;padding:48px 24px 32px;
    background:
        radial-gradient(ellipse 50% 60% at 50% 80%,rgba(201,164,74,0.04) 0%,transparent 80%);
}
.podium-slot{
    display:flex;flex-direction:column;align-items:center;
    text-align:center;
}
.podium-1{order:2;margin-bottom:20px}
.podium-2{order:1}
.podium-3{order:3}

.crown-icon{font-size:28px;margin-bottom:8px;filter:drop-shadow(0 0 8px rgba(201,164,74,0.5));animation:crownFloat 3s ease-in-out infinite}
@keyframes crownFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}

.podium-avatar{
    width:72px;height:72px;border-radius:50%;
    display:flex;align-items:center;justify-content:center;
    font-family:var(--font-h);font-size:22px;font-weight:900;
    margin-bottom:10px;
    transition:transform .3s,box-shadow .3s;
}
.podium-slot:hover .podium-avatar{transform:scale(1.08)}
.podium-avatar.gold{
    background:linear-gradient(135deg,rgba(201,164,74,0.2),rgba(201,164,74,0.05));
    border:2px solid var(--gold);
    color:var(--gold);
    box-shadow:0 0 30px rgba(201,164,74,0.2);
}
.podium-avatar.silver{
    background:linear-gradient(135deg,rgba(180,180,200,0.15),rgba(180,180,200,0.05));
    border:2px solid rgba(180,180,200,0.5);
    color:rgba(180,180,200,0.8);
    box-shadow:0 0 20px rgba(180,180,200,0.1);
}
.podium-avatar.bronze{
    background:linear-gradient(135deg,rgba(205,127,50,0.15),rgba(205,127,50,0.05));
    border:2px solid rgba(205,127,50,0.5);
    color:rgba(205,127,50,0.8);
    box-shadow:0 0 20px rgba(205,127,50,0.1);
}
.podium-name{font-family:var(--font-h);font-size:14px;font-weight:700;margin-bottom:3px}
.podium-nation{font-size:11px;letter-spacing:1px;margin-bottom:4px}
.podium-np{font-size:12px;color:var(--gold);font-weight:600}
.karus-text{color:var(--karus)}
.elmorad-text{color:var(--elmorad)}

/* Rank list */
.rank-list{padding:0 24px 24px}
.rank-row{
    display:grid;
    grid-template-columns:40px 1fr auto auto 100px;
    align-items:center;gap:12px;
    padding:12px 16px;
    border-radius:8px;
    transition:background .25s;
}
.rank-row:hover{background:rgba(201,164,74,0.03)}
.rank-row:not(:last-child){border-bottom:1px solid rgba(255,255,255,0.03)}

.r-pos{
    font-family:var(--font-h);font-size:14px;font-weight:700;
    color:var(--gray);text-align:center;
}
.r-name{font-weight:600;font-size:14px}
.r-badge{
    padding:2px 10px;border-radius:4px;
    font-size:10px;font-weight:700;letter-spacing:1px;
}
.karus-badge{background:rgba(255,102,102,0.1);border:1px solid rgba(255,102,102,0.2);color:var(--karus)}
.elmorad-badge{background:rgba(102,170,255,0.1);border:1px solid rgba(102,170,255,0.2);color:var(--elmorad)}
.r-class{font-size:12px;color:var(--gray)}
.r-np{text-align:right;font-size:13px;color:var(--gold);font-weight:600}

/* ================================================================
   EVENTS
   ================================================================ */
.events-grid{
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:20px;
}
.ev-card{
    position:relative;
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:10px;
    padding:22px;
    overflow:hidden;
    transition:border-color .3s,transform .3s;
}
.ev-card:hover{
    border-color:var(--border-h);
    transform:translateY(-2px);
}
.ev-glow{
    position:absolute;top:-30px;right:-30px;
    width:100px;height:100px;border-radius:50%;
    pointer-events:none;
}
.ev-glow-live{
    background:radial-gradient(circle,rgba(68,204,102,0.12) 0%,transparent 70%);
    animation:pulse 2s ease-in-out infinite;
}

.ev-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.ev-time{font-family:var(--font-h);font-size:18px;font-weight:700;color:var(--white)}
.ev-status{font-size:10px;font-weight:700;letter-spacing:1.5px;padding:3px 10px;border-radius:4px}
.ev-live{
    background:rgba(68,204,102,0.12);border:1px solid rgba(68,204,102,0.3);
    color:var(--green);
    animation:liveGlow 2s ease-in-out infinite;
}
@keyframes liveGlow{0%,100%{box-shadow:0 0 8px rgba(68,204,102,0.2)}50%{box-shadow:0 0 16px rgba(68,204,102,0.4)}}
.ev-soon{background:rgba(255,152,0,0.1);border:1px solid rgba(255,152,0,0.2);color:var(--fire2)}
.ev-upcoming{background:rgba(201,164,74,0.06);border:1px solid rgba(201,164,74,0.12);color:var(--gold)}
.ev-ended{background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.05);color:var(--gray)}

.ev-name{font-family:var(--font-h);font-size:15px;font-weight:700;margin-bottom:4px}
.ev-desc{font-size:12px;color:var(--gray);margin-bottom:14px}

.ev-bar{
    width:100%;height:4px;background:rgba(255,255,255,0.06);
    border-radius:4px;overflow:hidden;
}
.ev-bar-fill{
    height:100%;border-radius:4px;
    background:linear-gradient(90deg,var(--gold),var(--fire2));
    transition:width 1s ease;
}
.ev-bar-done{background:var(--gray);opacity:0.4}

.ev-card-ended{opacity:0.5}

/* ================================================================
   DOWNLOAD
   ================================================================ */
.sec-download{
    background:
        radial-gradient(ellipse 60% 50% at 50% 100%, rgba(201,164,74,0.04) 0%, transparent 60%),
        var(--bg);
}
.dl-bg-glow{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:800px;height:400px;border-radius:50%;
    background:radial-gradient(ellipse,rgba(201,164,74,0.02),transparent 60%);
    pointer-events:none;
}

.dl-layout{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:center;
}
.dl-info .sec-label{margin-bottom:12px}
.dl-info .sec-title{text-align:left;margin-bottom:16px}
.dl-desc{font-size:15px;line-height:1.7;color:var(--gray);margin-bottom:32px}

.dl-specs h4{
    font-family:var(--font-h);font-size:13px;letter-spacing:2px;
    color:var(--gold);margin-bottom:16px;
}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.spec{display:flex;gap:10px;font-size:13px}
.spec-key{
    font-weight:700;color:var(--gold);letter-spacing:1px;
    min-width:40px;
}
.spec-val{color:var(--gray)}

/* Download box */
.dl-box{
    position:relative;
    text-align:center;
    padding:48px 36px;
    background:var(--bg-card);
    border:1px solid var(--border);
    border-radius:16px;
}
.dl-box-glow{
    position:absolute;top:-1px;left:50%;transform:translateX(-50%);
    width:60%;height:2px;
    background:linear-gradient(90deg,transparent,var(--gold),transparent);
    opacity:0.4;border-radius:2px;
}

/* Ornamental frame corners */
.dl-box-frame{position:absolute;inset:12px;pointer-events:none}
.dl-box-corner{position:absolute;width:20px;height:20px}
.dl-box-corner::before,.dl-box-corner::after{
    content:'';position:absolute;background:var(--gold);opacity:0.15;
}
.dl-box-corner-tl{top:0;left:0}
.dl-box-corner-tl::before{top:0;left:0;width:20px;height:1px}
.dl-box-corner-tl::after{top:0;left:0;width:1px;height:20px}
.dl-box-corner-tr{top:0;right:0}
.dl-box-corner-tr::before{top:0;right:0;width:20px;height:1px}
.dl-box-corner-tr::after{top:0;right:0;width:1px;height:20px}
.dl-box-corner-bl{bottom:0;left:0}
.dl-box-corner-bl::before{bottom:0;left:0;width:20px;height:1px}
.dl-box-corner-bl::after{bottom:0;left:0;width:1px;height:20px}
.dl-box-corner-br{bottom:0;right:0}
.dl-box-corner-br::before{bottom:0;right:0;width:20px;height:1px}
.dl-box-corner-br::after{bottom:0;right:0;width:1px;height:20px}

.dl-icon{margin-bottom:20px}
.dl-name{
    font-family:var(--font-h);font-size:20px;font-weight:700;
    letter-spacing:2px;margin-bottom:6px;
}
.dl-ver{font-size:12px;color:var(--gray);margin-bottom:4px}
.dl-size{font-size:12px;color:var(--gray);margin-bottom:28px}
.dl-box .btn-fire{margin-bottom:20px}

.dl-mirrors{font-size:12px;color:var(--gray)}
.dl-mirrors a{
    color:var(--gold);margin-left:8px;
    border-bottom:1px solid transparent;
    transition:border-color .25s;
}
.dl-mirrors a:hover{border-bottom-color:var(--gold)}

/* ================================================================
   FOOTER
   ================================================================ */
.site-footer{
    position:relative;
    padding:60px 0 0;
    border-top:1px solid var(--border);
    background:
        radial-gradient(ellipse 60% 30% at 50% 0%,rgba(201,164,74,0.02) 0%,transparent 60%),
        #050609;
}
.footer-glow{
    position:absolute;top:-1px;left:0;right:0;height:1px;
    background:linear-gradient(90deg,transparent,rgba(201,164,74,0.3),transparent);
}

.footer-grid{
    display:grid;
    grid-template-columns:1.5fr 1fr 1fr 1fr;
    gap:40px;
    margin-bottom:40px;
}
.footer-brand{max-width:280px}
.footer-logo-link{margin-bottom:16px}
.footer-about{font-size:13px;line-height:1.7;color:var(--gray);margin-bottom:20px}
.footer-socials{display:flex;gap:10px}
.soc-btn{
    width:36px;height:36px;border-radius:8px;
    display:flex;align-items:center;justify-content:center;
    background:rgba(201,164,74,0.06);
    border:1px solid rgba(201,164,74,0.1);
    color:var(--gray);
    transition:color .25s,border-color .25s,background .25s,transform .2s;
}
.soc-btn:hover{
    color:var(--gold);border-color:rgba(201,164,74,0.3);
    background:rgba(201,164,74,0.1);
    transform:translateY(-2px);
}

.footer-col h4{
    font-family:var(--font-h);font-size:12px;font-weight:700;
    letter-spacing:2px;color:var(--gold);margin-bottom:16px;
}
.footer-col li{margin-bottom:8px}
.footer-col a{
    font-size:13px;color:var(--gray);transition:color .25s;
}
.footer-col a:hover{color:var(--white)}

.footer-bar{
    padding:20px 0;border-top:1px solid rgba(255,255,255,0.04);
    display:flex;justify-content:space-between;align-items:center;
    font-size:12px;color:rgba(255,255,255,0.25);
}
.footer-disclaimer{font-size:11px}

/* ================================================================
   HERO CHARACTER ART
   ================================================================ */
.hero-char{
    position:absolute;bottom:0;z-index:4;
    pointer-events:none;
    max-height:85vh;
    transition:transform .3s ease, opacity .3s ease;
}
.hero-char img{
    display:block;height:auto;
    max-height:85vh;
    filter:drop-shadow(0 0 40px rgba(0,0,0,0.8)) drop-shadow(0 0 80px rgba(201,164,74,0.1));
}
.hero-char-left{
    left:-2%;
    width:36%;
}
.hero-char-left img{
    width:100%;
    mask-image:linear-gradient(to right, transparent 0%, black 15%, black 70%, transparent 100%),
               linear-gradient(to top, black 0%, black 80%, transparent 100%);
    mask-composite:intersect;
    -webkit-mask-image:linear-gradient(to right, transparent 0%, black 15%, black 70%, transparent 100%),
                       linear-gradient(to top, black 0%, black 80%, transparent 100%);
    -webkit-mask-composite:destination-in;
}
.hero-char-right{
    right:-2%;
    width:36%;
}
.hero-char-right img{
    width:100%;
    mask-image:linear-gradient(to left, transparent 0%, black 15%, black 70%, transparent 100%),
               linear-gradient(to top, black 0%, black 80%, transparent 100%);
    mask-composite:intersect;
    -webkit-mask-image:linear-gradient(to left, transparent 0%, black 15%, black 70%, transparent 100%),
                       linear-gradient(to top, black 0%, black 80%, transparent 100%);
    -webkit-mask-composite:destination-in;
}

/* ================================================================
   ANIMATIONS
   ================================================================ */
[data-animate]{opacity:0;transform:translateY(30px);transition:opacity .8s ease,transform .8s ease}
[data-animate="fade-down"]{transform:translateY(-20px)}
[data-animate="scale"]{transform:scale(0.9)}
[data-animate].animated{opacity:1;transform:none}

/* ================================================================
   RESPONSIVE
   ================================================================ */
@media(max-width:1024px){
    .hero-char{width:30%;max-height:70vh}
    .hero-char img{max-height:70vh}
    .feat-grid{grid-template-columns:repeat(2,1fr)}
    .news-row{grid-template-columns:1fr}
    .dl-layout{grid-template-columns:1fr;gap:40px}
    .dl-info .sec-title{text-align:center}
    .dl-info{text-align:center}
    .spec-grid{max-width:400px;margin:0 auto}
    .footer-grid{grid-template-columns:1fr 1fr}
}

@media(max-width:768px){
    .nav-links{
        display:none;
        position:absolute;top:var(--nav-h);left:0;right:0;
        flex-direction:column;padding:16px 24px;
        background:rgba(6,7,11,0.98);
        border-bottom:1px solid var(--border);
    }
    .nav-links.open{display:flex}
    .hamburger{display:flex}
    .server-pill{display:none}

    .feat-grid{grid-template-columns:1fr}
    .events-grid{grid-template-columns:1fr 1fr}
    .rank-row{grid-template-columns:30px 1fr auto 80px;gap:8px}
    .r-class{display:none}
    .podium{gap:20px;padding:32px 16px 24px}
    .podium-avatar{width:56px;height:56px;font-size:18px}

    .hero-char{opacity:0.3;width:40%}
    .hero-char img{max-height:60vh}

    .hero-counters{gap:20px}
    .hc-num{font-size:22px}

    .section{padding:60px 0}
    .container{padding:0 16px}
    .hero-content{padding:var(--nav-h) 16px 40px}

    .footer-grid{grid-template-columns:1fr}
    .footer-bar{flex-direction:column;gap:8px;text-align:center}
}

@media(max-width:480px){
    .hero-char{display:none}
    .events-grid{grid-template-columns:1fr}
    .hero-buttons{flex-direction:column;align-items:center}
    .btn-fire,.btn-outline{width:100%;justify-content:center}
    .title-main{font-size:clamp(36px,12vw,60px)}
    .podium{gap:12px;padding:24px 8px 20px}
    .rank-list{padding:0 12px 16px}
    .rank-row{grid-template-columns:24px 1fr auto;gap:6px;padding:10px 8px}
    .r-badge{display:none}
    .dl-box{padding:32px 16px}
}
