.login-container{min-height:100vh;width:100vw;display:grid;grid-template-columns:1fr 1fr;background:#f5f5f5;position:relative;overflow:hidden}.login-right{grid-column:2;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:40px;position:relative;z-index:1}.login-wrapper{width:100%;max-width:440px;display:flex;flex-direction:column;position:relative;z-index:2}.login-card{width:100%;border-radius:16px;box-shadow:0 8px 32px #0000001f;background:#fff;border:none;padding:0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.login-header{text-align:center;margin-bottom:24px}.login-title{display:flex;align-items:center;justify-content:center;gap:12px;margin-bottom:8px!important}.login-title .logo-img{width:48px;height:48px;animation:bounce 2s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.login-subtitle{font-size:14px;color:#666}.login-tabs .ant-tabs-tab{font-size:14px;font-weight:500}.qrcode-section{text-align:center;padding:20px 0}.qrcode-container{display:flex;justify-content:center;margin-bottom:16px}.login-qrcode{border:2px solid #f0f0f0;border-radius:8px;padding:8px;background:#fff}.qrcode-status{font-size:14px;font-weight:500;margin-bottom:8px}.qrcode-tips{font-size:12px;color:#999}.login-form{padding:8px 0}.login-input{border-radius:6px}.login-input:hover{border-color:#40a9ff}.login-input:focus{border-color:#1890ff;box-shadow:0 0 0 2px #1890ff1a}.login-button{height:40px;border-radius:6px;font-size:16px;font-weight:500;background:linear-gradient(135deg,#1890ff,#096dd9);border:none}.login-button:hover{background:linear-gradient(135deg,#40a9ff,#1890ff);transform:translateY(-1px);box-shadow:0 4px 12px #1890ff4d}.login-button:active{transform:translateY(0)}.login-footer{position:absolute;bottom:40px;left:50%;transform:translate(-50%);text-align:center;width:100%;z-index:1}.login-footer .ant-typography{font-size:12px;color:#999;line-height:1.6}@media (max-width: 992px){.login-container{grid-template-columns:1fr}.login-right{grid-column:1;padding:40px 20px}.login-footer{position:relative;bottom:auto;left:auto;transform:none;margin-top:40px;padding:0 20px}}@media (max-width: 768px){.login-container{padding:20px 16px}.login-right,.login-wrapper{max-width:100%}.login-card{box-shadow:0 4px 16px #0000001a}}@media (max-width: 480px){.login-right{padding:24px 16px}.login-card{max-width:100%}.login-title{font-size:18px!important}.logo{font-size:20px}.login-qrcode{width:160px;height:160px}}.loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:#fffc;display:flex;align-items:center;justify-content:center;border-radius:12px;z-index:1000}.time-picker{display:flex;align-items:center;justify-content:center;gap:16px;height:200px;-webkit-user-select:none;user-select:none;margin:20px 0}.picker-column{position:relative;width:120px;height:100%;overflow:hidden;cursor:pointer;background:linear-gradient(to bottom,#fff0,#fffc,#fff 30%,#fff 70%,#fffc,#fff0);border-radius:12px}.picker-column:hover:not(.disabled){background:linear-gradient(to bottom,#1890ff0d,#1890ff1a 20%,#fff 35%,#fff 65%,#1890ff1a 80%,#1890ff0d)}.picker-item{height:66px;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;font-family:Courier New,monospace;transition:all .2s ease}.picker-item.prev,.picker-item.next{color:#999;font-size:36px;opacity:.5}.picker-item.current{color:#1890ff;font-size:64px;font-weight:700}.picker-separator{font-size:64px;font-weight:700;color:#1890ff;margin-top:-10px;padding:0 8px}.picker-highlight{position:absolute;top:50%;left:0;right:0;height:66px;transform:translateY(-50%);border-top:3px solid #1890ff;border-bottom:3px solid #1890ff;pointer-events:none;background:#1890ff14;border-radius:8px}.time-picker.disabled .picker-column{cursor:default}.time-picker.disabled .picker-item.current{color:#1890ff}.time-picker.disabled .picker-item.prev,.time-picker.disabled .picker-item.next{opacity:0}.time-picker.disabled .picker-highlight{border-color:transparent;background:transparent}@media (hover: none){.picker-column{-webkit-overflow-scrolling:touch}}.all-books-container{padding:24px;height:100%;overflow-y:auto}.all-books-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px}.all-books-loading p{color:#666;font-size:14px}.all-books-title{font-size:24px;font-weight:700;color:#333;margin-bottom:24px;text-align:center}.grade-filter{display:flex;align-items:flex-start;gap:12px;margin-bottom:24px;padding:16px;background:#f9f9f9;border-radius:8px}.filter-label{font-size:14px;color:#666;white-space:nowrap;padding-top:4px}.grade-tags{display:flex;flex-wrap:wrap;gap:8px}.grade-tag{cursor:pointer;padding:4px 12px;font-size:14px;border-radius:4px;transition:all .3s}.grade-tag:hover{background:#e6f7ff;color:#1890ff}.grade-tag.active{background:#1890ff;color:#fff}.books-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:16px}.book-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #00000014;cursor:pointer;transition:all .3s}.book-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f}.book-cover{width:100%;aspect-ratio:3/4;overflow:hidden;background:#f5f5f5}.book-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#f0f0f0;color:#ccc;font-size:48px}.book-info{padding:12px}.book-name{font-size:14px;font-weight:500;color:#333;margin:0 0 6px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.book-meta{display:flex;flex-wrap:wrap;gap:8px}.book-grade{font-size:12px;color:#1890ff;background:#e6f7ff;padding:2px 8px;border-radius:4px}.book-publisher{font-size:12px;color:#999}.books-empty{grid-column:1 / -1;padding:60px 0}.dashboard-layout{height:100vh;display:flex;flex-direction:column;color:#333}.dashboard-header{background:#fff;box-shadow:0 2px 8px #0000001a;z-index:10;height:80px;display:flex;align-items:center;padding:0 40px;gap:12px}.header-user-info{margin-left:auto}.user-tag{font-size:14px;color:#666}.header-logo{width:48px;height:48px}.header-title{font-size:32px;font-weight:700;color:#1890ff;margin:0}.dashboard-content{flex:1;display:flex}.dashboard-sider{background:#fff;box-shadow:2px 0 8px #0000000d;display:flex!important;flex-direction:column!important;height:100%!important}.dashboard-sider>div{height:100%!important;display:flex!important;flex-direction:column!important}.sider-content{display:flex;flex-direction:column;gap:16px;padding:20px;flex:1;justify-content:flex-end;min-height:0}.my-books-section{margin-bottom:8px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding:0 4px}.section-title{font-size:14px;color:#666}.change-book-icon{font-size:16px;color:#1890ff;cursor:pointer;padding:4px;border-radius:4px;transition:all .3s}.change-book-icon:hover{background:#e6f7ff;transform:scale(1.1)}.add-book-placeholder{border:2px dashed #d9d9d9;background:#fafafa}.add-book-placeholder:hover{border-color:#1890ff;background:#e6f7ff}.add-book-icon{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:40px;color:#bfbfbf}.add-book-placeholder:hover .add-book-icon{color:#1890ff}.logout-btn{display:flex;align-items:center;gap:12px;padding:16px;background:#fff2f0;border-radius:12px;cursor:pointer;transition:all .3s;border:1px solid #ffccc7}.logout-btn:hover{background:#ffccc7}.logout-icon{font-size:24px;color:#ff4d4f}.logout-text{font-size:16px;font-weight:500;color:#ff4d4f}.menu-item{display:flex;align-items:center;gap:12px;padding:20px;background:#f9f9f9;border-radius:12px;cursor:pointer;transition:all .3s}.menu-item-with-cover{flex-direction:column;gap:8px;padding:12px}.menu-item:hover{background:#e6f7ff;transform:translate(4px)}.menu-cover{width:100%;aspect-ratio:3/4;border-radius:8px;overflow:hidden;background:#f5f5f5;display:flex;align-items:center;justify-content:center}.menu-cover img{width:100%;height:100%;object-fit:cover}.book-placeholder-small{font-size:40px;color:#ccc}.menu-text{display:flex;flex-direction:column;align-items:center;gap:4px}.book-name-small{font-size:12px;color:#666;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;width:100%}.menu-item.active{background:#1890ff;color:#fff}.menu-item.active .menu-icon{color:#fff}.menu-icon{font-size:28px;color:#1890ff}.menu-item span{font-size:20px;font-weight:500}.dashboard-main{background:#f5f5f5;padding:40px;display:flex;justify-content:center;align-items:center}.timer-container{background:#fff;padding:60px;border-radius:24px;box-shadow:0 8px 24px #0000001a;text-align:center;width:100%;max-width:600px}.timer-title{font-size:36px;font-weight:700;color:#333;margin-bottom:20px}.timer-controls{display:flex;flex-direction:column;gap:24px;margin-top:20px}.mode-switch,.playback-controls{display:flex;gap:16px;justify-content:center}.mode-switch .ant-btn,.playback-controls .ant-btn{min-width:120px;height:60px;font-size:20px;border-radius:12px}.book-item{position:relative;cursor:pointer;border-radius:12px;overflow:hidden;box-shadow:0 2px 8px #0000001a;transition:all .3s;background:#fff}.book-item:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.book-item.selected{border:3px solid #1890ff}.book-cover{width:100%;height:200px;display:flex;align-items:center;justify-content:center;background:#f5f5f5}.book-cover img{width:100%;height:100%;object-fit:cover}.book-placeholder{font-size:64px;color:#ccc}.book-name{padding:16px;font-size:18px;font-weight:500;color:#333;text-align:center}.selected-badge{position:absolute;top:8px;right:8px;background:#1890ff;color:#fff;width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}html,body{margin:0;padding:0;overflow:hidden;width:100%;height:100%}.textbook-reader-layout{height:100vh;background:#f5f5f5;overflow:hidden}.textbook-reader-content{height:100vh;display:flex;flex-direction:column;overflow:hidden;max-width:100vw}.textbook-reader-content.fullscreen{height:100vh;overflow:hidden}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;gap:20px}.loading-message{font-size:18px;color:#666;margin-top:10px}.loading-progress{width:300px;display:flex;flex-direction:column;gap:8px}.progress-bar{width:100%;height:8px;background:#e0e0e0;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#1890ff;transition:width .3s ease;border-radius:4px}.progress-text{text-align:center;font-size:14px;color:#999}.page-wrapper{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 60px 90px;gap:20px;position:relative;overflow:hidden;max-width:100%;box-sizing:border-box}.page-container{position:relative;display:flex;justify-content:center;align-items:center;max-width:calc(100vw - 140px);max-height:calc(100vh - 200px);overflow:hidden}.page-image-wrapper{position:relative;display:inline-block;line-height:0;max-width:100%;max-height:100%}.page-image-wrapper img{display:block;max-width:100%;max-height:calc(100vh - 200px);width:auto;height:auto;object-fit:contain}.point-reads-container{position:absolute;top:0;left:0;right:0;bottom:0;pointer-events:none;overflow:hidden}.point-read-box{position:absolute;border:2px solid #1890ff;background:#1890ff4d;cursor:pointer;pointer-events:auto;transition:all .2s ease;border-radius:4px;z-index:101;box-sizing:border-box}.point-read-box:hover{background:#1890ff66;border-color:#1890ff}.point-read-box.active{background:#52c41a80;border-color:#52c41a}.page-image{box-shadow:0 4px 20px #00000026;border-radius:8px;cursor:pointer}.page-text-display{position:absolute;top:10px;left:50%;transform:translate(-50%);z-index:15;text-align:center;max-width:80%;background:#ffffffe6;padding:12px 24px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.text-english{font-size:18px;font-weight:500;color:#333;margin-bottom:4px;line-height:1.5}.text-chinese{font-size:14px;color:#666;line-height:1.5}.page-nav-side{position:fixed;top:50%;transform:translateY(-50%);z-index:30;display:flex;flex-direction:column;gap:20px}.page-nav-side-left{left:20px}.page-nav-side-right{right:20px}.page-nav-icon{width:50px;height:50px;display:flex;align-items:center;justify-content:center;background:#fff;box-shadow:0 2px 8px #00000026;border-radius:8px;border:none;font-size:20px}.page-nav-icon:hover:not(:disabled){background:#f0f0f0}.page-nav-icon:disabled{opacity:.4;cursor:not-allowed}.status-bar{position:fixed;bottom:0;left:0;right:0;background:#fff;padding:16px 20px;box-shadow:0 -2px 8px #0000001a;display:flex;justify-content:space-between;align-items:center;transition:opacity .3s;z-index:20;box-sizing:border-box}.status-bar .ant-btn{min-width:120px;height:50px;font-size:18px;border-radius:10px;margin-left:16px}.status-items{display:flex;align-items:center;justify-content:space-between;gap:20px;flex:1}.status-controls{display:flex;align-items:center;gap:20px}.status-item{display:flex;align-items:center;gap:8px;font-size:18px;color:#666}.status-item .anticon{font-size:24px}.status-actions{display:flex;align-items:center}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#ffffffde;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;height:100vh}
