*{margin:0;padding:0;box-sizing:border-box}:root{--surface-warm: #fafaf9;--surface-muted: #f5f5f4;--surface-contrast: #ffffff;--surface-overlay: rgba(255, 255, 255, .95);--border-warm: rgba(0, 0, 0, .08);--border-soft: rgba(0, 0, 0, .06);--text-primary: #18181b;--text-secondary: #52525b;--accent-soft: #4f7396;--accent-hover: #3d5a75;--shadow-warm: 0 1px 3px rgba(0, 0, 0, .08), 0 4px 12px rgba(0, 0, 0, .05);--bg-main: linear-gradient(135deg, #5b7c99 0%, #6b8caf 50%, #7a9cc0 100%);--card-bg: #ffffff;--card-muted: #f9fafb}:root[data-theme=dark]{--surface-warm: #1e1e1e;--surface-muted: #252525;--surface-contrast: #2a2a2a;--surface-overlay: rgba(42, 42, 42, .95);--border-warm: rgba(255, 255, 255, .1);--border-soft: rgba(255, 255, 255, .06);--text-primary: #e4e4e7;--text-secondary: #a1a1aa;--accent-soft: #7b9ab8;--accent-hover: #5b7c99;--shadow-warm: 0 1px 3px rgba(0, 0, 0, .3), 0 4px 12px rgba(0, 0, 0, .2);--bg-main: linear-gradient(135deg, #18181b 0%, #27272a 50%, #3f3f46 100%);--card-bg: #262626;--card-muted: #1c1c1c}html,body{overflow-x:hidden;max-width:100vw}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;background:var(--bg-main);min-height:100vh;color:var(--text-primary)}.screen{min-height:100vh;display:flex;align-items:center;justify-content:center}.hidden{display:none!important}.container{max-width:1200px;width:100%;padding:2rem}.language-switcher{position:fixed;top:12px;right:12px;z-index:4000;display:flex;align-items:center;gap:10px}.lang-buttons{display:flex;gap:4px;background:var(--surface-contrast);border:2px solid var(--accent-soft);border-radius:20px;padding:4px;box-shadow:0 4px 12px #14100c1a}.lang-btn-ui{padding:.5rem .9rem;background:transparent;border:none;border-radius:16px;cursor:pointer;font-weight:600;font-size:.85rem;color:var(--accent-soft);transition:all .2s ease}.lang-btn-ui:hover:not(.active){background:#667eea1a}.lang-btn-ui.active{background:var(--accent-soft);color:#fff;cursor:default}.theme-toggle{margin-left:10px;padding:.6rem .9rem;border-radius:50%;border:2px solid var(--accent-soft);background:var(--surface-contrast);color:var(--accent-soft);cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #14100c1a}.theme-toggle:hover{background:var(--accent-soft);color:#fff;transform:translateY(-2px);box-shadow:0 10px 22px #3e2e7659}.btn{padding:1rem 2rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#5b7c99,#4f7396);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 10px 20px #4f73964d}.btn-secondary{background:#6c757d;color:#fff}.btn-secondary:hover{background:#5a6268}.btn-delete{background:none;border:none;font-size:1.3rem;cursor:pointer;padding:.3rem .5rem;border-radius:4px;transition:all .2s;opacity:.6}.btn-delete:hover{opacity:1;background:#dc35451a;transform:scale(1.1)}.btn-admin{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;display:inline-flex;align-items:center;gap:.5rem}.btn-admin:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ef44444d}.btn-danger{background-color:#ef4444;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:background-color .2s}.btn-danger:hover{background-color:#dc2626}.btn-danger:disabled{background-color:var(--text-secondary);cursor:not-allowed}.badge{padding:.25rem .75rem;border-radius:20px;font-size:.85rem;font-weight:600;white-space:nowrap}.badge-new{background:linear-gradient(135deg,#5b7c99,#4f7396);color:#fff}.badge-progress{background:linear-gradient(135deg,#ec4899,#f43f5e);color:#fff}.progress-bar{width:100%;height:8px;background:#e9ecef;border-radius:10px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:linear-gradient(90deg,#5b7c99,#4f7396);border-radius:10px;transition:width .3s ease}.progress-section .progress-fill,.book-card .progress-section .progress-fill{animation:none!important}.toast-notification{position:fixed;top:80px;left:50%;transform:translate(-50%) translateY(-100px);padding:16px 24px;border-radius:8px;font-size:16px;font-weight:600;box-shadow:0 4px 12px #00000026;z-index:10000;opacity:0;transition:all .3s ease;max-width:90%;text-align:center}.toast-notification.show{opacity:1;transform:translate(-50%) translateY(0)}.toast-info{background:#3b82f6;color:#fff}.toast-warning{background:#f59e0b;color:#fff;font-size:18px;animation:pulse .5s ease-in-out 3}.toast-success{background:#22c55e;color:#fff}.toast-error{background:#ef4444;color:#fff}@keyframes pulse{0%,to{transform:translate(-50%) translateY(0) scale(1)}50%{transform:translate(-50%) translateY(0) scale(1.05)}}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:var(--text-primary);font-size:.95rem}.form-group input,.form-group select{padding:.75rem;border:2px solid var(--border-warm);border-radius:8px;font-size:1rem;background:var(--card-bg);color:var(--text-primary);transition:border-color .3s ease}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-soft);box-shadow:0 0 0 3px #4f73961a}.form-group small{color:var(--text-secondary);font-size:.85rem}.file-input-wrapper{display:flex;align-items:center;gap:15px;margin-top:8px}.file-input-button{padding:10px 20px;background:var(--accent-soft);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:background .3s;display:flex;align-items:center;gap:8px}.file-input-button:hover{background:var(--accent-hover)}.file-name{color:var(--text-secondary);font-size:14px;font-style:italic}#login-screen .container{text-align:center;background:var(--card-bg);border-radius:20px;padding:4rem;box-shadow:0 20px 60px #0000004d;max-width:800px}#login-screen h1{font-size:3rem;margin-bottom:1rem;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent}.hero-description{margin:2rem 0;text-align:left}.hero-description h2{font-size:1.8rem;color:var(--text-primary);margin-bottom:.5rem;text-align:center}.hero-description .subtitle{font-size:1.2rem;color:var(--text-secondary);margin-bottom:2rem;text-align:center}.features{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin:2rem 0}@media (max-width: 768px){.features{grid-template-columns:1fr;gap:.75rem}}.feature{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--card-muted);border-radius:10px;transition:all .3s ease}.feature:hover{background:var(--surface-contrast);transform:translate(5px)}.feature-icon{font-size:2rem;flex-shrink:0}.feature-text{font-size:1rem;color:var(--text-primary);font-weight:500}.method-description{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#667eea1a,#764ba21a);border-left:4px solid #667eea;border-radius:10px;font-size:1rem;line-height:1.6;color:var(--text-secondary);text-align:left}#login-screen .btn-primary{margin-top:2rem}.login-buttons{display:flex;flex-direction:column;gap:1rem;margin-top:2rem}.btn-google,.btn-mailru{display:flex;align-items:center;justify-content:center;padding:1rem 2rem;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;text-decoration:none;color:#fff}.btn-google{background:#fff;color:#333;border:2px solid #ddd}.btn-google:hover{transform:translateY(-2px);box-shadow:0 10px 20px #0000001a;border-color:#4285f4}.btn-mailru{background:linear-gradient(135deg,#168de2,#1a6db8)}.btn-mailru:hover{transform:translateY(-2px);box-shadow:0 10px 20px #168de266}#login-screen{position:relative;overflow:hidden}.trainer-preview-bg{position:absolute;top:50%;opacity:.15;pointer-events:none;z-index:-1}.trainer-preview-right{right:-100px;transform:translateY(-50%) rotate(5deg);animation:floatPreviewRight 6s ease-in-out infinite}.trainer-preview-left{left:-100px;transform:translateY(-50%) rotate(-5deg);animation:floatPreviewLeft 6s ease-in-out infinite;animation-delay:3s}@keyframes floatPreviewRight{0%,to{transform:translateY(-50%) rotate(5deg)}50%{transform:translateY(-45%) rotate(3deg)}}@keyframes floatPreviewLeft{0%,to{transform:translateY(-50%) rotate(-5deg)}50%{transform:translateY(-45%) rotate(-3deg)}}.preview-window{background:#fff;border-radius:20px;padding:2.5rem;box-shadow:0 20px 60px #0000004d;border:3px solid #667eea;min-width:500px}.preview-text{font-size:2.2rem;line-height:2.8;letter-spacing:1px;font-family:Courier New,monospace;margin-bottom:1.5rem}.char-demo{display:inline-block;position:relative;transition:all .3s ease}.char-demo.correct{color:#28a745;font-weight:700}.char-demo.incorrect{color:#dc3545;background:#ffe6e6;padding:0 6px;border-radius:6px;animation:shake .5s ease-in-out infinite}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}.preview-error-hint{padding:1.2rem;background:linear-gradient(135deg,#fff3cd,#ffe6e6);border-radius:12px;border-left:5px solid #dc3545;font-size:1.1rem;color:#721c24;font-weight:600;animation:pulsePreview 2s ease-in-out infinite}@keyframes pulsePreview{0%,to{opacity:1}50%{opacity:.8}}#login-screen .container{position:relative;z-index:1}.divider{display:flex;align-items:center;text-align:center;margin:1.5rem 0;color:var(--text-secondary)}.divider:before,.divider:after{content:"";flex:1;border-bottom:1px solid var(--border-color)}.divider span{padding:0 1rem;font-size:.9rem;text-transform:uppercase;letter-spacing:1px}.btn-guest{display:flex;align-items:center;justify-content:center;padding:1rem 2rem;border:2px dashed #667eea;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease;background:transparent;color:#667eea}.btn-guest:hover{background:#667eea1a;border-style:solid;transform:translateY(-2px);box-shadow:0 10px 20px #667eea33}.guest-mode-hint{margin-top:1rem;font-size:.9rem;color:var(--text-secondary);line-height:1.5}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:var(--card-bg);padding:1.5rem;border-radius:15px;border:1px solid var(--border-soft);box-shadow:var(--shadow-warm)}.user-info{display:flex;gap:1rem;align-items:center}.search-bar{margin-bottom:1.5rem}.search-bar input{width:100%;padding:1rem;border:2px solid var(--border-soft);border-radius:10px;font-size:1rem;background:var(--card-bg);color:var(--text-primary);transition:border-color .3s ease}.search-bar input:focus{outline:none;border-color:var(--accent-soft);box-shadow:0 0 0 3px #8a6dff26}.filters{display:flex;gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:var(--card-bg);border-radius:15px;border:1px solid var(--border-soft);box-shadow:var(--shadow-warm);flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.5rem;flex:1;min-width:150px}.filter-group label{font-weight:600;color:var(--text-primary);font-size:.9rem}.filter-group select{padding:.75rem;border:2px solid var(--border-soft);border-radius:8px;font-size:1rem;background:var(--card-bg);color:var(--text-primary);cursor:pointer;transition:all .3s ease}.filter-group select:hover{border-color:var(--accent-soft)}.filter-group select:focus{outline:none;border-color:var(--accent-soft);box-shadow:0 0 0 3px #8a6dff1f}.books-grid{display:flex;flex-direction:column;gap:2.25rem}.book-card{background:var(--card-bg);border-radius:15px;padding:2rem;transition:all .3s ease;border:1px solid var(--border-soft);box-shadow:var(--shadow-warm);display:flex;flex-direction:column;gap:1rem}.book-card:hover{transform:translateY(-5px);box-shadow:0 18px 32px #41342a33}.book-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.book-actions{display:flex;align-items:center;gap:.5rem}.book-header h3{margin:0;color:var(--text-primary);font-size:1.3rem;flex:1}.book-card .author{color:var(--text-secondary);font-size:1rem;margin:0}.book-card .description{color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-meta{display:flex;gap:1rem;flex-wrap:wrap}.book-meta span{font-size:.85rem;color:var(--text-secondary);padding:.25rem .75rem;background:var(--card-muted);border-radius:15px}.progress-section{margin-top:.5rem}.progress-stats{display:flex;justify-content:space-between;font-size:.85rem;color:var(--text-secondary)}.book-card .btn{margin-top:auto;width:100%}.no-books{text-align:center;padding:4rem 2rem;color:var(--text-secondary);font-size:1.2rem}.book-card .language{display:inline-block;padding:.25rem .75rem;background:var(--card-muted);border-radius:20px;font-size:.8rem;margin-top:.5rem}.book-card.personal{border-left:4px solid #007bff}.book-card.public{border-left:4px solid #28a745}.book-type-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:12px;font-weight:700;margin-left:8px}.book-type-badge.personal{background-color:#e3f2fd;color:#1976d2}.book-type-badge.public{background-color:#e8f5e8;color:#388e3c}.trainer-container{width:100%;max-width:1400px;padding:2rem}.trainer-header{display:flex;justify-content:space-between;align-items:center;background:var(--card-bg);padding:1.5rem;border-radius:15px;margin-bottom:2rem;box-shadow:var(--shadow-warm)}.stats{display:flex;gap:2rem}.stat{text-align:center}.stat-label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:.25rem}.stat-value{display:block;font-size:1.5rem;font-weight:700;color:var(--accent-soft)}.text-display{position:relative;background:var(--card-bg);padding:4.5rem 3rem 3.5rem;border-radius:15px;margin-bottom:2rem;box-shadow:var(--shadow-warm);min-height:200px}.touch-device .text-display{padding-bottom:50vh}:root{--vv-bottom-inset: 0px}.mobile-input-capture{position:fixed;left:0;top:0;width:100%;height:100%;margin:0;padding:0;opacity:0;color:transparent;background:transparent;border:none;outline:none;caret-color:transparent;font-size:16px;z-index:-1;pointer-events:none}.no-touch-device .mobile-actions{display:none}.touch-device .mobile-actions{display:flex;gap:.75rem;position:fixed;top:calc(env(safe-area-inset-top,0px) + 12px);left:12px;right:12px;z-index:2200;background:var(--surface-overlay);padding:.75rem;border-radius:12px;box-shadow:var(--shadow-warm)}.mobile-action-btn{flex:1;border:1px solid var(--border-soft);background:var(--card-bg);border-radius:12px;padding:.75rem 1rem;font-size:.95rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:.5rem;box-shadow:var(--shadow-warm);transition:transform .2s ease,box-shadow .2s ease}.mobile-action-btn:active{transform:translateY(1px);box-shadow:0 2px 6px #0000001f}:root[data-theme=dark] .trainer-header{background:var(--card-bg)}:root[data-theme=dark] .stat-label{color:var(--text-secondary)}:root[data-theme=dark] .stat-value{color:var(--accent-soft)}:root[data-theme=dark] .text-display{background:var(--card-bg)}:root[data-theme=dark] .touch-device .mobile-actions{background:var(--surface-overlay)}:root[data-theme=dark] .mobile-action-btn{border:1px solid var(--border-soft);background:var(--card-bg);box-shadow:0 4px 10px #0000001f}body.no-touch-device #mobile-typing-overlay{display:none}body.touch-device #mobile-typing-overlay{position:fixed;left:10px;right:10px;bottom:calc(40vh + env(safe-area-inset-bottom));padding:8px 12px;background:#000000d9;color:#fff;z-index:1200;display:flex;flex-direction:column;gap:4px;pointer-events:none;border-radius:10px;box-shadow:0 4px 10px #0000004d;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.mobile-overlay-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.08em;opacity:.7}.mobile-overlay-text{font-size:1rem;line-height:1.35;font-weight:600;word-break:break-word;text-shadow:0 1px 3px rgba(0,0,0,.35)}.mobile-overlay-correction{border-top:1px solid rgba(255,255,255,.15);padding-top:.65rem;display:flex;flex-direction:column;gap:.35rem}.mobile-overlay-meta{font-size:.9rem;opacity:.8}.mobile-correction-input{background:#ffffff1a;padding:8px 12px;border-radius:6px;font-family:Courier New,monospace;font-size:1.1rem;margin-top:4px}.mobile-correction-typed{color:#4ade80;font-weight:600}.mobile-correction-cursor{color:#60a5fa;font-weight:700;animation:blink 1s infinite}@keyframes blink{0%,49%{opacity:1}50%,to{opacity:0}}#mobile-typing-overlay.hidden{display:none}@media (max-width: 1024px){.text-display{max-height:calc(100vh - 230px);overflow-y:auto;-webkit-overflow-scrolling:touch;padding-top:140px}.mobile-keyboard-active .text-display{padding-bottom:calc(55vh + env(safe-area-inset-bottom,0px))}.mobile-keyboard-active .keyboard-container{display:none}.trainer-container{padding-top:120px}body.touch-device .correction-panel{position:fixed;left:10px;right:10px;top:100px;bottom:calc(40vh + env(safe-area-inset-bottom));margin:0;padding:1rem;z-index:1300;max-height:calc(60vh - 100px);overflow-y:auto}body.touch-device .correction-title{font-size:1.1rem}body.touch-device .correction-instruction{font-size:.95rem}body.touch-device .correction-progress{font-size:.85rem}.error-message{position:fixed;left:10px;right:10px;bottom:calc(max(env(safe-area-inset-bottom,0px),var(--vv-bottom-inset, 0px)) + 8px);top:auto;transform:none;max-width:calc(100% - 20px);margin:0;max-height:45vh;overflow:auto;z-index:3000}}.text-content{font-size:1.5rem;line-height:2;letter-spacing:.5px;white-space:pre-wrap}.char{position:relative}.char[data-newline=true]{color:transparent;font-size:0}.char[data-newline=true]:before{content:"↵";color:#6c757d;opacity:.4;font-size:14px;margin-left:2px;margin-right:2px}.char.correct{color:#22c55e}.char.incorrect{color:#ef4444;background:#ef44441a}.char.current{background:#facc1533;animation:blink 1s infinite}@keyframes blink{0%,50%,to{opacity:1}25%,75%{opacity:.5}}.error-message{position:absolute;top:2rem;left:50%;transform:translate(-50%);max-width:95%;width:auto;padding:1.5rem;background:#facc151a;border:3px solid #facc15;border-radius:12px;font-weight:600;color:var(--text-primary);box-shadow:0 4px 12px #facc1533;z-index:100}.correction-panel{margin-top:2rem;padding:2rem;background:#facc151a;border:3px solid #facc15;border-radius:15px;box-shadow:0 8px 24px #facc1533;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.correction-header{margin-bottom:1rem}.correction-title{color:#ef4444;font-size:1.5rem;margin-bottom:.5rem}.correction-instruction{font-size:1.1rem;color:var(--text-primary);margin-bottom:1rem;font-weight:600}.correction-progress{font-size:1rem;color:var(--text-secondary);margin-bottom:1rem}.correction-input{background:var(--card-bg);padding:1rem;border-radius:10px;font-size:1.3rem;font-family:monospace;border:2px solid #facc15;min-height:60px;display:flex;align-items:center;color:var(--accent-soft)!important;caret-color:var(--accent-soft)}.correction-input input,.correction-input textarea{border:none;background:transparent;outline:none;color:var(--accent-soft)!important;width:100%}.correction-input input::placeholder,.correction-input textarea::placeholder{color:#b2a1ff}.correction-text{color:var(--accent-soft);font-weight:700}.correction-cursor{color:var(--accent-soft);animation:blink 1s infinite;margin-left:2px}.completion-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.completion-content{background:var(--card-bg);border-radius:20px;padding:3rem;max-width:600px;width:90%;box-shadow:0 20px 60px #0000004d;animation:scaleIn .3s ease;text-align:center}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}.completion-content h2{font-size:2.5rem;margin-bottom:1rem;background:linear-gradient(135deg,#5b7c99,#4f7396);background-clip:text;-webkit-background-clip:text;-webkit-text-fill-color:transparent}.completion-message{font-size:1.3rem;color:var(--text-primary);margin-bottom:2rem;font-weight:600}.completion-stats{background:var(--card-muted);padding:1.5rem;border-radius:15px;margin-bottom:2rem;text-align:left}.completion-stats h3{color:var(--accent-soft);margin-bottom:1rem}.completion-stats p{font-size:1.1rem;color:var(--text-primary);margin-bottom:.5rem}:root[data-theme=dark] .char.correct{color:#4ade80}:root[data-theme=dark] .char.incorrect{color:#f87171;background:#f871711f}:root[data-theme=dark] .char.current{background:#9fa8ff29}:root[data-theme=dark] .error-message{background:var(--surface-overlay);border-left:4px solid var(--accent-soft)}:root[data-theme=dark] .correction-panel{background:var(--surface-overlay);border:3px solid var(--accent-soft);box-shadow:0 8px 24px #00000040}:root[data-theme=dark] .correction-title{color:var(--accent-soft)}:root[data-theme=dark] .correction-instruction{color:var(--text-primary)}:root[data-theme=dark] .correction-progress{color:var(--text-secondary)}:root[data-theme=dark] .correction-input{background:var(--card-bg);border:2px solid var(--accent-soft);color:#f5b000!important;caret-color:#f5b000}:root[data-theme=dark] .correction-input input,:root[data-theme=dark] .correction-input textarea{color:#f5b000!important}:root[data-theme=dark] .correction-input input::placeholder,:root[data-theme=dark] .correction-input textarea::placeholder{color:#f5c74d}:root[data-theme=dark] .correction-text,:root[data-theme=dark] .correction-cursor{color:#f5b000!important}:root[data-theme=dark] .completion-content{background:var(--card-bg);box-shadow:0 20px 60px #00000059}:root[data-theme=dark] .completion-message{color:var(--text-primary)}:root[data-theme=dark] .completion-stats{background:var(--card-muted)}:root[data-theme=dark] .completion-stats h3{color:var(--accent-soft)}:root[data-theme=dark] .completion-stats p{color:var(--text-primary)}:root[data-theme=dark] .tts-panel{background:var(--card-bg);border-color:var(--border-soft)}:root[data-theme=dark] .tts-panel h4{color:var(--text-primary)}:root[data-theme=dark] .tts-panel label{color:var(--text-primary)}:root[data-theme=dark] .tts-panel label:hover{color:var(--accent-soft)}.completion-buttons{display:flex;gap:1rem;justify-content:center}.word.speaking,.sentence.speaking{background:linear-gradient(135deg,#5b7c99,#4f7396)!important;color:#fff!important;transform:scale(1.05);box-shadow:0 4px 15px #4f739666;border-radius:4px;padding:2px 6px;margin:0 2px;animation:pulse 1s ease-in-out infinite alternate}.word.loading,.sentence.loading{background:linear-gradient(135deg,#f59e0b,#f97316)!important;color:#fff!important;border-radius:4px;padding:2px 6px;margin:0 2px;position:relative;overflow:hidden}.word.loading:after,.sentence.loading:after{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent);animation:shimmer 1.5s infinite}.word:hover,.sentence:hover{background:#4f73961a!important;border-radius:4px;transition:all .2s ease}@keyframes pulse{0%{opacity:.8;transform:scale(1.05)}to{opacity:1;transform:scale(1.08)}}@keyframes shimmer{0%{left:-100%}to{left:100%}}.tts-container{position:absolute;top:8px;right:8px;z-index:100}.tts-container-inline{display:inline-flex;align-items:center;margin-left:8px;vertical-align:middle}.tts-btn,#tts-toggle-btn{background:var(--surface-overlay);border:2px solid var(--border-warm);border-radius:6px;padding:8px 12px;cursor:pointer;font-size:16px;transition:all .3s ease;opacity:.6;margin-left:8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tts-btn:hover{opacity:.8;transform:scale(1.05)}.tts-btn.active,#tts-toggle-btn.active{background:linear-gradient(135deg,#5b7c99,#4f7396);color:#fff;opacity:1!important;border-color:var(--accent-soft);box-shadow:0 0 12px #4f739699,0 2px 8px #0003;transform:scale(1)}.tts-panel{position:absolute;top:calc(100% + 4px);right:0;background:var(--card-bg);border:1px solid var(--border-warm);border-radius:8px;box-shadow:var(--shadow-warm);z-index:1000;min-width:200px;transition:all .3s ease}.tts-panel.hidden{display:none}.tts-panel-content{padding:16px}.tts-panel h4{margin:0 0 12px;font-size:14px;font-weight:600;color:var(--text-primary)}.tts-panel label{display:block;margin:8px 0;font-size:13px;color:var(--text-primary);cursor:pointer;transition:color .2s ease}.tts-panel label:hover{color:var(--accent-soft)}.tts-panel input[type=radio],.tts-panel input[type=checkbox]{margin-right:8px;transform:scale(1.1)}.word{cursor:pointer!important}.word:hover{background-color:#4f73961a;border-radius:3px}.sentence{cursor:pointer!important}.sentence:hover{background-color:#4f73960d;border-radius:3px}:root{--k-white: #ffffff;--k-light-gray: #f0f0f0;--k-medium-gray: #e0e0e0;--k-dark-gray: #d0d0d0;--text-color: #38383a;--k-accent-pressed: #007aff}:root[data-theme=dark]{--k-white: #1f2331;--k-light-gray: #2b3145;--k-medium-gray: #343c53;--k-dark-gray: #3d4660;--text-color: #e8ebff;--k-accent-pressed: #9fa8ff}.keyboard-container{background:var(--card-bg);padding:20px;border-radius:12px;box-shadow:0 4px 10px #0000000d;border:1px solid var(--border-soft)}.keyboard-language{display:flex;gap:1rem;margin-bottom:1rem;justify-content:center}.lang-btn{padding:.5rem 1.5rem;border:2px solid var(--accent-soft);background:var(--card-bg);color:var(--accent-soft);border-radius:10px;cursor:pointer;font-weight:600;transition:all .3s ease}.lang-btn.active{background:var(--accent-soft);color:#fff}.keyboard{display:flex;flex-direction:column;gap:.5rem;align-items:center}.keyboard-row{display:flex;gap:8px;margin-bottom:8px}.keyboard-row.space-row{margin-top:10px}.key{box-shadow:0 2px 0 var(--border-soft)!important;background:var(--k-white)!important;border:1px solid var(--border-soft)!important;border-radius:6px;color:var(--text-color);font-size:16px;font-weight:500;width:50px;height:50px;display:flex;align-items:center;justify-content:center;transition:all .1s ease;-webkit-user-select:none;user-select:none}.key.wide{width:90px;font-size:14px}.key.wide-small{width:70px;font-size:14px}.key.extra-wide{width:100px;font-size:14px}.key.space{width:560px}.key.f-l-index,.key.f-r-index{background-color:var(--k-light-gray)!important}.key.f-l-middle,.key.f-r-middle,.key.f-l-ring,.key.f-r-ring{background-color:var(--k-medium-gray)!important}.key.f-l-pinky,.key.f-r-pinky,.key.wide,.key.wide-small,.key.extra-wide,.key.space{background-color:var(--k-dark-gray)!important}.key.space{background-color:var(--k-light-gray)!important}.key.pressed{transform:translateY(2px);box-shadow:none!important;background-color:var(--k-medium-gray)!important;color:var(--k-accent-pressed)!important}.key.space.pressed{background-color:#c4c4c4!important}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.modal-content{background-color:#fff;border-radius:8px;padding:0;max-width:500px;width:90%;max-height:90vh;overflow-y:auto;box-shadow:0 4px 6px #0000001a}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e0e0e0}.modal-header h2{margin:0;font-size:24px;color:#333}.modal-close{background:none;border:none;font-size:28px;cursor:pointer;color:#999;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.modal-close:hover{color:#333}.modal-body{padding:20px}.info-text{background-color:#e3f2fd;padding:12px;border-radius:4px;margin-bottom:20px;color:#1976d2}.warning-text{background-color:#fff3cd;border-left:4px solid #ffc107;padding:12px;border-radius:4px;margin-bottom:20px;color:#856404;font-size:14px;line-height:1.5}.warning-text strong{display:block;margin-bottom:8px;color:#856404}.app-footer{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:30px 20px;margin-top:50px;text-align:center}.footer-content{max-width:1200px;margin:0 auto}.footer-content p{margin:10px 0}.copyright{font-size:14px;font-weight:500}.footer-links{margin:15px 0}.footer-link{color:#fff;text-decoration:none;font-size:14px;transition:opacity .3s}.footer-link:hover{opacity:.8;text-decoration:underline}.separator{margin:0 15px;opacity:.6}.footer-note{font-size:12px;opacity:.8;margin-top:10px}@media (max-width: 768px){.language-switcher{position:fixed;top:10px;right:60px;z-index:1001}.theme-toggle{position:fixed;top:10px;right:10px;z-index:1001}.lang-switch-btn{padding:.5rem 1rem;font-size:.85rem}#lang-icon{font-size:1rem}#lang-text{font-size:.8rem}#login-screen .container{padding:1.5rem;margin:10px;max-width:calc(100vw - 20px)}#login-screen h1{font-size:2rem}.hero-description h2{font-size:1.3rem}.hero-description .subtitle{font-size:1rem}.features{display:grid!important;grid-template-columns:1fr!important;gap:10px;width:100%}.feature{padding:.75rem;width:100%;max-width:100%}.feature-icon{font-size:1.5rem}.feature-text{font-size:.9rem}.method-description{font-size:.9rem;padding:1rem}.login-buttons{flex-direction:column;gap:15px}.btn{width:100%;font-size:.9rem;padding:12px 20px}.preview-window{min-width:auto;width:100%}.books-container{padding:15px}.books-header{flex-direction:column;align-items:flex-start;gap:15px}.books-header h1{font-size:1.5rem}.user-info{font-size:.85rem}.filters{flex-direction:column;gap:10px}.filter-group,.filter-group select{width:100%}.books-grid{grid-template-columns:1fr;gap:15px}.book-card{padding:15px}.book-title{font-size:1.1rem}.book-author{font-size:.85rem}.trainer-container{padding:15px}.trainer-header{flex-direction:column;gap:10px;padding:15px}.stats{flex-direction:column;gap:10px;width:100%}.stat-item{font-size:.85rem}.text-display{padding:120px 15px 20px;font-size:1rem;line-height:1.6}.keyboard-container{padding:15px}.keyboard{transform:scale(.7);transform-origin:top center}.correction-overlay{padding:20px}.correction-content{padding:20px;max-width:90%}.correction-content h2{font-size:1.3rem}.correction-word{font-size:1.5rem}.admin-panel{padding:15px}.upload-form{padding:20px}.app-footer{padding:20px 15px}.footer-content p{font-size:.85rem}.footer-links{flex-direction:column;gap:10px}.separator{display:none}.footer-note{font-size:.75rem;line-height:1.4}.trainer-preview-bg{display:none}}@media (max-width: 480px){.app-title{font-size:1.5rem}.app-subtitle{font-size:.9rem}.login-container{margin:10px;padding:15px}.text-display{padding-top:120px;font-size:.9rem}.keyboard{transform:scale(.5)}.book-card{padding:12px}}@media (max-width: 1200px){.trainer-preview-bg{opacity:.1;right:-150px}.preview-window{min-width:400px;padding:2rem}.preview-text{font-size:1.8rem}}:root[data-theme=dark] .learning-status{color:var(--text-primary)}.learning-list{margin:0;padding-left:18px;list-style-position:outside;color:var(--text-secondary);opacity:.7}.learning-inline-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none}.learning-inline-overlay *{pointer-events:none}.learning-status{position:sticky;top:8px;left:8px;display:inline-block;padding:4px 8px;background:var(--surface-overlay);color:var(--text-primary);border-radius:8px;font-size:12px;line-height:1.3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);pointer-events:none}.learning-word-inline{position:absolute;font-size:10px;line-height:1.15;color:var(--accent-soft);font-weight:600;background:var(--surface-overlay);padding:2px 4px;border-radius:6px;box-shadow:0 2px 6px #00000014;pointer-events:none;z-index:5}.sentence-wrap{position:relative;display:inline-block;vertical-align:baseline}.sentence-translation{position:absolute;left:0;top:100%;margin-top:2px;max-width:100%;min-width:140px;font-size:11px;line-height:1.35;color:var(--text-secondary);opacity:.9;background:var(--surface-overlay);border:1px solid var(--border-soft);border-radius:10px;padding:6px 10px;box-shadow:0 4px 16px #0000001f;white-space:normal;word-break:break-word;pointer-events:none;z-index:10}.learning-sentence-inline{position:absolute;font-size:11px;line-height:1.35;color:var(--text-secondary);opacity:.85;background:var(--surface-overlay);border:1px solid var(--border-soft);border-radius:10px;padding:6px 10px;box-shadow:0 4px 16px #0000001f;pointer-events:none;z-index:10}.learning-word-inline .learning-word-text{display:inline-block;margin-right:4px}.learning-word-inline .learning-word-ipa{display:inline-block;color:var(--accent-soft);font-weight:600}.learning-toolbar{position:absolute;top:12px;right:16px;display:flex;gap:12px;align-items:center;background:var(--bg-primary);padding:8px 12px;border-radius:8px;box-shadow:0 2px 8px #0000001a;z-index:100}.tts-btn{background:var(--accent-color);border:none;border-radius:6px;padding:6px 12px;font-size:18px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.tts-btn:hover{background:var(--accent-hover);transform:scale(1.05)}.tts-btn:active{transform:scale(.95)}.tts-btn.active{background:var(--accent-hover);box-shadow:0 0 0 2px var(--accent-color)}@media (max-width: 768px){.learning-toolbar{position:relative;top:auto;float:none;width:100%;flex-wrap:wrap;justify-content:flex-start;gap:6px;padding:10px 12px;margin:0 0 12px;z-index:100;border-radius:0;box-shadow:0 2px 4px #00000026}.learning-select select{max-width:96px;font-size:12px}.learning-toggle{flex:1 1 auto;justify-content:flex-start;font-size:12px;padding:6px 8px;gap:4px}.learning-toggle label{font-size:12px}.learning-word-inline,.learning-sentence-inline{font-size:9px;padding:1px 3px}}.learning-toggle{display:inline-flex;align-items:center;gap:6px;padding:8px 12px;cursor:pointer;-webkit-user-select:none;user-select:none}.learning-toggle.disabled{opacity:.5;cursor:not-allowed}.learning-toggle.disabled input,.learning-toggle.disabled span{cursor:not-allowed}.learning-toggle input{width:14px;height:14px;cursor:pointer;pointer-events:auto}.learning-toggle input[type=radio]{margin:0;cursor:pointer}.learning-select{display:flex;gap:6px;align-items:center;font-size:13px;color:var(--text-secondary)}.learning-select select{padding:6px 10px;border-radius:8px;border:1px solid var(--border-soft);background:var(--card-bg);color:var(--text-primary)}.learning-sentence{margin:0;line-height:1.4;display:block}.learning-sentence-wrapper{display:block;margin-bottom:8px;position:relative}.learning-original-sentence{display:block;position:relative}.learning-translation-inline{margin-top:2px;font-size:11px;line-height:1.35;color:var(--text-secondary);opacity:.7;pointer-events:none}.learning-overlay{position:relative;margin-top:16px;padding:8px 4px 0;pointer-events:none;font-size:11px;line-height:1.3;color:var(--text-secondary);opacity:.6;display:flex;flex-direction:column;gap:6px}.learning-sentence .learning-word{position:relative;display:inline-flex;flex-direction:column;align-items:center;gap:1px;padding:0 4px}.learning-sentence .learning-word:before{content:attr(data-translation);display:block;font-size:10px;color:var(--text-secondary);opacity:.7;line-height:1.1;pointer-events:none;white-space:nowrap}.learning-translation{font-size:11px;color:var(--text-secondary);opacity:.6;margin-top:2px;line-height:1.35}.learning-line{display:block;margin:0 0 10px;pointer-events:none}.learning-loading,.learning-error{padding:12px;font-size:14px;color:var(--text-secondary)}.learning-loading:before{content:"";display:inline-block;width:14px;height:14px;margin-right:8px;border-radius:50%;border:2px solid var(--accent-soft);border-top-color:transparent;animation:spin .8s linear infinite;vertical-align:text-bottom}@keyframes spin{to{transform:rotate(360deg)}}.info-banner{background:var(--card-bg);border:2px dashed #667eea;border-radius:12px;padding:1.5rem;margin-bottom:2rem;display:flex;gap:1.5rem;align-items:flex-start}.info-banner.hidden{display:none}.info-banner-icon{font-size:3rem;flex-shrink:0}.info-banner-content{flex:1}.info-banner-content h3{margin:0 0 .5rem;color:#667eea;font-size:1.3rem}.info-banner-content p{margin:.5rem 0;color:var(--text-primary)}.info-banner-content ul{margin:.5rem 0;padding-left:0;list-style:none;color:var(--text-secondary)}.info-banner-content li{margin:.3rem 0;line-height:1.5}.info-banner-cta{margin-top:1rem;color:#667eea!important;font-size:1.05rem}.info-banner-buttons{display:flex;gap:.75rem;margin-top:1rem;flex-wrap:wrap}.btn-sm{padding:.5rem 1rem;font-size:.9rem}.mobile-desktop-banner{background:linear-gradient(135deg,#3b82f61a,#93c5fd1a);border:2px solid rgba(59,130,246,.3);border-radius:12px;padding:1rem 1.5rem;margin-bottom:1.5rem;display:flex;gap:1rem;align-items:center}.touch-device-only{display:none}body.touch-device .touch-device-only{display:flex}body.no-touch-device .touch-device-only{display:none!important}.mobile-desktop-banner-icon{font-size:2rem;flex-shrink:0}.mobile-desktop-banner-content{flex:1}.mobile-desktop-banner-content p{margin:0;color:var(--text-primary);font-size:.95rem;line-height:1.5}@media (max-width: 768px){.info-banner{flex-direction:column;padding:1rem}.info-banner-icon{font-size:2rem}.info-banner-content h3{font-size:1.1rem}.info-banner-buttons{flex-direction:column}.info-banner-buttons .btn{width:100%}.mobile-desktop-banner{padding:.875rem 1rem;margin-bottom:1rem}.mobile-desktop-banner-icon{font-size:1.5rem}.mobile-desktop-banner-content p{font-size:.875rem}}.guest-login-modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;transition:opacity .3s ease}.guest-login-modal.show{opacity:1}.guest-login-content{background:var(--card-bg);border-radius:20px;padding:3rem;max-width:500px;width:90%;box-shadow:0 20px 60px #0000004d;text-align:center;transform:scale(.9);transition:transform .3s ease}.guest-login-modal.show .guest-login-content{transform:scale(1)}.guest-login-icon{font-size:4rem;margin-bottom:1rem;animation:bounce 1s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}.guest-login-content h2{font-size:1.5rem;margin-bottom:2rem;color:var(--text-primary);line-height:1.5}.guest-login-buttons{display:flex;flex-direction:column;gap:1rem}.guest-close-btn{margin-top:.5rem}.guest-toast{position:fixed;bottom:2rem;right:2rem;background:var(--card-bg);color:var(--text-primary);padding:1rem 1.5rem;border-radius:10px;box-shadow:0 10px 30px #0000004d;z-index:9999;opacity:0;transform:translateY(20px);transition:all .3s ease;max-width:400px;font-size:.95rem;line-height:1.5}.guest-toast.show{opacity:1;transform:translateY(0)}.guest-toast-info{border-left:4px solid #667eea}.guest-toast-warning{border-left:4px solid #ffc107;background:linear-gradient(135deg,#ffc1071a,#ff98001a)}.guest-toast-error{border-left:4px solid #dc3545;background:linear-gradient(135deg,#dc35451a,#c823331a)}.guest-toast-success{border-left:4px solid #28a745;background:linear-gradient(135deg,#28a7451a,#2086371a)}.guest-mode-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:linear-gradient(135deg,#667eea33,#764ba233);border:2px dashed #667eea;border-radius:20px;font-size:.9rem;font-weight:600;color:#667eea}.guest-restricted{opacity:.6;cursor:not-allowed;position:relative}.guest-restricted:after{content:"🔒";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;opacity:0;transition:opacity .3s ease}.guest-restricted:hover:after{opacity:1}@media (max-width: 768px){.guest-login-content{padding:2rem;width:95%}.guest-login-icon{font-size:3rem}.guest-login-content h2{font-size:1.2rem}.guest-toast{bottom:1rem;right:1rem;left:1rem;max-width:none}}.translations-section{margin-top:2rem;padding:2rem;background:var(--surface-warm);border-radius:12px;border:1px solid var(--border-warm)}.translations-section h2{margin-top:0;margin-bottom:.5rem;color:var(--text-primary)}.translations-section>p{color:var(--text-secondary);margin-bottom:1.5rem}.translations-actions{display:grid;grid-template-columns:1fr;gap:1.5rem}@media (min-width: 900px){.translations-actions{grid-template-columns:repeat(3,1fr)}}.action-card{padding:1.5rem;background:var(--surface-contrast);border-radius:8px;border:1px solid var(--border-soft)}.action-card h3{margin-top:0;margin-bottom:.5rem;font-size:1.1rem;color:var(--text-primary)}.action-card p{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.action-card .form-group{margin-bottom:1rem}.action-card .form-control{width:100%;padding:.5rem;border:1px solid var(--border-soft);border-radius:4px;font-size:.9rem}.action-card button{width:100%;margin-bottom:.5rem}.action-card button:last-of-type{margin-bottom:0}.status-message{margin-top:1rem;padding:.75rem;border-radius:4px;font-size:.9rem;background:var(--surface-overlay);border:1px solid var(--border-soft)}.status-message.success{background:#d4edda;border-color:#c3e6cb;color:#155724}.status-message.error{background:#f8d7da;border-color:#f5c6cb;color:#721c24}.status-message.hidden{display:none}#admin-progress-list{display:grid;grid-template-columns:1fr;gap:1rem}@media (min-width: 900px){#admin-progress-list{grid-template-columns:repeat(2,1fr)}}.progress-summary{grid-column:1 / -1;padding:1rem;background:var(--surface-contrast);border-radius:8px;margin-bottom:0;border-left:4px solid var(--accent-soft)}.progress-summary p{margin:0;color:var(--text-primary)}.progress-item{display:flex;flex-direction:column;justify-content:space-between;padding:1.5rem;background:var(--surface-warm);border-radius:12px;border:1px solid var(--border-warm);box-shadow:var(--shadow-warm);transition:transform .2s ease,box-shadow .2s ease;height:100%}.progress-item:hover{transform:translateY(-2px);box-shadow:0 8px 16px #231d1726}.progress-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.progress-info h4{margin:0;color:var(--text-primary);font-size:1.1rem}.progress-info .book-author{margin:0;color:var(--text-secondary);font-size:.9rem;font-style:italic}.progress-details{display:flex;flex-wrap:wrap;gap:1rem;font-size:.9rem;color:var(--text-secondary)}.progress-details span{display:inline-block}.progress-details strong{color:var(--text-primary)}.progress-info small{color:var(--text-muted);font-size:.85rem}.progress-actions{display:flex;gap:.5rem;flex-shrink:0;margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-soft)}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid var(--border-soft)}.admin-header h1{color:#2c3e50;margin:0}.upload-section{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 4px 20px #0000001a;border:1px solid #e9ecef}.upload-section h2{color:#2c3e50;margin-bottom:.5rem}.upload-section p{color:#6c757d;margin-bottom:2rem;line-height:1.6}.upload-form{display:flex;flex-direction:column;gap:1.5rem}.form-actions{display:flex;justify-content:flex-start;margin-top:1rem}.upload-progress{margin-top:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px;border:1px solid #e9ecef}.upload-progress .progress-bar{width:100%;height:12px;background:#e9ecef;border-radius:6px;overflow:hidden;margin-bottom:1rem}.upload-progress .progress-fill{height:100%;background:linear-gradient(90deg,#667eea,#764ba2);width:0%;transition:width .3s ease;animation:progress-animation 2s infinite!important}@keyframes progress-animation{0%{width:0%}50%{width:70%}to{width:100%}}.upload-result{margin-top:2rem}.success-message{padding:1.5rem;background:linear-gradient(135deg,#00b894,#00a085);color:#fff;border-radius:8px;box-shadow:0 4px 12px #00b8944d}.success-message h3{margin:0 0 1rem;font-size:1.2rem}.success-message p{margin:.5rem 0;opacity:.95}.error-message{padding:1.5rem;background:linear-gradient(135deg,#e17055,#d63031);color:#fff;border-radius:8px;box-shadow:0 4px 12px #e170554d}.error-message h3{margin:0 0 1rem;font-size:1.2rem}.error-message p{margin:.5rem 0;opacity:.95}.fb2-metadata{margin-top:1rem;padding:1rem;background:#ffffff1a;border-radius:6px;border-left:4px solid rgba(255,255,255,.3)}.fb2-metadata h4{margin:0 0 .5rem;font-size:1rem;opacity:.9}.fb2-metadata p{margin:.3rem 0;font-size:.9rem;opacity:.85}.books-management-section{margin-top:40px;padding-top:30px;border-top:2px solid var(--border-soft)}.books-management-section h2{color:var(--text-primary);margin-bottom:10px}.admin-books-list{margin-top:20px}.admin-book-item{display:flex;justify-content:space-between;align-items:center;padding:15px;margin:10px 0;background:var(--card-bg);border:1px solid var(--border-soft);border-radius:8px}.admin-book-info{flex:1}.admin-book-title{font-weight:700;color:var(--text-primary);margin-bottom:5px}.admin-book-meta{font-size:14px;color:var(--text-secondary)}.admin-book-stats{margin-top:6px;display:flex;gap:12px;font-size:13px;color:var(--text-secondary)}.admin-book-actions{display:flex;gap:10px}.upload-info{background:var(--card-muted);border:1px solid var(--border-soft);border-radius:8px;padding:20px;margin:20px 0}.info-section{margin-bottom:20px}.info-section:last-child{margin-bottom:0}.info-section h4{margin:0 0 10px;color:var(--text-primary);font-size:16px}.info-section ul{margin:10px 0;padding-left:20px}.info-section li{margin:5px 0}.info-section p{margin:10px 0 0;color:var(--text-secondary);line-height:1.4}.users-section{background:var(--card-bg);padding:2rem;border-radius:12px;box-shadow:var(--shadow-warm);border:1px solid var(--border-soft);margin-top:2rem}.users-section h2{color:var(--text-primary);margin-bottom:.5rem}.users-section>p{color:var(--text-secondary);margin-bottom:1.5rem;line-height:1.6}.users-filters{display:flex;gap:1rem;align-items:flex-end;margin-bottom:1.5rem;flex-wrap:wrap}.users-filters .filter-group{display:flex;flex-direction:column;gap:4px}.users-filters .filter-group label{font-size:14px;color:var(--text-primary);font-weight:500}.users-filters .filter-group input{padding:10px 14px;border:1px solid var(--border-soft);border-radius:6px;font-size:14px;width:150px;box-sizing:border-box}.users-filters .filter-group input:focus{outline:none;border-color:var(--accent-soft);box-shadow:0 0 0 3px #667eea1a}.users-filters .filter-actions{display:flex;gap:8px}.users-list{display:flex;flex-direction:column;gap:.75rem}.user-card{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;background:var(--card-bg);border:1px solid var(--border-soft);border-radius:8px;transition:box-shadow .2s}.user-card:hover{box-shadow:0 2px 8px #00000026}.user-card-info{flex:1}.user-card-title{font-weight:600;color:var(--text-primary);margin-bottom:4px}.user-card-meta{font-size:14px;color:var(--text-secondary)}.user-card-actions{display:flex;gap:8px}.role-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:11px;font-weight:600;text-transform:uppercase}.role-badge.role-admin{background:#4ed67d29;color:#4ade80}.role-badge.role-user{background:#9fa8ff2e;color:var(--accent-soft)}.empty-message{text-align:center;color:var(--text-secondary);padding:2rem}.pagination{display:flex;justify-content:space-between;align-items:center;margin-top:1rem;padding:1rem;background:var(--card-bg);border-radius:8px}.pagination-info{font-size:14px;color:var(--text-secondary)}.pagination-buttons{display:flex;gap:4px}.pagination-buttons .btn{min-width:36px}.user-book-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;border:1px solid var(--border-soft);border-radius:8px;margin-bottom:.5rem}.user-book-info{flex:1}.user-book-title{font-weight:500;color:var(--text-primary);margin-bottom:4px}.user-book-meta{font-size:13px;color:var(--text-secondary)}.btn-sm{padding:6px 12px;font-size:13px}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal.hidden{display:none}.modal-content{background:var(--card-bg);border-radius:12px;width:90%;max-width:600px;max-height:80vh;overflow:hidden;box-shadow:0 10px 40px #00000059}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid var(--border-soft)}.modal-header h2{margin:0;font-size:18px;color:var(--text-primary)}.modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);padding:0;line-height:1}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:1.5rem;overflow-y:auto;max-height:calc(80vh - 60px)}.user-books-list{display:flex;flex-direction:column;gap:.5rem}
