*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#f5f5f5;height:100vh;height:100dvh;overflow:hidden;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}#app,.view{height:100vh;height:100dvh;display:flex;flex-direction:column}.hidden{display:none!important}.header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:15px 20px;padding-top:calc(15px + env(safe-area-inset-top));display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a;position:sticky;top:0;z-index:100;-webkit-overflow-scrolling:touch}.header h1,.header h2{font-size:1.2rem;font-weight:600}.header-title-group{display:flex;align-items:center;gap:8px}.zoom-level-badge{font-size:.75rem;color:#ffffffe6;background:#fff3;padding:2px 8px;border-radius:10px;font-weight:500}.header-buttons{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:center}.btn-primary{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 16px;border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.btn-primary:hover{background:#ffffff4d;transform:translateY(-1px)}.btn-secondary{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:8px 16px;border-radius:20px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.btn-secondary:hover{background:#fff3;transform:translateY(-1px)}.btn-default{background:#fff;border:none;color:#333;font-size:1.2rem;cursor:pointer;padding:8px;min-width:40px}.btn-back,.btn-menu{background:transparent;border:none;color:#fff;font-size:1.2rem;cursor:pointer;padding:8px;min-width:40px}.btn-menu{position:relative}.btn-menu.active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:20px;height:3px;background:#fff;border-radius:2px}.file-list-container{flex:1;overflow-y:auto;padding:20px}.file-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px;padding:10px}.file-item{background:#fff;border-radius:12px;padding:20px;text-align:center;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;position:relative;overflow:hidden}.file-item:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026}.file-item:active{transform:translateY(-2px)}.file-icon{font-size:2.5rem;margin-bottom:10px}.file-name{font-size:.9rem;color:#333;font-weight:500;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;line-height:1.4;max-height:2.8em;word-break:break-word}.file-size{font-size:.8rem;color:#666;margin-top:5px}.file-date{font-size:.7rem;color:#999;margin-top:3px}.file-last-read{font-size:.65rem;color:#667eea;margin-top:2px;font-weight:500}.delete-btn{position:absolute;top:10px;right:10px;background:#ff00001a;border:none;color:#e53e3e;width:24px;height:24px;border-radius:50%;cursor:pointer;display:none;font-size:.8rem}.file-item:hover .delete-btn{display:block}.empty-state{text-align:center;padding:60px 20px;color:#666}.empty-icon{font-size:4rem;margin-bottom:20px;opacity:.5}.empty-state p{margin:10px 0;font-size:1rem}.empty-state p:first-of-type{font-size:1.2rem;font-weight:500;color:#333}.pdf-container{flex:1;background:#525659;overflow-y:auto;overflow-x:auto;padding:20px;position:relative;-webkit-overflow-scrolling:touch;display:flex;justify-content:flex-start;align-items:flex-start}.pdf-pages{display:flex;flex-direction:column;align-items:center;gap:20px;margin:0 auto;-webkit-transform:translateZ(0);transform:translateZ(0);min-width:fit-content}.pdf-page{background:#fff;box-shadow:0 2px 10px #0000004d;margin-bottom:0;display:block;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;flex-shrink:0;-webkit-flex-shrink:0;min-width:0;min-height:0}.loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#fff;font-size:1.2rem;z-index:10}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;color:#999}.page-loading:before{content:"";width:30px;height:30px;border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:10px}.controls{background:#fff;padding:12px 15px;padding-bottom:calc(12px + env(safe-area-inset-bottom));display:flex;justify-content:center;align-items:center;gap:15px;border-top:1px solid #e0e0e0;box-shadow:0 -2px 10px #0000001a;position:relative}.zoom-menu{position:absolute;top:calc(55px + env(safe-area-inset-top));right:15px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;padding:8px 0;z-index:1000;min-width:150px;-webkit-overflow-scrolling:touch}.zoom-menu-item{display:block;width:100%;padding:12px 20px;background:none;border:none;text-align:left;font-size:.95rem;color:#333;cursor:pointer;transition:background-color .2s}.zoom-menu-item:hover{background:#f5f5f5}.zoom-menu-item:active{background:#e0e0e0}.btn-control{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s ease}.btn-control:hover{background:#5a6fd8;transform:translateY(-1px)}.btn-control:disabled{background:#ccc;cursor:not-allowed;transform:none}#pageInfo{font-weight:500;color:#333;min-width:100px;text-align:center;font-size:.9rem}.zoom-controls{position:fixed;right:20px;top:50%;transform:translateY(-50%);background:#fff;border-radius:25px;box-shadow:0 4px 20px #0003;display:flex;flex-direction:column;align-items:center;padding:10px 0;gap:10px;z-index:50}.btn-zoom{background:#667eea;color:#fff;border:none;width:44px;height:44px;border-radius:50%;cursor:pointer;font-size:1.4rem;display:flex;align-items:center;justify-content:center;transition:all .3s ease;font-weight:700}.btn-zoom:hover{background:#5a6fd8;transform:scale(1.1)}#zoomLevel{font-size:.85rem;color:#333;font-weight:500;margin:5px 0;padding:4px 8px;border-radius:4px}@media(max-width:768px){.header{padding:12px 15px}.header h1,.header h2{font-size:1rem}.zoom-level-badge{font-size:.7rem;padding:1px 6px}.btn-primary{padding:6px 12px;font-size:.8rem}.file-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;padding:5px}.file-item{padding:15px 10px}.file-icon{font-size:2rem}.file-name{font-size:.8rem}.controls{padding:10px;gap:15px}.btn-control{padding:8px 12px;font-size:.8rem}.zoom-controls{right:10px;padding:8px 0}.btn-zoom{width:35px;height:35px;font-size:1rem}.zoom-menu{right:10px;min-width:130px}}@media(max-width:480px){.file-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr))}.zoom-controls{right:5px}.btn-zoom{width:30px;height:30px;font-size:.9rem}.zoom-menu{right:5px;min-width:120px}}@keyframes fadeIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.file-item{animation:fadeIn .3s ease}@media(hover:none){.file-item:hover{transform:none}.file-item:active,.btn-primary:active,.btn-control:active{transform:scale(.95)}}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;animation:fadeIn .3s ease}.modal-content{background:#fff;border-radius:12px;max-width:500px;width:90%;max-height:80vh;overflow:hidden;box-shadow:0 10px 40px #0000004d;animation:slideInUp .3s ease}.modal-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center}.modal-header h3{margin:0;font-size:1.2rem}.close-btn{background:transparent;border:none;color:#fff;font-size:1.5rem;cursor:pointer;padding:5px;line-height:1}.modal-body{padding:20px;max-height:50vh;overflow-y:auto}.modal-footer{padding:20px;border-top:1px solid #e0e0e0;display:flex;justify-content:flex-end;gap:10px}.modal-footer .btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;padding:10px 24px;border-radius:6px;font-size:.95rem;cursor:pointer;transition:all .3s ease;font-weight:500}.modal-footer .btn-primary:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.modal-footer .btn-secondary{background:#f5f5f5;border:1px solid #ddd;color:#333;padding:10px 24px;border-radius:6px;font-size:.95rem;cursor:pointer;transition:all .3s ease;font-weight:500}.modal-footer .btn-secondary:hover{background:#e0e0e0;transform:translateY(-1px)}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#333}.form-group input{width:100%;padding:10px;border:1px solid #ddd;border-radius:6px;font-size:1rem;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea33}.help-text{background:#f8f9fa;padding:15px;border-radius:6px;margin-top:15px}.help-text p{margin-bottom:10px;color:#555}.help-text ol{margin-left:20px;color:#666}.help-text li{margin-bottom:5px}.help-text a{color:#667eea;text-decoration:none}.help-text a:hover{text-decoration:underline}.feishu-loading{position:fixed;top:0;left:0;width:100%;height:100%;background:#ffffffe6;display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:999}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}.feishu-loading p{color:#333;font-size:1rem}.file-source{position:absolute;top:10px;left:10px;background:#667eeae6;color:#fff;padding:2px 8px;border-radius:12px;font-size:.7rem;font-weight:500}.file-source.cache{background:#52c41ae6}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media(max-width:768px){.modal-content{width:95%;max-height:90vh}.modal-header,.modal-body,.modal-footer{padding:15px}.help-text{padding:10px}}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;z-index:9999}.message-container{position:fixed;bottom:20px;bottom:calc(20px + env(safe-area-inset-bottom));right:20px;z-index:10000;display:flex;flex-direction:column-reverse;gap:10px;max-width:400px;max-height:80vh;overflow-y:auto}.message{display:flex;align-items:center;padding:16px 20px;border-radius:8px;box-shadow:0 4px 12px #00000026;background:#fff;transform:translate(100%);opacity:0;transition:all .3s ease;cursor:pointer}.message.show{transform:translate(0);opacity:1}.message.hide{transform:translate(100%);opacity:0}.message-icon{font-size:24px;margin-right:12px;flex-shrink:0}.message-text{flex:1;font-size:14px;color:#333;word-break:break-word}.message-close{font-size:20px;color:#999;cursor:pointer;margin-left:12px;flex-shrink:0;transition:color .2s}.message-close:hover{color:#666}.message-info{border-left:4px solid #1890ff}.message-success{border-left:4px solid #52c41a}.message-error{border-left:4px solid #ff4d4f}.message-warning{border-left:4px solid #faad14}.message-info .message-icon{color:#1890ff}.message-success .message-icon{color:#52c41a}.message-error .message-icon{color:#ff4d4f}.message-warning .message-icon{color:#faad14}@media(max-width:768px){.message-container{left:10px;right:10px;bottom:10px;bottom:calc(10px + env(safe-area-inset-bottom));max-width:none}.message{padding:12px 16px}.message-icon{font-size:20px}.message-text{font-size:13px}}
