*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh}.app{min-height:100vh;padding:2rem}.container{max-width:1400px;margin:0 auto}.header{text-align:center;color:#fff;margin-bottom:3rem;position:relative}.header h1{font-size:3rem;margin-bottom:.5rem;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.subtitle{font-size:1.2rem;opacity:.9}.admin-link{position:absolute;top:0;right:0;padding:.75rem 1.5rem;background:#fff3;color:#fff;text-decoration:none;border-radius:8px;font-weight:500;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);transition:all .3s ease}.admin-link:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 12px #0003}.main-content{display:grid;grid-template-columns:1fr 1fr;gap:2rem}@media (max-width: 968px){.main-content{grid-template-columns:1fr}}.generator-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 10px 40px #0000001a}.form{display:flex;flex-direction:column;gap:1.5rem}.input-group{display:flex;flex-direction:column;gap:.5rem}.input-group label{font-weight:600;color:#333;font-size:1rem}textarea{padding:1rem;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .3s ease}textarea:focus{outline:none;border-color:#667eea}textarea:disabled{background-color:#f5f5f5;cursor:not-allowed}.submit-btn{padding:1rem 2rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.submit-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.mode-hint{font-size:.9rem;color:#666;text-align:center;margin:0;padding:.75rem;background:#f0f7ff;border-radius:8px;border-left:3px solid #2196f3}.error-box{background-color:#fee;border-left:4px solid #f44;padding:1rem;border-radius:8px;color:#c33}.result-box{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border-left:4px solid #4caf50;padding:1.5rem;border-radius:8px;margin-top:1.5rem}.result-box h3{color:#2e7d32;margin-bottom:1rem}.result-content{background:#fff;padding:1rem;border-radius:8px}.video-container{display:flex;flex-direction:column;gap:1rem}.video-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f5f5f5;border-radius:8px}.download-btn{padding:.5rem 1rem;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:.9rem;cursor:pointer;transition:all .3s ease}.download-btn:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 2px 8px #4caf504d}.video-player{width:100%;max-width:100%;border-radius:8px;box-shadow:0 4px 12px #0000001a;background:#000}.video-url-section{padding:.75rem;background:#f5f5f5;border-radius:8px;word-break:break-all}.video-url-section strong{display:block;margin-bottom:.5rem;color:#333}.video-link{color:#2196f3;text-decoration:none;font-size:.9rem}.video-link:hover{text-decoration:underline}.api-response-details{margin-top:1rem;border:2px solid #e0e0e0;border-radius:8px;overflow:hidden}.api-response-details summary{padding:1rem;background:#f5f5f5;cursor:pointer;font-weight:600;-webkit-user-select:none;user-select:none;transition:background .3s ease}.api-response-details summary:hover{background:#e8e8e8}.api-response-details[open] summary{border-bottom:2px solid #e0e0e0;background:#667eea;color:#fff}.api-section{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-left:4px solid #667eea}.api-info-box{background:#fff;border-radius:8px;padding:1rem}.api-meta{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:#f0f4ff;border-radius:6px;margin-bottom:1rem;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:#666}.api-summary{cursor:pointer;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:6px;margin-bottom:1rem;font-weight:600;-webkit-user-select:none;user-select:none;transition:all .3s ease;display:block}.api-summary:hover{transform:translate(4px);box-shadow:0 2px 8px #667eea4d}.result-json.highlight{border:2px solid #e0e0e0;box-shadow:inset 0 2px 4px #0000000d}.copy-json-btn{width:100%;padding:.75rem;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:500;cursor:pointer;margin-top:1rem;transition:all .3s ease}.copy-json-btn:hover{background:#45a049;transform:translateY(-2px);box-shadow:0 4px 12px #4caf504d}.no-video-notice{padding:1rem;background:#fff3e0;border-left:3px solid #ff9800;border-radius:6px;color:#e65100;font-size:.9rem}.result-json{background:#f5f5f5;padding:1rem;margin:0;overflow-x:auto;font-size:.85rem;max-height:400px;overflow-y:auto;line-height:1.5;font-family:Courier New,monospace}.loading-box{background:#e3f2fd;border-left:4px solid #2196f3;padding:1.5rem;border-radius:8px;text-align:center;margin-top:1.5rem}.spinner{border:4px solid #f3f3f3;border-top:4px solid #2196f3;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin:0 auto 1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tasks-section{background:#fff;border-radius:16px;padding:2rem;box-shadow:0 10px 40px #0000001a}.tasks-section h2{color:#333;margin-bottom:1rem}.refresh-btn{padding:.5rem 1rem;background:#667eea;color:#fff;border:none;border-radius:6px;cursor:pointer;margin-bottom:1rem;font-size:.9rem;transition:background .3s ease}.refresh-btn:hover{background:#5568d3}.empty-message{text-align:center;color:#999;padding:2rem;font-style:italic}.tasks-list{display:flex;flex-direction:column;gap:1rem;max-height:600px;overflow-y:auto}.task-card{border:2px solid #e0e0e0;border-radius:12px;padding:1rem;transition:transform .2s ease,box-shadow .2s ease}.task-card.clickable{cursor:pointer}.task-card.clickable:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026;border-color:#667eea}.task-card.completed{border-color:#4caf50;background-color:#f1f8f4}.task-card.failed{border-color:#f44336;background-color:#fff5f5}.task-card.processing{border-color:#2196f3;background-color:#f0f7ff}.task-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.task-id{font-weight:600;color:#666;font-size:.9rem}.task-status{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500}.task-status.completed{background:#c8e6c9;color:#2e7d32}.task-status.failed{background:#ffcdd2;color:#c62828}.task-status.processing{background:#bbdefb;color:#1565c0}.task-status.pending{background:#fff9c4;color:#f57f17}.task-prompt{color:#333;margin-bottom:.5rem;line-height:1.5}.task-time{color:#999;font-size:.85rem}.task-hint{margin-top:.75rem;padding:.5rem;border-radius:6px;font-size:.85rem;text-align:center;font-weight:500}.task-hint.success{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);color:#2e7d32}.task-hint.failed{background:linear-gradient(135deg,#ffebee,#ffcdd2);color:#c62828}.task-error-section{margin-top:.5rem}.task-error{color:#c62828;font-size:.9rem;padding:.5rem;background:#ffebee;border-radius:4px;margin:0}.task-error-preview{margin-top:.5rem;padding:.5rem;background:#fff3e0;border-left:3px solid #ff9800;border-radius:4px;color:#e65100;font-size:.85rem;line-height:1.4;word-break:break-word}.view-details-btn{padding:.25rem .75rem;background:#f44336;color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:background .3s ease}.view-details-btn:hover{background:#d32f2f}.stats-panel{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1rem;padding:1rem;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-radius:12px}.stat-item{display:flex;flex-direction:column;align-items:center;padding:.75rem;background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a}.stat-item.success{border-left:4px solid #4caf50}.stat-item.failed{border-left:4px solid #f44336}.stat-item.processing{border-left:4px solid #2196f3}.stat-label{font-size:.85rem;color:#666;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700;color:#333}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;justify-content:center;align-items:center;z-index:1000;padding:2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:16px;max-width:800px;width:100%;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}.modal-content.modal-large{max-width:900px;max-height:90vh}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:2px solid #e0e0e0}.modal-header h3{margin:0;color:#333}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:#999;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s ease}.close-btn:hover{background:#f0f0f0;color:#333}.modal-body{padding:1.5rem}.detail-section{margin-bottom:1.5rem}.detail-section h4{color:#667eea;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:2px solid #e0e0e0}.detail-section p{margin:.5rem 0;line-height:1.6}.detail-grid-simple{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detail-grid-simple>div{display:flex;flex-direction:column;gap:.25rem}.detail-grid-simple>div.full-width{grid-column:1 / -1}.detail-grid-simple strong{color:#666;font-size:.9rem}.detail-grid-simple span{color:#333}.video-actions{display:flex;gap:1rem;margin:1rem 0}.video-action-btn{flex:1;padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;text-align:center}.video-action-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.video-url-box{padding:1rem;background:#f5f5f5;border-radius:8px;margin-top:1rem}.video-url-box strong{display:block;margin-bottom:.5rem;color:#333}.url-text{word-break:break-all;color:#666;font-size:.85rem;font-family:monospace;background:#fff;padding:.5rem;border-radius:4px;border:1px solid #e0e0e0;margin-bottom:.5rem;max-height:100px;overflow-y:auto}.copy-url-btn{width:100%;padding:.5rem;background:#2196f3;color:#fff;border:none;border-radius:4px;font-size:.85rem;cursor:pointer;transition:all .3s ease}.copy-url-btn:hover{background:#1976d2;transform:translateY(-1px)}.detail-section.error-section{background:#fff5f5;padding:1.5rem;border-radius:8px;border-left:4px solid #f44336}.error-message-box{background:#fff;padding:1rem;border-radius:6px;border:1px solid #ffcdd2}.error-message{color:#c62828;font-weight:500;font-size:1rem;margin:0 0 .5rem;line-height:1.6}.error-time{color:#999;font-size:.85rem;margin:0}.error-details-json{background:#f5f5f5;padding:1rem;border-radius:8px;overflow-x:auto;font-size:.85rem;line-height:1.5;border:1px solid #e0e0e0;max-height:400px;overflow-y:auto}@media (max-width: 768px){.stats-panel{grid-template-columns:repeat(2,1fr)}.modal-overlay{padding:1rem}.modal-content{max-height:90vh}}.admin-dashboard{min-height:100vh;background:linear-gradient(135deg,#1e3c72,#2a5298);padding:2rem}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;background:#fff;padding:1.5rem 2rem;border-radius:12px;box-shadow:0 4px 12px #0000001a}.admin-title h1{margin:0;color:#1e3c72;font-size:2rem}.admin-title p{margin:.25rem 0 0;color:#666;font-size:.95rem}.admin-actions{display:flex;gap:1rem}.btn-refresh,.btn-back{padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;font-weight:500}.btn-refresh{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-refresh:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.btn-back{background:#f5f5f5;color:#333}.btn-back:hover{background:#e0e0e0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a;display:flex;align-items:center;gap:1rem;transition:transform .3s ease}.stat-card:hover{transform:translateY(-4px)}.stat-card.total{border-left:4px solid #2196f3}.stat-card.success{border-left:4px solid #4caf50}.stat-card.failed{border-left:4px solid #f44336}.stat-card.rate{border-left:4px solid #ff9800}.stat-icon{font-size:2.5rem}.stat-info{flex:1}.stat-label{font-size:.9rem;color:#666;margin-bottom:.25rem}.stat-value{font-size:2rem;font-weight:700;color:#333}.charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.5rem;margin-bottom:2rem}.chart-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a}.chart-card.full-width{grid-column:1 / -1}.chart-card h3{margin:0 0 1rem;color:#333;font-size:1.1rem}.admin-toolbar{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a;margin-bottom:1.5rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}.toolbar-left,.toolbar-right{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.filter-group,.search-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-weight:500;color:#333}.filter-select{padding:.5rem 1rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.95rem;cursor:pointer;transition:border-color .3s ease}.filter-select:focus{outline:none;border-color:#667eea}.search-input{padding:.5rem 1rem;border:2px solid #e0e0e0;border-radius:6px;font-size:.95rem;min-width:250px;transition:border-color .3s ease}.search-input:focus{outline:none;border-color:#667eea}.btn-export,.btn-danger{padding:.5rem 1rem;border:none;border-radius:6px;font-size:.95rem;cursor:pointer;transition:all .3s ease;font-weight:500}.btn-export{background:#2196f3;color:#fff}.btn-export:hover{background:#1976d2;transform:translateY(-2px)}.btn-danger{background:#f44336;color:#fff}.btn-danger:hover:not(:disabled){background:#d32f2f;transform:translateY(-2px)}.btn-danger:disabled{opacity:.5;cursor:not-allowed}.admin-tasks{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 4px 12px #0000001a}.admin-tasks h3{margin:0 0 1rem;color:#333}.tasks-table-container{overflow-x:auto}.tasks-table{width:100%;border-collapse:collapse}.tasks-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.tasks-table th{padding:1rem;text-align:left;font-weight:600}.tasks-table tbody tr{border-bottom:1px solid #e0e0e0;transition:background-color .3s ease}.tasks-table tbody tr:hover{background-color:#f5f5f5}.tasks-table td{padding:1rem}.task-id{font-family:monospace;color:#666;font-size:.9rem}.status-badge{padding:.25rem .75rem;border-radius:12px;font-size:.85rem;font-weight:500;display:inline-block}.status-badge.completed{background:#c8e6c9;color:#2e7d32}.status-badge.failed{background:#ffcdd2;color:#c62828}.status-badge.processing{background:#bbdefb;color:#1565c0}.status-badge.pending{background:#fff9c4;color:#f57f17}.task-prompt{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.task-time{color:#666;font-size:.9rem}.task-actions{display:flex;gap:.5rem}.btn-view,.btn-delete{padding:.25rem .5rem;border:none;background:none;cursor:pointer;font-size:1.2rem;border-radius:4px;transition:all .3s ease}.btn-view:hover{background:#e3f2fd}.btn-delete:hover{background:#ffebee}.empty-row{text-align:center;padding:2rem!important;color:#999;font-style:italic}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1000;padding:2rem;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content.detail-modal{max-width:900px;max-height:85vh}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-bottom:1.5rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item.full{grid-column:1 / -1}.detail-item label{font-weight:600;color:#666;font-size:.9rem}.detail-item span{color:#333}.detail-section{margin-top:1.5rem;padding:1rem;background:#f5f5f5;border-radius:8px}.detail-section.error{background:#ffebee;border-left:4px solid #f44336}.detail-section h4{margin:0 0 .75rem;color:#333}.json-viewer{background:#fff;padding:1rem;border-radius:4px;overflow-x:auto;font-size:.85rem;line-height:1.5;border:1px solid #e0e0e0;max-height:300px;overflow-y:auto}@media (max-width: 1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}.charts-grid{grid-template-columns:1fr}}@media (max-width: 768px){.admin-dashboard{padding:1rem}.admin-header{flex-direction:column;gap:1rem}.stats-grid{grid-template-columns:1fr}.admin-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{flex-direction:column}.search-input{min-width:100%}.detail-grid{grid-template-columns:1fr}}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}#root{width:100%}
