*{margin:0;padding:0;box-sizing:border-box}
:root{
  --gold:#f5c518;
  --dark-gold:#c8960a;
  --teal:#1a6b6b;
}
html,body{
  width:100%;height:100%;
  overflow:hidden;
  background:#0a1a0a;
  font-family:'Baloo 2',cursive;
  touch-action:none;
  user-select:none;
  -webkit-user-select:none;
  -webkit-tap-highlight-color:transparent;
}
#wrap{
  position:relative;
  width:100%;height:100%;
  max-width:480px;
  margin:0 auto;
  overflow:hidden;
}
canvas{display:block;width:100%;height:100%;cursor:crosshair;}

.screen{
  position:absolute;inset:0;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  transition:opacity .3s ease;
  z-index:20;
}
.screen.off{opacity:0;pointer-events:none}

/* INTRO */
#intro{background:linear-gradient(180deg,#061a08 0%,#0e3012 55%,#061408 100%);gap:0;}
.intro-sazka{height:52px;object-fit:contain;filter:drop-shadow(0 2px 10px rgba(0,0,0,.9));margin-bottom:10px;}
.intro-lovci{width:90%;max-width:380px;object-fit:contain;filter:drop-shadow(0 6px 20px rgba(0,0,0,.95));margin-bottom:18px;}
.animals-row{display:flex;align-items:flex-end;justify-content:center;gap:2px;margin-bottom:28px;width:92%;}
.animals-row img{flex:1;max-width:80px;height:64px;object-fit:contain;filter:drop-shadow(0 4px 8px rgba(0,0,0,.8));animation:abounce 2s ease-in-out infinite;}
.animals-row img:nth-child(1){animation-delay:0s;max-height:56px}
.animals-row img:nth-child(2){animation-delay:.18s;max-height:72px}
.animals-row img:nth-child(3){animation-delay:.35s;max-height:62px}
.animals-row img:nth-child(4){animation-delay:.5s;max-height:58px}
.animals-row img:nth-child(5){animation-delay:.65s;max-height:68px}
@keyframes abounce{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-12px) rotate(2deg)}}
.play-btn{
  font-family:'Baloo 2',cursive;font-size:30px;color:#0d2e10;
  background:linear-gradient(180deg,#ffe040 0%,var(--gold) 45%,var(--dark-gold) 100%);
  border:none;border-radius:60px;padding:16px 64px;cursor:pointer;
  box-shadow:0 6px 0 #7a5500,0 10px 28px rgba(0,0,0,.6);
  transition:transform .1s,box-shadow .1s;letter-spacing:.5px;
}
.play-btn:active{transform:translateY(4px);box-shadow:0 2px 0 #7a5500,0 4px 12px rgba(0,0,0,.5)}
.tagline{color:rgba(255,255,255,.5);font-family:'Nunito',sans-serif;font-size:12px;margin-top:10px;letter-spacing:1px;}

/* COUNTDOWN */
#countdown{background:rgba(0,0,0,.6);backdrop-filter:blur(6px)}
#cnt-num{
  font-size:140px;line-height:1;color:var(--gold);
  text-shadow:0 0 60px rgba(245,197,24,.9),0 4px 0 #7a5500;
  animation:cntpop .9s ease-in-out forwards;
}
@keyframes cntpop{0%{transform:scale(1.6);opacity:0}30%{transform:scale(1);opacity:1}85%{transform:scale(1);opacity:1}100%{transform:scale(.7);opacity:0}}

/* WAVE ANNOUNCE */
#wave-ann{background:rgba(0,0,0,.65);backdrop-filter:blur(8px)}
.wa-title{font-size:52px;color:#fff;text-shadow:0 3px 0 var(--teal),0 0 40px rgba(26,107,107,.7);margin-bottom:6px;}
.wa-sub{font-family:'Nunito',sans-serif;font-size:17px;color:rgba(255,255,255,.65);}

/* HUD */
#hud{
  position:absolute;top:0;left:0;right:0;
  padding:10px 14px 6px;
  display:flex;justify-content:space-between;align-items:center;
  z-index:15;
  background:linear-gradient(180deg,rgba(0,0,0,.75) 0%,transparent 100%);
  pointer-events:none;
}
#hud.off{display:none}
#score-disp{font-size:30px;color:var(--gold);text-shadow:0 2px 8px rgba(0,0,0,.9),0 0 20px rgba(245,197,24,.4);min-width:80px;}
#wave-disp{font-size:14px;color:rgba(255,255,255,.75);font-family:'Nunito',sans-serif;font-weight:800;background:rgba(0,0,0,.5);padding:4px 12px;border-radius:20px;}
#timer-disp{font-size:30px;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.8);min-width:52px;text-align:right;}
#timer-disp.urgent{color:#ff4040;animation:urgpulse .45s ease-in-out infinite}
@keyframes urgpulse{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}

/* COMBO flash */
#combo-disp{
  position:absolute;top:58px;left:50%;transform:translateX(-50%);
  font-size:22px;color:#ff8c00;
  text-shadow:0 2px 8px rgba(0,0,0,.8);
  z-index:16;pointer-events:none;
  opacity:0;transition:opacity .2s;
  white-space:nowrap;
}
#combo-disp.show{opacity:1}

