.app-header{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;padding:1rem 1.5rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 4px 6px #0000001a}.app-header h1{margin:0;font-size:1.8rem;font-weight:700}.login-btn{background:rgba(255,255,255,.95);color:#667eea;border:none;padding:.6rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 4px #0000001a}.login-btn:hover{background:white;transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.header-nav{display:flex;gap:.5rem;align-items:center}.nav-btn{background:rgba(255,255,255,.2);color:#fff;border:2px solid transparent;padding:.5rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.nav-btn:hover{background:rgba(255,255,255,.3)}.nav-btn.active{background:white;color:#667eea;border-color:#fff}.logout-btn{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.3);padding:.5rem 1rem;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .3s ease;margin-left:.5rem}.logout-btn:hover{background:rgba(255,255,255,.25);border-color:#ffffff80}@media (max-width: 768px){.app-header{padding:.75rem 1rem;flex-direction:row;gap:.5rem}.app-header h1{font-size:1.25rem}.header-nav{width:100%;justify-content:center;flex-wrap:wrap}.nav-btn{flex:1;padding:.5rem 1rem;font-size:.9rem}.logout-btn{flex:0 0 auto;margin-left:0;margin-top:.5rem;width:100%}}.auth-container{background:rgba(31,41,55,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;padding:1.5rem;max-width:400px;margin:2rem auto;border:2px solid #374151}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-form h3{text-align:center;color:#60a5fa;margin-bottom:.5rem}.auth-input{padding:.75rem;border-radius:.5rem;border:1px solid #4b5563;background:rgba(17,24,39,.8);color:#e5e7eb;font-size:1rem;transition:all .2s ease}.auth-input:focus{outline:none;border-color:#3b82f6;background:rgba(17,24,39,1)}.auth-input::placeholder{color:#6b7280}.auth-error{background:rgba(220,38,38,.1);border:1px solid #dc2626;color:#fca5a5;padding:.75rem;border-radius:.5rem;font-size:.9rem}.auth-toggle{background:transparent;border:none;color:#60a5fa;cursor:pointer;font-size:.9rem;padding:.5rem;transition:color .2s ease}.auth-toggle:hover{color:#93c5fd;text-decoration:underline}.auth-status{display:flex;align-items:center;gap:.75rem;padding:.5rem 1rem;background:rgba(31,41,55,.5);border-radius:.5rem}.user-email{color:#60a5fa;font-size:.9rem;white-space:nowrap}.btn-sm{padding:.4rem 1rem;font-size:.85rem}.stats-page{max-width:1400px;margin:0 auto;padding:0 1.5rem 2rem}.stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.stats-header h2{font-size:2rem;color:#60a5fa;margin:0}.no-user-message{text-align:center;padding:3rem 1rem;background:rgba(31,41,55,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;border:2px solid #374151}.no-user-message h2{color:#60a5fa;margin-bottom:1rem}.no-user-message p{color:#9ca3af}.overview-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:2rem}.stat-card{background:rgba(31,41,55,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;border:2px solid #374151;padding:1.25rem;display:flex;align-items:center;gap:1rem;transition:all .2s ease}.stat-card:hover{border-color:#3b82f6;transform:translateY(-2px)}.stat-card.warning{border-color:#fbbf24}.stat-icon{font-size:2rem}.stat-info{flex:1}.stat-label{color:#9ca3af;font-size:.9rem;margin-bottom:.25rem}.stat-value{color:#60a5fa;font-size:1.75rem;font-weight:600}.detailed-stats{background:rgba(31,41,55,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;border:2px solid #374151;padding:1.5rem}.detailed-stats h3{color:#60a5fa;margin-bottom:1rem;font-size:1.25rem}.stats-table{overflow-x:auto}.table-header,.table-row{display:grid;grid-template-columns:2fr 1fr 1fr 1fr 1.5fr 1.5fr 1.5fr;gap:1rem;padding:.75rem 1rem;align-items:center}.table-header{background:rgba(17,24,39,.5);border-radius:.5rem;font-weight:600;color:#60a5fa;font-size:.9rem;margin-bottom:.5rem}.table-row{border-bottom:1px solid #374151;transition:background .2s ease}.table-row:hover{background:rgba(59,130,246,.05)}.table-row:last-child{border-bottom:none}.col-code{display:flex;flex-direction:column;gap:.25rem}.code-label{color:#e5e7eb;font-weight:500}.code-value{color:#9ca3af;font-size:.85rem}.col-attempts,.col-streak{color:#9ca3af}.accuracy-badge{display:inline-block;padding:.25rem .75rem;border-radius:.375rem;font-weight:600;font-size:.9rem}.accuracy-badge.good{background:rgba(34,197,94,.2);color:#4ade80;border:1px solid #22c55e}.accuracy-badge.ok{background:rgba(251,191,36,.2);color:#fbbf24;border:1px solid #f59e0b}.accuracy-badge.weak{background:rgba(239,68,68,.2);color:#f87171;border:1px solid #ef4444}.mode-stat{color:#9ca3af;font-size:.85rem}@media (max-width: 1024px){.table-header,.table-row{grid-template-columns:2fr 1fr 1fr 1fr}.col-easy,.col-hard,.col-expert{display:none}}@media (max-width: 768px){.stats-page{padding:0 1rem 2rem}.stats-header h2{font-size:1.5rem}.overview-cards{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{padding:1rem}.stat-icon,.stat-value{font-size:1.5rem}.table-header,.table-row{grid-template-columns:1.5fr .75fr 1fr;gap:.5rem;padding:.75rem .5rem;font-size:.85rem}.col-streak{display:none}}*{box-sizing:border-box;margin:0;padding:0;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.app-container{min-height:100vh;font-family:system-ui,-apple-system,sans-serif;background:linear-gradient(135deg,#0f172a 0%,#1e293b 100%);color:#e5e7eb}.trainer-content{max-width:1200px;margin:0 auto;padding:1rem}.trainer-header{text-align:center;margin-bottom:1rem}.mobile-controls{display:none}.desktop-only{display:block}.header{text-align:center;margin-bottom:2rem}.header h1{font-size:2rem;margin-bottom:.5rem;background:linear-gradient(135deg,#60a5fa,#3b82f6);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.instructions{color:#9ca3af;max-width:600px;margin:0 auto}.mode-toggle{display:flex;gap:.5rem;justify-content:center;margin:1.5rem auto .5rem}.mode-btn{padding:.5rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem;border:2px solid #3b82f6;background:transparent;color:#9ca3af}.mode-btn.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:#3b82f6}.mode-btn:hover{border-color:#60a5fa;color:#e5e7eb}.mode-btn.active:hover{transform:translateY(-2px);box-shadow:0 5px 15px #3b82f64d}.mode-description{color:#60a5fa;font-size:.9rem;margin-top:.5rem}.category-toggle{display:flex;gap:.5rem;justify-content:center;margin:1rem auto 0;flex-wrap:wrap}.category-btn{padding:.4rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.9rem;border:1px solid #6b7280;background:rgba(31,41,55,.5);color:#9ca3af}.category-btn.active{background:rgba(59,130,246,.2);color:#60a5fa;border-color:#3b82f6}.category-btn:hover{border-color:#60a5fa;color:#e5e7eb;background:rgba(59,130,246,.1)}.progress-controls{display:flex;gap:1rem;justify-content:center;align-items:center;margin:1rem auto 0;flex-wrap:wrap}.checkbox-label{display:flex;align-items:center;gap:.5rem;color:#60a5fa;font-size:.9rem;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.btn-reset{padding:.4rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.85rem;border:1px solid #dc2626;background:rgba(220,38,38,.1);color:#fca5a5}.btn-reset:hover{background:rgba(220,38,38,.2);border-color:#ef4444;color:#fecaca}.mastered-badge{margin-left:.5rem;font-size:1.2rem;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.stats-badge{margin-left:.5rem;font-size:.85rem;color:#9ca3af;background:rgba(75,85,99,.3);padding:.2rem .5rem;border-radius:.25rem}.btn-stats{padding:.4rem 1rem;border-radius:.375rem;font-weight:500;cursor:pointer;transition:all .2s ease;font-size:.85rem;border:1px solid #3b82f6;background:rgba(59,130,246,.1);color:#60a5fa}.btn-stats:hover{background:rgba(59,130,246,.2);border-color:#60a5fa}.stats-panel{background:rgba(31,41,55,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:.75rem;padding:1.5rem;margin:1rem auto;border:2px solid #374151;max-width:600px}.stats-panel h3{color:#60a5fa;text-align:center;margin-bottom:1rem;font-size:1.25rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem}.stat-item{display:flex;flex-direction:column;align-items:center;padding:1rem;background:rgba(17,24,39,.5);border-radius:.5rem;border:1px solid #4b5563}.stat-label{color:#9ca3af;font-size:.85rem;margin-bottom:.5rem;text-align:center}.stat-value{color:#60a5fa;font-size:1.5rem;font-weight:600}.stat-value.weak{color:#fbbf24}.game-container{display:flex;gap:2rem;max-width:1200px;margin:0 auto}.game-container.mobile{flex-direction:column}.classes-section{flex:2}.class-row{border:2px solid #374151;border-radius:.75rem;padding:1rem;margin-bottom:1rem;background:rgba(31,41,55,.5);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.class-row.correct{border-color:#16a34a;background:rgba(22,163,74,.1)}.class-row.incorrect{border-color:#dc2626;background:rgba(220,38,38,.1)}.class-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem;gap:.5rem}.class-label{font-weight:600;font-size:1.1rem;flex:1}.play-sound-btn{padding:.5rem 1rem;border-radius:.5rem;border:2px solid #3b82f6;background:linear-gradient(135deg,#1f2937,#111827);color:#60a5fa;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem}.play-sound-btn:hover:not(:disabled){background:linear-gradient(135deg,#2563eb,#3b82f6);color:#fff;transform:translateY(-2px);box-shadow:0 5px 15px #3b82f64d}.play-sound-btn:disabled{opacity:.6;cursor:not-allowed}.hint-btn{background:rgba(59,130,246,.1);border:1px solid #3b82f6;border-radius:.375rem;padding:.25rem .5rem;font-size:1rem;cursor:pointer;transition:all .2s ease}.hint-btn:hover{background:rgba(59,130,246,.2);transform:scale(1.05)}.hint{background:rgba(251,191,36,.1);border:1px solid #fbbf24;border-radius:.375rem;padding:.5rem;margin-bottom:.75rem;color:#fbbf24;font-size:.9rem;font-weight:500}.slots-container{display:flex;gap:.5rem;flex-wrap:wrap;width:100%;overflow:visible}.slot{width:50px;height:50px;border-radius:.5rem;border:2px dashed #4b5563;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;background:rgba(17,24,39,.5);cursor:pointer;transition:all .2s ease;flex-shrink:0;min-width:50px;min-height:50px}.slot-wide{min-width:80px;width:auto;padding:0 .5rem}.draggable-value{cursor:grab;display:flex;align-items:center;justify-content:center;width:100%;height:100%;touch-action:none}.draggable-value:active{cursor:grabbing}.slot:hover{border-color:#6b7280;background:rgba(17,24,39,.8)}.controls{display:flex;gap:.75rem;margin:1rem 0;align-items:center;justify-content:center;flex-wrap:wrap}.btn{padding:.75rem 1.5rem;border-radius:.5rem;font-weight:600;cursor:pointer;transition:all .2s ease;font-size:1rem;border:none}.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px #3b82f64d}.btn-secondary{background:transparent;color:#e5e7eb;border:1px solid #6b7280}.btn-secondary:hover{background:rgba(107,114,128,.1);border-color:#9ca3af}.score{font-size:1.1rem;font-weight:600;color:#60a5fa}.tiles-section{flex:1;min-width:250px}.tiles-section h2{font-size:1.25rem;margin-bottom:.5rem}.tiles-instructions{font-size:.9rem;color:#9ca3af;margin-bottom:1rem}.tiles-container{display:flex;flex-wrap:wrap;gap:.5rem;padding:1rem;background:rgba(17,24,39,.5);border-radius:.75rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-height:100px}.tile{min-width:60px;min-height:60px;padding:.5rem .75rem;border-radius:.5rem;border:2px solid #6b7280;display:flex;align-items:center;justify-content:center;cursor:grab;font-size:1.25rem;font-weight:700;color:#fff;background:linear-gradient(135deg,#1f2937,#111827);transition:all .2s ease;flex-shrink:0;min-width:50px;padding:0 .5rem;width:auto}.tile:hover{transform:translateY(-2px);box-shadow:0 5px 15px #0000004d;border-color:#3b82f6}.tile.selected{border-color:#3b82f6;background:linear-gradient(135deg,#2563eb,#3b82f6);transform:scale(1.1);box-shadow:0 0 20px #3b82f680}.tile:active{cursor:grabbing}.all-placed{font-size:.9rem;color:#60a5fa;font-style:italic}@media (max-width: 768px){.desktop-only{display:none!important}.mobile-controls{display:block;background:rgba(17,24,39,.5);border-radius:.75rem;padding:1rem;margin-top:1rem;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.mobile-controls .mode-toggle,.mobile-controls .category-toggle{margin:.5rem 0}.mobile-controls .mode-btn,.mobile-controls .category-btn{font-size:.9rem;padding:.5rem .75rem}.trainer-content{padding:.5rem}.trainer-header{margin-bottom:.75rem}.trainer-header h1{font-size:1.5rem}.game-container{gap:1rem}.class-row{padding:.75rem}.slots-container{gap:.75rem;width:100%}.slot{width:50px;height:50px;min-width:50px;min-height:50px;font-size:1.1rem}.tile{min-width:70px;min-height:60px;font-size:1.1rem;padding:.5rem 1rem;touch-action:none}.btn{padding:.75rem 1.25rem;font-size:1rem;flex:1;min-width:140px}.controls{justify-content:center;gap:.5rem;margin:.75rem 0}.tiles-section{margin-top:.5rem}.tiles-section h2{font-size:1.1rem;margin-bottom:.5rem}.tiles-instructions{font-size:.85rem;margin-bottom:.5rem}.tiles-container{gap:.75rem;padding:.75rem;min-height:80px}}@media (max-width: 480px){.slots-container{gap:.5rem;width:100%}.slot{width:50px;height:50px;min-width:50px;min-height:50px;font-size:1rem}.tile{min-width:65px;min-height:55px;font-size:1rem}}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
