*{margin:0;padding:0;box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background-color:#1a1a1a;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-tap-highlight-color:transparent;-webkit-touch-callout:none}html,body{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden;background-color:#1a1a1a}body{min-width:320px;min-height:100vh;display:block}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2}button{font-family:inherit;cursor:pointer;border:none;background:none;transition:all .2s ease}button:active{transform:scale(.98)}@media(hover:none)and (pointer:coarse){button:focus,button:focus-visible{outline:none}}html{scroll-behavior:smooth}body{overscroll-behavior-y:contain}@supports (-webkit-touch-callout: none){body{min-height:-webkit-fill-available}}.home-page{min-height:100vh;padding:1rem;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);color:#fff;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.home-header{text-align:center;padding:2rem 1rem;margin-bottom:2rem}.home-header h1{font-size:2rem;margin:0 0 .5rem;font-weight:700}.upload-section{max-width:500px;margin:0 auto 3rem;padding:0 1rem}.upload-toggle{display:flex;gap:.5rem;margin-bottom:1rem}.toggle-button{flex:1;padding:.75rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#999;font-size:.9rem;font-weight:600;cursor:pointer;transition:all .3s ease}.toggle-button:hover{background:#ffffff14;border-color:#fff3}.toggle-button.active{background:linear-gradient(135deg,#4a90e2,#357abd);border-color:#4a90e2;color:#fff;box-shadow:0 2px 10px #4a90e24d}.upload-button{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:1.25rem;background:linear-gradient(135deg,#4a90e2,#357abd);border:none;border-radius:16px;color:#fff;cursor:pointer;transition:all .3s ease;font-size:1.1rem;font-weight:600;box-shadow:0 4px 15px #4a90e24d}.upload-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #4a90e266}.upload-button:active{transform:translateY(0)}.upload-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.upload-icon{font-size:1.5rem}.text-input-section{display:flex;flex-direction:column;gap:1rem}.pgn-textarea{width:100%;padding:1rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px;color:#fff;font-family:Courier New,monospace;font-size:.9rem;line-height:1.5;resize:vertical;transition:all .3s ease}.pgn-textarea:focus{outline:none;border-color:#4a90e2;background:#ffffff14;box-shadow:0 0 0 3px #4a90e233}.pgn-textarea:disabled{opacity:.5;cursor:not-allowed}.pgn-textarea::placeholder{color:#666}.uploading{display:flex;align-items:center;gap:.5rem}.file-input{display:none}.error-message{margin-top:1rem;padding:1rem;background:#ef444433;border:1px solid rgba(239,68,68,.5);border-radius:8px;color:#fca5a5;text-align:center;font-size:.9rem}.repertoires-section{max-width:800px;margin:0 auto;padding:0 1rem}.empty-state p{margin:.5rem 0}.empty-hint{font-size:.9rem;color:#555}.repertoires-list{display:flex;flex-direction:column;gap:1rem}.repertoire-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;position:relative}.delete-button{position:absolute;top:.75rem;left:.75rem;width:2rem;height:2rem;border-radius:50%;background:#ef4444cc;border:1px solid rgba(239,68,68,1);color:#fff;font-size:1.25rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:10}.delete-button:hover{background:#ef4444;transform:scale(1.1)}.delete-button:active{transform:scale(.95)}.repertoire-card:hover{background:#ffffff14;border-color:#4a90e280;transform:translateY(-2px);box-shadow:0 4px 20px #0000004d}.repertoire-card:active{transform:translateY(0)}.repertoire-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.repertoire-name{margin:0;font-size:1.3rem;font-weight:600}.repertoire-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem;margin-bottom:1rem}.stat-subvalue{font-size:.8rem;color:#666;font-weight:400}.last-studied{font-size:.85rem;color:#666;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}@media(max-width:640px){.home-header h1{font-size:1.75rem}.upload-button{font-size:1rem;padding:1rem}.toggle-button{font-size:.85rem;padding:.625rem}.pgn-textarea{font-size:.85rem}.repertoire-card{padding:1.25rem}.repertoire-name{font-size:1.1rem}.repertoire-stats{grid-template-columns:repeat(2,1fr)}}.chapter-selection{min-height:100vh;padding:1rem;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);color:#fff;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.chapter-header{text-align:center;padding:1rem;margin-bottom:2rem;position:relative}.back-button{position:absolute;left:0;top:50%;transform:translateY(-50%);background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:.5rem 1rem;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s ease}.back-button:hover{background:#ffffff26}.back-button:active{transform:translateY(-50%) scale(.95)}.header-info h1{font-size:1.75rem;margin:0 0 .5rem;font-weight:700}.subtitle{color:#999;font-size:.9rem;margin:0}.chapters-section{max-width:800px;margin:0 auto;padding:0 1rem}.empty-state{text-align:center;padding:4rem 2rem;color:#666}.chapters-list{display:flex;flex-direction:column;gap:1rem}.chapter-card{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:1.5rem;cursor:pointer;transition:all .3s ease;position:relative}.chapter-card.due{border-color:#ef44444d;background:#ef44440d}.chapter-card:hover{background:#ffffff14;border-color:#4a90e280;transform:translateY(-2px);box-shadow:0 4px 20px #0000004d}.chapter-card:active{transform:translateY(0)}.chapter-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.chapter-name{margin:0;font-size:1.2rem;font-weight:600}.due-badge{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;padding:.375rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;box-shadow:0 2px 8px #ef44444d}.chapter-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;margin-bottom:1rem}.stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.75rem;color:#999;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.1rem;font-weight:600;color:#fff}.next-review{font-size:.85rem;color:#666;padding-top:1rem;border-top:1px solid rgba(255,255,255,.1)}@media(max-width:640px){.header-info h1{font-size:1.5rem}.back-button{font-size:.8rem;padding:.4rem .8rem}.chapter-card{padding:1.25rem}.chapter-name{font-size:1.1rem}.chapter-stats{grid-template-columns:repeat(3,1fr)}}.study-session{height:100vh;background:linear-gradient(135deg,#1a1a1a,#2d2d2d);color:#fff;display:flex;flex-direction:column;overflow:hidden}.study-session.loading{justify-content:center;align-items:center}.chessboard-container{width:100%;max-width:600px;max-height:600px;flex-shrink:0;position:relative;margin:0 auto}.chessboard-container:after{content:"";position:absolute;inset:0;border-radius:8px;pointer-events:none;transition:all .3s ease}.chessboard-container.feedback-correct:after{box-shadow:0 0 0 4px #22c55e,0 0 20px #22c55e80}.chessboard-container.feedback-incorrect:after{box-shadow:0 0 0 4px #ef4444,0 0 20px #ef444480}.scrollable-content{flex:1;overflow-y:auto;overflow-x:hidden;padding:.5rem 1rem 1rem;display:flex;flex-direction:column;gap:.5rem;position:relative;z-index:1;align-items:stretch}.study-session .played-moves{font-size:.9rem;color:#999;text-align:left;padding:.5rem 1rem;font-family:monospace;min-height:2rem;overflow:hidden;white-space:nowrap}.study-session .back-button-row{padding:.5rem 1rem;width:100%}.study-session .back-button{background:transparent;border:none;color:#999;font-size:1rem;cursor:pointer;padding:.5rem 0;transition:color .2s ease;white-space:nowrap}.study-session .back-button:hover{color:#fff}.study-session .back-button:active{transform:scale(.95)}.comment-section{display:flex;flex-direction:column;gap:.75rem}.move-comment{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;padding:.75rem;font-size:.9rem;line-height:1.4;color:#e5e5e5}@media(max-width:640px){.scrollable-content{padding:.75rem}.played-moves{font-size:.85rem}.move-comment{font-size:.85rem;padding:.6rem}}.app{min-height:100vh;width:100%;margin:0;padding:0}
