:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#f9f9f9;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.login-container{max-width:400px;margin:0 auto;padding:2rem;border:1px solid #ccc;border-radius:8px;background-color:#fff;box-shadow:0 2px 4px #0000001a}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;color:#333}.form-group input{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}button[type=submit]{width:100%;padding:.75rem;background-color:#646cff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background-color .2s}button[type=submit]:hover{background-color:#535bf2}.error-message{background-color:#ffebee;color:#c62828;padding:1rem;border-radius:4px;margin-bottom:1rem;border:1px solid #ffcdd2}.levels-container{max-width:800px;margin:0 auto;padding:2rem}.level-form{background-color:#f5f5f5;padding:1.5rem;border-radius:8px;margin-bottom:2rem}.levels-list{margin-top:2rem}.level-item{background-color:#fff;padding:1rem;border-radius:8px;margin-bottom:1rem;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center}.level-info{flex-grow:1}.level-number{font-weight:700;color:#646cff}.edit-form{width:100%}.edit-form input,.edit-form textarea{width:100%;margin-bottom:.5rem;padding:.5rem;border:1px solid #ccc;border-radius:4px}.edit-buttons{display:flex;gap:.5rem}.level-item h4{margin:.5rem 0}.level-item p{margin:0;color:#666}.level-detail-container{max-width:1200px;margin:0 auto;padding:2rem}.back-button{margin-bottom:2rem}.level-metadata{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin-bottom:2rem}.level-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.level-description{color:#666;line-height:1.6}.books-section{background-color:#fff;padding:2rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.books-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:2rem}.book-card{background-color:#f5f5f5;border-radius:8px;padding:1rem;cursor:pointer;transition:transform .2s}.book-card:hover{transform:translateY(-4px)}.book-card img{width:100%;height:200px;object-fit:cover;border-radius:4px;margin-bottom:1rem}.book-card h4{margin:0;color:#333}.edit-metadata .form-group{margin-bottom:1rem}.edit-metadata label{display:block;margin-bottom:.5rem;font-weight:500}.edit-metadata input,.edit-metadata textarea{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px}.button-group{display:flex;gap:1rem;margin-top:1rem}.book-form-container{max-width:1200px;margin:0 auto;padding:2rem}.pages-container{margin:2rem 0;display:flex;flex-direction:column;gap:1rem}.page-section{display:flex;flex-direction:row;flex-wrap:wrap;justify-content:center;gap:1rem;align-items:start;background-color:#f5f5f5;padding:1rem;border-radius:8px}.page-number{font-weight:500;color:#666;margin-bottom:.5rem}.text-input{grid-column:1}.image-upload{padding:.5rem;background-color:#f8f8f8;border-radius:4px}.image-upload label{display:block;margin-bottom:.5rem;font-weight:500;color:#333;font-size:.9rem}.image-preview{display:block;width:100%;height:120px;object-fit:contain;margin:.5rem 0;border-radius:4px;box-shadow:0 2px 4px #0000001a}.form-group input[type=text]{width:100%;padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:.9rem}.submit-button{width:100%;padding:1rem;background-color:#646cff;color:#fff;border:none;border-radius:4px;cursor:pointer;margin-top:2rem}.submit-button:hover{background-color:#535bf2}.book-title{margin-bottom:2rem}.print-buttons{margin-top:20px;display:flex;gap:10px;justify-content:center}.print-button{padding:10px 20px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:16px}.print-button:hover{background-color:#45a049}@keyframes marching-ants{0%{background-position:0 0,0 100%,0 0,100% 0}to{background-position:20px 0,-20px 100%,0 -20px,100% 20px}}:root{--rc-drag-handle-size: 12px;--rc-drag-handle-mobile-size: 24px;--rc-drag-handle-bg-colour: rgba(0, 0, 0, .2);--rc-drag-bar-size: 6px;--rc-border-color: rgba(255, 255, 255, .7);--rc-focus-color: #0088ff}.ReactCrop{position:relative;display:inline-block;cursor:crosshair;max-width:100%}.ReactCrop *,.ReactCrop *:before,.ReactCrop *:after{box-sizing:border-box}.ReactCrop--disabled,.ReactCrop--locked{cursor:inherit}.ReactCrop__child-wrapper{overflow:hidden;max-height:inherit}.ReactCrop__child-wrapper>img,.ReactCrop__child-wrapper>video{display:block;max-width:100%;max-height:inherit}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>img,.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__child-wrapper>video{touch-action:none}.ReactCrop:not(.ReactCrop--disabled) .ReactCrop__crop-selection{touch-action:none}.ReactCrop__crop-mask{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.ReactCrop__crop-selection{position:absolute;top:0;left:0;transform:translateZ(0);cursor:move}.ReactCrop--disabled .ReactCrop__crop-selection{cursor:inherit}.ReactCrop--circular-crop .ReactCrop__crop-selection{border-radius:50%}.ReactCrop--circular-crop .ReactCrop__crop-selection:after{pointer-events:none;content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:1px solid var(--rc-border-color);opacity:.3}.ReactCrop--no-animate .ReactCrop__crop-selection{outline:1px dashed white}.ReactCrop__crop-selection:not(.ReactCrop--no-animate .ReactCrop__crop-selection){animation:marching-ants 1s;background-image:linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to right,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%),linear-gradient(to bottom,#fff 50%,#444 50%);background-size:10px 1px,10px 1px,1px 10px,1px 10px;background-position:0 0,0 100%,0 0,100% 0;background-repeat:repeat-x,repeat-x,repeat-y,repeat-y;color:#fff;animation-play-state:running;animation-timing-function:linear;animation-iteration-count:infinite}.ReactCrop__crop-selection:focus{outline:2px solid var(--rc-focus-color);outline-offset:-1px}.ReactCrop--invisible-crop .ReactCrop__crop-mask,.ReactCrop--invisible-crop .ReactCrop__crop-selection{display:none}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after,.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{content:"";display:block;position:absolute;background-color:#fff6}.ReactCrop__rule-of-thirds-vt:before,.ReactCrop__rule-of-thirds-vt:after{width:1px;height:100%}.ReactCrop__rule-of-thirds-vt:before{left:33.3333333333%}.ReactCrop__rule-of-thirds-vt:after{left:66.6666666667%}.ReactCrop__rule-of-thirds-hz:before,.ReactCrop__rule-of-thirds-hz:after{width:100%;height:1px}.ReactCrop__rule-of-thirds-hz:before{top:33.3333333333%}.ReactCrop__rule-of-thirds-hz:after{top:66.6666666667%}.ReactCrop__drag-handle{position:absolute;width:var(--rc-drag-handle-size);height:var(--rc-drag-handle-size);background-color:var(--rc-drag-handle-bg-colour);border:1px solid var(--rc-border-color)}.ReactCrop__drag-handle:focus{background:var(--rc-focus-color)}.ReactCrop .ord-nw{top:0;left:0;transform:translate(-50%,-50%);cursor:nw-resize}.ReactCrop .ord-n{top:0;left:50%;transform:translate(-50%,-50%);cursor:n-resize}.ReactCrop .ord-ne{top:0;right:0;transform:translate(50%,-50%);cursor:ne-resize}.ReactCrop .ord-e{top:50%;right:0;transform:translate(50%,-50%);cursor:e-resize}.ReactCrop .ord-se{bottom:0;right:0;transform:translate(50%,50%);cursor:se-resize}.ReactCrop .ord-s{bottom:0;left:50%;transform:translate(-50%,50%);cursor:s-resize}.ReactCrop .ord-sw{bottom:0;left:0;transform:translate(-50%,50%);cursor:sw-resize}.ReactCrop .ord-w{top:50%;left:0;transform:translate(-50%,-50%);cursor:w-resize}.ReactCrop__disabled .ReactCrop__drag-handle{cursor:inherit}.ReactCrop__drag-bar{position:absolute}.ReactCrop__drag-bar.ord-n{top:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(-50%)}.ReactCrop__drag-bar.ord-e{right:0;top:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(50%)}.ReactCrop__drag-bar.ord-s{bottom:0;left:0;width:100%;height:var(--rc-drag-bar-size);transform:translateY(50%)}.ReactCrop__drag-bar.ord-w{top:0;left:0;width:var(--rc-drag-bar-size);height:100%;transform:translate(-50%)}.ReactCrop--new-crop .ReactCrop__drag-bar,.ReactCrop--new-crop .ReactCrop__drag-handle,.ReactCrop--fixed-aspect .ReactCrop__drag-bar,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-n,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-e,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-s,.ReactCrop--fixed-aspect .ReactCrop__drag-handle.ord-w{display:none}@media (pointer: coarse){.ReactCrop .ord-n,.ReactCrop .ord-e,.ReactCrop .ord-s,.ReactCrop .ord-w{display:none}.ReactCrop__drag-handle{width:var(--rc-drag-handle-mobile-size);height:var(--rc-drag-handle-mobile-size)}}.image-editor-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000}.image-editor-container{background-color:#fff;padding:2rem;border-radius:8px;max-width:90vw;max-height:90vh;overflow:auto;display:flex;flex-direction:column}.image-editor-content{margin:1rem 0;display:flex;flex-direction:column;align-items:center}.loading,.error{padding:2rem;text-align:center;background-color:#f5f5f5;border-radius:4px;margin:1rem 0}.error{color:#dc3545}.image-editor-info{margin-top:1rem;padding:1rem;background-color:#f5f5f5;border-radius:4px;width:100%}.image-editor-actions{display:flex;gap:1rem;margin-top:1rem;justify-content:flex-end}.save-button{background-color:#646cff;color:#fff;order:2}.save-button:hover{background-color:#535bf2}.cancel-button{background-color:#e0e0e0;color:#666;order:1}.cancel-button:hover{background-color:#d0d0d0}.ReactCrop{max-width:100%;background-color:#f5f5f5;border-radius:4px}.ReactCrop__image{max-height:70vh;object-fit:contain}button:disabled{opacity:.5;cursor:not-allowed}.keyboard-hint{color:#666;font-size:.9rem;font-style:italic;margin-top:.5rem}.file-input-container{margin:.5rem 0}.hidden-input{display:none}.file-input-button{display:inline-flex;align-items:center;padding:.5rem 1rem;background-color:#f0f0f0;border:2px dashed #ccc;border-radius:4px;cursor:pointer;font-size:.9rem;color:#666;transition:all .2s ease;width:100%;justify-content:center}.file-input-button:hover{background-color:#e8e8e8;border-color:#999;color:#333}.file-input-button.has-file{background-color:#e8f5e9;border:2px solid #4caf50;color:#2e7d32}.file-input-button.has-file:hover{background-color:#c8e6c9;border-color:#2e7d32}.file-input-button:before{content:"📁";margin-right:8px;font-size:1.1em}.file-input-button.has-file:before{content:"📄"}.word-bank-container{max-width:800px;margin:0 auto;padding:2rem}.add-word-form{margin-bottom:2rem}.form-group{display:flex;flex-direction:column;gap:1rem}.word-input{width:100%;padding:1rem;font-size:1.2rem;border:1px solid #ccc;border-radius:4px}.add-button{width:100%;padding:1rem;background-color:#646cff;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1.2rem}.add-button:hover{background-color:#535bf2}.search-container{margin-bottom:1rem}.search-input{width:100%;padding:.5rem;font-size:1rem;border:1px solid #ccc;border-radius:4px}.words-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1rem}.word-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;background-color:#f5f5f5;border-radius:4px}.delete-button{padding:.25rem .5rem;background-color:#f44;color:#fff;border:none;border-radius:4px;cursor:pointer}.delete-button:hover{background-color:#c00}.error-message{color:#f44;margin:1rem 0;padding:.5rem;background-color:#ffe5e5;border-radius:4px}.success-message{color:#4caf50;margin:1rem 0;padding:.5rem;background-color:#e5ffe5;border-radius:4px}.nav-bar{background-color:#f8f8f8;padding:1rem;border-bottom:1px solid #eaeaea;margin-bottom:2rem}.nav-links{max-width:1200px;margin:0 auto;display:flex;gap:2rem}.nav-link{text-decoration:none;color:#666;font-weight:500;padding:.5rem 1rem;border-radius:4px;transition:all .2s ease}.nav-link:hover{background-color:#eaeaea;color:#333}.nav-link.active{background-color:#646cff;color:#fff}.nav-link.active:hover{background-color:#535bf2}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
