*{margin:0;padding:0;box-sizing:border-box}.image-crop-page{max-width:1000px;margin:0 auto;padding:1rem}.image-crop-page h2{margin-bottom:.5rem;color:#1e40af}.image-crop-page .desc{color:#4b5563;margin-bottom:1.5rem;font-size:.95rem}.upload-area{border:2px dashed #d1d5db;border-radius:8px;padding:2rem 1rem;text-align:center;cursor:pointer;transition:border-color .2s;margin-bottom:1.5rem}.upload-area:hover{border-color:#2563eb}.upload-area p{margin:.5rem 0}.upload-area .hint{color:#6b7280;font-size:.85rem}.upload-area .file-name{color:#1e40af;font-weight:500;margin-top:.5rem}.crop-section{margin-bottom:2rem}.crop-section h3{margin-bottom:1rem;color:#1e40af}.crop-controls{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.crop-controls label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.crop-controls input[type=number]{width:100%;padding:.5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.9rem}.preview-container{margin-bottom:1.5rem}.preview-container h4{margin-bottom:.75rem;color:#1e40af}.preview-wrapper{position:relative;display:inline-block;background:#f9fafb;padding:1rem;border-radius:6px;border:1px solid #e5e7eb}.preview-img{display:block;max-width:100%;max-height:500px;margin:0 auto}.crop-overlay{position:absolute;top:0;left:0;width:200px;height:200px;border:2px dashed #2563eb;box-sizing:border-box;pointer-events:none;background:#0000001a}.action-bar{text-align:center}.crop-btn{padding:.75rem 2rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:500;font-size:1rem;cursor:pointer;transition:background .2s}.crop-btn:hover:not(:disabled){background:#1d4ed8}.crop-btn:disabled{opacity:.7;cursor:not-allowed}.error{color:#dc2626;font-weight:500;padding:.5rem 1rem;background:#fef2f2;border-radius:4px;margin-top:.5rem}@media (max-width: 768px){.crop-controls{grid-template-columns:1fr}.preview-wrapper{width:100%}}.base64-page,.md5-page,.text-trim-page,.text-compare-page,.text-format-page,.image-compress-page,.image-convert-page,.time-timestamp-page,.time-calendar-page,.qrcode-page,.random-page,.encoding-page{max-width:1000px;margin:0 auto;padding:1rem}.base64-page h2,.md5-page h2,.text-trim-page h2,.text-compare-page h2,.text-format-page h2,.image-compress-page h2,.image-convert-page h2,.time-timestamp-page h2,.time-calendar-page h2,.qrcode-page h2,.random-page h2,.encoding-page h2{margin-bottom:.5rem;color:#1e40af}.base64-page .desc,.md5-page .desc,.text-trim-page .desc,.text-compare-page .desc,.text-format-page .desc,.image-compress-page .desc,.image-convert-page .desc,.time-timestamp-page .desc,.time-calendar-page .desc,.qrcode-page .desc,.random-page .desc,.encoding-page .desc{color:#4b5563;margin-bottom:1.5rem;font-size:.95rem}.download-btn{margin-top:.75rem;padding:.5rem 1rem;background:#10b981;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.download-btn:hover:not(:disabled){background:#059669}.download-btn:disabled{opacity:.7;cursor:not-allowed}.preview-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.preview-panel{display:flex;flex-direction:column}.preview-panel h4{margin-bottom:.5rem;font-size:1.1rem;color:#1e40af}.preview-img{max-width:100%;max-height:300px;margin:0 auto;display:block}.tabs{display:flex;gap:.5rem;margin-bottom:1.5rem}.tab-btn{padding:.5rem 1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.tab-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.tab-btn:hover:not(.active){background:#f1f5f9}@media (max-width: 768px){.split-container,.preview-grid,.tabs{grid-template-columns:1fr}}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,sans-serif;line-height:1.6;color:#1f2937;background-color:#fff}a{text-decoration:none;color:#2563eb}input,textarea,button,select,option{font-family:inherit;font-size:1rem}button{cursor:pointer}.json-format-page,.url-encode-decode-page,.m3u8-download-page,.bilibili-download-page{max-width:1000px;margin:0 auto;padding:1rem}.json-format-page h2,.url-encode-decode-page h2,.m3u8-download-page h2,.bilibili-download-page h2{margin-bottom:.5rem;color:#1e40af}.json-format-page .desc,.url-encode-decode-page .desc,.m3u8-download-page .desc,.bilibili-download-page .desc{color:#4b5563;margin-bottom:1.5rem;font-size:.95rem}.input-section{margin-bottom:1.5rem}.input-section h3{margin-bottom:.75rem;color:#1e40af;font-size:1.1rem}.url-input-group,.bvid-input-group{display:flex;gap:.5rem}.url-input,.bvid-input{flex:1;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem}.start-btn{padding:.75rem 1.5rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.start-btn:hover:not(:disabled){background:#1d4ed8}.start-btn:disabled{opacity:.7;cursor:not-allowed}.status-section{margin-bottom:1.5rem}.status-section h3{margin-bottom:.75rem;color:#1e40af;font-size:1.1rem}.status-text{padding:.75rem;background:#f9fafb;border-radius:6px;margin-bottom:1rem;word-break:break-all}.progress-container{margin-bottom:1rem}.progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.progress-fill{height:100%;background:#2563eb;border-radius:4px;transition:width .3s ease}.progress-text{text-align:right;font-size:.85rem;color:#6b7280}.error-container,.download-info{margin-bottom:1.5rem}.download-info h3{margin-bottom:.75rem;color:#1e40af;font-size:1.1rem}.size-info{display:flex;justify-content:space-between;margin-bottom:1rem;padding:.75rem;background:#f9fafb;border-radius:6px;font-size:.9rem}.files-list h4{margin-bottom:.5rem;color:#1e40af}.files-list ul{list-style:none;padding:0}.files-list li{padding:.25rem .5rem;background:#f1f5f9;border-radius:4px;margin-bottom:.25rem;font-size:.9rem}.final-download-section{margin-bottom:2rem;padding:1.5rem;background:#f0fdf4;border-radius:8px;border:1px solid #bbf7d0}.final-download-section h3{margin-bottom:.75rem;color:#059669}.download-final-btn{padding:.75rem 2rem;background:#059669;color:#fff;border:none;border-radius:6px;font-weight:500;font-size:1rem;cursor:pointer;transition:background .2s}.download-final-btn:hover:not(:disabled){background:#047857}.download-final-btn:disabled{opacity:.7;cursor:not-allowed}.help-section{margin-bottom:1.5rem;padding:1.5rem;background:#f0fdf4;border-radius:8px;border:1px solid #bbf7d0}.help-section h3{margin-bottom:.75rem;color:#059669}.help-section ul{list-style:none;padding:0}.help-section li{padding:.5rem 0;border-bottom:1px solid #e0f2fe;font-size:.9rem}.help-section li:last-child{border-bottom:none}.help-section li:before{content:"🔍";margin-right:.5rem}.tips-section{margin-top:2rem;padding:1.5rem;background:#f0f9ff;border-radius:8px;border:1px solid #bae6fd}.tips-section h3{margin-bottom:.75rem;color:#0284c7}.tips-section ul{list-style:none;padding:0}.tips-section li{padding:.5rem 0;border-bottom:1px solid #e0f2fe;font-size:.9rem}.tips-section li:last-child{border-bottom:none}.tips-section li:before{content:"💡";margin-right:.5rem}.log-section{margin-bottom:1.5rem}.log-section h3{margin-bottom:.75rem;color:#1e40af;font-size:1.1rem}.log-container{max-height:200px;overflow-y:auto;padding:.75rem;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb}.log-message{padding:.25rem .5rem;margin-bottom:.25rem;background:#f1f5f9;border-radius:4px;font-size:.9rem;word-break:break-all}.log-message:last-child{margin-bottom:0}.video-info-section{margin-bottom:1.5rem}.video-info-section h3{margin-bottom:.75rem;color:#1e40af;font-size:1.1rem}.video-card{display:flex;gap:1rem;align-items:flex-start}.video-cover{flex-shrink:0}.video-cover img{width:120px;height:67px;object-fit:cover;border-radius:4px;border:1px solid #e5e7eb}.video-details h4{margin-bottom:.5rem;color:#1f2937}.video-details p{margin:.25rem 0;font-size:.9rem}.quality-section{margin-bottom:1.5rem}.quality-section h3{margin-bottom:.75rem;color:#1e40af;font-size:1.1rem}.quality-selector{display:flex;flex-wrap:wrap;gap:.5rem}.quality-btn{padding:.5rem 1rem;background:#f9fafb;border:1px solid #e5e7eb;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.quality-btn:hover:not(.active){background:#f1f5f9}.quality-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}@media (max-width: 768px){.url-input-group,.bvid-input-group,.video-card{flex-direction:column}.video-cover img{width:100%;height:auto}.size-info{flex-direction:column;gap:.5rem}}.split-container{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.panel{display:flex;flex-direction:column}.panel h3{margin-bottom:.5rem;font-size:1.1rem;color:#1e40af}.input-area,.output-area{flex:1;width:100%}.input-area{min-height:200px;padding:.75rem;border:1px solid #d1d5db;border-radius:6px;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9rem;resize:vertical}.output-area{min-height:200px;padding:.75rem;background:#f9fafb;border-radius:6px;overflow-x:auto;font-family:SFMono-Regular,Consolas,Liberation Mono,Menlo,monospace;font-size:.9rem}.formatted-json,.encoded-decoded-text{margin:0;white-space:pre-wrap;word-break:break-all}.error{color:#dc2626;font-weight:500}.placeholder{color:#9ca3af;font-style:italic}.copy-btn{margin-top:.75rem;padding:.5rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-weight:500;cursor:pointer;transition:background .2s}.copy-btn:hover:not(:disabled){background:#1d4ed8}.copy-btn:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 768px){.split-container{grid-template-columns:1fr}}
