*,*:before,*:after{box-sizing:border-box}body{font-family:Tahoma,Helvetica,Arial,sans-serif;font-size:clamp(12px,3.5vw,18px);margin:0;padding:0}.app-header{padding:.8em 1.2em;background-color:#f0f0f0;border-bottom:2px solid #ddd;font-size:1em}.app-container{max-width:900px;width:100%;margin:0 auto}.training-section{padding:1.5em 5% 5em;text-align:center}.section-title{font-size:1.35em;margin-bottom:.2em}.section-subtitle{font-size:.95em;color:#666;margin-bottom:2em}.swatches{display:flex;justify-content:center;flex-wrap:wrap;gap:0}.swatch{margin:.8em;height:clamp(80px,18vw,160px);width:clamp(90px,20vw,180px);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:1em;transition:box-shadow .1s;-webkit-tap-highlight-color:transparent}.swatch:active{box-shadow:0 0 0 3px gray}.swatch-count{margin-top:.8em;color:#888;font-size:.9em}.nav-row{display:flex;justify-content:flex-end;margin-top:.4em;padding-right:1em}.arrow-btn{color:#333;font-weight:700;font-size:1.8em;cursor:pointer;border-radius:6px;padding:0 .2em;line-height:1;-webkit-tap-highlight-color:transparent}.train-box{margin-top:3em}.train-btn{background-color:#ddd;box-shadow:#e0e0e0 0 .15em .6em;border:2px solid #CCC;margin-top:2em;padding:.5em 1.2em;border-radius:8px;cursor:pointer;display:inline-block;margin-bottom:1em;font-size:1em}.train-btn:active{background-color:#bbb}.train-hint{font-size:.95em;color:#555;padding:0 5%;margin-top:.8em}.progress-box{max-width:900px;width:100%;text-align:center;margin:0 auto;font-weight:700;font-size:1.8em;padding:4em 5%}.progress-bar{height:1.2em;border:2px solid #ccc;background-color:#f2f2f2;margin-top:1em;border-radius:4px;overflow:hidden}.progress-fill{background-color:#d0d0d0;height:100%;transition:width .3s ease}.progress-pct{font-size:.5em;margin-top:.8em;color:#888}.testing-section{padding:2em 5% 3em;text-align:center}.swatch-label{cursor:pointer;font-size:.95em;text-align:center;margin-top:.3em;color:#aaa}.swatch-label.active{color:#222}.test-hint{margin-top:2em;font-size:.9em;color:#555}.back-btn{background-color:#ddd;border:2px solid #CCC;border-radius:8px;padding:.45em 1em;cursor:pointer;font-size:.9em;margin-top:1em;font-family:inherit}.back-btn:active{background-color:#bbb}.code-box{margin:2em 5%}.code-header{margin-bottom:.8em;font-weight:700;font-size:1em}.code-pre{text-align:left;font-family:DejaVu Sans Mono,monospace;font-size:.75em;white-space:pre-wrap;word-break:break-all;background-color:#f4f4f4;padding:1.2em 1em;margin:0;border:2px solid #eee}@media(max-width:480px){.section-title{font-size:1.2em}.swatch{height:clamp(70px,22vw,120px);width:clamp(80px,25vw,140px);margin:.5em}.train-btn{width:80%}}
