/* ═══════════════════════════════════════════════════════════════
   STICKMAN ELITE SNIPER — Military-Tactical Dark Theme
   ═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@400;600;700&family=Orbitron:wght@400;700;900&family=Share+Tech+Mono&display=swap');

:root{
    --bg:#070810; --blood:#c0392b; --blood-hi:#e74c3c;
    --gold:#f0a500; --gold-dim:rgba(240,165,0,0.15);
    --hud-bg:rgba(8,10,18,0.82); --hud-border:rgba(240,165,0,0.2);
    --text:#ddd5c4; --accent:#d4a017; --danger:#e74c3c; --success:#2ecc71;
    --f-display:'Orbitron',monospace; --f-body:'Rajdhani',sans-serif; --f-mono:'Share Tech Mono',monospace;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html,body{width:100%;height:100%;overflow:hidden;background:var(--bg);font-family:var(--f-body);color:var(--text);touch-action:none;-webkit-user-select:none;user-select:none;}

/* Canvas */
#gameCanvas{position:fixed;top:0;left:0;width:100%;height:100%;display:block;z-index:1;}

/* UI Layer */
#ui-layer{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10;}
#ui-layer>*{pointer-events:auto;}

/* ── OVERLAYS (menu screens) ─────────────────────── */
.overlay{
    position:absolute;top:0;left:0;right:0;bottom:0;
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    background:rgba(4,5,12,0.94);z-index:20;gap:14px;padding:20px;
    animation:fadeIn 0.3s ease;
}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

/* ══════════════════════════════════════════════════════
   MAIN MENU — Cinematic Military Design
   ══════════════════════════════════════════════════════ */
#menu-screen{
    background:transparent;overflow:hidden;
}

/* Animated background canvas behind menu */
#menuCanvas{
    position:absolute;top:0;left:0;width:100%;height:100%;z-index:0;
    pointer-events:none;
}

#menu-content{
    position:relative;z-index:2;text-align:center;
    animation:menuSlideIn 0.8s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes menuSlideIn{
    from{opacity:0;transform:translateY(30px) scale(0.95)}
    to{opacity:1;transform:translateY(0) scale(1)}
}

/* Animated crosshair above title */
#menu-crosshair{
    font-family:var(--f-mono);font-size:3rem;color:rgba(255,60,60,0.25);
    letter-spacing:0;line-height:1;margin-bottom:10px;
    animation:crossPulse 2s ease-in-out infinite;
}
@keyframes crossPulse{0%,100%{opacity:0.2;transform:scale(1)}50%{opacity:0.5;transform:scale(1.15)}}

/* Tactical badge */
#menu-badge{
    font-family:var(--f-mono);font-size:0.65rem;color:var(--gold);
    letter-spacing:0.5em;text-transform:uppercase;
    border:1px solid rgba(240,165,0,0.2);display:inline-block;
    padding:4px 18px;margin-bottom:16px;
    background:rgba(240,165,0,0.04);
}

/* Title */
#game-title{
    font-family:var(--f-display);line-height:1;margin-bottom:4px;
    display:flex;flex-direction:column;align-items:center;gap:2px;
}
.title-line1{
    font-size:clamp(2rem,7vw,4.2rem);font-weight:900;
    color:var(--text);letter-spacing:0.12em;
    text-shadow:0 0 60px rgba(240,165,0,0.15),0 2px 0 rgba(0,0,0,0.4);
}
.title-line2{
    font-size:clamp(1.4rem,5vw,2.8rem);font-weight:700;
    color:var(--blood-hi);letter-spacing:0.15em;
    text-shadow:0 0 40px rgba(231,76,60,0.3),0 2px 0 rgba(0,0,0,0.5);
}

/* Gold rule below title */
#title-rule{
    width:180px;height:1px;margin:12px auto;
    background:linear-gradient(90deg,transparent,var(--gold),transparent);
    opacity:0.4;
}

#game-subtitle{
    font-family:var(--f-display);font-size:clamp(0.6rem,2.5vw,0.9rem);
    color:var(--accent);letter-spacing:0.45em;opacity:0.7;margin-bottom:32px;
}

/* Buttons */
#menu-buttons{display:flex;flex-direction:column;align-items:center;gap:10px;}

.menu-btn{
    width:280px;max-width:85vw;padding:14px 24px;
    background:linear-gradient(135deg,rgba(240,165,0,0.08),rgba(240,165,0,0.02));
    border:1px solid var(--hud-border);color:var(--text);
    font-family:var(--f-display);font-size:0.85rem;font-weight:600;
    letter-spacing:0.1em;border-radius:3px;cursor:pointer;
    transition:all 0.25s;text-transform:uppercase;
    display:flex;align-items:center;justify-content:center;gap:10px;
    position:relative;overflow:hidden;
}
.menu-btn::before{
    content:'';position:absolute;left:0;top:0;width:3px;height:100%;
    background:var(--gold);opacity:0;transition:opacity 0.25s;
}
.menu-btn:hover,.menu-btn:active{
    background:linear-gradient(135deg,rgba(240,165,0,0.2),rgba(240,165,0,0.06));
    border-color:var(--accent);transform:translateX(3px);
}
.menu-btn:hover::before{opacity:1;}
.menu-btn.primary{
    background:linear-gradient(135deg,rgba(240,165,0,0.18),rgba(240,165,0,0.06));
    border-color:rgba(240,165,0,0.4);font-size:0.95rem;
}
.menu-btn.primary:hover{
    background:linear-gradient(135deg,rgba(240,165,0,0.3),rgba(240,165,0,0.1));
    box-shadow:0 0 20px rgba(240,165,0,0.15);
}
.menu-btn.small{font-size:0.75rem;padding:10px 16px;width:200px;opacity:0.6;}
.menu-btn.small:hover{opacity:1;}
.btn-icon{font-size:1rem;opacity:0.7;}

