*{margin:0;padding:0;box-sizing:border-box}
body{overflow:hidden;background:#000;font-family:'DM Sans','Segoe UI',sans-serif;touch-action:none}
canvas{display:block;filter:saturate(1.5)}
#ui{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:10}

/* ── HUD ── */
#hud-wrap{position:absolute;top:12px;left:0;right:0;display:flex;flex-direction:column;align-items:center;gap:10px;transition:opacity 0.3s}
#hud-wrap.hidden-hud{opacity:0;pointer-events:none}
#hud-row{display:flex;align-items:center;gap:8px;width:100%;padding:0 16px;flex-wrap:wrap;justify-content:center}
.pill{display:flex;align-items:center;gap:8px;background:rgba(0,0,0,0.7);border:1.5px solid rgba(255,255,255,0.12);border-radius:24px;padding:8px 18px;white-space:nowrap}
.pill-label{font-size:11px;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.05em;font-family:'FuturaCond',sans-serif}
.pill-val{font-size:28px;font-weight:800;font-family:'FuturaCond',sans-serif;line-height:1;color:#fff}
.pill-val.pos{color:#7dde9c}
.pill-val.neg{color:#f08080}
#pill-name{font-family:'FuturaCond',sans-serif;font-size:18px;font-weight:800;color:#7dde9c;letter-spacing:0.02em;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
#pill-progress{flex:1;display:flex;align-items:center;gap:8px;min-width:80px}
#field-progress{flex:1;height:6px;background:rgba(255,255,255,0.12);border-radius:3px;overflow:hidden;min-width:40px}
#field-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#f47c7c,#ffd966 60%,#7dde9c);transition:width 0.3s}
.pill-tag{font-size:12px;color:rgba(255,255,255,0.5);font-family:'FuturaCond',sans-serif;letter-spacing:0.03em}
.pill-tag span{color:rgba(255,255,255,0.85);font-weight:800;font-family:'FuturaCond',sans-serif;font-size:14px}
#hud-pips{display:flex;align-items:center;gap:4px}
.pip{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.15)}
.pip.on{background:#ffd966}
#sync-dot{width:9px;height:9px;border-radius:50%}
#sync-dot.online{background:#7dde9c}
#sync-dot.offline{background:#f08080}
#sync-dot.pending{background:#ffd966}
#hud-stakes-row{display:flex;justify-content:center;gap:10px}
#stakes-pill{display:flex;align-items:center;gap:8px;background:rgba(93,64,55,0.85);border:2px solid rgba(141,110,99,0.5);border-radius:24px;padding:10px 24px}
#stakes-pill .pill-label{font-size:12px}
#stakes-pill .pill-val{color:#ffd966;font-size:32px}
#syncoin-pill{display:flex;align-items:center;gap:8px;background:rgba(0,0,0,0.7);border:2px solid rgba(255,215,0,0.3);border-radius:24px;padding:10px 24px}
#syncoin-pill .pill-label{font-size:12px;color:rgba(255,215,0,0.6)}
#syncoin-pill .pill-val{color:#FFD700;font-size:32px}
#syncoin-pill.pulse{animation:coinPulse 0.3s ease-out}
@keyframes coinPulse{0%{transform:scale(1)}50%{transform:scale(1.1)}100%{transform:scale(1)}}

#combo-text{position:absolute;top:35%;left:50%;transform:translate(-50%,-50%);font-family:'FuturaCond',sans-serif;font-size:64px;font-weight:800;text-shadow:0 4px 24px rgba(0,0,0,0.7);opacity:0;pointer-events:none;transition:opacity 0.4s,transform 0.4s;letter-spacing:0.02em}
#controls-hint{position:absolute;bottom:60px;left:50%;transform:translateX(-50%);display:flex;gap:50px;opacity:0.8;transition:opacity 1s}
.hint-arrow{width:64px;height:64px;border-radius:50%;background:rgba(255,255,255,0.18);border:2.5px solid rgba(255,255,255,0.4);display:flex;align-items:center;justify-content:center;color:#fff;font-size:28px;font-weight:900;font-family:'FuturaCond',sans-serif}
#touch-left,#touch-right{position:absolute;top:0;width:50%;height:100%;pointer-events:none;cursor:pointer}
#touch-left{left:0}
#touch-right{right:0}
@font-face{font-family:'FuturaCond';src:url('../assets/Futura Condensed Extra Bold.otf') format('opentype');font-weight:800}
.overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:all;z-index:100}
#start-screen{background:url('../assets/BG.jpg') center/cover no-repeat;justify-content:flex-start;padding-top:0;overflow-y:auto}
#start-step1,#start-step2{width:100%;min-height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;transition:opacity 0.4s}
#start-step1{position:relative;justify-content:space-between;padding:6vh 0 4vh}
#start-step2{position:absolute;top:0;left:0;opacity:0;pointer-events:none}
#start-step2.active{opacity:1;pointer-events:all}
#start-step1.hide{opacity:0;pointer-events:none}
.start-logo{height:44px;opacity:0.9;filter:brightness(0) invert(1)}
.start-config{position:absolute;top:20px;right:20px;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;color:rgba(255,255,255,0.45)}
.start-title{width:min(420px,55vw);filter:drop-shadow(0 8px 25px rgba(0,0,0,0.4))}
.btn-start{font-family:'FuturaCond',sans-serif;font-size:28px;letter-spacing:0;text-transform:uppercase;color:#0d30e1;background:linear-gradient(180deg,#f0f5c4 0%,#e6eeaa 100%);border:none;padding:18px 80px;border-radius:40px;cursor:pointer;box-shadow:0 6px 0 #a8d830,0 8px 20px rgba(0,0,0,0.3);transition:transform 0.12s,box-shadow 0.12s}
.btn-start:hover{transform:translateY(-2px);box-shadow:0 8px 0 #a8d830,0 10px 25px rgba(0,0,0,0.3)}
.btn-start:active{transform:translateY(4px);box-shadow:0 2px 0 #a8d830,0 4px 10px rgba(0,0,0,0.3)}
.btn-mode{font-family:'FuturaCond',sans-serif;font-size:22px;letter-spacing:0;text-transform:uppercase;padding:16px 50px;border-radius:40px;cursor:pointer;border:none;transition:transform 0.12s,box-shadow 0.12s,background 0.2s;color:#0d30e1;background:linear-gradient(180deg,#f0f5c4 0%,#e6eeaa 100%);box-shadow:0 6px 0 #a8d830,0 8px 20px rgba(0,0,0,0.3);white-space:nowrap}
.btn-mode:hover{transform:translateY(-2px);box-shadow:0 8px 0 #a8d830,0 10px 25px rgba(0,0,0,0.3)}
.btn-mode:active,.btn-mode.selected{transform:translateY(2px);background:linear-gradient(180deg,#3b6ef5 0%,#2a5cd4 100%);color:#fff;box-shadow:0 3px 0 #a8d830,0 5px 15px rgba(0,0,0,0.3)}

/* ── Webcam control selector ── */
.step2-controls{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}
.control-label{font-family:'FuturaCond',sans-serif;font-size:14px;color:#0032EA;text-transform:uppercase;letter-spacing:0.08em;opacity:0.6}
.control-buttons{display:flex;gap:10px}
.btn-control{font-family:'FuturaCond',sans-serif;font-size:16px;letter-spacing:0;text-transform:uppercase;padding:10px 28px;border-radius:30px;cursor:pointer;border:2px solid rgba(0,50,234,0.2);background:rgba(255,255,255,0.5);color:#0032EA;transition:all 0.2s}
.btn-control:hover{background:rgba(255,255,255,0.8)}
.btn-control.selected{background:#0032EA;color:#fff;border-color:#0032EA}
#webcam-setup{display:flex;flex-direction:column;align-items:center;gap:8px;margin-top:4px}
#webcam-setup video{width:200px;height:150px;border-radius:10px;object-fit:cover;transform:scaleX(-1);background:#111;border:2px solid rgba(0,50,234,0.2)}
#webcam-status{font-family:'FuturaCond',sans-serif;font-size:13px;color:#0032EA;text-align:center;max-width:240px}
/* Setup indicator: continuous dot follows body position */
.webcam-indicator{--pos:50%;width:80px;height:6px;border-radius:3px;background:linear-gradient(90deg,rgba(0,50,234,0.12) 0%,rgba(0,50,234,0.25) 35%,rgba(0,200,100,0.35) 45%,rgba(0,200,100,0.35) 55%,rgba(0,50,234,0.25) 65%,rgba(0,50,234,0.12) 100%);position:relative;overflow:visible;margin-top:-2px}
.webcam-indicator::after{content:'';position:absolute;top:-4px;left:var(--pos);width:14px;height:14px;border-radius:50%;transform:translateX(-50%);transition:background 0.2s}
.webcam-indicator[data-zone="center"]::after{background:#00c853}
.webcam-indicator[data-zone="left"]::after,.webcam-indicator[data-zone="right"]::after{background:#0032EA;box-shadow:0 0 8px rgba(0,50,234,0.5)}

/* ── Webcam gameplay preview ── */
#webcam-game-preview{position:absolute;bottom:20px;left:20px;width:140px;border-radius:10px;overflow:hidden;border:2px solid rgba(255,255,255,0.25);background:#000;z-index:15;opacity:0.75;pointer-events:none;transition:opacity 0.3s}
#webcam-game-preview video{width:100%;height:auto;display:block;object-fit:cover;transform:scaleX(-1)}
/* Game indicator: continuous dot follows body position */
.webcam-game-indicator{--pos:50%;width:50px;height:4px;border-radius:2px;background:linear-gradient(90deg,rgba(255,255,255,0.08) 0%,rgba(255,255,255,0.15) 35%,rgba(125,222,156,0.3) 45%,rgba(125,222,156,0.3) 55%,rgba(255,255,255,0.15) 65%,rgba(255,255,255,0.08) 100%);position:absolute;bottom:8px;left:50%;transform:translateX(-50%)}
.webcam-game-indicator::after{content:'';position:absolute;top:-4px;left:var(--pos);width:10px;height:10px;border-radius:50%;transform:translateX(-50%);transition:background 0.2s;box-shadow:0 0 6px rgba(125,222,156,0.4)}
.webcam-game-indicator[data-zone="center"]::after{background:#7dde9c}
.webcam-game-indicator[data-zone="left"]::after,.webcam-game-indicator[data-zone="right"]::after{background:#5bbcff;box-shadow:0 0 6px rgba(91,188,255,0.5)}

/* ── Countdown overlay ── */
#countdown-overlay{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;z-index:60;pointer-events:none}
#countdown-number{font-family:'FuturaCond',sans-serif;font-size:clamp(100px,20vw,180px);font-weight:800;color:#fff;text-shadow:0 0 60px rgba(255,255,255,0.4),0 4px 20px rgba(0,0,0,0.6);animation:countPop 0.8s ease-out both;letter-spacing:-0.02em}
@keyframes countPop{0%{transform:scale(2);opacity:0}15%{transform:scale(1);opacity:1}80%{opacity:1}100%{transform:scale(0.8);opacity:0}}

.step2-board{
  position:relative;
  max-width:720px;width:90%;
  padding:48px 60px 40px;
  display:flex;flex-direction:column;align-items:center;gap:28px;
  background:none;border-radius:0;box-shadow:none;transform:none;
}
.step2-board::before{
  content:'';position:absolute;
  inset:-20px -16px -24px -20px;
  background:#E4DEC5;
  clip-path:polygon(3% 10%, 0% 65%, 8% 97%, 100% 100%, 99.5% 18%, 92% 0%);
  z-index:0;
}
.step2-board::after{
  content:'';position:absolute;
  inset:-10px -28px -40px -12px;
  background:#37CEFF;
  clip-path:polygon(3% 10%, 0% 65%, 8% 97%, 100% 100%, 99.5% 18%, 92% 0%);
  z-index:-1;
}
.step2-board>*{position:relative;z-index:1}
.step2-instructions{color:#0032EA;font-family:'FuturaCond',sans-serif;font-size:22px;text-transform:uppercase;text-align:center;line-height:24px;letter-spacing:0;max-width:425px}
.step2-modes{display:flex;gap:14px}
.step2-board .settings{margin-bottom:0}
.step2-board .setting-row{margin-bottom:12px}
.step2-board .setting-input{
  background:#fff;
  border:2px solid rgba(0,50,234,0.15);
  border-radius:14px;
  color:#0032EA;
  font-family:'FuturaCond',sans-serif;
  font-size:18px;
  font-weight:800;
  padding:14px 18px;
  text-transform:uppercase;
  box-shadow:0 2px 6px rgba(0,0,0,0.06);
  transition:border-color 0.2s,box-shadow 0.2s;
}
.step2-board .setting-input::placeholder{
  color:rgba(0,50,234,0.3);
  font-weight:800;
  text-transform:uppercase;
}
.step2-board .setting-input:focus{
  border-color:#0032EA;
  box-shadow:0 0 0 3px rgba(0,50,234,0.1);
}
.step2-board #form-error{color:#c62828}
.btn-back{position:absolute;top:20px;left:24px;background:none;border:none;color:rgba(255,255,255,0.6);font-family:'FuturaCond',sans-serif;font-size:18px;cursor:pointer;display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:24px;transition:all 0.2s;letter-spacing:0}
.btn-back:hover{color:#fff;background:rgba(255,255,255,0.1)}
#game-over{
  background:rgba(0,0,0,0.8);
}
#game-over .screen-icon{
  width:64px;height:64px;
  margin-bottom:16px;
}
#game-over .screen-title{
  font-size:clamp(42px,8vw,64px);
  color:#ff4444;
  text-shadow:0 0 40px rgba(255,68,68,0.5),0 4px 20px rgba(0,0,0,0.5);
  margin-bottom:4px;
}
#game-over .score-label{
  font-family:'DM Sans',sans-serif;
  font-size:12px;
  font-weight:500;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.35);
  margin-top:20px;
  margin-bottom:4px;
}
#game-over .big-score{
  color:#fff;
  font-size:clamp(48px,10vw,72px);
  text-shadow:0 2px 20px rgba(255,255,255,0.15);
}
#game-over .screen-sub{
  color:rgba(255,255,255,0.45);
  font-size:14px;
  margin-bottom:36px;
}
#win-screen{background:rgba(27,94,32,0.88)}
.screen-title{color:#fff;font-family:'FuturaCond',sans-serif;font-size:38px;font-weight:800;margin-bottom:8px;text-shadow:0 4px 25px rgba(0,0,0,0.35);text-align:center;line-height:1.15;letter-spacing:0}
.screen-sub{color:rgba(255,255,255,0.85);font-size:17px;margin-bottom:30px;text-align:center;max-width:500px;line-height:1.45}
.btn{background:linear-gradient(180deg,#f0f5c4 0%,#e6eeaa 100%);color:#0d30e1;border:none;padding:16px 50px;font-family:'FuturaCond',sans-serif;font-size:22px;font-weight:800;border-radius:40px;cursor:pointer;box-shadow:0 6px 0 #a8d830,0 8px 20px rgba(0,0,0,0.3);transition:transform 0.12s,box-shadow 0.12s;letter-spacing:0;text-transform:uppercase}
.btn:hover{transform:translateY(-2px);box-shadow:0 8px 0 #a8d830,0 10px 25px rgba(0,0,0,0.3)}
.btn:active{transform:translateY(4px);box-shadow:0 2px 0 #a8d830,0 4px 10px rgba(0,0,0,0.3)}
.end-buttons{display:flex;align-items:center;justify-content:center;gap:12px}
.btn-retry{width:56px;height:56px;border-radius:50%;border:none;background:rgba(255,255,255,0.15);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);transition:transform 0.12s,background 0.2s;box-shadow:0 4px 12px rgba(0,0,0,0.3)}
.btn-retry:hover{background:rgba(255,255,255,0.25);transform:scale(1.1)}
.btn-retry:active{transform:scale(0.95);background:rgba(255,255,255,0.3)}
.big-score{color:#FFD700;font-size:56px;font-weight:800;margin:8px 0;font-family:'FuturaCond',sans-serif}
.screen-sub strong{color:#fff;font-weight:800}
/* ── Start logos ── */
.start-logos{position:absolute;top:50%;left:200px;right:200px;transform:translateY(-50%);display:flex;align-items:center;justify-content:space-between}
.start-logos img{flex-shrink:0}
/* ── Pest alert ── */
.pest-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:45;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:8px}
.pest-overlay.hidden{display:none}
.pest-overlay svg{filter:drop-shadow(0 4px 16px rgba(0,0,0,0.5))}
.pest-overlay .pest-name{font-family:'FuturaCond',sans-serif;font-size:18px;font-weight:800;color:#F44336;text-shadow:0 2px 8px rgba(0,0,0,0.6);text-transform:uppercase;letter-spacing:0.05em}
@keyframes pestEnter{0%{opacity:0;transform:translate(-50%,-50%) scale(0.3) rotate(-20deg)}40%{opacity:1;transform:translate(-50%,-50%) scale(1.15) rotate(5deg)}60%{transform:translate(-50%,-50%) scale(0.95) rotate(-3deg)}100%{transform:translate(-50%,-50%) scale(1) rotate(0deg)}}
@keyframes pestShake{0%,100%{transform:translate(-50%,-50%) scale(1) rotate(0deg)}25%{transform:translate(-50%,-50%) scale(1) rotate(4deg)}75%{transform:translate(-50%,-50%) scale(1) rotate(-4deg)}}
@keyframes pestExit{0%{opacity:1;transform:translate(-50%,-50%) scale(1)}100%{opacity:0;transform:translate(-50%,-50%) scale(0.5) rotate(15deg)}}
.pest-overlay.enter{animation:pestEnter 0.4s ease-out forwards}
.pest-overlay.shake{animation:pestShake 0.15s ease-in-out 4}
.pest-overlay.exit{animation:pestExit 0.3s ease-in forwards}
/* ── Celebration overlay text ── */
.celebration-text{position:absolute;bottom:80px;left:0;right:0;text-align:center;z-index:40;pointer-events:none;font-family:'DM Sans',sans-serif;font-size:clamp(18px,2.5vw,28px);font-weight:500;font-style:italic;color:rgba(255,245,180,0.85);letter-spacing:0.02em;opacity:0;transition:opacity 0.6s ease}
.celebration-text.visible{opacity:1}
.celebration-text.hidden{display:none}
/* ── Win product cards ── */
.win-products-grid{display:flex;gap:16px;justify-content:center;margin-bottom:20px}
.win-prize-card{display:flex;flex-direction:column;align-items:center;gap:6px;background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);border-radius:16px;padding:16px 24px;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);min-width:100px;transition:transform 0.2s}
.win-prize-card:hover{transform:translateY(-2px)}
.win-prize-icon{font-size:36px;line-height:1}
.win-prize-name{font-family:'FuturaCond',sans-serif;font-size:14px;font-weight:800;color:#c2fcd8;text-transform:uppercase;letter-spacing:0.05em}
/* ── Preloader ── */
#preloader{
  position:fixed;inset:0;z-index:9999;
  background:radial-gradient(ellipse at 50% 120%, #7EC8E3 0%, #1976D2 40%, #0d47a1 100%);
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  transition:opacity 0.6s cubic-bezier(0.22,1,0.36,1);
  overflow:hidden;
}
#preloader::before{
  content:'';position:absolute;inset:0;
  background:
    radial-gradient(circle at 30% 20%, rgba(255,255,255,0.08) 0%, transparent 50%),
    radial-gradient(circle at 70% 80%, rgba(0,0,0,0.15) 0%, transparent 50%);
  pointer-events:none;
}
#preloader.done{opacity:0;pointer-events:none}
#preload-number{
  position:relative;
  font-family:'FuturaCond','Syne',sans-serif;
  font-size:clamp(140px,32vw,300px);
  font-weight:800;
  line-height:0.85;
  color:#fff;
  letter-spacing:0.02em;
  user-select:none;
  text-shadow:0 4px 40px rgba(0,0,0,0.2);
}
#preload-number span{
  font-size:clamp(36px,7vw,72px);
  font-weight:800;
  color:rgba(255,255,255,0.5);
  vertical-align:super;
  margin-left:4px;
}
#preload-bar-track{
  position:relative;
  width:min(280px,50vw);height:3px;
  background:rgba(255,255,255,0.15);
  border-radius:2px;
  margin-top:40px;
  overflow:hidden;
}
#preload-bar-fill{
  height:100%;width:0%;
  background:rgba(255,255,255,0.9);
  border-radius:2px;
  transition:width 0.3s ease-out;
}
#preload-label{
  position:relative;
  font-family:'FuturaCond','Syne',sans-serif;
  font-size:13px;
  font-weight:800;
  letter-spacing:0.25em;
  text-transform:uppercase;
  color:rgba(255,255,255,0.45);
  margin-top:16px;
}
.hidden{display:none!important}
.settings{width:100%;max-width:320px;margin-bottom:24px}
.setting-row{margin-bottom:16px}
.setting-label{color:rgba(255,255,255,0.9);font-size:14px;font-weight:700;margin-bottom:6px;display:flex;justify-content:space-between;align-items:center}
.setting-val{color:#FFD700;font-size:14px;font-weight:800;min-width:60px;text-align:right}
.setting-slider{-webkit-appearance:none;appearance:none;width:100%;height:8px;border-radius:4px;background:rgba(255,255,255,0.2);outline:none}
.setting-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#FFB300,#F57C00);cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,0.3)}
.setting-slider::-moz-range-thumb{width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,#FFB300,#F57C00);cursor:pointer;border:none}
.setting-input{width:100%;padding:12px 16px;border:2px solid rgba(255,255,255,0.3);border-radius:12px;background:rgba(0,0,0,0.3);color:#fff;font-family:'FuturaCond',sans-serif;font-size:16px;font-weight:600;outline:none;transition:border-color 0.2s;letter-spacing:0}
.setting-input::placeholder{color:rgba(255,255,255,0.45)}
.setting-input:focus{border-color:#a8d830}
.mode-btn{background:rgba(255,255,255,0.1);color:rgba(255,255,255,0.7);border:2px solid rgba(255,255,255,0.2);padding:10px 24px;font-size:15px;font-weight:700;border-radius:25px;cursor:pointer;transition:all 0.2s}
.mode-btn.active{background:rgba(255,255,255,0.2);color:#fff;border-color:#FFB300}
.mode-btn:hover{background:rgba(255,255,255,0.15)}
#player-turn-banner{position:absolute;top:100px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,0.6);color:#FFD700;padding:10px 30px;border-radius:15px;font-size:20px;font-weight:800;z-index:50;display:none;pointer-events:none}

/* ── Ranking ── */
.ranking-box{width:100%;max-width:380px;margin:16px auto 0;max-height:260px;overflow:hidden}
.ranking-title{font-family:'FuturaCond',sans-serif;font-size:16px;color:rgba(255,255,255,0.5);text-transform:uppercase;letter-spacing:0.1em;text-align:center;margin-bottom:8px}
.ranking-list{list-style:none;padding:0;margin:0}
.ranking-item{display:flex;align-items:center;gap:10px;padding:6px 12px;border-radius:10px;margin-bottom:4px;font-family:'FuturaCond',sans-serif;font-size:13px;color:#fff;background:rgba(255,255,255,0.06)}
.ranking-item.current{background:rgba(255,215,0,0.15);border:1px solid rgba(255,215,0,0.3)}
.ranking-pos{font-size:15px;font-weight:800;min-width:24px;text-align:center;color:rgba(255,255,255,0.4)}
.ranking-item:nth-child(1) .ranking-pos{color:#FFD700}
.ranking-item:nth-child(2) .ranking-pos{color:#C0C0C0}
.ranking-item:nth-child(3) .ranking-pos{color:#CD7F32}
.ranking-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-weight:500;font-family:'DM Sans',sans-serif}
.ranking-score{font-weight:800;color:#ffd966;font-size:14px;font-family:'FuturaCond',sans-serif}
.ranking-pages{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:8px}
.ranking-pages button{background:rgba(255,255,255,0.1);border:1px solid rgba(255,255,255,0.2);color:#fff;border-radius:50%;width:28px;height:28px;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;pointer-events:all}
.ranking-pages button:hover{background:rgba(255,255,255,0.2)}
.ranking-pages button:disabled{opacity:0.3;cursor:default}
.ranking-pages span{font-family:'DM Sans',sans-serif;font-size:11px;color:rgba(255,255,255,0.4)}
