:root{
  color-scheme:dark;
  --bg:#040404;
  --panel:#0d0d0d;
  --panel2:#151515;
  --line:#292929;
  --line-strong:#414141;
  --text:#f5f5f2;
  --muted:#8b8b86;
  --acid:#d4ff00;
  --acid-soft:rgba(212,255,0,.13);
  --violet:#7c2cff;
  --violet-deep:#35105e;
  --green:#37d67a;
  --red:#ff5a5f;
  --orange:#ff8a3d;
  --shadow:0 28px 90px rgba(0,0,0,.62);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
html,body{margin:0;min-height:100%;background:var(--bg);color:var(--text);font-family:Inter,system-ui,-apple-system,"Segoe UI",sans-serif}
body{overflow-x:hidden;background:
  radial-gradient(circle at 50% -12%,rgba(124,44,255,.17),transparent 31%),
  radial-gradient(circle at 87% 8%,rgba(212,255,0,.06),transparent 19%),
  linear-gradient(180deg,#050505 0%,#020202 100%)}
button,input{font:inherit}
button{color:inherit}
.noise{position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.08;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 180 180' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E")}
.page-shell{width:min(100%,920px);margin:0 auto;padding:22px 22px 48px}
.hero{text-align:center;margin-bottom:25px;position:relative;padding-top:14px}
.top-actions{display:flex;justify-content:flex-end;gap:8px;min-height:38px}
.ghost-button{border:1px solid var(--line);background:rgba(10,10,10,.65);border-radius:999px;padding:8px 13px;color:#bcbcb7;cursor:pointer}
.ghost-button:hover{color:var(--text);border-color:var(--acid)}
.logo{display:block;width:min(100%,600px);height:auto;margin:-8px auto 0}
.logo-text{font:900 108px/1 Georgia,serif;fill:#f2f2ef;letter-spacing:-7px}
.tagline{margin:-12px 0 0;color:#aaa9a3;letter-spacing:.06em;font-size:.88rem;text-transform:lowercase}
.app-card{width:100%;position:relative;overflow:hidden;background:linear-gradient(180deg,rgba(20,20,20,.94),rgba(7,7,7,.98));border:1px solid var(--line);border-radius:22px;padding:25px;box-shadow:var(--shadow)}
.app-card:before{content:"";position:absolute;left:-80px;top:-40px;width:260px;height:160px;border:1px solid rgba(212,255,0,.22);transform:rotate(-8deg);filter:blur(.1px)}
.app-card:after{content:"";position:absolute;right:-110px;bottom:-70px;width:300px;height:180px;border:1px solid rgba(124,44,255,.22);transform:rotate(11deg)}
.card-head,.switch-row,.meta-row,.actions,.section-title-row,.progress-copy,.tutorial-actions{display:flex;align-items:center;justify-content:space-between;gap:12px}
.card-head{position:relative;z-index:1;margin-bottom:20px}
.card-head h1{font-size:clamp(1.8rem,4vw,2.65rem);margin:3px 0 0;letter-spacing:-.04em}
.eyebrow{display:inline-block;color:var(--acid);font-size:.71rem;font-weight:900;letter-spacing:.15em}
.round-badge{border:1px solid rgba(212,255,0,.25);background:var(--acid-soft);color:var(--acid);padding:8px 11px;border-radius:999px;font-size:.78rem;font-weight:800}
.switch-row{position:relative;z-index:2;align-items:flex-end}
.control-group{display:grid;gap:7px;flex:1}
.control-label{font-size:.68rem;text-transform:uppercase;letter-spacing:.12em;color:#777772}
.segmented{display:flex;padding:4px;background:#070707;border:1px solid var(--line);border-radius:12px}
.segmented button{flex:1;border:0;color:var(--muted);background:transparent;padding:10px 15px;border-radius:8px;cursor:pointer;font-weight:800}
.segmented button small{font-size:.58rem;color:#777;vertical-align:top;margin-left:2px}
.segmented button.active{background:linear-gradient(135deg,var(--acid),#a6c900);color:#0a0a0a;box-shadow:0 0 28px rgba(212,255,0,.15)}
.segmented button.active small{color:#252525}
.meta-row{font-size:.8rem;color:var(--muted);margin:17px 2px 12px;flex-wrap:wrap;position:relative;z-index:1}
.hint-box{min-height:230px;border:1px solid var(--line);background:
  linear-gradient(135deg,rgba(124,44,255,.08),transparent 38%),
  repeating-linear-gradient(120deg,rgba(255,255,255,.015) 0 1px,transparent 1px 10px),
  #080808;border-radius:17px;padding:25px;display:grid;place-items:center;text-align:center;position:relative;overflow:hidden;z-index:1}
.hint-box:before,.hint-box:after{content:"";position:absolute;width:190px;height:1px;background:linear-gradient(90deg,transparent,var(--acid),transparent);opacity:.4}
.hint-box:before{top:18px;left:-32px;transform:rotate(-8deg)}
.hint-box:after{right:-34px;bottom:18px;transform:rotate(8deg)}
.music-player{display:grid;place-items:center;gap:13px;width:100%;position:relative;z-index:1}
.player-main{display:flex;align-items:center;justify-content:center;gap:22px}
.play-btn{width:88px;height:88px;border-radius:50%;border:1px solid #4e4e4a;background:radial-gradient(circle at 35% 30%,#292929,#0d0d0d 60%);color:var(--acid);font-size:1.9rem;cursor:pointer;box-shadow:inset 0 0 0 7px #0a0a0a,0 0 45px rgba(124,44,255,.15)}
.play-btn:hover{border-color:var(--acid);box-shadow:inset 0 0 0 7px #0a0a0a,0 0 34px rgba(212,255,0,.17)}
.audio-copy{display:grid;gap:4px;text-align:left}
.audio-copy strong{font-size:1.65rem;letter-spacing:-.04em}
.audio-copy span{font-size:.82rem;color:var(--muted)}
.waveform{display:flex;align-items:center;justify-content:center;gap:4px;height:46px;width:min(100%,360px)}
.waveform i{display:block;width:4px;border-radius:99px;background:linear-gradient(180deg,var(--acid),var(--violet));opacity:.5;animation:waveIdle 1.4s ease-in-out infinite;animation-delay:calc(var(--i) * -70ms)}
.waveform.playing i{opacity:1;animation-duration:.55s}
@keyframes waveIdle{0%,100%{height:10px}50%{height:calc(13px + (var(--i) % 5) * 5px)}}
.volume-row{display:flex;align-items:center;gap:10px;color:#888;font-size:.76rem}
.volume-row input{accent-color:var(--acid);width:130px}
.text-mode-box{display:grid;gap:12px;max-width:650px}
.text-mode-box .beta-pill{justify-self:center;border:1px solid rgba(124,44,255,.45);background:rgba(124,44,255,.1);color:#c6a6ff;border-radius:999px;padding:6px 10px;font-size:.7rem;font-weight:900;text-transform:uppercase;letter-spacing:.1em}
.hint-text{max-width:580px;font-size:1.08rem;line-height:1.65;margin:0}
.clue-row{position:relative;z-index:1;display:flex;align-items:center;justify-content:space-between;gap:15px;margin:13px 0 0;padding:14px 16px;background:#090909;border:1px solid var(--line);border-radius:13px}
.clue-row p{margin:4px 0 0;color:#c8c8c3;line-height:1.45}
.clue-label{color:var(--acid);font-size:.66rem;font-weight:900;letter-spacing:.13em;text-transform:uppercase}
.cover-hint{width:64px;min-width:64px;aspect-ratio:1;border-radius:9px;overflow:hidden;border:1px solid #444;position:relative;display:grid;place-items:center;background:linear-gradient(145deg,#111,#080808);box-shadow:inset 0 0 0 1px rgba(255,255,255,.025);transition:border-color .2s ease,transform .2s ease,box-shadow .2s ease}
.cover-hint.is-locked:after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(255,255,255,.025) 0 7px,transparent 7px 14px);pointer-events:none}
.cover-hint-question{position:relative;z-index:1;font-size:2rem;line-height:1;font-weight:900;color:var(--acid);text-shadow:0 0 18px color-mix(in srgb,var(--acid) 45%,transparent);user-select:none}
.cover-hint img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:none;transform:scale(1.02);opacity:0;transition:opacity .25s ease,transform .25s ease}
.cover-hint.is-revealed{border-color:color-mix(in srgb,var(--acid) 48%,#444);box-shadow:0 0 22px color-mix(in srgb,var(--acid) 13%,transparent)}
.cover-hint.is-revealed img{opacity:1;transform:scale(1)}
.progress-wrap{margin:17px 0 18px;position:relative;z-index:1}
.progress-copy{font-size:.72rem;color:#777;margin-bottom:8px;text-transform:uppercase;letter-spacing:.08em}
.progress-copy strong{color:#aaa}
.progress{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.step{height:8px;border-radius:99px;background:#292929;position:relative;overflow:hidden}
.step.used{background:linear-gradient(90deg,var(--violet),var(--acid))}
.step.current{outline:1px solid rgba(212,255,0,.45);outline-offset:2px}
.guess-area{display:grid;gap:10px;position:relative;z-index:4}
.input-wrap{position:relative}
.guess-area input{width:100%;border:1px solid var(--line);border-radius:12px;background:#080808;color:white;padding:15px 16px;outline:none}
.guess-area input:focus{border-color:var(--acid);box-shadow:0 0 0 3px rgba(212,255,0,.09)}
.suggestions{position:absolute;z-index:20;top:calc(100% + 6px);left:0;right:0;border:1px solid #3a3a36;border-radius:14px;background:rgba(12,12,12,.98);box-shadow:0 22px 65px rgba(0,0,0,.82),0 0 0 1px rgba(212,255,0,.04);max-height:min(56vh,540px);overflow-y:auto;overscroll-behavior:contain;scrollbar-gutter:stable;scrollbar-width:auto;scrollbar-color:var(--acid) #1a1a1a}
.suggestions::-webkit-scrollbar{width:14px}
.suggestions::-webkit-scrollbar-track{background:#171717;border-left:1px solid #292929;border-radius:0 13px 13px 0}
.suggestions::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--acid),#91ae00);border:3px solid #171717;border-radius:999px}
.suggestions::-webkit-scrollbar-thumb:hover{background:#e4ff66}
.suggestions-head{position:sticky;top:0;z-index:3;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 13px;background:rgba(18,18,18,.96);border-bottom:1px solid #30302d;backdrop-filter:blur(8px)}
.suggestions-head strong{font-size:.72rem;color:var(--acid);text-transform:uppercase;letter-spacing:.07em}
.suggestions-head span{font-size:.68rem;color:#777;text-align:right}
.suggestion{min-height:68px;padding:9px 12px;cursor:pointer;border-bottom:1px solid #242424;display:grid;grid-template-columns:48px minmax(0,1fr) minmax(90px,150px);align-items:center;gap:11px;transition:background .12s ease,border-color .12s ease}
.suggestion:last-child{border-bottom:0}
.suggestion:hover,.suggestion.selected{background:linear-gradient(90deg,rgba(212,255,0,.12),rgba(124,44,255,.08));box-shadow:inset 3px 0 0 var(--acid)}
.suggestion-cover{position:relative;width:48px;height:48px;border-radius:8px;overflow:hidden;display:grid;place-items:center;background:linear-gradient(145deg,#111,#2b1644);border:1px solid #40403b;color:var(--acid);font:900 1.15rem Georgia,serif}
.suggestion-cover img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#111}
.suggestion-copy{display:grid;gap:4px;min-width:0}
.suggestion-copy strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.91rem;color:#f2f2ef}
.suggestion-copy small{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#777;font-size:.71rem}
.suggestion-album{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#9a9a95;font-size:.72rem;text-align:right}
.suggestion:hover .suggestion-copy strong,.suggestion.selected .suggestion-copy strong{color:var(--acid)}
.suggestions-empty{margin:0;padding:22px 14px;color:#777;text-align:center;font-size:.8rem}
button.primary,.link-button{border:0;background:linear-gradient(135deg,var(--acid),#a7c900);color:#080808;border-radius:12px;padding:13px 18px;text-decoration:none;text-align:center;cursor:pointer;font-weight:900}
button.primary:hover,.link-button:hover{filter:brightness(1.07)}
button.secondary{border:1px solid #383838;background:#151515;color:white;border-radius:12px;padding:13px 18px;cursor:pointer;font-weight:800}
button.secondary:hover{border-color:#666}
button:disabled,input:disabled{opacity:.45;cursor:not-allowed}
.actions button{flex:1}
.attempts-section{margin-top:24px;position:relative;z-index:1}
.attempts-section h2{font-size:.72rem;color:var(--muted);text-transform:uppercase;letter-spacing:.11em;margin:0}
.shortcut{font-size:.7rem;color:#5f5f5b}
.attempts-list{display:grid;gap:8px;margin-top:9px}
.empty{border:1px dashed var(--line);border-radius:12px;padding:14px;color:#73736f;margin:0}
.attempt{display:flex;justify-content:space-between;gap:12px;border:1px solid var(--line);border-radius:12px;padding:12px 14px;background:#0b0b0b}
.attempt.wrong{border-color:rgba(255,90,95,.38);color:#ff9da0}
.attempt.correct{border-color:rgba(55,214,122,.6);background:rgba(55,214,122,.07);color:#97f0bd}
.info-section{padding:58px 4px 8px}
.info-section>h2{font-size:clamp(1.8rem,4vw,2.7rem);margin:7px 0 22px;letter-spacing:-.04em}
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.feature-card{border:1px solid var(--line);background:linear-gradient(180deg,#101010,#080808);border-radius:16px;padding:20px;min-height:205px}
.feature-card>strong{color:var(--acid);font-size:.74rem;letter-spacing:.12em}
.feature-card h3{font-size:1.25rem;margin:20px 0 8px}
.feature-card p{margin:0;color:#979792;line-height:1.55;font-size:.88rem}
footer{display:flex;justify-content:center;gap:18px;flex-wrap:wrap;color:#666;font-size:.78rem;margin-top:30px}
footer a,footer button{color:#a98cff;text-decoration:none;background:none;border:0;padding:0;cursor:pointer;font:inherit}
.modal{position:fixed;inset:0;background:rgba(0,0,0,.88);backdrop-filter:blur(13px);display:grid;place-items:center;padding:20px;z-index:100}
.modal[hidden]{display:none}
.modal-card{width:min(100%,440px);max-height:min(90vh,760px);overflow:auto;position:relative;text-align:center;background:linear-gradient(180deg,#121212,#080808);border:1px solid var(--line);border-radius:20px;padding:28px;box-shadow:0 28px 100px #000}
.close{position:absolute;right:12px;top:8px;border:0;background:none;color:#888;font-size:1.8rem;cursor:pointer}
.result-status{color:#97f0bd;text-transform:uppercase;font-size:.72rem;font-weight:900;letter-spacing:.13em}
.cover-placeholder,.result-cover{width:160px;aspect-ratio:1;border-radius:14px;margin:18px auto;border:1px solid #3d3d3d;background:#111}
.result-cover{display:block;object-fit:cover}
.result-cover[hidden]{display:none}
.cover-placeholder{display:grid;place-items:center;background:linear-gradient(145deg,#0c0c0c,#25113e)}
.cover-placeholder span{font:900 82px Georgia,serif;color:white;text-shadow:8px 8px 0 var(--violet-deep)}
.modal-card h2{margin:8px 0;font-size:1.8rem;letter-spacing:-.04em}
.modal-card p{color:var(--muted);line-height:1.55}
.full{display:block;width:100%;margin-top:10px}
.link-button{display:block;margin-top:18px}
.share-pattern{display:flex;justify-content:center;gap:5px;margin:15px 0}
.share-pattern span{width:18px;height:18px;border-radius:4px;background:#292929}
.share-pattern span.good{background:var(--green)}
.share-pattern span.bad{background:var(--red)}
.share-pattern span.skip{background:#777}
.tutorial-card{width:min(100%,520px)}
.tutorial-preview{margin:18px 0;border:1px dashed #373737;border-radius:15px;min-height:190px;background:#070707;display:grid;place-items:center;padding:18px}
.tutorial-preview .demo-play{width:68px;height:68px;border-radius:50%;display:grid;place-items:center;border:1px solid var(--acid);color:var(--acid);font-size:1.35rem;margin:auto}
.tutorial-preview .demo-lines{display:grid;gap:8px;width:min(100%,330px)}
.tutorial-preview .demo-lines span{height:11px;border-radius:99px;background:#262626}
.tutorial-preview .demo-lines span:nth-child(2){background:linear-gradient(90deg,var(--violet),var(--acid));width:72%}
.tutorial-preview .demo-clue{color:var(--acid);font-size:1.2rem;font-weight:900}
.tutorial-dots{display:flex;justify-content:center;gap:7px;margin:18px 0}
.tutorial-dots i{width:8px;height:8px;border-radius:50%;background:#3b3b3b}
.tutorial-dots i.active{background:var(--acid)}
.tutorial-actions button{flex:1}
.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin:20px 0}
.stat-tile{border:1px solid var(--line);background:#0a0a0a;border-radius:14px;padding:17px 10px}
.stat-tile strong{display:block;color:var(--acid);font-size:1.8rem}
.stat-tile span{color:#777;font-size:.75rem;text-transform:uppercase;letter-spacing:.09em}
.danger-button{border:1px solid rgba(255,90,95,.4);background:rgba(255,90,95,.08);color:#ff9da0;border-radius:12px;padding:13px 18px;cursor:pointer;font-weight:800}
@media(max-width:700px){
  .page-shell{padding:14px 12px 35px}
  .top-actions{justify-content:center}
  .app-card{padding:17px;border-radius:17px}
  .switch-row{align-items:stretch;flex-direction:column}
  .meta-row{display:grid;gap:5px}
  .hint-box{min-height:215px;padding:20px 14px}
  .feature-grid{grid-template-columns:1fr}
  .feature-card{min-height:0}
  .logo-text{font-size:92px}
  .tagline{font-size:.75rem}
}
@media(max-width:470px){
  .page-shell{padding-inline:8px}
  .app-card{padding:13px}
  .card-head{align-items:flex-start}
  .round-badge{font-size:.68rem}
  .segmented button{padding:9px 7px}
  .actions{display:grid;grid-template-columns:1fr}
  .player-main{gap:15px}
  .play-btn{width:78px;height:78px}
  .audio-copy strong{font-size:1.4rem}
  .clue-row{align-items:flex-start}
  .shortcut{display:none}
  .logo-text{font-size:79px}
  .modal-card{padding:24px 18px}
}

@media(max-width:600px){
  .suggestions{position:fixed;left:10px;right:10px;top:auto;bottom:10px;max-height:min(62vh,520px);border-radius:16px;z-index:140}
  .suggestion{grid-template-columns:46px minmax(0,1fr);min-height:65px}
  .suggestion-album{grid-column:2;text-align:left;margin-top:-4px}
  .suggestions-head{padding:11px 12px}
}

/* ===== PATCH V4: album themes, large picker and contact ===== */
:root{
  --acid-rgb:234,115,105;
  --violet-rgb:254,254,254;
  --theme-bg:#160302;
  --theme-cover-image:none;
}
body{
  position:relative;
  isolation:isolate;
  background:
    radial-gradient(circle at 50% -10%,rgba(var(--violet-rgb),.11),transparent 34%),
    radial-gradient(circle at 87% 8%,rgba(var(--acid-rgb),.08),transparent 21%),
    linear-gradient(180deg,var(--theme-bg) 0%,#020202 62%,#010101 100%);
}
body::before{
  content:"";
  position:fixed;
  z-index:-3;
  inset:-8vh -6vw auto;
  height:68vh;
  background-image:var(--theme-cover-image);
  background-position:center 22%;
  background-size:cover;
  filter:blur(54px) saturate(.9);
  opacity:.16;
  transform:scale(1.08);
  pointer-events:none;
  transition:background-image .35s ease,opacity .35s ease;
}
body::after{
  content:"";
  position:fixed;
  z-index:-2;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.38),rgba(0,0,0,.82) 45%,#020202 100%);
}
.logo g path{stroke:var(--acid)!important;transition:stroke .25s ease}
.logo g circle:first-of-type{fill:var(--violet)!important;transition:fill .25s ease}
.ghost-link{display:inline-flex;align-items:center;justify-content:center;text-decoration:none}
.theme-trigger::before{content:"◐";margin-right:6px;color:var(--acid)}

/* Lista utworów: więcej pozycji, większy scrollbar i miniatury albumów */
.suggestions{
  max-height:min(70vh,660px);
  scrollbar-width:auto;
  scrollbar-color:var(--acid) #151515;
}
.suggestions::-webkit-scrollbar{width:16px}
.suggestions::-webkit-scrollbar-track{background:#151515;border-left:1px solid #303030;border-radius:0 13px 13px 0}
.suggestions::-webkit-scrollbar-thumb{background:linear-gradient(180deg,var(--acid),var(--violet));border:4px solid #151515;border-radius:999px}
.suggestion{min-height:68px;padding:8px 12px;grid-template-columns:52px minmax(0,1fr) minmax(105px,auto)}
.suggestion-cover{width:52px;height:52px;border-radius:9px;box-shadow:0 0 0 1px rgba(255,255,255,.09)}
.suggestion-copy strong{font-size:.92rem}
.suggestion-copy small{font-size:.72rem}
.suggestion-album{max-width:210px;font-size:.71rem;line-height:1.35}
.suggestion.selected,.suggestion:hover{background:linear-gradient(90deg,rgba(var(--acid-rgb),.16),rgba(var(--violet-rgb),.07))}

/* Motywy albumowe */
.theme-modal-card{width:min(94vw,860px);max-height:min(90vh,830px);overflow:hidden;display:flex;flex-direction:column;text-align:left}
.theme-modal-card h2{margin:.35rem 0 .25rem;font-size:clamp(1.65rem,4vw,2.4rem)}
.modal-intro{margin:0 0 14px;color:var(--muted);line-height:1.55}
.auto-theme-button{width:100%;border:1px solid var(--line-strong);border-radius:13px;background:#111;color:#d6d6d0;padding:13px 15px;cursor:pointer;text-align:left;margin-bottom:12px}
.auto-theme-button.active{border-color:var(--acid);background:rgba(var(--acid-rgb),.10);color:var(--text);box-shadow:0 0 0 3px rgba(var(--acid-rgb),.07)}
.auto-theme-button::before{content:"AUTO";display:inline-block;margin-right:10px;color:var(--acid);font-size:.68rem;font-weight:900;letter-spacing:.08em}
.theme-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;overflow-y:auto;padding:2px 4px 8px 2px;scrollbar-color:var(--acid) #181818;scrollbar-width:auto}
.theme-card{position:relative;display:grid;grid-template-columns:58px minmax(0,1fr);gap:10px;align-items:center;border:1px solid #303030;border-radius:14px;background:#0d0d0d;padding:8px;text-align:left;color:var(--text);cursor:pointer;min-height:76px}
.theme-card:hover{border-color:var(--acid);transform:translateY(-1px)}
.theme-card.active{border-color:var(--acid);box-shadow:0 0 0 2px rgba(var(--acid-rgb),.12);background:linear-gradient(135deg,rgba(var(--acid-rgb),.12),#0d0d0d 55%)}
.theme-card img{display:block;width:58px;height:58px;object-fit:cover;border-radius:9px;background:#161616}
.theme-card-copy{min-width:0;display:grid;gap:7px}
.theme-card-copy strong{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.78rem}
.theme-swatches{display:flex;gap:5px}
.theme-swatches i{display:block;width:22px;height:8px;border-radius:99px;border:1px solid rgba(255,255,255,.13)}
.theme-selected-mark{position:absolute;right:7px;top:6px;width:19px;height:19px;border-radius:50%;display:none;place-items:center;background:var(--acid);color:#050505;font-size:.7rem;font-weight:900}
.theme-card.active .theme-selected-mark{display:grid}

/* Kontakt / fan project */
.contact-shell{width:min(100%,820px);margin:0 auto;padding:26px 20px 56px}
.contact-header{text-align:center;margin-bottom:20px}
.contact-header .logo{width:min(100%,470px)}
.back-link{display:inline-flex;align-items:center;gap:7px;color:var(--muted);text-decoration:none;border:1px solid var(--line);border-radius:999px;padding:8px 13px;margin-bottom:10px}
.back-link:hover{color:var(--text);border-color:var(--acid)}
.contact-card{background:linear-gradient(180deg,rgba(18,18,18,.94),rgba(7,7,7,.97));border:1px solid var(--line);border-radius:20px;padding:clamp(20px,5vw,38px);box-shadow:var(--shadow)}
.contact-card h1{font-size:clamp(2rem,7vw,4rem);line-height:.95;margin:.4rem 0 1rem}
.contact-lead{max-width:680px;color:#aaa;line-height:1.7;font-size:1.02rem}
.contact-sections{display:grid;gap:0;margin-top:26px}
.contact-section{padding:24px 0;border-top:1px solid #292929}
.contact-section h2{margin:0 0 9px;font-size:1.13rem}
.contact-section p{margin:0;color:#9d9d98;line-height:1.65}
.contact-email{display:inline-flex;margin-top:13px;color:#050505;background:var(--acid);border-radius:11px;padding:11px 14px;text-decoration:none;font-weight:800}
.contact-note{margin-top:12px!important;font-size:.78rem;color:#696965!important}
.fan-badge{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(var(--acid-rgb),.45);background:rgba(var(--acid-rgb),.08);color:var(--acid);border-radius:999px;padding:7px 11px;font-size:.72rem;font-weight:800;letter-spacing:.06em;text-transform:uppercase}
.contact-footer{display:flex;justify-content:center;flex-wrap:wrap;gap:15px;margin-top:20px;color:#6f6f6b;font-size:.78rem}
.contact-footer a{color:var(--acid);text-decoration:none}

@media(max-width:760px){
  .theme-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .top-actions{justify-content:center;flex-wrap:wrap}
}
@media(max-width:620px){
  .suggestions{position:fixed;left:8px;right:8px;bottom:8px;top:auto;max-height:min(72vh,650px);z-index:160}
  .suggestion{grid-template-columns:48px minmax(0,1fr);min-height:64px}
  .suggestion-cover{width:48px;height:48px}
  .suggestion-album{grid-column:2;max-width:none;text-align:left;margin-top:-4px}
  .theme-modal-card{padding:22px 15px 15px}
  .theme-grid{grid-template-columns:1fr}
  .theme-card{grid-template-columns:64px minmax(0,1fr)}
  .theme-card img{width:64px;height:64px}
}

/* Pełne przepięcie starszych neonów na aktualnie wybraną paletę */
.app-card:before{border-color:rgba(var(--acid-rgb),.22)}
.app-card:after{border-color:rgba(var(--violet-rgb),.22)}
.round-badge{border-color:rgba(var(--acid-rgb),.3)}
.segmented button.active,
button.primary,
.link-button{background:linear-gradient(135deg,var(--acid),var(--violet));box-shadow:0 0 28px rgba(var(--acid-rgb),.15)}
.hint-box{background:
  linear-gradient(135deg,rgba(var(--violet-rgb),.08),transparent 38%),
  repeating-linear-gradient(115deg,rgba(255,255,255,.015) 0 1px,transparent 1px 7px),#090909}
.play-btn{box-shadow:inset 0 0 0 7px #0a0a0a,0 0 45px rgba(var(--violet-rgb),.15)}
.play-btn:hover{box-shadow:inset 0 0 0 7px #0a0a0a,0 0 34px rgba(var(--acid-rgb),.19)}
.text-mode-box .beta-pill{border-color:rgba(var(--violet-rgb),.45);background:rgba(var(--violet-rgb),.10);color:var(--violet)}
.step.current{outline-color:rgba(var(--acid-rgb),.5)}
.guess-area input:focus{box-shadow:0 0 0 3px rgba(var(--acid-rgb),.10)}
.suggestions{box-shadow:0 22px 65px rgba(0,0,0,.82),0 0 0 1px rgba(var(--acid-rgb),.07)}
.suggestion-cover{background:linear-gradient(145deg,#111,rgba(var(--violet-rgb),.20))}
.suggestion:hover,.suggestion.selected{box-shadow:inset 3px 0 0 var(--acid)}

/* ===== PATCH V5: kategorie + działający tryb tekstowy ===== */
.category-control{
  margin:18px 0 4px;
  padding:14px;
  border:1px solid var(--line);
  border-radius:15px;
  background:rgba(7,7,7,.72);
}
.category-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px}
.category-head>span:last-child{color:#73736f;font-size:.72rem}
.category-tabs{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:8px}
.category-tabs button{
  position:relative;
  min-width:0;
  min-height:58px;
  display:grid;
  grid-template-columns:auto minmax(0,1fr) auto;
  align-items:center;
  gap:7px;
  border:1px solid #2b2b2b;
  border-radius:12px;
  padding:9px 10px;
  color:#969690;
  background:#0a0a0a;
  cursor:pointer;
  transition:border-color .18s ease,background .18s ease,color .18s ease,transform .18s ease;
}
.category-tabs button:hover{border-color:rgba(var(--acid-rgb),.65);color:var(--text);transform:translateY(-1px)}
.category-tabs button.active{
  color:var(--text);
  border-color:var(--acid);
  background:linear-gradient(135deg,rgba(var(--acid-rgb),.16),rgba(var(--violet-rgb),.05));
  box-shadow:0 0 0 2px rgba(var(--acid-rgb),.07);
}
.category-tabs b{
  width:25px;height:25px;border-radius:8px;display:grid;place-items:center;
  background:#181818;color:var(--acid);font-size:.72rem;
}
.category-tabs span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left;font-size:.78rem;font-weight:800}
.category-tabs small{
  min-width:24px;padding:3px 5px;border-radius:99px;text-align:center;
  background:#171717;color:#73736f;font-size:.62rem;font-weight:800;
}
.category-tabs button.active small{background:var(--acid);color:#050505}
.segmented [data-type="text"] small{
  display:inline-grid;place-items:center;min-width:20px;height:18px;margin-left:5px;padding:0 5px;
  border-radius:99px;background:#242424;color:#aaa;font-size:.62rem;
}
.segmented [data-type="text"].active small{background:var(--acid);color:#050505}
.text-mode-box{width:min(100%,760px);margin:auto}
.lyric-fragment{
  max-width:720px;
  margin:18px auto 0;
  font-size:clamp(1.15rem,2.4vw,1.75rem);
  line-height:1.55;
  font-weight:650;
  letter-spacing:.01em;
  text-wrap:balance;
}
.empty-text-mode{display:grid;place-items:center;gap:12px;min-height:170px;text-align:center}
.empty-text-mode .hint-text{max-width:650px;margin:0;font-size:1.05rem;line-height:1.55}
.text-import-note{margin:0;color:#777;font-size:.78rem;line-height:1.55}
.text-import-note strong{color:var(--acid)}

@media(max-width:820px){
  .category-tabs{grid-template-columns:repeat(3,minmax(0,1fr))}
  .category-tabs button:nth-child(4),.category-tabs button:nth-child(5){grid-column:span 1}
}
@media(max-width:560px){
  .category-control{padding:10px}
  .category-head{align-items:flex-start;flex-direction:column;gap:3px}
  .category-tabs{grid-template-columns:repeat(2,minmax(0,1fr))}
  .category-tabs button:first-child{grid-column:1/-1}
  .category-tabs button{min-height:52px;padding:8px}
  .category-tabs span{font-size:.73rem}
}

/* czytelniejsze pełne nazwy kategorii */
.category-tabs button{grid-template-columns:auto minmax(0,1fr);padding-right:34px}
.category-tabs button small{position:absolute;right:7px;top:7px}
.category-tabs button span{font-size:.72rem}

/* ===== V6 PUBLIC: anonimowe statystyki + ranking globalny ===== */
.ranking-trigger{border-color:rgba(var(--acid-rgb),.34);color:var(--acid)}
.result-score{margin:8px 0 2px!important;color:var(--acid)!important;font-weight:850;letter-spacing:.02em}
.profile-panel{
  display:grid;gap:12px;text-align:left;margin:18px 0;padding:15px;
  border:1px solid var(--line);border-radius:15px;background:#090909;
}
.profile-panel p{margin:4px 0 0!important;font-size:.8rem}
.profile-form{display:grid;grid-template-columns:minmax(0,1fr) auto;gap:8px}
.profile-form input{
  min-width:0;border:1px solid var(--line);border-radius:11px;background:#050505;color:var(--text);
  padding:12px 13px;outline:none;
}
.profile-form input:focus{border-color:var(--acid);box-shadow:0 0 0 3px rgba(var(--acid-rgb),.09)}
.profile-form button{margin:0}
.profile-status{min-height:1.2em;color:#8d8d88;font-size:.74rem}
.advanced-stats-grid{margin-top:-8px}
.advanced-stats-grid .stat-tile strong{font-size:1.35rem}

.ranking-card{width:min(100%,760px);text-align:left}
.ranking-card>h2,.ranking-card>.eyebrow,.ranking-card>.modal-intro{text-align:center}
.ranking-controls{display:grid;grid-template-columns:1.45fr repeat(3,minmax(105px,1fr));gap:9px;align-items:end;margin:20px 0 14px}
.ranking-controls label{display:grid;gap:6px;color:#777;font-size:.67rem;text-transform:uppercase;letter-spacing:.08em}
.ranking-controls select{
  width:100%;border:1px solid var(--line);border-radius:10px;background:#080808;color:var(--text);
  padding:10px 30px 10px 10px;outline:none;
}
.ranking-controls select:focus{border-color:var(--acid)}
.ranking-scope{height:42px}
.ranking-scope button{padding:8px 10px;font-size:.75rem}
.ranking-status{min-height:1.3em;margin:4px 0 10px;color:#858580;font-size:.76rem;text-align:left}
.ranking-table-wrap{overflow:auto;border:1px solid var(--line);border-radius:14px;background:#080808;max-height:48vh}
.ranking-table{width:100%;border-collapse:collapse;min-width:520px}
.ranking-table th,.ranking-table td{padding:12px 14px;border-bottom:1px solid #242424;text-align:left}
.ranking-table th{position:sticky;top:0;z-index:2;background:#111;color:#777;font-size:.67rem;text-transform:uppercase;letter-spacing:.1em}
.ranking-table th:first-child,.ranking-table td:first-child{width:50px;text-align:center}
.ranking-table th:nth-child(3),.ranking-table td:nth-child(3),
.ranking-table th:nth-child(4),.ranking-table td:nth-child(4){text-align:right}
.ranking-table td{font-size:.84rem}
.ranking-table td strong{color:#f2f2ef}
.ranking-table td small{display:inline-block;margin-left:7px;padding:2px 6px;border-radius:999px;background:var(--acid);color:#050505;font-size:.58rem;font-weight:900;text-transform:uppercase}
.ranking-table tr.is-mine{background:linear-gradient(90deg,rgba(var(--acid-rgb),.12),rgba(var(--violet-rgb),.05))}
.ranking-table tr:last-child td{border-bottom:0}
.ranking-empty{text-align:center!important;color:#777;padding:24px!important}

.legal-page{width:min(100%,820px);margin:0 auto;padding:25px 20px 60px}
.legal-header{margin-bottom:28px}
.legal-header a{color:var(--acid);text-decoration:none}
.legal-card{border:1px solid var(--line);border-radius:20px;background:linear-gradient(180deg,#111,#070707);padding:clamp(20px,4vw,38px);box-shadow:var(--shadow)}
.legal-card h1{font-size:clamp(2rem,6vw,3.5rem);margin:8px 0 12px;letter-spacing:-.05em}
.legal-card h2{margin:30px 0 8px;font-size:1.15rem;color:var(--acid)}
.legal-card p,.legal-card li{color:#aaa9a3;line-height:1.7}
.legal-card code{color:var(--acid);background:#080808;border:1px solid var(--line);border-radius:6px;padding:2px 6px}
.legal-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.legal-actions a{display:inline-flex;text-decoration:none}

@media(max-width:760px){
  .ranking-controls{grid-template-columns:1fr 1fr}
  .ranking-scope{grid-column:1/-1}
  .profile-form{grid-template-columns:1fr}
  .ranking-card{padding:22px 13px}
}
@media(max-width:500px){
  .ranking-controls{grid-template-columns:1fr}
  .ranking-scope{grid-column:auto}
  .ranking-table th,.ranking-table td{padding:10px}
  .stats-grid{grid-template-columns:1fr 1fr}
}

/* ===== V10: miniatury kategorii, roadmap, report bug i mobile UI ===== */
:root{
  --keyboard-offset:0px;
  --mobile-dock-height:0px;
}
body.modal-open{overflow:hidden}

/* Górna nawigacja: więcej funkcji bez łamania interfejsu */
.top-actions{position:relative;z-index:8;align-items:center}
.bug-trigger{border-color:rgba(255,138,61,.42);color:#ffc294}
.version-label{color:#555;font-size:.68rem;letter-spacing:.08em;text-transform:uppercase}

/* Karty kategorii z oryginalnymi okładkami */
.category-tabs{
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:9px;
}
.category-tabs button{
  min-height:118px;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:0;
  padding:0;
  overflow:hidden;
  isolation:isolate;
  border-radius:14px;
  background:#080808;
  text-align:left;
}
.category-tabs button::after{
  content:"";
  position:absolute;
  inset:0;
  z-index:-1;
  background:linear-gradient(180deg,transparent 24%,rgba(5,5,5,.68) 58%,#080808 100%);
  pointer-events:none;
}
.category-tabs button.active{
  background:#090909;
  box-shadow:0 0 0 2px rgba(var(--acid-rgb),.12),0 12px 30px rgba(0,0,0,.28);
}
.category-thumb{
  position:relative;
  display:block;
  width:100%;
  height:64px;
  overflow:hidden;
  background:#111;
}
.category-thumb img{
  display:block;
  width:100%;
  height:100%;
  object-fit:cover;
  filter:saturate(.8) brightness(.72) contrast(1.08);
  transform:scale(1.02);
  transition:filter .2s ease,transform .25s ease;
}
.category-tabs button:hover .category-thumb img,
.category-tabs button.active .category-thumb img{
  filter:saturate(1) brightness(.9) contrast(1.06);
  transform:scale(1.055);
}
.category-thumb b{
  position:absolute;
  left:7px;
  top:7px;
  z-index:2;
  width:24px;
  height:24px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.13);
  border-radius:8px;
  background:rgba(3,3,3,.78);
  backdrop-filter:blur(7px);
  color:var(--acid);
  font-size:.68rem;
}
.category-copy{
  display:grid;
  gap:2px;
  min-width:0;
  padding:10px 10px 11px;
}
.category-copy strong{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#f1f1ee;
  font-size:.78rem;
  line-height:1.1;
}
.category-copy em{
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
  color:#777772;
  font-size:.59rem;
  font-style:normal;
  letter-spacing:.05em;
  text-transform:uppercase;
}
.category-tabs button small{
  position:absolute;
  right:7px;
  top:7px;
  z-index:3;
  min-width:27px;
  padding:4px 6px;
  border:1px solid rgba(255,255,255,.1);
  background:rgba(3,3,3,.8);
  backdrop-filter:blur(7px);
  color:#bbb;
}
.category-tabs button.active small{background:var(--acid);border-color:var(--acid);color:#050505}

/* Roadmap */
.roadmap-card{width:min(96vw,680px);text-align:left}
.roadmap-card>h2{font-size:clamp(1.8rem,5vw,2.45rem)}
.roadmap-list{display:grid;gap:10px;margin:20px 0}
.roadmap-item{
  display:grid;
  grid-template-columns:82px minmax(0,1fr);
  gap:14px;
  align-items:start;
  padding:15px;
  border:1px solid var(--line);
  border-radius:14px;
  background:#090909;
}
.roadmap-item>span{
  display:inline-grid;
  place-items:center;
  min-height:28px;
  padding:5px 8px;
  border:1px solid #353535;
  border-radius:999px;
  color:#8c8c87;
  font-size:.62rem;
  font-weight:900;
  letter-spacing:.08em;
}
.roadmap-item.is-live>span{border-color:rgba(55,214,122,.45);background:rgba(55,214,122,.08);color:#97f0bd}
.roadmap-item.is-progress>span{border-color:rgba(var(--acid-rgb),.45);background:rgba(var(--acid-rgb),.08);color:var(--acid)}
.roadmap-item strong{display:block;margin:1px 0 5px;color:#f4f4f1}
.roadmap-item p{margin:0!important;font-size:.82rem}

/* Report bug */
.bug-card{width:min(96vw,610px);text-align:left}
.bug-card>h2{font-size:clamp(1.8rem,5vw,2.35rem)}
.bug-form{display:grid;gap:14px;margin-top:18px}
.bug-form label:not(.bug-check){display:grid;gap:7px}
.bug-form label>span{color:#969691;font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.08em}
.bug-form select,.bug-form textarea{
  width:100%;
  border:1px solid var(--line);
  border-radius:12px;
  background:#080808;
  color:#f5f5f2;
  padding:13px 14px;
  outline:none;
  resize:vertical;
}
.bug-form select:focus,.bug-form textarea:focus{border-color:var(--acid);box-shadow:0 0 0 3px rgba(var(--acid-rgb),.09)}
.bug-check{display:flex;align-items:flex-start;gap:10px;padding:12px;border:1px solid var(--line);border-radius:12px;background:#090909}
.bug-check input{margin-top:2px;accent-color:var(--acid)}
.bug-check span{font-size:.76rem!important;line-height:1.45;text-transform:none!important;letter-spacing:0!important;font-weight:500!important}
.bug-note{margin:0!important;font-size:.72rem}
.bug-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bug-status{min-height:20px;color:var(--acid);font-size:.76rem;text-align:center}

/* Lista odpowiedzi – dotyk i klawiatura mobilna */
.suggestions{
  touch-action:pan-y;
  -webkit-overflow-scrolling:touch;
  user-select:none;
}
.suggestion{touch-action:pan-y}
.suggestions-close{
  display:none;
  border:1px solid #333;
  background:#111;
  color:#aaa;
  border-radius:8px;
  padding:6px 9px;
  font-size:.68rem;
  cursor:pointer;
}

/* Mobilny dock: podstawowe akcje pod kciukiem */
.mobile-game-dock{display:none}

@media(max-width:820px){
  .page-shell{padding-bottom:calc(92px + env(safe-area-inset-bottom))}
  .top-actions{
    justify-content:flex-start;
    flex-wrap:nowrap;
    width:calc(100% + 24px);
    margin-left:-12px;
    padding:2px 12px 8px;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    scrollbar-width:none;
    scroll-snap-type:x proximity;
  }
  .top-actions::-webkit-scrollbar{display:none}
  .top-actions>*{flex:0 0 auto;scroll-snap-align:start}
  .ghost-button{min-height:40px;padding:9px 13px}

  .category-tabs{
    display:flex;
    gap:10px;
    margin:0 -10px;
    padding:0 10px 6px;
    overflow-x:auto;
    overscroll-behavior-x:contain;
    scrollbar-width:none;
    scroll-snap-type:x mandatory;
  }
  .category-tabs::-webkit-scrollbar{display:none}
  .category-tabs button,
  .category-tabs button:first-child{
    flex:0 0 148px;
    grid-column:auto;
    min-height:118px;
    scroll-snap-align:start;
  }
  .category-head{align-items:center;flex-direction:row}

  .mobile-game-dock{
    position:fixed;
    left:50%;
    bottom:max(8px,env(safe-area-inset-bottom));
    z-index:85;
    width:min(calc(100% - 18px),520px);
    min-height:64px;
    transform:translateX(-50%);
    display:grid;
    grid-template-columns:repeat(3,1fr);
    gap:6px;
    padding:7px;
    border:1px solid #323232;
    border-radius:18px;
    background:rgba(8,8,8,.94);
    backdrop-filter:blur(18px);
    box-shadow:0 14px 55px rgba(0,0,0,.75);
    transition:opacity .18s ease,transform .18s ease;
  }
  .mobile-game-dock button{
    min-width:0;
    min-height:48px;
    display:grid;
    grid-template-columns:auto 1fr;
    align-items:center;
    justify-content:center;
    gap:6px;
    border:1px solid #2d2d2d;
    border-radius:12px;
    background:#101010;
    color:#ddd;
    cursor:pointer;
  }
  .mobile-game-dock button:first-child{border-color:rgba(var(--acid-rgb),.38);color:var(--acid)}
  .mobile-game-dock button span{font-size:1rem}
  .mobile-game-dock button small{overflow:hidden;text-overflow:ellipsis;font-size:.68rem;font-weight:800}
  .mobile-game-dock button:disabled{opacity:.38}
  body.keyboard-open .mobile-game-dock,
  body.modal-open .mobile-game-dock{opacity:0;pointer-events:none;transform:translate(-50%,18px)}

  .guess-area input{font-size:16px}
  .modal{padding:0;align-items:end}
  .modal-card{
    width:100%;
    max-width:none;
    max-height:min(94dvh,880px);
    border-radius:22px 22px 0 0;
    padding:26px 16px calc(20px + env(safe-area-inset-bottom));
  }
}

@media(max-width:620px){
  .app-card{overflow:visible}
  .hero{margin-bottom:15px}
  .logo{margin-top:2px}
  .category-control{margin-inline:-4px}
  .category-head>span:last-child{max-width:52%;text-align:right}
  .hint-box{min-height:195px}
  .player-main{gap:14px}
  .play-btn{width:74px;height:74px}
  .waveform{height:36px}
  .meta-row{font-size:.72rem}
  .clue-row{padding:12px}

  .suggestions{
    position:fixed;
    left:8px;
    right:8px;
    top:auto;
    bottom:calc(var(--keyboard-offset) + 8px);
    z-index:180;
    max-height:min(54dvh,500px);
    border-radius:16px;
  }
  .suggestions-head{gap:8px}
  .suggestions-head>span{display:none}
  .suggestions-close{display:inline-flex;margin-left:auto}
  .suggestion{grid-template-columns:48px minmax(0,1fr);padding:10px;min-height:70px}
  .suggestion-album{grid-column:2;text-align:left;margin-top:-5px}
  .suggestion-cover{width:48px;height:48px}

  .roadmap-item{grid-template-columns:1fr;gap:8px}
  .roadmap-item>span{justify-self:start}
  .bug-actions{grid-template-columns:1fr}
}

@media(max-width:390px){
  .category-tabs button,.category-tabs button:first-child{flex-basis:136px}
  .category-copy{padding-inline:8px}
  .category-copy strong{font-size:.74rem}
  .mobile-game-dock button{grid-template-columns:1fr;gap:1px}
  .mobile-game-dock button span{font-size:.92rem}
  .mobile-game-dock button small{font-size:.62rem}
}

@media(prefers-reduced-motion:reduce){
  .category-thumb img,.mobile-game-dock{transition:none}
}

/* ===== V10.1 HOTFIX: kompaktowe kategorie + wymuszenie poprawnego layoutu ===== */
.category-tabs{
  display:grid!important;
  grid-template-columns:repeat(5,minmax(0,1fr))!important;
  gap:9px!important;
  overflow:visible;
  margin:0;
  padding:0;
}
.category-tabs button,
.category-tabs button:first-child{
  position:relative;
  min-width:0!important;
  min-height:76px!important;
  height:76px!important;
  display:grid!important;
  grid-template-columns:48px minmax(0,1fr)!important;
  grid-template-rows:1fr!important;
  align-items:center!important;
  gap:9px!important;
  padding:8px 30px 8px 8px!important;
  overflow:hidden!important;
  border-radius:12px!important;
  text-align:left!important;
  scroll-snap-align:none;
}
.category-tabs button::after{
  background:linear-gradient(100deg,rgba(var(--acid-rgb),.035),transparent 48%)!important;
}
.category-thumb{
  position:relative!important;
  display:block!important;
  width:48px!important;
  min-width:48px!important;
  height:48px!important;
  border:1px solid rgba(255,255,255,.08);
  border-radius:10px!important;
  overflow:hidden!important;
  background:#101010!important;
}
.category-thumb img{
  display:block!important;
  width:100%!important;
  height:100%!important;
  max-width:none!important;
  object-fit:cover!important;
  object-position:center!important;
  filter:saturate(.78) brightness(.72) contrast(1.06)!important;
  transform:none!important;
}
.category-tabs button:hover .category-thumb img,
.category-tabs button.active .category-thumb img{
  filter:saturate(.95) brightness(.88) contrast(1.05)!important;
  transform:none!important;
}
.category-thumb b{
  left:3px!important;
  top:auto!important;
  bottom:3px!important;
  width:19px!important;
  height:19px!important;
  border-radius:6px!important;
  font-size:.59rem!important;
}
.category-copy{
  display:grid!important;
  align-content:center!important;
  gap:4px!important;
  min-width:0!important;
  padding:0!important;
  overflow:hidden!important;
}
.category-copy strong{
  display:block!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  color:#f2f2ee!important;
  font-size:.76rem!important;
  line-height:1.1!important;
}
.category-copy em{
  display:block!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  white-space:nowrap!important;
  color:#777772!important;
  font-size:.54rem!important;
  line-height:1.15!important;
  letter-spacing:.045em!important;
}
.category-tabs button small{
  right:6px!important;
  top:6px!important;
  min-width:23px!important;
  padding:3px 5px!important;
  font-size:.57rem!important;
}

@media(max-width:920px){
  .category-tabs{
    display:flex!important;
    gap:9px!important;
    margin:0 -10px!important;
    padding:0 10px 7px!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
    overscroll-behavior-x:contain;
    scroll-snap-type:x proximity;
    scrollbar-width:none;
  }
  .category-tabs::-webkit-scrollbar{display:none}
  .category-tabs button,
  .category-tabs button:first-child{
    flex:0 0 164px!important;
    width:164px!important;
    height:74px!important;
    min-height:74px!important;
    scroll-snap-align:start!important;
  }
}

@media(max-width:560px){
  .category-control{padding:10px!important}
  .category-head{align-items:center!important;flex-direction:row!important;gap:8px!important}
  .category-head>span:last-child{max-width:54%;text-align:right}
  .category-tabs button,
  .category-tabs button:first-child{
    flex-basis:152px!important;
    width:152px!important;
    grid-template-columns:44px minmax(0,1fr)!important;
    padding:7px 27px 7px 7px!important;
  }
  .category-thumb{width:44px!important;min-width:44px!important;height:44px!important}
  .category-copy strong{font-size:.72rem!important}
  .category-copy em{font-size:.50rem!important}
}

/* ===== V11: albumy, kolory prób i kontakt w aplikacji ===== */
.album-filter{
  margin-top:12px;
  padding:13px 14px;
  border:1px solid var(--line);
  border-radius:14px;
  background:linear-gradient(180deg,rgba(15,15,15,.88),rgba(7,7,7,.93));
}
.album-filter-head,.album-filter-row{display:flex;align-items:center;justify-content:space-between;gap:12px}
.album-filter-head p{margin:4px 0 0;color:#777772;font-size:.72rem;line-height:1.4}
.album-filter-row{margin-top:10px}
.album-filter-row input{
  width:100%;min-width:0;height:44px;padding:0 13px;border-radius:11px;
  border:1px solid #323232;background:#0a0a0a;color:#f2f2ee;font:inherit;
  outline:none;
}
.album-filter-row input:focus{border-color:#d9a52b;box-shadow:0 0 0 3px rgba(217,165,43,.12)}
.album-filter-row span{flex:0 0 auto;max-width:42%;color:#8b8b86;font-size:.68rem;text-align:right}
.album-clear{border:0;background:none;color:#e8ba43;font:inherit;font-size:.7rem;font-weight:800;cursor:pointer;padding:5px}
.album-clear:hover{color:#ffd86c}

/* Wynik próby ma zawsze znaczenie semantyczne, niezależne od wybranego motywu. */
.step.result-wrong{background:#d9474f!important}
.step.result-album{background:#e6b72f!important}
.step.result-correct{background:#39c979!important}
.step.result-skip{background:#6d6d6d!important}
.step.current{outline-color:rgba(255,255,255,.3)!important}
.attempt.wrong{border-color:rgba(217,71,79,.62)!important;background:rgba(217,71,79,.075)!important;color:#ff999e!important}
.attempt.same-album{border-color:rgba(230,183,47,.68);background:rgba(230,183,47,.08);color:#f4d66f}
.attempt.skipped{border-color:rgba(150,150,150,.32);color:#aaa;background:rgba(255,255,255,.025)}
.attempt.correct{border-color:rgba(57,201,121,.68)!important;background:rgba(57,201,121,.085)!important;color:#99efbb!important}
.share-pattern span.album{background:#e6b72f}

.contact-modal-card{width:min(94vw,620px)}
.contact-modal-sections{display:grid;gap:10px;margin:20px 0}
.contact-modal-sections section{padding:16px;border:1px solid var(--line);border-radius:13px;background:#0b0b0b}
.contact-modal-sections strong{display:block;margin-bottom:7px;color:#f2f2ee}
.contact-modal-sections p{margin:0;color:#92928d;line-height:1.55}
.contact-modal-card .contact-email{margin-top:12px;background:#2f8fe9;color:#fff}

@media(max-width:700px){
  .album-filter{padding:11px}
  .album-filter-head{align-items:flex-start}
  .album-filter-head p{font-size:.66rem}
  .album-filter-row{align-items:stretch;flex-direction:column;gap:7px}
  .album-filter-row span{max-width:none;text-align:left}
}

/* ===== V11.1 HOTFIX: album w wyszukiwarce, przewijanie listy i świeże miniatury ===== */
.category-thumb img{
  filter:saturate(.92) brightness(.82) contrast(1.05)!important;
}
.category-tabs button:hover .category-thumb img,
.category-tabs button.active .category-thumb img{
  filter:saturate(1) brightness(.98) contrast(1.04)!important;
}

/* Zewnętrzny panel pozostaje nieruchomy, przewija się wyłącznie lista wyników. */
.suggestions:not([hidden]){
  display:flex!important;
  flex-direction:column!important;
  overflow:hidden!important;
  touch-action:pan-y!important;
}
.suggestions-list{
  flex:1 1 auto;
  min-height:0;
  max-height:calc(min(56vh,540px) - 46px);
  overflow-x:hidden;
  overflow-y:auto;
  overscroll-behavior:contain;
  touch-action:pan-y!important;
  -webkit-overflow-scrolling:touch;
  scrollbar-gutter:stable;
  scrollbar-width:auto;
  scrollbar-color:#e6b72f #171717;
}
.suggestions-list::-webkit-scrollbar{width:14px}
.suggestions-list::-webkit-scrollbar-track{background:#171717;border-left:1px solid #303030}
.suggestions-list::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#f0c344,#b98213);border:3px solid #171717;border-radius:999px}
.suggestion{cursor:pointer}

@media(max-width:620px){
  .suggestions:not([hidden]){
    height:min(60dvh,540px)!important;
    max-height:min(60dvh,540px)!important;
  }
  .suggestions-list{
    max-height:none;
    padding-bottom:max(10px,env(safe-area-inset-bottom));
  }
}


/* =========================================================
   V12 — SERCE / TŁO / BOKI / SUBTELNE ANIMACJE
   Warstwa wizualna; bez zmian w logice gry.
   ========================================================= */
body{
  background:
    radial-gradient(circle at 50% -8%,rgba(64,157,255,.16),transparent 34%),
    radial-gradient(circle at 8% 18%,rgba(25,112,210,.08),transparent 22%),
    radial-gradient(circle at 92% 22%,rgba(205,45,52,.07),transparent 20%),
    linear-gradient(180deg,#050608 0%,#030304 44%,#010101 100%);
}
.side-art{
  position:fixed;
  top:0;
  bottom:0;
  width:min(25vw,360px);
  z-index:0;
  pointer-events:none;
  background-repeat:no-repeat;
  background-size:cover;
  opacity:.72;
  filter:saturate(.98) contrast(1.08) brightness(1.08);
  animation:sideBreath 14s ease-in-out infinite alternate;
}
.side-art-left{
  left:0;
  background-image:
    linear-gradient(90deg,rgba(0,0,0,.00),rgba(0,0,0,.68)),
    url("assets/visual/side-left-hotfix.webp?v=12-1");
  background-position:left center;
}
.side-art-right{
  right:0;
  background-image:
    linear-gradient(270deg,rgba(0,0,0,.00),rgba(0,0,0,.68)),
    url("assets/visual/side-right-hotfix.webp?v=12-1");
  background-position:right center;
  animation-delay:-7s;
}
.page-shell{position:relative;z-index:2}
.hero{animation:v12FadeUp .72s ease both}
.hero::before{
  content:"";
  position:absolute;
  left:50%;
  top:52px;
  width:min(72vw,620px);
  height:250px;
  transform:translateX(-50%);
  background:radial-gradient(circle,rgba(65,165,255,.17),transparent 68%);
  filter:blur(22px);
  pointer-events:none;
  z-index:-1;
  animation:heroHalo 6s ease-in-out infinite;
}
.logo-stage{position:relative;width:min(92vw,350px);margin:0 auto;display:grid;place-items:center;isolation:isolate}
.logo-stage::before,.logo-stage::after{content:"";position:absolute;inset:10% 8%;border-radius:50%;pointer-events:none;z-index:-1}
.logo-stage::before{background:radial-gradient(circle,rgba(70,180,255,.44) 0%,rgba(70,180,255,.18) 34%,transparent 70%);filter:blur(18px);animation:heartHalo 3.2s ease-in-out infinite}
.logo-stage::after{inset:23% 20%;border:1px solid rgba(94,191,255,.30);box-shadow:0 0 32px rgba(71,174,255,.24),inset 0 0 24px rgba(71,174,255,.12);animation:heartRing 3.2s ease-in-out infinite}
.logo-heart{
  width:100%;
  max-height:320px;
  object-fit:contain;
  margin:0 auto;
  filter:drop-shadow(0 0 18px rgba(65,165,255,.48)) drop-shadow(0 0 44px rgba(65,165,255,.24));
  animation:logoFloat 5.5s ease-in-out infinite,logoGlow 3.2s ease-in-out infinite;
}
.tagline{margin-top:-6px;animation:v12FadeUp .9s ease both}
.app-card{animation:v12FadeUp .92s ease both}
.info-section{animation:v12FadeUp 1.05s ease both}
.feature-card,.category-tabs button,.ghost-button,.play-btn,button.primary,button.secondary{
  transition:transform .22s ease,border-color .22s ease,box-shadow .22s ease,filter .22s ease;
}
.feature-card:hover,.category-tabs button:hover{
  transform:translateY(-3px);
  box-shadow:0 17px 38px rgba(0,0,0,.32),0 0 0 1px rgba(72,161,255,.08);
}
.ghost-button:hover,.play-btn:hover,button.primary:hover,button.secondary:hover{transform:translateY(-1px)}
.modal:not([hidden]) .modal-card{animation:modalPop .24s ease both}
.attempt{animation:attemptIn .25s ease both}
.step.used{animation:stepFlash .28s ease both}

@keyframes v12FadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
@keyframes logoFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-5px)}}
@keyframes logoGlow{0%,100%{filter:drop-shadow(0 0 18px rgba(65,165,255,.42)) drop-shadow(0 0 42px rgba(65,165,255,.18))}50%{filter:drop-shadow(0 0 28px rgba(86,186,255,.72)) drop-shadow(0 0 72px rgba(65,165,255,.34))}}
@keyframes heartHalo{0%,100%{opacity:.65;transform:scale(.94)}50%{opacity:1;transform:scale(1.08)}}
@keyframes heartRing{0%,100%{opacity:.28;transform:scale(.94)}50%{opacity:.76;transform:scale(1.08)}}
@keyframes heroHalo{0%,100%{opacity:.72;transform:translateX(-50%) scale(1)}50%{opacity:1;transform:translateX(-50%) scale(1.06)}}
@keyframes sideBreath{0%{opacity:.62;transform:translateY(0) scale(1)}100%{opacity:.78;transform:translateY(-12px) scale(1.012)}}
@keyframes modalPop{from{opacity:0;transform:translateY(10px) scale(.985)}to{opacity:1;transform:translateY(0) scale(1)}}
@keyframes attemptIn{from{opacity:0;transform:translateX(-8px)}to{opacity:1;transform:translateX(0)}}
@keyframes stepFlash{0%{filter:brightness(1.55)}100%{filter:brightness(1)}}

@media(max-width:1250px){
  .side-art{width:150px;opacity:.46}
}
@media(max-width:860px){
  .side-art{display:none}
  .logo-stage{width:min(82vw,300px)}
  .logo-heart{max-height:275px}
  .hero::before{width:min(92vw,450px);height:210px}
}
@media(prefers-reduced-motion:reduce){
  .logo-heart,.logo-stage::before,.logo-stage::after,.side-art,.hero,.tagline,.app-card,.info-section,.modal-card,.attempt,.step.used{animation:none!important}
  *{scroll-behavior:auto!important;transition-duration:.01ms!important}
}


/* === Kukondle v1.5 banner patch v3: animated SVG logo === */
.hero{padding-top:8px;margin-bottom:18px}
.hero::before{display:none!important}
.logo-stage-svg{position:relative;width:min(92vw,920px);max-width:920px;margin:4px auto 0;display:flex;align-items:center;justify-content:center;isolation:isolate}
.logo-stage-svg::before,.logo-stage-svg::after{content:none!important;display:none!important}
.logo-banner-svg{display:block;width:100%;height:auto;margin:0 auto;object-fit:contain;object-position:center center}
.hero .tagline{display:none}
@media(max-width:860px){.hero{padding-top:6px;margin-bottom:14px}.logo-stage-svg{width:min(96vw,700px)}}
@media(max-width:520px){.logo-stage-svg{width:min(98vw,560px)}}


/* === Kukondle v1.5 banner patch v4: refined SVG centering, realistic flame, margins === */
.hero{padding-top:22px!important;margin-bottom:34px!important;}
.hero::before{display:none!important;}
.logo-stage-svg{position:relative;width:min(90vw,900px)!important;max-width:900px!important;margin:14px auto 22px!important;display:flex;align-items:center;justify-content:center;isolation:isolate;}
.logo-stage-svg::before,.logo-stage-svg::after{content:none!important;display:none!important;}
.logo-banner-svg{display:block;width:100%;height:auto;margin:0 auto;object-fit:contain;object-position:center center;}
.hero .tagline{display:none!important;}
@media(max-width:860px){.hero{padding-top:18px!important;margin-bottom:26px!important}.logo-stage-svg{width:min(94vw,700px)!important;margin:12px auto 18px!important;}}
@media(max-width:520px){.hero{padding-top:16px!important;margin-bottom:22px!important}.logo-stage-svg{width:min(96vw,560px)!important;margin:10px auto 14px!important;}}


/* === Kukondle v1.5 banner patch v5: real transparent fire overlay === */
.hero{
  padding-top:26px!important;
  margin-bottom:42px!important;
}
.hero::before{
  display:none!important;
}
.logo-stage-flame{
  position:relative!important;
  width:min(90vw,900px)!important;
  max-width:900px!important;
  aspect-ratio:1502 / 686;
  margin:22px auto 30px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  isolation:isolate;
  overflow:visible;
}
.logo-stage-flame::before{
  content:""!important;
  position:absolute!important;
  left:50%!important;
  top:47%!important;
  width:min(22vw,220px)!important;
  height:min(20vw,200px)!important;
  transform:translate(-50%,-50%)!important;
  border-radius:50%;
  background:radial-gradient(circle,rgba(88,194,255,.30) 0%,rgba(48,166,255,.14) 38%,rgba(25,105,177,.06) 62%,transparent 78%);
  filter:blur(18px);
  opacity:.86;
  pointer-events:none;
  z-index:0;
  animation:kukondleRealHeartGlow 3.4s ease-in-out infinite;
}
.logo-stage-flame::after{
  content:none!important;
  display:none!important;
}
.logo-banner-base{
  position:relative!important;
  z-index:2!important;
  display:block!important;
  width:100%!important;
  height:auto!important;
  max-height:none!important;
  object-fit:contain!important;
  object-position:center center!important;
  margin:0 auto!important;
  filter:drop-shadow(0 0 8px rgba(42,154,255,.10))!important;
  animation:none!important;
}
.logo-fire-real{
  position:absolute!important;
  left:50%!important;
  top:2.2%!important;
  width:clamp(150px,19.2vw,214px)!important;
  height:auto!important;
  transform:translateX(-50%)!important;
  z-index:3!important;
  pointer-events:none!important;
  user-select:none!important;
  opacity:.78;
  mix-blend-mode:screen;
  filter:saturate(1.25) contrast(1.08) drop-shadow(0 0 10px rgba(55,181,255,.36)) drop-shadow(0 0 22px rgba(55,181,255,.18));
}
.hero .tagline{
  display:none!important;
}
@keyframes kukondleRealHeartGlow{
  0%,100%{opacity:.66;transform:translate(-50%,-50%) scale(.97)}
  50%{opacity:.95;transform:translate(-50%,-50%) scale(1.05)}
}
@media(max-width:860px){
  .hero{padding-top:22px!important;margin-bottom:32px!important;}
  .logo-stage-flame{width:min(94vw,700px)!important;margin:18px auto 24px!important;}
  .logo-stage-flame::before{width:180px!important;height:165px!important;}
  .logo-fire-real{width:clamp(120px,25vw,170px)!important;top:2.4%!important;}
}
@media(max-width:520px){
  .hero{padding-top:18px!important;margin-bottom:26px!important;}
  .logo-stage-flame{width:min(96vw,560px)!important;margin:16px auto 20px!important;}
  .logo-fire-real{width:clamp(100px,28vw,145px)!important;top:2.8%!important;}
}
@media(prefers-reduced-motion:reduce){
  .logo-stage-flame::before{animation:none!important;}
}


/* === Kukondle v1.5 banner patch v6: no flame, clean centered banner === */
.hero{
  padding-top:26px!important;
  margin-bottom:42px!important;
}
.hero::before{
  display:none!important;
}
.logo-stage-clean{
  position:relative!important;
  width:min(90vw,900px)!important;
  max-width:900px!important;
  aspect-ratio:1502 / 686;
  margin:22px auto 30px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  isolation:isolate;
  overflow:visible;
}
.logo-stage-clean::before{
  content:""!important;
  position:absolute!important;
  left:50%!important;
  top:47%!important;
  width:min(22vw,220px)!important;
  height:min(20vw,200px)!important;
  transform:translate(-50%,-50%)!important;
  border-radius:50%;
  background:radial-gradient(circle,rgba(88,194,255,.24) 0%,rgba(48,166,255,.11) 38%,rgba(25,105,177,.045) 62%,transparent 78%);
  filter:blur(18px);
  opacity:.78;
  pointer-events:none;
  z-index:0;
  animation:kukondleCleanHeartGlow 3.4s ease-in-out infinite;
}
.logo-stage-clean::after{
  content:none!important;
  display:none!important;
}
.logo-banner-base{
  position:relative!important;
  z-index:2!important;
  display:block!important;
  width:100%!important;
  height:auto!important;
  max-height:none!important;
  object-fit:contain!important;
  object-position:center center!important;
  margin:0 auto!important;
  filter:drop-shadow(0 0 8px rgba(42,154,255,.08))!important;
  animation:none!important;
}
.logo-fire-real{
  display:none!important;
}
.hero .tagline{
  display:none!important;
}
@keyframes kukondleCleanHeartGlow{
  0%,100%{opacity:.58;transform:translate(-50%,-50%) scale(.98)}
  50%{opacity:.86;transform:translate(-50%,-50%) scale(1.04)}
}
@media(max-width:860px){
  .hero{padding-top:22px!important;margin-bottom:32px!important;}
  .logo-stage-clean{width:min(94vw,700px)!important;margin:18px auto 24px!important;}
  .logo-stage-clean::before{width:180px!important;height:165px!important;}
}
@media(max-width:520px){
  .hero{padding-top:18px!important;margin-bottom:26px!important;}
  .logo-stage-clean{width:min(96vw,560px)!important;margin:16px auto 20px!important;}
}
@media(prefers-reduced-motion:reduce){
  .logo-stage-clean::before{animation:none!important;}
}


/* === Kukondle side graphics patch v2: album-cover collage sides + cache-busting === */
.side-art{
  width:min(27vw,390px)!important;
  opacity:.82!important;
  filter:saturate(1.06) contrast(1.08) brightness(.92)!important;
  background-repeat:no-repeat!important;
  background-size:cover!important;
}
.side-art-left{
  background-image:
    linear-gradient(90deg,rgba(0,0,0,.02) 0%,rgba(0,0,0,.14) 38%,rgba(0,0,0,.78) 100%),
    url("assets/visual/side-left-collage-v2.webp?v=side-collage-v2")!important;
  background-position:left center!important;
}
.side-art-right{
  background-image:
    linear-gradient(270deg,rgba(0,0,0,.02) 0%,rgba(0,0,0,.14) 38%,rgba(0,0,0,.78) 100%),
    url("assets/visual/side-right-collage-v2.webp?v=side-collage-v2")!important;
  background-position:right center!important;
}
@media(max-width:1250px){
  .side-art{width:min(23vw,260px)!important;opacity:.62!important;}
}
@media(max-width:860px){
  .side-art{display:none!important;}
}


/* === Kukondle final hotfix: stats + suggestions + no hero CTA v2 === */
.hero-cta,
#startGameBtn{
  display:none!important;
}
.public-play-stats{
  position:relative;
  z-index:2;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:6px;
  width:max-content;
  max-width:100%;
  margin:10px auto 16px;
  padding:8px 13px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:999px;
  background:rgba(255,255,255,.035);
  color:var(--muted);
  font-size:.82rem;
  font-weight:750;
  line-height:1.35;
  text-align:center;
  box-shadow:0 10px 28px rgba(0,0,0,.18);
}
.public-play-stats strong{
  color:#ffd84f;
  font-weight:950;
}
.public-play-stats.is-loading,
.public-play-stats.is-error{
  color:rgba(234,241,255,.52);
}
.app-card,
.guess-area,
.input-wrap{
  overflow:visible!important;
}
.input-wrap{
  position:relative!important;
  display:grid!important;
  gap:8px!important;
}
.suggestions[hidden]{
  display:none!important;
}
.suggestions:not([hidden]){
  position:relative!important;
  inset:auto!important;
  display:flex!important;
  flex-direction:column!important;
  width:100%!important;
  max-height:min(42vh,360px)!important;
  height:auto!important;
  margin:4px 0 10px!important;
  overflow:hidden!important;
  border-radius:14px!important;
  z-index:15!important;
  box-shadow:0 18px 50px rgba(0,0,0,.72),0 0 0 1px rgba(255,255,255,.06)!important;
}
.suggestions-list{
  flex:1 1 auto!important;
  min-height:0!important;
  max-height:calc(min(42vh,360px) - 48px)!important;
  overflow-x:hidden!important;
  overflow-y:auto!important;
  overscroll-behavior:contain!important;
  -webkit-overflow-scrolling:touch!important;
  padding-bottom:14px!important;
  scrollbar-gutter:stable!important;
}
.suggestions-head{
  flex:0 0 auto!important;
}
.actions{
  position:relative!important;
  z-index:1!important;
  margin-top:0!important;
}
.attempts-section{
  position:relative!important;
  z-index:0!important;
  margin-top:24px!important;
}
@media(max-width:860px){
  .public-play-stats{
    width:100%;
    margin:8px auto 14px;
    border-radius:16px;
    font-size:.78rem;
    flex-wrap:wrap;
  }
  .suggestions:not([hidden]){
    max-height:min(46dvh,400px)!important;
  }
  .suggestions-list{
    max-height:calc(min(46dvh,400px) - 48px)!important;
    padding-bottom:max(14px,env(safe-area-inset-bottom))!important;
  }
  .suggestion{
    min-height:66px!important;
  }
}


/* === Share card / social share === */
.share-actions{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin-top:10px;
}
.share-actions > button{
  width:100%;
}
@media (max-width:560px){
  .share-actions{
    grid-template-columns:1fr;
  }
}

/* === Kukondle isolated share-card addon v11-9 === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{
  width:100%;
}
@media(max-width:560px){
  .share-actions{
    grid-template-columns:1fr;
  }
}

/* === Kukondle share card v12 fixed layout === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{width:100%;}
@media(max-width:560px){
  .share-actions{grid-template-columns:1fr;}
}

/* === Kukondle template-based share card v13 === */
.share-actions{display:grid!important;grid-template-columns:1fr 1fr;gap:10px;width:100%;margin:10px 0 0;}
.share-actions > button{width:100%;}
@media(max-width:560px){.share-actions{grid-template-columns:1fr;}}

/* === Kukondle share-card template buttons fix v13 === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{width:100%;}
@media(max-width:560px){.share-actions{grid-template-columns:1fr;}}

/* === Share template buttons 404 fix === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{
  width:100%;
}
@media(max-width:560px){
  .share-actions{
    grid-template-columns:1fr;
  }
}

/* === Kukondle inline share card buttons v14 === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{
  width:100%;
}
@media(max-width:560px){
  .share-actions{
    grid-template-columns:1fr;
  }
}

/* === Kukondle CSP-safe share card buttons v15 === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{
  width:100%;
}
@media(max-width:560px){
  .share-actions{
    grid-template-columns:1fr;
  }
}

/* === Kukondle share-card template v17 === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{width:100%;}
@media(max-width:560px){
  .share-actions{grid-template-columns:1fr;}
}

/* === Kukondle share-card template v18 === */
.share-actions{
  display:grid!important;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0 0;
}
.share-actions > button{width:100%;}
@media(max-width:560px){
  .share-actions{grid-template-columns:1fr;}
}
html,
body {
  width: 100%;
  max-width: 100%;
  overflow-x: hidden;
}

body {
  margin: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

.app,
.page,
.page-shell,
.container,
.hero,
.main-card,
.app-card {
  max-width: 100%;
}

@media (max-width: 720px) {
  .page-shell,
  .container,
  .app,
  main {
    width: 100%;
    max-width: 100%;
    padding-left: 12px;
    padding-right: 12px;
  }

  .logo-stage,
  .hero,
  .main-card,
  .app-card {
    width: 100%;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }
}

/* === Kukondle mobile viewport/layout safe v21 ===
   Fix po rozjazdach na telefonie:
   - poprawiony meta viewport w HTML
   - brak poziomego przesuwu
   - hero/logo/top-actions nie wychodzą poza viewport
*/
html,
body{
  width:100%!important;
  max-width:100%!important;
  overflow-x:hidden!important;
}

body{
  margin:0!important;
}

img,
svg,
video,
canvas{
  max-width:100%!important;
}

.page-shell{
  width:100%!important;
  max-width:920px!important;
  margin-left:auto!important;
  margin-right:auto!important;
  overflow-x:clip!important;
}

.hero,
.logo-stage,
.logo-stage-clean,
.logo-stage-flame,
.logo-stage-svg{
  max-width:100%!important;
  overflow:visible!important;
}

.logo-banner-base,
.logo-banner-svg,
.logo,
.logo-heart{
  max-width:100%!important;
  height:auto!important;
}

@media(max-width:860px){
  .page-shell{
    max-width:100%!important;
    padding-left:max(12px, env(safe-area-inset-left))!important;
    padding-right:max(12px, env(safe-area-inset-right))!important;
  }

  .top-actions{
    width:100%!important;
    max-width:100%!important;
    margin-left:0!important;
    margin-right:0!important;
    padding-left:0!important;
    padding-right:0!important;
    justify-content:flex-start!important;
    overflow-x:auto!important;
    overflow-y:hidden!important;
  }

  .logo-stage-clean,
  .logo-stage-flame,
  .logo-stage-svg{
    width:100%!important;
    max-width:100%!important;
    margin-left:auto!important;
    margin-right:auto!important;
  }

  .app-card,
  .category-control,
  .feature-card,
  .info-section{
    width:100%!important;
    max-width:100%!important;
    margin-left:0!important;
    margin-right:0!important;
  }
}

@media(max-width:520px){
  .page-shell{
    padding-left:max(10px, env(safe-area-inset-left))!important;
    padding-right:max(10px, env(safe-area-inset-right))!important;
  }

  .app-card{
    padding-left:13px!important;
    padding-right:13px!important;
  }
}

/* === KUKONDLE CLEANUP P0 LAYOUT v24 ===
   Przyczyna krzywego układu:
   - styles.css został wcześniej przypadkiem nadpisany samym hotfixem,
     więc zniknął bazowy layout strony.
   - dodatkowo mode-growth-copy siedzi tylko w lewej kolumnie,
     a .switch-row było wyrównywane do dołu, przez co "Audio/Tekst"
     zjeżdżało niżej niż "Daily/Endless".

   Ten blok przywraca stabilny układ bez kolejnego łatania na ślepo.
*/

/* Stare CTA w hero wyłączone. Przycisk wrócimy później do środka karty, nie nad kartę. */
.hero-cta-block{
  display:none!important;
}

/* Główna naprawa krzywego rzędu: wyrównanie obu kontrolek od góry. */
.switch-row{
  align-items:flex-start!important;
}

.control-group{
  min-width:0;
}

.mode-growth-copy{
  margin:8px 0 0!important;
  text-align:left!important;
  color:rgba(233,244,255,.72)!important;
  font-size:.82rem!important;
  line-height:1.35!important;
}

.mode-growth-copy p{
  margin:0!important;
}

/* Ekran końca gry z P0 — style, które zniknęły po nadpisaniu CSS. */
.result-growth-panel{
  margin:10px 0 12px;
  padding:12px;
  border:1px solid rgba(88,177,255,.18);
  border-radius:18px;
  background:rgba(255,255,255,.045);
}

.result-growth-panel h3{
  margin:0 0 6px;
  color:#f7fbff;
  font-size:1rem;
}

.daily-done-hint{
  margin:8px 0 0;
  color:#8fd5ff;
  font-weight:800;
}

.result-actions-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
  width:100%;
  margin:10px 0;
}

.result-actions-grid > button{
  width:100%;
}

.legacy-share{
  opacity:.82;
}

/* Mobile: tu te sekcje mają iść pod sobą, bez udawania desktopu. */
@media(max-width:860px){
  .hero{
    padding-top:10px!important;
    margin-bottom:12px!important;
  }

  .hero .tagline{
    display:block!important;
    margin:6px auto 10px!important;
    font-size:.82rem!important;
    line-height:1.3!important;
  }

  .switch-row{
    align-items:stretch!important;
    flex-direction:column!important;
    gap:14px!important;
  }

  .mode-growth-copy{
    text-align:center!important;
    font-size:.8rem!important;
    max-width:360px;
    margin-left:auto!important;
    margin-right:auto!important;
  }

  .segmented{
    width:100%!important;
  }

  .app-card{
    margin-top:0!important;
  }
}

@media(max-width:560px){
  .result-actions-grid{
    grid-template-columns:1fr;
  }
}

/* === KUKONDLE PRE-REACT STABILIZATION v25 ===
   Ostatnie porządki przed migracją:
   - end screen jako główny punkt share,
   - daily streak jako lekki localStorage hint,
   - stabilne przyciski result actions,
   - bez ruszania obecnego klimatu UI.
*/
.daily-done-hint{
  margin:8px 0 0!important;
  color:#8fd5ff!important;
  font-weight:850!important;
  line-height:1.35!important;
}

.result-actions-grid{
  display:grid!important;
  grid-template-columns:1fr 1fr!important;
  gap:10px!important;
  width:100%!important;
  margin:10px 0!important;
}

.result-actions-grid > button{
  width:100%!important;
  min-height:44px!important;
}

@media(max-width:560px){
  .result-actions-grid{
    grid-template-columns:1fr!important;
  }
}