/* Footer controls */
#menu-footer{
    display:flex;gap:14px;justify-content:center;flex-wrap:wrap;
    margin-top:36px;
}
#menu-footer span{font-size:0.7rem;opacity:0.35;letter-spacing:0.05em;}
#menu-footer kbd{
    font-family:var(--f-mono);background:rgba(255,255,255,0.06);
    border:1px solid rgba(255,255,255,0.1);padding:2px 6px;
    border-radius:2px;font-size:0.6rem;margin-right:4px;
}

#menu-version{
    position:absolute;bottom:12px;right:16px;
    font-family:var(--f-mono);font-size:0.55rem;opacity:0.15;z-index:2;
}

/* ── HUD ─────────────────────────────────────────── */
#hud{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;padding:10px;background:none !important;z-index:15;}
#hud-top{display:flex;justify-content:space-between;align-items:center;gap:8px;}
#hud-top>div{
    background:var(--hud-bg);border:1px solid var(--hud-border);
    padding:6px 14px;border-radius:3px;
    font-family:var(--f-display);font-size:0.9rem;letter-spacing:0.05em;
}
#hud-timer{color:var(--gold);font-weight:700;font-size:1.2rem;min-width:50px;text-align:center;}
#hud-timer.danger{color:var(--danger);animation:pulseDanger 0.5s infinite;}
@keyframes pulseDanger{0%,100%{opacity:1}50%{opacity:0.4}}
#hud-score{color:var(--text);}
#combo-display{color:var(--gold);font-weight:700;}

#hud-bottom{
    position:absolute;bottom:12px;left:12px;right:12px;
    display:flex;justify-content:space-between;align-items:flex-end;gap:8px;
}
#hud-bottom>div{background:var(--hud-bg);border:1px solid var(--hud-border);padding:5px 10px;border-radius:3px;font-family:var(--f-display);font-size:0.8rem;}
#hud-objective{flex:1;text-align:center;color:var(--accent);font-size:0.75rem;}
#hud-wind{position:absolute;top:48px;right:12px;background:var(--hud-bg);border:1px solid var(--hud-border);padding:3px 10px;border-radius:3px;font-family:var(--f-display);font-size:0.7rem;}
#hud-stars{position:absolute;top:48px;left:50%;transform:translateX(-50%);font-size:1.3rem;letter-spacing:6px;opacity:0.4;}
#hud-stars .star{color:#444;transition:color 0.3s;}
#hud-stars .star.earned{color:var(--gold);opacity:1;}

/* ── Pause button ─────────────────────────────────── */
#btn-pause{
    position:absolute;top:10px;right:10px;z-index:25;
    background:var(--hud-bg);border:1px solid var(--hud-border);
    color:var(--text);font-size:1rem;padding:6px 10px;border-radius:3px;cursor:pointer;
}

/* ── Screens common ───────────────────────────────── */
.screen-title{
    font-family:var(--f-display);font-size:clamp(1.2rem,4vw,1.8rem);
    letter-spacing:0.12em;margin-bottom:12px;
}
.success-title{color:var(--success);}
.fail-title{color:var(--danger);}

/* Level select grid */
#level-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:8px;max-width:380px;margin:16px auto;}
#level-grid .level-btn{
    aspect-ratio:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
    background:var(--hud-bg);border:1px solid var(--hud-border);border-radius:4px;
    color:var(--text);font-family:var(--f-display);font-weight:700;font-size:1.1rem;
    cursor:pointer;transition:all 0.2s;min-width:48px;
}
#level-grid .level-btn.locked{opacity:0.25;cursor:not-allowed;}
#level-grid .level-btn:not(.locked):hover{border-color:var(--accent);background:rgba(240,165,0,0.1);}
.stars-small{font-size:0.5rem;margin-top:2px;color:var(--gold);}

/* Level intro */
#intro-content{max-width:460px;text-align:center;}
.intro-badge{font-family:var(--f-mono);font-size:0.65rem;color:var(--gold);letter-spacing:0.4em;margin-bottom:12px;opacity:0.7;}
#intro-title{font-family:var(--f-display);font-size:1.3rem;color:var(--text);margin-bottom:8px;letter-spacing:0.08em;}
.intro-rule{width:80px;height:1px;margin:8px auto 14px;background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:0.3;}
#intro-content p{font-size:0.9rem;line-height:1.6;margin-bottom:6px;opacity:0.8;}
.highlight-text{color:var(--accent) !important;font-weight:600;opacity:1 !important;}
.twist-text{color:var(--blood-hi) !important;font-style:italic;}