/* END SCREEN */
#end{
  background:linear-gradient(180deg,#061a08 0%,#0e3012 55%,#061408 100%);
  padding:16px 20px 24px;overflow-y:auto;
  justify-content:flex-start;padding-top:28px;
}
.end-sazka{height:40px;object-fit:contain;margin-bottom:12px;filter:drop-shadow(0 2px 8px rgba(0,0,0,.8))}
.end-title{font-family:'Nunito',sans-serif;font-size:18px;color:rgba(255,255,255,.6);font-weight:700}
.end-score{font-size:80px;line-height:1;color:var(--gold);text-shadow:0 4px 0 #7a5500,0 0 50px rgba(245,197,24,.6);}
.end-score-lbl{font-family:'Nunito',sans-serif;font-size:12px;color:rgba(255,255,255,.4);letter-spacing:3px;text-transform:uppercase;margin-bottom:20px;}
.name-wrap{width:100%;max-width:310px;display:flex;flex-direction:column;align-items:center;margin-bottom:14px;}
.name-wrap label{font-family:'Nunito',sans-serif;font-size:11px;color:rgba(255,255,255,.5);letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;}
#pname{font-family:'Baloo 2',cursive;font-size:20px;width:100%;padding:10px 18px;border-radius:12px;border:2px solid rgba(245,197,24,.5);background:rgba(0,0,0,.5);color:#fff;text-align:center;outline:none;}
#pname::placeholder{color:rgba(255,255,255,.25)}
#pname:focus{border-color:var(--gold)}
.save-btn{
  font-family:'Baloo 2',cursive;font-size:16px;
  color:#0d2e10;
  background:linear-gradient(180deg,#ffe040 0%,var(--gold) 45%,var(--dark-gold) 100%);
  border:none;border-radius:30px;
  padding:9px 28px;cursor:pointer;
  margin-top:8px;
  box-shadow:0 4px 0 #7a5500;
  transition:transform .1s,box-shadow .1s;
  -webkit-font-smoothing:antialiased;
}
.save-btn:active{transform:translateY(2px);box-shadow:0 2px 0 #7a5500}
.save-btn.saved{background:linear-gradient(180deg,#6dbf6d,#3a9a3a);color:#fff;box-shadow:0 4px 0 #1e5a1e}
.end-btns{display:flex;flex-direction:column;gap:8px;width:100%;max-width:310px;margin-bottom:18px;}
.btn-cta{font-family:'Baloo 2',cursive;font-size:22px;color:#0d2e10;background:linear-gradient(180deg,#ffe040 0%,var(--gold) 45%,var(--dark-gold) 100%);border:none;border-radius:50px;padding:15px 20px;cursor:pointer;box-shadow:0 5px 0 #7a5500,0 8px 20px rgba(0,0,0,.5);text-decoration:none;display:block;text-align:center;transition:transform .1s,box-shadow .1s;}
.btn-cta:active{transform:translateY(3px);box-shadow:0 2px 0 #7a5500}
.btn-sec{font-family:'Baloo 2',cursive;font-size:17px;color:#fff;background:rgba(255,255,255,.1);border:1.5px solid rgba(255,255,255,.25);border-radius:50px;padding:11px 20px;cursor:pointer;transition:background .15s;}
.btn-sec:active{background:rgba(255,255,255,.22)}
.lb-wrap{width:100%;max-width:310px;background:rgba(0,0,0,.45);border-radius:14px;border:1px solid rgba(245,197,24,.25);overflow:hidden;}
#lb-rows{max-height:min(320px,38vh);overflow-y:auto;-webkit-overflow-scrolling:touch;}

/* ── MOBILE COMPACT END SCREEN ───────────── */
@media (max-height: 820px) {
  #end{padding-top:14px;padding-bottom:16px;}
  .end-sazka{height:30px;margin-bottom:6px;}
  .end-title{font-size:14px;}
  .end-score{font-size:56px;}
  .end-score-lbl{margin-bottom:12px;}
  .name-wrap{margin-bottom:8px;}
  .end-btns{margin-bottom:12px;gap:6px;}
}

/* ── COOKIE BANNER ───────────────────────── */
#ck-banner{
  position:fixed;bottom:0;left:50%;right:auto;z-index:9999;
  transform:translateX(-50%);
  width:100%;max-width:480px;
  background:linear-gradient(0deg,#061a08 0%,#0d2b0f 100%);
  border-top:1px solid rgba(245,197,24,.3);
  border-left:1px solid rgba(245,197,24,.15);
  border-right:1px solid rgba(245,197,24,.15);
  border-radius:12px 12px 0 0;
  padding:14px 18px 18px;
  font-family:'Nunito',sans-serif;
  box-shadow:0 -4px 24px rgba(0,0,0,.65);
  transition:transform .35s ease;
}
#ck-banner.hidden{transform:translateX(-50%) translateY(110%);}
#ck-banner p{
  font-size:12px;line-height:1.6;
  color:rgba(255,255,255,.6);
  margin-bottom:12px;
}
#ck-banner p a{color:var(--gold);text-decoration:underline;}
/* hlavní tlačítka — stejná úroveň */
.ck-main{display:flex;gap:8px;margin-bottom:8px;}
.ck-accept,.ck-decline{
  flex:1;
  font-family:'Baloo 2',cursive;font-size:14px;font-weight:700;
  border:none;border-radius:30px;padding:10px 0;cursor:pointer;
}
.ck-accept{
  color:#0d2e10;
  background:linear-gradient(180deg,#ffe040 0%,var(--gold) 45%,var(--dark-gold) 100%);
  box-shadow:0 3px 0 #7a5500;
}
.ck-decline{
  color:rgba(255,255,255,.75);
  background:rgba(255,255,255,.08);
  border:1.5px solid rgba(255,255,255,.2);
}
/* nastavení — třetí úroveň, jen odkaz */
.ck-settings-link{
  display:block;text-align:center;
  font-size:11.5px;color:rgba(255,255,255,.4);
  text-decoration:underline;cursor:pointer;
  background:none;border:none;width:100%;font-family:'Nunito',sans-serif;
}
.ck-settings-link:hover{color:rgba(255,255,255,.7);}

/* panel nastavení */
#ck-panel{
  display:none;
  margin-bottom:12px;
  background:rgba(0,0,0,.35);
  border-radius:10px;
  padding:12px 14px;
  border:1px solid rgba(255,255,255,.08);
}
#ck-panel.open{display:block;}
.ck-toggle-row{
  display:flex;align-items:center;justify-content:space-between;
  margin-bottom:10px;
}
.ck-toggle-row:last-child{margin-bottom:0;}
.ck-toggle-label{font-size:12px;color:rgba(255,255,255,.7);}
.ck-toggle-label span{display:block;font-size:10.5px;color:rgba(255,255,255,.35);margin-top:1px;}
/* toggle switch */
.ck-switch{position:relative;width:40px;height:22px;flex-shrink:0;}
.ck-switch input{opacity:0;width:0;height:0;}
.ck-slider{
  position:absolute;inset:0;border-radius:22px;
  background:rgba(255,255,255,.15);cursor:pointer;
  transition:background .2s;
}
.ck-slider:before{
  content:'';position:absolute;
  width:16px;height:16px;border-radius:50%;
  background:#fff;left:3px;top:3px;
  transition:transform .2s;
}
.ck-switch input:checked + .ck-slider{background:var(--gold);}
.ck-switch input:checked + .ck-slider:before{transform:translateX(18px);}
.ck-switch input:disabled + .ck-slider{opacity:.5;cursor:not-allowed;}

.lb-head{background:rgba(245,197,24,.12);padding:9px 14px;font-size:13px;color:var(--gold);font-family:'Nunito',sans-serif;font-weight:900;letter-spacing:2px;text-transform:uppercase;text-align:center;}
.lb-row{display:flex;align-items:center;padding:7px 14px;border-top:1px solid rgba(255,255,255,.05);gap:8px;}
.lb-rank{font-size:13px;color:rgba(255,255,255,.35);min-width:22px;font-family:'Nunito',sans-serif;font-weight:700}
.lb-rank.g{color:#f5c518}.lb-rank.s{color:#c0c0c0}.lb-rank.b{color:#cd7f32}
.lb-name{flex:1;font-size:15px;color:#fff}
.lb-pts{font-size:15px;color:var(--gold)}
.lb-row.you{background:rgba(245,197,24,.08);border-left:3px solid var(--gold)}

#mute-btn{
  position:absolute;bottom:52px;right:14px;
  width:32px;height:32px;
  background:none;border:none;padding:0;
  cursor:pointer;z-index:20;
  opacity:0.55;
  transition:opacity .15s;
}
#mute-btn:active{opacity:1;}
#mute-btn svg{width:100%;height:100%;display:block;}
#xhair{position:absolute;width:44px;height:44px;pointer-events:none;z-index:12;display:none;transform:translate(-50%,-50%);}

/* věkové varování */
#age-warning{
  position:fixed;bottom:0;left:50%;transform:translateX(-50%);
  width:100%;max-width:480px;
  z-index:9998;
  background:rgba(6,16,8,.85);
  backdrop-filter:blur(4px);
  border-top:1px solid rgba(255,255,255,.08);
  padding:7px 16px;
  display:flex;align-items:center;justify-content:center;gap:8px;
  font-family:'Nunito',sans-serif;font-size:11px;
  color:rgba(255,255,255,.45);
  letter-spacing:.3px;
  pointer-events:none;
}
#age-warning .aw-badge{
  display:inline-flex;align-items:center;justify-content:center;
  width:20px;height:20px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.35);
  font-size:9px;font-weight:900;font-family:'Nunito',sans-serif;
  color:rgba(255,255,255,.5);
  flex-shrink:0;
}
