/* ===========================================================
   Klikovací výzva GBC — kreslený "sticker" design
   =========================================================== */
:root{
  --pan:#ff7a59;          /* Panelárna */
  --pan-d:#e85b39;
  --vgp:#3aa7ff;          /* VGP */
  --vgp-d:#1f87e0;
  --ink:#23203a;          /* tmavý obrys */
  --bg1:#fff4e0;
  --bg2:#ffe3c2;
  --paper:#fffdf7;
  --yellow:#ffd54a;
  --green:#5fd38a;
  --pink:#ff8fb1;
  --shadow:6px 6px 0 var(--ink);
  --shadow-sm:3px 3px 0 var(--ink);
  --radius:22px;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
html{background:#fdf3e6}
body{
  font-family:'Nunito','Segoe UI',system-ui,sans-serif;
  color:var(--ink);
  background:transparent;
  min-height:100vh;
  overflow-x:hidden;
}
h1,h2,h3,h4,.logo,.pin-reveal{font-family:'Baloo 2','Segoe UI',sans-serif}
a{color:inherit}
.hidden{display:none !important}

/* klidné fixní pozadí (kryje celý viewport → žádný "předěl" při scrollu) */
.bg-blobs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden;
  background:linear-gradient(180deg,#fef7ec 0%,#fdeedd 55%,#fce6d3 100%)}
.bg-blobs span{position:absolute;border-radius:50%;filter:blur(70px);opacity:.16}
.bg-blobs span:nth-child(1){width:46vw;height:46vw;background:var(--pan);left:-12vw;top:-10vw}
.bg-blobs span:nth-child(2){width:50vw;height:50vw;background:var(--vgp);right:-14vw;bottom:-12vw}
.bg-blobs span:nth-child(3){display:none}

.screen{position:relative;z-index:1;max-width:1080px;margin:0 auto;padding:24px 18px 60px}

/* ---------- karty / tlačítka ---------- */
.card{
  background:var(--paper);
  border:4px solid var(--ink);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:22px;
  margin-bottom:20px;
}
.btn{
  font-family:'Baloo 2','Segoe UI',sans-serif;font-size:1.05rem;font-weight:700;
  border:4px solid var(--ink);border-radius:16px;cursor:pointer;
  padding:12px 18px;background:#fff;box-shadow:var(--shadow-sm);
  transition:transform .08s ease,box-shadow .08s ease,background .15s;
}
.btn:hover{transform:translate(-1px,-1px);box-shadow:5px 5px 0 var(--ink)}
.btn:active{transform:translate(3px,3px);box-shadow:0 0 0 var(--ink)}
.btn-primary{background:var(--yellow)}
.btn-ghost{background:#fff}
.btn-big{width:100%;font-size:1.2rem;padding:14px}
.icon-btn{font-size:1.2rem;border:3px solid var(--ink);background:#fff;border-radius:12px;
  width:42px;height:42px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .08s}
.icon-btn:active{transform:translate(2px,2px);box-shadow:none}
.icon-btn.playing{background:var(--yellow);animation:pulse 1s ease-in-out infinite}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.12)}}

/* ---------- AUTH ---------- */
.auth-hero{text-align:center;margin:10px 0 22px}
.auth-emojis{font-size:2.6rem;animation:wiggle 3s ease-in-out infinite}
@keyframes wiggle{0%,100%{transform:rotate(-4deg)}50%{transform:rotate(4deg)}}
.logo{font-size:clamp(2.4rem,7vw,4rem);line-height:1;letter-spacing:.5px;
  color:var(--ink);text-shadow:4px 4px 0 var(--yellow)}
.tagline{margin-top:8px;display:flex;flex-direction:column;align-items:center;gap:8px}
.tagline-duel{display:inline-flex;align-items:center;gap:8px;justify-content:center;flex-wrap:nowrap}
.duel-team{display:inline-flex;align-items:center;justify-content:center;padding:5px 13px;
  border:3px solid var(--ink);border-radius:999px;box-shadow:var(--shadow-sm);
  font-family:'Baloo 2','Segoe UI',sans-serif;font-size:1.08rem;font-weight:800;line-height:1;
  width:132px;text-align:center;white-space:nowrap}
.duel-pan{background:#ffd9c9;color:var(--pan-d)}
.duel-vgp{background:#cfe7ff;color:var(--vgp-d)}
.duel-vs-mark{width:88px;height:88px;object-fit:contain;display:block}
.tagline-season{display:inline-flex;align-items:center;gap:6px;font-size:.9rem;font-weight:800;
  padding:4px 11px;border:2px dashed var(--ink);border-radius:999px;background:#fff8ea;opacity:.9;white-space:nowrap}
.auth-card{max-width:460px;margin:0 auto}
.tabs{display:flex;gap:10px;margin-bottom:18px}
.tab{flex:1;font-family:'Baloo 2';font-weight:700;font-size:1rem;padding:10px;cursor:pointer;
  border:4px solid var(--ink);border-radius:14px;background:#fff;box-shadow:var(--shadow-sm)}
.tab.is-active{background:var(--ink);color:#fff}
.auth-form{display:flex;flex-direction:column;gap:14px}
.auth-form .row{display:flex;gap:12px}
.auth-form .row label{flex:1;min-width:0}
label{display:flex;flex-direction:column;gap:6px;font-weight:600}
input{font-family:'Nunito','Segoe UI',sans-serif;font-size:1rem;padding:12px;border:3px solid var(--ink);
  border-radius:12px;background:#fff;outline:none;width:100%;max-width:100%}
input:focus{box-shadow:var(--shadow-sm)}
.pin-input{letter-spacing:.6em;text-align:center;font-size:1.4rem;font-family:'Baloo 2'}
.field-label{font-family:'Baloo 2','Segoe UI',sans-serif;font-weight:800;font-size:1rem;margin-top:6px}
.pick{display:flex;gap:12px}
.pick-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;
  font-family:'Nunito','Segoe UI',sans-serif;font-weight:600;padding:14px;cursor:pointer;background:#fff;
  border:3px solid var(--ink);border-radius:16px;transition:transform .1s,background .15s}
.pick-btn .pick-emoji{font-size:1.8rem}
.pick-btn:hover{transform:translateY(-2px)}
.pick-btn.is-active{background:var(--yellow);box-shadow:var(--shadow-sm)}

/* ---------- výběr budovy / týmu v registraci (tematické karty) ---------- */
.pick-building,.pick-gender{gap:14px;margin-top:2px}
.pick-building .pick-btn,.pick-gender .pick-btn{position:relative;gap:9px;padding:16px 10px 14px;
  border-width:3px;border-color:transparent;border-radius:18px;overflow:hidden;
  transition:transform .12s,box-shadow .15s,background .15s,border-color .15s,color .15s}
.pick-building .pick-btn .pick-emoji,.pick-gender .pick-btn .pick-emoji{font-size:1.8rem;
  width:56px;height:56px;display:grid;place-items:center;border-radius:50%;border:3px solid transparent;
  transition:background .15s,border-color .15s}
.pick-building .pick-btn span:last-child,.pick-gender .pick-btn span:last-child{
  font-family:'Baloo 2','Segoe UI',sans-serif;font-weight:800;font-size:1.06rem}
.pick-building .pick-btn:hover,.pick-gender .pick-btn:hover{transform:translateY(-3px);box-shadow:var(--shadow-sm)}

/* výchozí stav: bez rámečku, jen jemně tónované pozadí karty + ikony */
.pick-building .pick-btn[data-building="panelarna"]{background:#fff1ea}
.pick-building .pick-btn[data-building="panelarna"] .pick-emoji{background:#ffe2d6}
.pick-building .pick-btn[data-building="vgp"]{background:#eaf4ff}
.pick-building .pick-btn[data-building="vgp"] .pick-emoji{background:#d9ecff}
.pick-gender .pick-btn[data-gender="m"]{background:#eef3ff}
.pick-gender .pick-btn[data-gender="m"] .pick-emoji{background:#dde7ff}
.pick-gender .pick-btn[data-gender="f"]{background:#ffeef6}
.pick-gender .pick-btn[data-gender="f"] .pick-emoji{background:#ffe0ee}

/* aktivní = plná barva + bílá ikona + fajfka v rohu */
.pick-building .pick-btn.is-active[data-building="panelarna"]{background:var(--pan);color:#fff;border-color:var(--ink)}
.pick-building .pick-btn.is-active[data-building="vgp"]{background:var(--vgp);color:#fff;border-color:var(--ink)}
.pick-gender .pick-btn.is-active[data-gender="m"]{background:#5b8def;color:#fff;border-color:var(--ink)}
.pick-gender .pick-btn.is-active[data-gender="f"]{background:#e86fa6;color:#fff;border-color:var(--ink)}
.pick-building .pick-btn.is-active .pick-emoji,.pick-gender .pick-btn.is-active .pick-emoji{
  background:#fff;border-color:#fff}
.pick-building .pick-btn.is-active::after,.pick-gender .pick-btn.is-active::after{
  content:'✓';position:absolute;top:7px;right:11px;font-weight:900;font-size:1.05rem;color:#fff;line-height:1}
.pick-building .pick-btn.is-active,.pick-gender .pick-btn.is-active{box-shadow:var(--shadow-sm)}
.form-msg{font-weight:600;min-height:1.2em;color:#d63b3b}
.form-msg.ok{color:#2f9e54}
.admin-link{text-align:center;margin-top:18px;opacity:.6;font-size:.9rem}

/* ---------- animace přihlašovací obrazovky ---------- */
#screen-auth:not(.hidden) .logo,
#screen-auth:not(.hidden) .tagline,
#screen-auth:not(.hidden) .admin-link{animation:authRise .6s cubic-bezier(.2,1.2,.4,1) both}
#screen-auth:not(.hidden) .logo{animation-delay:.05s}
#screen-auth:not(.hidden) .tagline{animation-delay:.2s}
#screen-auth:not(.hidden) .admin-link{animation-delay:.6s}
#screen-auth:not(.hidden) .auth-card{animation:authCard .65s cubic-bezier(.2,1.3,.4,1) both;animation-delay:.35s}
@keyframes authRise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
@keyframes authCard{from{opacity:0;transform:translateY(28px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}

/* VS mark pulzuje, týmy se k sobě naklánějí */
.duel-vs-mark{animation:vsPulse 2.4s ease-in-out infinite}
@keyframes vsPulse{0%,100%{transform:scale(1) rotate(-3deg)}50%{transform:scale(1.1) rotate(3deg)}}
.duel-pan{animation:leanL 2.8s ease-in-out infinite}
.duel-vgp{animation:leanR 2.8s ease-in-out infinite}
@keyframes leanL{0%,100%{transform:translateX(0)}50%{transform:translateX(4px)}}
@keyframes leanR{0%,100%{transform:translateX(0)}50%{transform:translateX(-4px)}}

/* plynulé přepnutí tabů přihlášení/registrace */
.auth-form:not(.hidden){animation:formIn .35s ease}
@keyframes formIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}

/* zatřesení kartou při špatném přihlášení (vyšší prioritou přebije vstupní animaci) */
#screen-auth .auth-card.shake{animation:authShake .5s ease}
@keyframes authShake{10%,90%{transform:translateX(-2px)}20%,80%{transform:translateX(4px)}
  30%,50%,70%{transform:translateX(-9px)}40%,60%{transform:translateX(9px)}}

/* ---------- PIN modal ---------- */
.modal{position:fixed;inset:0;z-index:50;display:flex;align-items:center;justify-content:center;
  background:rgba(35,32,58,.55);padding:18px}
.modal-box{background:var(--paper);border:5px solid var(--ink);border-radius:26px;
  box-shadow:8px 8px 0 var(--ink);padding:30px;max-width:420px;text-align:center}
.modal-box h2{margin:10px 0}
.modal-box p{margin-bottom:16px}
.confetti-emoji{font-size:3rem}
.pop-in{animation:pop .4s cubic-bezier(.2,1.4,.5,1)}
@keyframes pop{0%{transform:scale(.6);opacity:0}100%{transform:scale(1);opacity:1}}
.pin-reveal{font-size:3.4rem;letter-spacing:.4em;padding:14px 10px 14px 24px;margin:0 0 16px;
  background:var(--yellow);border:4px dashed var(--ink);border-radius:18px}
.modal-box .btn{margin-top:8px}

/* ---------- DASHBOARD ---------- */
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;
  background:var(--paper);border:4px solid var(--ink);border-radius:18px;
  box-shadow:var(--shadow-sm);padding:10px 16px}
.brand{font-family:'Baloo 2';font-weight:800;font-size:1.3rem}
.topbar-right{display:flex;align-items:center;gap:10px}
.badge{font-weight:700;padding:6px 12px;border:3px solid var(--ink);border-radius:999px;background:#fff}
.badge.b-pan{background:var(--pan);color:#fff}
.badge.b-vgp{background:var(--vgp);color:#fff}
.countdown{background:var(--ink);color:#fff;border-radius:16px;padding:12px 16px;
  text-align:center;font-weight:700;margin-bottom:18px;box-shadow:var(--shadow-sm)}

/* stage */
.stage-card{padding:14px 14px 0}
.stage-head{display:flex;justify-content:center;align-items:center;margin-bottom:10px}
.verdict{font-family:'Baloo 2';font-weight:700;background:var(--yellow);
  border:3px solid var(--ink);border-radius:999px;padding:4px 14px;font-size:.95rem}
.tug-stage{position:relative;width:100%;padding:14px 0 4px}
.tug{display:flex;align-items:center;gap:10px}

/* týmové panely s čísly */
.tug-team{flex:1 1 0;min-width:0;position:relative;text-align:center;
  border:3px solid var(--ink);border-radius:18px;background:#fff;padding:14px 8px 10px;
  box-shadow:var(--shadow-sm);transition:transform .4s ease,box-shadow .4s ease,filter .4s ease}
.tug-badge{width:54px;height:54px;margin:0 auto;display:grid;place-items:center;font-size:1.9rem;
  border:3px solid var(--ink);border-radius:50%}
.tug-pan .tug-badge{background:#ffd9c9}
.tug-vgp .tug-badge{background:#cfe7ff}
.tug-name{font-family:'Baloo 2';font-weight:800;font-size:1.05rem;margin-top:6px}
.tug-avg{margin-top:2px;line-height:1.05}
.tug-avg b{font-family:'Baloo 2';font-size:2rem}
.tug-avg span{display:block;font-size:.64rem;opacity:.65;font-weight:600}
.tug-pan .tug-avg b{color:var(--pan-d)}
.tug-vgp .tug-avg b{color:var(--vgp-d)}
.tug-total{font-size:.74rem;opacity:.72;font-weight:600;margin-top:5px}
.tug-crown{display:none;position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  font-family:'Baloo 2';font-weight:800;font-size:.68rem;background:var(--yellow);
  border:2px solid var(--ink);border-radius:999px;padding:2px 9px;white-space:nowrap}
.tug-team.is-leading{transform:translateY(-4px) scale(1.04)}
.tug-team.is-leading .tug-crown{display:block}
.tug-pan.is-leading{box-shadow:5px 6px 0 var(--pan-d)}
.tug-vgp.is-leading{box-shadow:5px 6px 0 var(--vgp-d)}
.tug-team.is-losing{filter:saturate(.55) opacity(.92)}

/* prostředek: dominační pruh (fronta = úvaz klouže k vítězi) */
.tug-mid{flex:1.3 1 0;min-width:96px;display:flex;flex-direction:column;justify-content:center;gap:12px}
.tug-bar{position:relative;height:30px}
.tb-track{position:absolute;inset:0;border:3px solid var(--ink);border-radius:999px;overflow:hidden;background:#efe3d0}
.tb-pan,.tb-vgp{position:absolute;top:0;bottom:0;width:50%;transition:width .9s cubic-bezier(.2,1,.4,1)}
.tb-pan{left:0;background:linear-gradient(180deg,#ff9576,#ec6440)}
.tb-vgp{right:0;background:linear-gradient(180deg,#5cb8ff,#2f93e6)}
.tb-pct{position:absolute;top:50%;transform:translateY(-50%);font-family:'Baloo 2';font-weight:800;
  font-size:.74rem;color:#fff;text-shadow:1px 1px 0 rgba(0,0,0,.28)}
.tb-pan .tb-pct{left:10px}
.tb-vgp .tb-pct{right:10px}
.tb-tie{position:absolute;left:50%;top:-5px;bottom:-5px;width:2px;transform:translateX(-50%);
  background:var(--ink);opacity:.35;border-radius:2px}
.tb-knot{position:absolute;left:50%;margin-left:-9px;top:50%;margin-top:-21px;width:18px;height:42px;z-index:2;
  border:3px solid var(--ink);border-radius:7px;box-shadow:var(--shadow-sm);
  background:repeating-linear-gradient(0deg,#7a4e22 0 4px,#5a380f 4px 8px);transition:left .9s cubic-bezier(.2,1,.4,1)}
.tug-gap{text-align:center;font-size:.78rem;font-weight:700;opacity:.82;min-height:1.1em;line-height:1.2}

.slogan-bubble{position:relative;margin:24px auto 16px;max-width:80%;background:#fff;
  border:3px solid var(--ink);border-radius:18px;padding:12px 18px;text-align:center;
  font-weight:600;box-shadow:var(--shadow-sm)}
/* ocas bubliny mířící nahoru k provazu (obrys + bílá výplň) */
.slogan-bubble::before,.slogan-bubble::after{content:"";position:absolute;left:50%;bottom:100%;
  width:0;height:0;border-style:solid;transform:translateX(-50%)}
.slogan-bubble::before{border-width:0 12px 13px 12px;
  border-color:transparent transparent var(--ink) transparent}
.slogan-bubble::after{border-width:0 8px 9px 8px;
  border-color:transparent transparent #fff transparent;margin-bottom:-3px}

/* grid karet */
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.grid h3{margin-bottom:12px}
.grid h4{margin:16px 0 8px}
@media(max-width:760px){.grid{grid-template-columns:1fr}}

/* rozpis denního stropu */
.plan-box{display:flex;align-items:baseline;justify-content:space-between;flex-wrap:wrap;gap:4px 10px;
  background:var(--bg2);border:3px solid var(--ink);border-radius:14px;padding:8px 14px;margin-bottom:12px}
.plan-day{font-family:'Baloo 2';font-weight:700;font-size:1.15rem}
.plan-day b{color:var(--pan-d);font-size:1.5rem}
.plan-note{font-size:.82rem;opacity:.8}

/* stepper */
.log-date{margin-bottom:10px}
.stepper{display:flex;gap:8px;align-items:stretch;margin-bottom:14px}
.stepper .step{font-family:'Baloo 2';font-weight:700;border:3px solid var(--ink);border-radius:12px;
  background:#fff;cursor:pointer;padding:0 10px;box-shadow:var(--shadow-sm);min-width:46px}
.stepper .step:active{transform:translate(2px,2px);box-shadow:none}
#log-count{flex:1;text-align:center;font-size:1.5rem;font-family:'Baloo 2'}
.remaining{margin-top:10px;font-weight:600}
.log-hint{display:inline-flex;align-items:center;gap:5px;margin-top:12px;cursor:pointer;
  font-family:inherit;font-size:.9rem;font-weight:700;color:var(--vgp-d);background:none;
  border:none;padding:4px 0;text-decoration:underline dotted;text-underline-offset:3px}
.log-hint:hover{color:var(--pan-d)}
.flash-card{animation:flashcard 1.4s ease}
@keyframes flashcard{0%,100%{box-shadow:var(--shadow)}
  25%{box-shadow:0 0 0 4px var(--yellow),var(--shadow)}
  60%{box-shadow:0 0 0 4px var(--yellow),var(--shadow)}}
.backfill{margin-top:14px;border-top:2px dashed var(--ink);padding-top:10px}
.backfill summary{cursor:pointer;font-weight:700}
.backfill-body{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px;align-items:center}
.backfill-body input{flex:1;min-width:120px}

/* osobní statistiky — dlaždice + progres */
.progress-card{display:flex;flex-direction:column}
.stat-tiles{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:12px;
  flex:1 1 auto;margin-bottom:18px}
.stile{border:3px solid var(--ink);border-radius:14px;background:#fff;padding:12px 6px;text-align:center;
  box-shadow:var(--shadow-sm);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px}
.stile-emoji{font-size:1.5rem;line-height:1}
.stile-val{font-family:'Baloo 2';font-weight:800;font-size:1.6rem;line-height:1.05}
.stile-label{font-size:.76rem;font-weight:600;opacity:.75}
.stile-sub{font-size:.66rem;opacity:.6}
.month-progress{margin-top:auto}
.mp-top{display:flex;justify-content:space-between;font-weight:700;margin-bottom:5px}
.mp-top b{font-family:'Baloo 2'}
.mp-bar{height:20px;border:3px solid var(--ink);border-radius:999px;background:#fff;overflow:hidden}
.mp-bar > i{display:block;height:100%;width:0;border-radius:999px;
  background:linear-gradient(90deg,#7fe0a3,#3fae6e);transition:width .9s cubic-bezier(.2,1,.4,1)}

/* sloupcový graf dnů */
.daychart{position:relative;display:flex;align-items:flex-end;gap:3px;height:256px;
  margin:12px 0 16px;padding-top:16px;border-bottom:3px solid var(--ink)}
.dc-bar{flex:1;min-width:3px;max-width:26px;margin:0 auto;
  border:2px solid var(--ink);border-bottom:none;border-radius:6px 6px 0 0;background:#e7d9c2;
  transition:height .6s cubic-bezier(.2,1,.4,1)}
.dc-bar.has{background:linear-gradient(180deg,#7fe0a3,#3fae6e)}
.dc-bar.today{background:linear-gradient(180deg,#ffe07a,#f4b400)}
.dc-bar.holiday{background:repeating-linear-gradient(135deg,#e7d9c2,#e7d9c2 5px,#d8c8ab 5px,#d8c8ab 10px);border-style:dashed}
.capline{position:absolute;left:0;right:0;border-top:2px dashed var(--pan-d);opacity:.6;pointer-events:none}
.capline span{position:absolute;right:2px;top:-15px;font-size:.66rem;font-weight:700;color:var(--pan-d)}
.daychart-sm{height:96px}
.dc-bar[data-tip]{cursor:pointer}
.dc-bar[data-tip]:hover{filter:brightness(1.08);outline:2px solid var(--ink);outline-offset:-1px}
.chart-tip{position:fixed;z-index:80;pointer-events:none;background:var(--ink);color:#fff;
  font-weight:700;font-size:.82rem;line-height:1.4;padding:8px 12px;border-radius:10px;
  white-space:pre-line;text-align:center;box-shadow:var(--shadow-sm);max-width:220px}
.chart-tip.hidden{display:none}

/* building stats */
.building-stats{display:flex;flex-direction:column;gap:16px}
.bs-row{display:flex;flex-direction:column;gap:6px;cursor:pointer;padding:10px;margin:0;
  border:2px solid #eadfca;border-radius:14px;transition:background .15s,border-color .15s}
.bs-row:hover{background:var(--bg2);border-color:var(--ink)}
.bs-go{font-style:normal;opacity:.5;font-weight:800}
.bs-top{display:flex;justify-content:space-between;align-items:center;font-weight:700}
.bs-top .avg{font-family:'Baloo 2';font-size:1.3rem}
.b-tag{display:inline-block;padding:3px 14px;border:2px solid var(--ink);border-radius:999px;
  font-family:'Baloo 2';font-weight:800;font-size:.98rem;color:#fff;line-height:1.5}
.b-tag.b-pan{background:var(--pan)}
.b-tag.b-vgp{background:var(--vgp)}
.bs-sub{font-size:.84rem;opacity:.8;display:flex;align-items:center;gap:6px}
.bar{height:18px;border:3px solid var(--ink);border-radius:999px;background:#fff;overflow:hidden}
.bar > i{display:block;height:100%;width:0;transition:width .9s cubic-bezier(.2,1,.4,1)}
.bar-pan > i{background:var(--pan)}
.bar-vgp > i{background:var(--vgp)}

/* souboj budov v rámci pohlaví (ženy P vs V, muži P vs V) */
#gender-stats{display:flex;flex-direction:column;gap:16px}
.gbattle{padding:12px 14px;border:3px solid var(--ink);border-radius:14px;background:var(--bg2)}
.gbattle-title{font-family:'Baloo 2';font-weight:800;font-size:1.1rem;margin-bottom:10px}
.gbattle-head{display:flex;justify-content:space-between;align-items:baseline;gap:12px;
  font-size:.95rem;font-weight:700;margin-bottom:10px}
.gbh{display:inline-flex;align-items:baseline;gap:6px;padding:3px 10px;border-radius:10px}
.gbh b{font-family:'Baloo 2';font-weight:800}
.gbh small{opacity:.6;font-weight:600}
.gbh-pan{color:var(--pan-d)}
.gbh-vgp{color:var(--vgp-d)}
.gbh.win{background:#fff;box-shadow:inset 0 0 0 2px currentColor}
.gbattle-bar{display:flex;height:24px;border:3px solid var(--ink);border-radius:999px;overflow:hidden}
.gbattle-bar > div{transition:width .9s cubic-bezier(.2,1,.4,1);min-width:0}
.gp-pan{background:var(--pan)}
.gp-vgp{background:var(--vgp)}
.stats-card h4{margin-top:22px}
@media(min-width:760px){
  #gender-stats{gap:22px}
  .stats-card h4{margin-top:28px}
}

/* leaderboard */
.leaderboard{list-style:none;display:flex;flex-direction:column;gap:8px}
.leaderboard li{display:flex;align-items:center;gap:10px;border:3px solid var(--ink);
  border-radius:14px;padding:8px 12px;background:#fff;font-weight:600}
.lb-rank{font-family:'Baloo 2';font-weight:800;width:30px;height:30px;display:grid;place-items:center;
  border:3px solid var(--ink);border-radius:50%;background:var(--bg2);flex:none}
.lb-item.m1 .lb-rank{background:var(--yellow)}
.lb-item.m2 .lb-rank{background:#dcdce4}
.lb-item.m3 .lb-rank{background:#e9b27a}
.leaderboard li[data-id]{cursor:pointer;transition:background .15s}
.leaderboard li[data-id]:hover{background:var(--bg2)}
.leaderboard .lb-total{margin-left:auto;font-family:'Baloo 2';font-size:1.1rem}
.lb-pager{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:12px;font-weight:700}
.lb-pager .pg{font-family:'Baloo 2';border:3px solid var(--ink);background:#fff;border-radius:10px;
  width:38px;height:34px;cursor:pointer;box-shadow:var(--shadow-sm);font-size:1.15rem}
.lb-pager .pg:not(:disabled):active{transform:translate(2px,2px);box-shadow:none}
.lb-pager .pg:disabled{opacity:.4;cursor:default;box-shadow:none}

/* detail modal (budova / účastník) */
.modal-detail{max-width:720px;width:100%;text-align:left;position:relative;max-height:86vh;overflow:auto}
.modal-close{position:absolute;top:12px;right:12px;border:3px solid var(--ink);background:#fff;
  width:34px;height:34px;border-radius:10px;cursor:pointer;font-weight:800;box-shadow:var(--shadow-sm);z-index:2}
.modal-detail h2{margin:0 40px 6px 0}
.modal-h4{font-family:'Baloo 2';font-size:1rem;margin:16px 0 8px}
.muted{opacity:.7;font-size:.85rem;margin-bottom:10px}
.ptable{width:100%;border-collapse:collapse}
.ptable th,.ptable td{padding:9px 10px;border-bottom:2px solid #efe6d2;text-align:left;vertical-align:top}
.ptable th{font-family:'Baloo 2';font-size:.85rem;white-space:nowrap}
.ptable .num{text-align:right;font-family:'Baloo 2';white-space:nowrap}
.ptable .pname span{font-weight:700}
.ptable .pname .ex-break{margin-top:5px}
.ptable .prow{cursor:pointer;transition:background .15s}
.ptable .prow:hover{background:var(--bg2)}
.ptable tr:last-child td{border-bottom:none}

/* hlavička modalu budovy */
.modal-bld-head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-bottom:8px}
.modal-bld-head .b-tag{font-size:1.15rem;padding:5px 18px}
.modal-bld-total{font-size:.95rem;font-weight:700;opacity:.85}
.modal-bld-total b{font-family:'Baloo 2';font-size:1.2rem;opacity:1}

/* měsíční přehled cviků v detailu osoby */
.ex-months{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin:6px 0 4px}
.ex-month{border:2px solid #eadfca;border-radius:14px;padding:12px;background:#fff}
.ex-month-head{display:flex;align-items:baseline;justify-content:space-between;gap:8px;
  font-weight:700;margin-bottom:8px}
.ex-month-head span{font-family:'Baloo 2'}
.ex-month-head b{font-family:'Baloo 2';font-size:1.25rem}
.ex-month .ex-break{margin-top:0}
.leaderboard .dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--ink);flex:none}
.dot.panelarna{background:var(--pan)}.dot.vgp{background:var(--vgp)}

/* měsíční tabulka */
.month-switch{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.mbtn{font-family:'Baloo 2';font-weight:700;padding:8px 14px;border:3px solid var(--ink);
  border-radius:12px;background:#fff;cursor:pointer;box-shadow:var(--shadow-sm)}
.mbtn.is-active{background:var(--ink);color:#fff}
.month-meta{font-weight:600;margin-bottom:12px}
.month-meta b{font-family:'Baloo 2'}
.month-grid{display:flex;flex-direction:column;gap:18px}
.week-block{display:flex;flex-direction:column;gap:10px}
.week-head{display:flex;justify-content:space-between;align-items:center;gap:10px;
  font-family:'Baloo 2';font-weight:800;font-size:.95rem;padding:6px 12px;
  background:var(--bg2);border:3px solid var(--ink);border-radius:12px}
.week-sum{background:#fff;border:2px solid var(--ink);border-radius:999px;padding:2px 12px;font-size:.88rem;white-space:nowrap}
.week-days{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.day-cell{display:flex;flex-direction:column;gap:8px;border:3px solid var(--ink);border-radius:14px;
  padding:10px 12px;background:#fff;transition:background .2s}
.day-cell.today{background:var(--yellow)}
.day-cell.future{opacity:.5;background:#f4ece0}
.day-cell.saved{box-shadow:inset 0 0 0 2px var(--green)}
.day-head{display:flex;align-items:center;justify-content:space-between;gap:8px}
.day-date{font-weight:800;font-size:.95rem;font-family:'Baloo 2'}
.day-controls{display:flex;align-items:stretch;gap:8px}
.day-ex{flex:1 1 auto;min-width:0;max-width:none;height:42px;padding:6px 8px;font-size:.9rem;font-weight:700;
  border:2px solid var(--ink);border-radius:10px;background:#fff;cursor:pointer}
.day-input{flex:0 0 84px;width:84px;min-width:0;height:42px;padding:6px;font-size:1.15rem;font-weight:700;
  text-align:center;border:2px solid var(--ink);border-radius:10px;background:#fff}
.day-cell.future .day-ex,
.day-cell.future .day-input{pointer-events:none;background:transparent;border-color:#ccc;color:#999}
.day-pts{font-size:.82rem;font-weight:700;color:#666;text-align:right}
.day-pts b{font-family:'Baloo 2';color:var(--ink)}
.day-tick{font-weight:800;color:var(--green);min-width:16px;text-align:center;font-size:1.1rem}
.day-tick.err{color:#d63b3b}

/* buňka státního svátku */
.day-cell.holiday{justify-content:flex-start;background:repeating-linear-gradient(135deg,#f3ece0,#f3ece0 10px,#ece2d1 10px,#ece2d1 20px);
  border-style:dashed}
.day-cell.holiday .day-date{opacity:.8}
.holiday-label{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  text-align:center;padding:6px 0}
.holiday-label b{font-family:'Baloo 2';font-size:1rem}
.holiday-label span{font-size:.85rem;font-weight:700;opacity:.75}

@media(max-width:760px){
  .week-days{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:480px){
  .week-days{grid-template-columns:1fr}
}

.foot{text-align:center;margin-top:18px;opacity:.7;font-weight:600}

/* confetti */
.confetti-layer{position:fixed;inset:0;pointer-events:none;z-index:60;overflow:hidden}
.confetti-layer i{position:absolute;width:12px;height:12px;border-radius:3px}

/* float +N popup */
.float-num{position:fixed;z-index:61;font-family:'Baloo 2';font-weight:800;font-size:2.2rem;
  color:var(--green);pointer-events:none;text-shadow:2px 2px 0 var(--ink)}

/* ===================== MOBIL / RESPONZIVITA ===================== */
@media(max-width:620px){
  .screen{padding:14px 11px 48px}
  .card{padding:16px;border-width:3px;border-radius:18px;box-shadow:4px 4px 0 var(--ink)}

  .duel-team{font-size:.96rem;padding:4px 10px;border-width:2px;width:112px}
  .duel-vs-mark{width:36px;height:36px}
  .tagline-season{font-size:.82rem;padding:4px 9px}

  .topbar{flex-wrap:wrap;gap:8px;padding:9px 12px}
  .brand{font-size:1.05rem}
  .badge{font-size:.82rem;padding:5px 10px}
  .topbar-right{gap:8px}

  .stage-head{gap:6px}
  .verdict{font-size:.8rem;padding:4px 10px}
  .slogan-bubble{max-width:100%;font-size:.9rem;padding:10px 12px}

  /* přetahovaná na mobilu – kompaktnější panely */
  .tug{gap:6px}
  .tug-team{padding:12px 4px 8px}
  .tug-badge{width:44px;height:44px;font-size:1.5rem}
  .tug-name{font-size:.92rem}
  .tug-avg b{font-size:1.55rem}
  .tug-total{font-size:.66rem}
  .tug-crown{font-size:.6rem;padding:2px 7px}
  .tug-mid{min-width:68px}
  .tug-bar{height:26px}
  .tb-knot{height:36px;margin-top:-18px;width:16px;margin-left:-8px}
  .tb-pct{font-size:.64rem}
  .tug-gap{font-size:.68rem}

  .modal-box{padding:22px}
  .pin-reveal{font-size:2.3rem;letter-spacing:.22em;padding:12px 6px 12px 16px}

  /* stepper v jedné řádce, tlačítka se smrští */
  .stepper{gap:6px}
  .stepper .step{min-width:0;flex:1;padding:8px 4px;font-size:.95rem}
  #log-count{flex:1.4;font-size:1.4rem;min-width:60px}

  .plan-day b{font-size:1.3rem}
  .ring-wrap{width:140px}
  .gl{font-size:.8rem;padding:3px 8px}
  .gl b{font-size:.95rem}
  .leaderboard li{font-size:.9rem;padding:7px 10px;gap:8px}
  .stat-tiles{gap:7px}
  .stile{padding:8px 4px}
  .stile-val{font-size:1.2rem}
  .stile-label{font-size:.68rem}
  .daychart{height:200px}
}

@media(max-width:760px){
  .auth-form .row{flex-direction:column;gap:14px}     /* jméno + příjmení pod sebe */
}

@media(max-width:380px){
  .logo{font-size:2rem}
  .tagline{gap:6px}
  .tagline-duel{gap:6px}
  .duel-team{width:102px;font-size:.9rem;padding:4px 8px}
  .duel-vs-mark{width:30px;height:30px}
  .gender-head{font-size:.75rem}
  .stepper .step{font-size:.85rem}
}

/* ── Fyzická výzva: výběr cviku, body, rozpad ─────────────────────────────── */
.pick-exercise{margin:6px 0 4px}
.pick-exercise .pick-btn{padding:10px 6px;position:relative}
.pick-exercise .pick-btn .pick-emoji{font-size:1.5rem}
.pick-exercise .pick-btn.is-active{background:var(--green);color:#063}
.pick-coef{font-size:.72rem;font-weight:800;opacity:.7}
.points-preview{text-align:center;font-weight:700;margin:2px 0 6px;color:#555}
.points-preview b{font-family:'Baloo 2';font-size:1.15rem;color:var(--ink)}

/* rozpad po cviku (jemné barevné štítky) */
.ex-break{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.ex-chip{font-size:.8rem;font-weight:800;border-radius:999px;padding:3px 11px;white-space:nowrap;
  background:var(--bg2);color:#5a4f3a}
.ex-chip.ex-anglicak{background:#ffe6d2;color:#9a4d12}
.ex-chip.ex-kliky{background:#dcecff;color:#10568f}
.ex-chip.ex-drepy{background:#dcf4e3;color:#1d7a3f}

/* (styly mini-selectu .day-ex jsou v sekci měsíční mřížky výše) */