/* Complete */
#complete-stars{font-size:2.5rem;letter-spacing:12px;margin:8px 0;}
#complete-stats{font-size:0.85rem;opacity:0.7;line-height:1.8;}

/* Fail */
#fail-reason{color:var(--danger);font-size:0.95rem;max-width:300px;text-align:center;margin-bottom:16px;}

/* Settings */
.settings-group{display:flex;flex-direction:column;gap:12px;margin:12px 0 20px;}
.setting-row{display:flex;align-items:center;gap:10px;font-size:0.95rem;cursor:pointer;}
.setting-row input[type="checkbox"]{accent-color:var(--accent);width:18px;height:18px;}
.volume-row{display:flex;align-items:center;gap:10px;width:100%;}
.volume-row span:first-child{min-width:55px;}
.volume-slider{flex:1;-webkit-appearance:none;appearance:none;height:4px;background:rgba(240,165,0,0.15);border-radius:2px;outline:none;cursor:pointer;}
.volume-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;}
.volume-slider::-moz-range-thumb{width:14px;height:14px;border-radius:50%;background:var(--accent);cursor:pointer;border:none;}
.vol-value{font-family:var(--f-mono);font-size:0.8rem;min-width:36px;text-align:right;opacity:0.6;}

/* Hitmarker */
#hitmarker{
    position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);
    pointer-events:none;z-index:30;
    font-family:var(--f-display);font-size:1.4rem;font-weight:900;
    text-shadow:0 0 12px currentColor;
}

/* ── Mobile Controls ──────────────────────────────── */
#mobile-controls{position:fixed;bottom:0;left:0;right:0;height:220px;pointer-events:none;z-index:20;}
#mobile-controls>*{pointer-events:auto;}
#joystick-base{
    position:absolute;bottom:20px;left:20px;width:120px;height:120px;border-radius:50%;
    background:rgba(255,255,255,0.06);border:2px solid rgba(240,165,0,0.25);
    touch-action:none;
}
#joystick-knob{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    width:50px;height:50px;border-radius:50%;
    background:rgba(240,165,0,0.2);border:2px solid rgba(240,165,0,0.45);
}
#btn-fire{
    position:absolute;bottom:20px;right:20px;width:80px;height:80px;border-radius:50%;
    background:rgba(255,50,50,0.15);border:2px solid rgba(255,50,50,0.4);
    color:rgba(255,50,50,0.8);font-size:2rem;line-height:1;cursor:pointer;
    font-family:var(--f-display);touch-action:none;
}
#btn-fire:active{background:rgba(255,50,50,0.35);border-color:rgba(255,50,50,0.7);}
#btn-scope-m{
    position:absolute;bottom:115px;right:30px;width:46px;height:46px;border-radius:50%;
    background:rgba(255,255,255,0.06);border:1px solid rgba(240,165,0,0.25);
    color:var(--text);font-size:1.2rem;cursor:pointer;font-family:var(--f-display);
    touch-action:none;
}
#btn-scope-m:active{background:rgba(240,165,0,0.15);}
#btn-breath-m{
    position:absolute;bottom:155px;left:40px;width:46px;height:46px;border-radius:50%;
    background:rgba(100,200,255,0.06);border:1px solid rgba(100,200,255,0.25);
    color:rgba(100,200,255,0.7);font-size:1.2rem;cursor:pointer;font-family:var(--f-display);
    touch-action:none;
}
#btn-breath-m:active{background:rgba(100,200,255,0.2);}

/* ── Reload Bar ──────────────────────────────────── */
#reload-bar{
    position:fixed;bottom:60px;left:50%;transform:translateX(-50%);
    width:180px;height:18px;
    background:rgba(0,0,0,0.6);border:1px solid rgba(240,165,0,0.3);
    border-radius:3px;z-index:25;overflow:hidden;
}
#reload-fill{
    height:100%;width:0%;border-radius:2px;
    background:linear-gradient(90deg,#d48a00,#f0a500);
    transition:none;
}
#reload-text{
    position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
    font-family:var(--f-display);font-size:0.55rem;color:var(--text);
    letter-spacing:0.12em;text-shadow:0 1px 2px rgba(0,0,0,0.8);
}

/* ── Responsive ───────────────────────────────────── */
@media(orientation:portrait){
    #hud-top>div{font-size:0.8rem;padding:4px 10px;}
    #hud-timer{font-size:1rem;}
    #hud-bottom>div{font-size:0.7rem;padding:3px 8px;}
    .menu-btn{width:240px;font-size:0.8rem;padding:12px 18px;}
    #level-grid{max-width:300px;}
    #menu-footer{flex-direction:column;gap:6px;}
}
@media(max-height:500px)and(orientation:landscape){
    #hud-top>div{padding:3px 8px;font-size:0.7rem;}
    .menu-btn{padding:8px 14px;font-size:0.75rem;width:220px;}
    .title-line1{font-size:1.6rem;}
    .title-line2{font-size:1.1rem;}
}
