*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Microsoft YaHei,PingFang SC,Hiragino Sans GB,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;display:flex;flex-direction:column;align-items:center;padding:16px;margin:0}.container{width:100%;max-width:1400px;flex:1;min-height:calc(100vh - 32px);display:flex;flex-direction:column;background:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;padding:24px 32px;margin:0}.page-title{text-align:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid #e0e0e0;flex-shrink:0}.page-title h1{font-size:32px;font-weight:500;color:#333;margin:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.logo{text-align:center;margin-bottom:40px}.logo h1{font-size:48px;font-weight:300;color:#333;letter-spacing:-1px}.search-box{position:relative;width:100%;max-width:900px;margin:0 auto 24px;flex-shrink:0}.search-input-wrapper{position:relative;display:flex;align-items:center;width:100%;border:2px solid #dfe1e5;border-radius:24px;padding:8px 8px 8px 16px;background:#fff;transition:all .3s ease;gap:8px}.search-input-wrapper:hover{box-shadow:0 2px 8px #0000001a}.search-input-wrapper.focused{border-color:#4285f4;box-shadow:0 2px 8px #4285f44d}.search-icon{width:20px;height:20px;margin-right:4px;color:#9aa0a6;flex-shrink:0}.search-input{flex:1;border:none;outline:none;font-size:16px;color:#333;background:transparent;padding:4px 0}.search-input::placeholder{color:#9aa0a6}.search-button-inline{padding:8px 20px;background:#4285f4;color:#fff;border:none;border-radius:16px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s;white-space:nowrap;flex-shrink:0}.search-button-inline:hover{background:#3367d6}.search-button-inline:active{background:#2e5aa8}.btn-upload-image{margin-left:6px;background:#5f6368!important;padding:8px;position:relative;display:inline-flex;align-items:center;justify-content:center}.btn-upload-image:hover{background:#4a4d51!important}.btn-upload-image-icon{width:20px;height:20px;display:block}.btn-upload-image-badge{position:absolute;top:2px;right:2px;min-width:14px;height:14px;padding:0 3px;font-size:10px;line-height:14px;text-align:center;background:#f44336;color:#fff;border-radius:7px;display:none}.btn-upload-image.has-cached-image .btn-upload-image-badge{display:block}.ref-image-cell{white-space:nowrap;vertical-align:middle}.ref-image-thumb{display:inline-block;cursor:pointer;border-radius:6px;overflow:hidden;border:1px solid #e0e0e0;transition:box-shadow .2s}.ref-image-thumb:hover{box-shadow:0 2px 8px #0003}.ref-image-thumb img{display:block;max-height:40px;max-width:56px;width:auto;height:auto;object-fit:cover;vertical-align:middle}.search-button{margin:20px auto 0;display:block;padding:10px 24px;background:#4285f4;color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:background .2s}.search-button:hover{background:#3367d6}.search-button:active{background:#2e5aa8}.table-container{flex:1;min-height:0;display:flex;flex-direction:column;margin-top:0}.table-header{display:flex;align-items:center;margin-bottom:12px;flex-shrink:0}.table-title{font-size:20px;font-weight:500;color:#333;flex-shrink:0}.table-header-divider{width:1px;height:24px;background:#e0e0e0;flex-shrink:0;margin:0 16px}.table-header-actions{display:flex;align-items:center;gap:10px;flex:1;min-width:0;justify-content:flex-end}.table-search{position:relative;display:flex;align-items:center}.table-search-input{padding:8px 12px 8px 36px;border:1px solid #dfe1e5;border-radius:4px;font-size:14px;width:250px;outline:none;transition:border-color .2s}.table-search-input:focus{border-color:#4285f4}.table-search-icon{position:absolute;left:12px;width:16px;height:16px;color:#9aa0a6}.table-wrapper{flex:1;min-height:0;overflow:auto;border-radius:8px;border:1px solid #e0e0e0}table{width:100%;border-collapse:collapse;background:#fff;font-size:14px}thead{background:#f8f9fa}th{padding:12px 16px;text-align:left;font-weight:500;color:#5f6368;border-bottom:2px solid #e0e0e0;white-space:nowrap}td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#333;box-sizing:border-box}tbody td{min-height:52px}tbody tr{transition:background-color .2s}tbody tr:hover{background-color:#f8f9fa}tbody tr:last-child td{border-bottom:none}.status-badge{display:inline-block;padding:4px 12px;border-radius:12px;font-size:12px;font-weight:500}.status-active{background:#e8f5e9;color:#2e7d32}.status-pending{background:#fff3e0;color:#e65100}.status-completed{background:#e3f2fd;color:#1565c0}.status-update{background:#fff9c4;color:#f57f17}input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#4285f4}td.action-cell{vertical-align:middle}td.action-cell .action-buttons{display:flex;align-items:center;gap:8px;flex-wrap:wrap;min-height:32px}.action-buttons{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.btn-download,.btn-view-report,.btn-update,.btn-view,.btn-filter{padding:6px 12px;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-download{background:#4caf50;color:#fff}.btn-download:hover{background:#45a049}.btn-view-report{background:#2196f3;color:#fff}.btn-view-report:hover{background:#1976d2}.btn-update{background:#ff9800;color:#fff}.btn-update:hover{background:#e68900}.btn-view{background:#2196f3;color:#fff}.btn-view:hover{background:#0b7dda}.btn-filter{background:#9c27b0;color:#fff}.btn-filter:hover{background:#7b1fa2}.btn-primary{padding:6px 12px;background:#2196f3;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.btn-primary:hover{background:#1976d2}.btn-danger{padding:6px 12px;background:#f44336;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;transition:background .2s}.btn-danger:hover{background:#d32f2f}.no-results{text-align:center;padding:40px;color:#9aa0a6;font-size:16px}.empty-state{text-align:center;padding:60px 20px;color:#9aa0a6}.empty-state-icon{font-size:48px;margin-bottom:16px}.empty-state-text{font-size:16px}.loading{text-align:center;padding:40px;color:#9aa0a6;font-size:16px}.loading:after{content:"...";animation:dots 1.5s steps(4,end) infinite}@keyframes dots{0%,20%{content:"."}40%{content:".."}60%,to{content:"..."}}
