: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}
}
