:root{--primary-color:#4a8bfa;--primary-hover:#3b7de6;--secondary-color:#6c757d;--secondary-hover:#5a6268;--success-color:#28a745;--success-hover:#218838;--danger-color:#dc3545;--light-gray:#f8f9fa;--lighter-gray:#f1f3f5;--border-color:#dee2e6;--text-color:#212529;--light-text:#6c757d}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;color:var(--text-color);background-color:#f9f9f9}.container{padding:20px}.container,.uploader-main{max-width:1200px;margin:0 auto}header{margin-bottom:2rem;padding-bottom:1rem;text-align:center}.header-content{flex-direction:column}.branding,.header-content{display:flex;align-items:center}.branding{margin-bottom:1rem}.logo-container{display:flex;justify-content:center;align-items:center;width:140px;position:relative}.logo-container:after{content:"";position:absolute;width:100%;height:100%;background:radial-gradient(circle,rgba(74,139,250,.2) 0,hsla(0,0%,100%,0) 70%);z-index:-1;animation:pulse-glow 4s infinite}@keyframes pulse-glow{0%{opacity:.5;transform:scale(.8)}50%{opacity:.8;transform:scale(1.1)}to{opacity:.5;transform:scale(.8)}}.brand-logo{width:110px;height:110px;transform-origin:center;animation:logo-pulse 3s ease-in-out infinite;filter:drop-shadow(0 0 8px rgba(74,139,250,.5));transition:all .3s ease}.brand-logo:hover{filter:drop-shadow(0 0 12px rgba(74,139,250,.8));transform:scale(1.05) rotate(5deg)}@keyframes logo-pulse{0%{transform:scale(1);filter:drop-shadow(0 0 8px rgba(74,139,250,.5))}50%{transform:scale(1.05);filter:drop-shadow(0 0 15px rgba(74,139,250,.7))}to{transform:scale(1);filter:drop-shadow(0 0 8px rgba(74,139,250,.5))}}.brand-text{display:flex;flex-direction:column;text-align:left;min-width:300px}.title-container{display:flex;align-items:baseline;gap:.75rem}h1{font-size:2.6rem;margin:0;color:#333;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.1);background:linear-gradient(135deg,#333 10%,#404040 70%,#555);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px;line-height:1.2}.version-badge{font-size:1.3rem;font-weight:600;color:#666;background:linear-gradient(135deg,#f8f9fa,#e9ecef);border:1px solid #dee2e6;border-radius:12px;padding:.25rem .75rem;text-shadow:none;letter-spacing:0;white-space:nowrap;box-shadow:0 1px 3px rgba(0,0,0,.1)}.brand-tagline{font-size:1rem;color:var(--light-text);display:flex;align-items:center;gap:12px}.flow-text{font-weight:700;background:linear-gradient(90deg,#4a8bfa,#c471ed,#f64f59,#c471ed,#4a8bfa);background-size:200% auto;color:transparent;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:flow 4s linear infinite;padding:0 5px;text-shadow:0 0 2px rgba(74,139,250,.3)}@keyframes flow{to{background-position:200%}}.app-description{font-size:1.1rem;color:var(--light-text);text-align:center;margin-top:0;margin-bottom:1rem;width:100%}.header-divider{width:100%;height:1px;background-color:var(--border-color);margin:0}.bilibili-link{display:inline-flex;align-items:center;color:#00a1d6;text-decoration:none;font-weight:700;border-radius:4px;padding:2px 6px;transition:background-color .2s ease}.bilibili-link:hover{background-color:rgba(0,161,214,.1)}.bilibili-icon{display:inline-block;width:16px;height:16px;margin-right:4px;background-image:url('data:image/svg+xml;charset=utf-8,<svg t="1641365547353" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2421" width="16" height="16"><path d="M777.514667 131.669333a53.333333 53.333333 0 0 1 0 75.434667L728.746667 255.829333h49.92A160 160 0 0 1 938.666667 415.872v320a160 160 0 0 1-160 160H245.333333A160 160 0 0 1 85.333333 735.872v-320a160 160 0 0 1 160-160h49.749334L246.4 207.146667a53.333333 53.333333 0 1 1 75.392-75.434667l113.152 113.152c3.370667 3.370667 6.186667 7.04 8.448 10.965333h137.088c2.261333-3.925333 5.12-7.68 8.490667-11.008l113.109333-113.152a53.333333 53.333333 0 0 1 75.434667 0z m1.152 231.253334H245.333333a53.333333 53.333333 0 0 0-53.205333 49.365333L192 415.872v320a53.333333 53.333333 0 0 0 49.365333 53.205333L245.333333 789.333333h533.333334a53.333333 53.333333 0 0 0 53.205333-49.365333L832 735.872v-320a53.333333 53.333333 0 0 0-53.333333-53.333333z m-426.666667 106.666666c29.44 0 53.333333 23.893333 53.333333 53.333334v53.333333a53.333333 53.333333 0 1 1-106.666666 0v-53.333333c0-29.44 23.893333-53.333333 53.333333-53.333334z m320 0c29.44 0 53.333333 23.893333 53.333333 53.333334v53.333333a53.333333 53.333333 0 1 1-106.666666 0v-53.333333c0-29.44 23.893333-53.333333 53.333333-53.333334z" p-id="2422" fill="%2300a1d6"></path></svg>');background-size:cover}.animation-groups{display:flex;flex-direction:column;gap:2rem}.animation-group{background-color:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px rgba(0,0,0,.05);position:relative}.group-header{display:flex;flex-direction:column;width:100%;margin-bottom:1rem}.group-header-title{width:100%;display:flex;justify-content:space-between;align-items:center}.group-header h3{color:var(--primary-color);font-size:1.4rem;margin-bottom:.5rem}.group-divider{height:1px;background-color:var(--border-color);width:100%;margin-top:.5rem;margin-bottom:1rem}.group-settings{gap:1rem}.group-settings,.setting-item{display:flex;align-items:center}.setting-item label{margin-right:.5rem;font-size:.9rem;white-space:nowrap}.animation-name,.frame-rate{padding:.3rem .5rem;border:1px solid var(--border-color);border-radius:6px;font-size:.9rem;transition:border-color .2s}.animation-name:focus,.frame-rate:focus{border-color:var(--primary-color);outline:none}.animation-name{width:120px}.frame-rate{width:60px}.frame-count{width:80px}.frame-count-setting{background-color:#fff3cd;border:1px solid #ffeaa7;border-radius:6px;padding:8px;margin-top:8px}.frame-count-setting label{color:#856404;font-weight:600}.setting-item .frame-count{width:80px}.frame-info{margin-top:4px}.frame-info small{color:#6c757d;font-size:.8rem;line-height:1.3}.remove-group-button{background:none;border:none;color:var(--danger-color);font-size:1.5rem;cursor:pointer;width:30px;height:30px;display:flex;align-items:center;justify-content:center;transition:background-color .2s;border-radius:50%}.remove-group-button:hover{background-color:rgba(220,53,69,.1)}.upload-section{display:flex;gap:1rem}.upload-area{flex:1 1;border:2px dashed var(--border-color);border-radius:12px;padding:2rem;text-align:center;transition:border-color .3s,background-color .3s;background-color:var(--lighter-gray);display:flex;align-items:center;justify-content:center;min-height:200px}.upload-area.highlight{border-color:var(--primary-color);background-color:rgba(74,139,250,.05)}.upload-content{display:flex;flex-direction:column;align-items:center}.upload-icon{width:48px;height:48px;margin-bottom:1rem;opacity:.7;color:var(--primary-color)}.upload-button{display:inline-block;background-color:var(--primary-color);color:#fff;padding:.5rem 1rem;border-radius:6px;margin-top:.5rem;cursor:pointer;transition:background-color .2s}.upload-button:hover{background-color:var(--primary-hover)}.selected-files{flex:1 1;max-width:400px}.file-list{list-style:none;max-height:200px;overflow-y:auto;border:1px solid var(--border-color);border-radius:6px;margin:.5rem 0;padding:.5rem;background-color:#fff}.file-item{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-bottom:1px solid var(--border-color)}.file-item:last-child{border-bottom:none}.file-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1 1;padding-right:.5rem;font-size:.9rem}.remove-file-button{background:none;border:none;color:var(--danger-color);cursor:pointer;font-size:1.2rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;transition:background-color .2s;border-radius:50%}.remove-file-button:hover{background-color:rgba(220,53,69,.1)}.file-actions{display:flex;justify-content:flex-end;margin-top:.5rem}.global-actions{display:flex;justify-content:space-between;margin-top:2rem}.actions-right,.generate-group{display:flex;align-items:center}.generate-group{gap:1rem}.filename-setting{margin-right:1rem}.output-file-name{padding:.5rem;border:1px solid var(--border-color);border-radius:6px;width:150px;transition:border-color .2s}.output-file-name:focus{border-color:var(--primary-color);outline:none}.add-group-button,.primary-button,.secondary-button{padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-weight:500;transition:background-color .2s;border:none}.primary-button{background-color:var(--primary-color);color:#fff}.primary-button:hover:not(:disabled){background-color:var(--primary-hover)}.secondary-button{background-color:var(--secondary-color);color:#fff}.secondary-button:hover:not(:disabled){background-color:var(--secondary-hover)}.add-group-button{background-color:var(--success-color);color:#fff}.add-group-button:hover:not(:disabled){background-color:var(--success-hover)}.add-group-button:disabled,.primary-button:disabled,.secondary-button:disabled{opacity:.5;cursor:not-allowed}.result-section{margin-top:2rem;background-color:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 2px 8px rgba(0,0,0,.05)}.result-section h2{color:var(--primary-color);font-size:1.4rem;margin-bottom:.5rem}.result-divider{height:1px;background-color:var(--border-color);width:100%;margin-top:.5rem;margin-bottom:1.5rem}.result-content{display:flex;gap:2rem}.preview,.result-files{flex:1 1;width:calc(50% - 1rem);margin-bottom:1.5rem}.preview h3,.result-files h3{margin-bottom:.5rem;font-size:1.1rem}#resultFileList{list-style:none;margin-bottom:1rem;max-height:200px;overflow-y:auto}.result-file{display:flex;justify-content:space-between;align-items:center;padding:.5rem;border-bottom:1px solid var(--border-color)}.download-button{background-color:var(--success-color);color:#fff;border:none;padding:.3rem .5rem;border-radius:4px;cursor:pointer;font-size:.8rem}.preview-container{max-width:100%;height:100%;overflow:hidden;border:1px solid var(--border-color);border-radius:6px;display:flex;align-items:center;justify-content:center;min-height:300px}#previewImage{max-width:100%;max-height:100%;object-fit:contain;display:block}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.7);display:flex;flex-direction:column;justify-content:center;align-items:center;z-index:1000;color:#fff}.spinner{width:50px;height:50px;border-radius:50%;border:5px solid hsla(0,0%,100%,.3);border-top-color:#fff;animation:spin 1s ease-in-out infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(1turn)}}.notification{position:fixed;top:20px;right:20px;padding:10px 20px;border-radius:6px;z-index:1001;animation:fadeIn .3s,fadeOut .3s 2.7s;max-width:300px}.notification.success{background-color:var(--success-color);color:#fff}.notification.error{background-color:var(--danger-color);color:#fff}.notification.warning{background-color:#ff9800;color:#fff}.notification.info{background-color:var(--primary-color);color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeOut{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(-20px)}}.usage-stats{justify-content:center;gap:15px;font-size:.85rem;background-color:#f0f8ff;padding:4px 10px;border-radius:20px;color:var(--primary-color);margin:0 auto}.stat-item,.usage-stats{display:flex;align-items:center}.stat-label{margin-right:.3rem;color:var(--light-text)}.stat-value{font-weight:700;color:var(--primary-color)}.usage-stats.error{color:var(--danger-color);background-color:#fff0f0}footer{margin-top:3rem;padding-top:1rem;border-top:1px solid var(--border-color);color:var(--light-text);font-size:.9rem;text-align:center}.footer-content,footer{display:flex;flex-direction:column;align-items:center}.footer-content{justify-content:center;width:100%;gap:1rem}.footer-stats{margin-bottom:0}.footer-copyright{margin-top:0}.footer-link{color:var(--primary-color);text-decoration:none}.footer-link:hover{text-decoration:underline}.social-icon{display:inline-block;width:24px;height:24px}.bilibili-footer-icon{background-image:url('data:image/svg+xml;charset=utf-8,<svg t="1641365547353" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="2421" width="24" height="24"><path d="M777.514667 131.669333a53.333333 53.333333 0 0 1 0 75.434667L728.746667 255.829333h49.92A160 160 0 0 1 938.666667 415.872v320a160 160 0 0 1-160 160H245.333333A160 160 0 0 1 85.333333 735.872v-320a160 160 0 0 1 160-160h49.749334L246.4 207.146667a53.333333 53.333333 0 1 1 75.392-75.434667l113.152 113.152c3.370667 3.370667 6.186667 7.04 8.448 10.965333h137.088c2.261333-3.925333 5.12-7.68 8.490667-11.008l113.109333-113.152a53.333333 53.333333 0 0 1 75.434667 0z m1.152 231.253334H245.333333a53.333333 53.333333 0 0 0-53.205333 49.365333L192 415.872v320a53.333333 53.333333 0 0 0 49.365333 53.205333L245.333333 789.333333h533.333334a53.333333 53.333333 0 0 0 53.205333-49.365333L832 735.872v-320a53.333333 53.333333 0 0 0-53.333333-53.333333z m-426.666667 106.666666c29.44 0 53.333333 23.893333 53.333333 53.333334v53.333333a53.333333 53.333333 0 1 1-106.666666 0v-53.333333c0-29.44 23.893333-53.333333 53.333333-53.333334z m320 0c29.44 0 53.333333 23.893333 53.333333 53.333334v53.333333a53.333333 53.333333 0 1 1-106.666666 0v-53.333333c0-29.44 23.893333-53.333333 53.333333-53.333334z" p-id="2422" fill="%2300a1d6"></path></svg>');background-size:cover}@media (max-width:768px){.upload-section{flex-direction:column}.selected-files{max-width:100%}.actions-right,.generate-group,.global-actions{flex-direction:column;align-items:stretch}.actions-right{margin-top:1rem}.filename-setting{margin-right:0;margin-bottom:.5rem}.group-header{flex-direction:column;align-items:flex-start}.group-settings{margin-top:1rem;flex-wrap:wrap;width:100%}.footer-content{flex-direction:column;gap:.5rem}.branding{flex-direction:column;text-align:center}.brand-text{text-align:center;min-width:auto;width:100%}.logo-container{width:120px;margin-bottom:15px}.brand-logo{margin-right:0;width:100px;height:100px}.title-container{flex-direction:column;align-items:flex-start;gap:.5rem}h1{font-size:2.2rem}.version-badge{font-size:1.1rem;padding:.2rem .6rem}.result-content{flex-direction:column}.preview,.result-files{width:100%}.group-header-title{flex-direction:column;align-items:flex-start}}.file-item.empty{color:var(--light-text);font-style:italic;justify-content:center;padding:1rem}.tab-container{width:100%}.tab-header{display:flex;border-bottom:2px solid var(--border-color);margin-bottom:1rem}.tab-button{background:none;padding:.75rem 1.5rem;cursor:pointer;font-size:1rem;color:var(--light-text);border:none;border-bottom:2px solid transparent;transition:all .2s;position:relative}.tab-button:hover{color:var(--primary-color);background-color:rgba(74,144,226,.05)}.tab-button.active{color:var(--primary-color);border-bottom-color:var(--primary-color);font-weight:600}.tab-content{min-height:400px}.png-preview-tab,.spine-preview,.spine-preview-tab{width:100%}.spine-controls{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:1rem;background-color:#f8f9fa;border-radius:6px;border:1px solid var(--border-color)}.animation-selector{display:flex;align-items:center;gap:.5rem}.animation-selector label{font-weight:500;color:var(--text-color);white-space:nowrap}.animation-selector select{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;background-color:#fff;color:var(--text-color);min-width:120px;transition:border-color .2s}.animation-selector select:focus{border-color:var(--primary-color);outline:none}.animation-selector select:disabled{background-color:#f5f5f5;color:var(--light-text);cursor:not-allowed}.play-pause-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;background-color:var(--primary-color);color:#fff;cursor:pointer;transition:all .2s}.play-pause-button:hover:not(:disabled){background-color:var(--primary-hover);transform:scale(1.05)}.play-pause-button:disabled{background-color:var(--light-text);cursor:not-allowed;transform:none}.background-color-selector{display:flex;align-items:center;gap:.5rem}.background-color-selector label{font-weight:500;color:var(--text-color);white-space:nowrap}.color-picker-container{display:flex;align-items:center;gap:.5rem}.color-picker{width:40px;height:40px;border:2px solid var(--border-color);border-radius:50%;cursor:pointer;background:none;padding:0;transition:all .2s}.color-picker:hover{border-color:var(--primary-color);transform:scale(1.05)}.color-picker::-webkit-color-swatch-wrapper{padding:0;border-radius:50%;overflow:hidden}.color-picker::-webkit-color-swatch{border:none;border-radius:50%}.color-picker::-moz-color-swatch{border:none;border-radius:50%}.color-preview{width:20px;height:20px;border-radius:50%;border:2px solid var(--border-color);cursor:pointer;transition:transform .2s}.color-preview:hover{transform:scale(1.1)}.spine-container{position:relative;width:100%;min-height:400px;border:1px solid var(--border-color);border-radius:6px;overflow:hidden;background-color:#f8f9fa}.spine-player-container{width:100%;height:400px;background-color:#fff}.spine-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;justify-content:center;align-items:center;background-color:rgba(248,249,250,.9);z-index:10}.spine-loading .spinner{width:40px;height:40px;border-radius:50%;border:4px solid rgba(74,144,226,.3);border-top:4px solid var(--primary-color);animation:spin 1s ease-in-out infinite;margin-bottom:1rem}.spine-loading p{color:var(--text-color);font-size:.9rem}.event-notification{position:absolute;top:1rem;right:1rem;z-index:20;animation:eventFadeIn .2s ease-out,eventFadeOut .2s ease-in .6s;animation-fill-mode:both}.event-notification-content{display:flex;align-items:center;gap:.5rem;background:linear-gradient(135deg,#ff6b6b,#ee5a24);color:#fff;padding:.75rem 1rem;border-radius:8px;box-shadow:0 4px 12px rgba(0,0,0,.15);font-weight:600;font-size:.9rem;border:2px solid hsla(0,0%,100%,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.event-icon{font-size:1.1rem;animation:eventPulse .6s ease-in-out}.event-name{white-space:nowrap;text-shadow:0 1px 2px rgba(0,0,0,.2)}@keyframes eventFadeIn{0%{opacity:0;transform:translateX(100%) scale(.8)}to{opacity:1;transform:translateX(0) scale(1)}}@keyframes eventFadeOut{0%{opacity:1;transform:translateX(0) scale(1)}to{opacity:0;transform:translateX(100%) scale(.8)}}@keyframes eventPulse{0%,to{transform:scale(1)}50%{transform:scale(1.2)}}@media (max-width:768px){.tab-button{padding:.5rem 1rem;font-size:.9rem}.spine-controls{flex-direction:column;align-items:stretch;gap:.75rem}.animation-selector{justify-content:space-between}.animation-selector select{min-width:150px}.play-pause-button{align-self:center}.background-color-selector{justify-content:space-between}.color-picker-container{gap:.75rem}.spine-container{min-height:300px}.spine-player-container{height:300px}.event-notification{top:.5rem;right:.5rem}.event-notification-content{padding:.5rem .75rem;font-size:.8rem}.event-icon{font-size:1rem}}.event-config-section{margin-top:1rem;border-top:1px solid var(--border-color);padding-top:1rem}.accordion{border:1px solid var(--border-color);border-radius:8px;overflow:hidden;background:var(--card-bg)}.accordion-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--light-bg);cursor:pointer;transition:background-color .2s;-webkit-user-select:none;-moz-user-select:none;user-select:none}.accordion-header:hover{background:rgba(74,144,226,.05)}.accordion-header span{font-weight:500;color:var(--text-color)}.accordion-icon{transition:transform .2s;color:var(--light-text)}.accordion-icon.expanded{transform:rotate(180deg)}.accordion-content{padding:1rem;border-top:1px solid var(--border-color);background:var(--card-bg)}.event-config{width:100%}.event-config-layout{display:flex;gap:1.5rem;align-items:flex-start}.event-controls{flex:1 1;display:flex;flex-direction:column;gap:.75rem}.event-control-row{display:flex;flex-direction:column;gap:.25rem}.event-control-row label{font-weight:500;color:var(--text-color);font-size:.9rem}.event-name-input{padding:.5rem;border:1px solid var(--border-color);border-radius:4px;font-size:.9rem;background:#fff;color:var(--text-color);transition:border-color .2s;width:100%}.event-name-input:focus{outline:none;border-color:var(--primary-color)}.event-frame-slider{width:100%;height:8px;border-radius:4px;background:#e0e0e0;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.event-frame-slider::-webkit-slider-track{width:100%;height:8px;border-radius:4px;background:#e0e0e0}.event-frame-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;-webkit-transition:all .2s;transition:all .2s;box-shadow:0 2px 4px rgba(0,0,0,.2)}.event-frame-slider::-webkit-slider-thumb:hover{background:var(--primary-hover);transform:scale(1.1)}.event-frame-slider::-moz-range-track{width:100%;height:8px;border-radius:4px;background:#e0e0e0;border:none}.event-frame-slider::-moz-range-thumb{width:20px;height:20px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none;-moz-transition:all .2s;transition:all .2s;box-shadow:0 2px 4px rgba(0,0,0,.2)}.event-frame-slider::-moz-range-thumb:hover{background:var(--primary-hover);transform:scale(1.1)}.event-preview{flex:1 1;max-width:280px}.frame-preview{background:#fff;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.preview-header{background:var(--light-bg);padding:.5rem .75rem;font-size:.8rem;font-weight:500;color:var(--text-color);text-align:center;border-bottom:1px solid var(--border-color)}.preview-image-container{padding:.75rem;display:flex;justify-content:center;align-items:center;min-height:120px;background:#fafafa}.preview-image{max-width:100%;max-height:150px;object-fit:contain;border-radius:4px;box-shadow:0 2px 4px rgba(0,0,0,.1)}.preview-placeholder{display:flex;align-items:center;justify-content:center;color:var(--light-text);font-size:.85rem;height:100px}@media (max-width:768px){.event-config-section{margin-top:.75rem;padding-top:.75rem}.accordion-header{padding:.5rem .75rem}.accordion-content{padding:.75rem}.event-config-layout{flex-direction:column;gap:1rem}.event-preview{max-width:none}.event-control-row label{font-size:.85rem}.event-name-input{padding:.4rem;font-size:.85rem}.preview-image-container{min-height:100px}.preview-image{max-height:120px}}.fullscreen-button{position:absolute;bottom:12px;right:12px;width:44px;height:44px;border:none;border-radius:50%;background:rgba(74,139,250,.9);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,.2);z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.fullscreen-button:hover{background:#4a8bfa;transform:scale(1.1);box-shadow:0 4px 16px rgba(74,139,250,.4)}.fullscreen-button:active{transform:scale(.95)}.spine-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.85);display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:modalOverlayFadeIn .3s ease-out}@keyframes modalOverlayFadeIn{0%{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}to{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}}.spine-modal-content{background:#fff;border-radius:12px;width:95vw;height:90vh;max-width:1400px;max-height:1000px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.3);animation:modalContentSlideIn .3s ease-out}@keyframes modalContentSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.spine-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:linear-gradient(135deg,#f8f9fa,#e9ecef)}.spine-modal-header h3{margin:0;color:var(--text-color);font-size:1.25rem;font-weight:600}.spine-modal-close{background:none;border:none;cursor:pointer;padding:8px;border-radius:6px;color:var(--light-text);transition:all .2s ease;display:flex;align-items:center;justify-content:center}.spine-modal-close:hover{background:rgba(220,53,69,.1);color:#dc3545;transform:scale(1.1)}.spine-modal-controls{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);background:#fff;justify-content:space-between}.spine-modal-controls,.spine-modal-controls .left-controls,.spine-modal-controls .right-controls{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap}.spine-modal-controls .background-image-selector{margin-left:auto}.spine-modal-controls .background-color-selector{margin-left:0}.spine-modal-player-container{flex:1 1;position:relative;background:#f5f5f5;display:flex;align-items:center;justify-content:center;overflow:hidden;-webkit-user-select:none;-moz-user-select:none;user-select:none}.spine-modal-player-container:active{cursor:-webkit-grabbing!important;cursor:grabbing!important}.spine-player-container-modal{width:100%;height:100%;border-radius:0}.spine-modal-player-container .spine-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:hsla(0,0%,100%,.95);border-radius:12px;padding:2rem;box-shadow:0 8px 32px rgba(0,0,0,.1)}.spine-modal-player-container .spine-loading .spinner{width:48px;height:48px;border-width:4px}.spine-modal-player-container .spine-loading p{font-size:1.1rem;margin-top:1rem}.spine-modal-player-container .event-notification{position:absolute;top:20px;right:20px;z-index:20;font-size:1.1rem;padding:.75rem 1.25rem;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.2)}.background-image-selector{display:flex;align-items:center;gap:.5rem}.background-image-selector label{font-weight:500;color:var(--text-color);white-space:nowrap}.background-image-controls{display:flex;align-items:center;gap:.5rem}.upload-background-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:2px solid var(--primary-color);border-radius:6px;background:var(--primary-color);color:#fff;cursor:pointer;transition:all .2s;text-decoration:none}.upload-background-button:hover{background:var(--primary-hover);border-color:var(--primary-hover);transform:scale(1.05)}.clear-background-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:2px solid #dc3545;border-radius:6px;background:#dc3545;color:#fff;cursor:pointer;transition:all .2s}.clear-background-button:hover{background:#c82333;border-color:#c82333;transform:scale(1.05)}.background-preview{width:40px;height:32px;border:2px solid var(--border-color);border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;background:#f8f9fa}.background-thumbnail{width:100%;height:100%;object-fit:cover;object-position:center}.background-placeholder{font-size:.7rem;color:var(--light-text);text-align:center}@media (max-width:768px){.spine-modal-content{width:98vw;height:95vh;margin:0}.spine-modal-header{padding:.75rem 1rem}.spine-modal-header h3{font-size:1.1rem}.spine-modal-controls{padding:.75rem 1rem;gap:1rem;flex-direction:column;align-items:stretch;justify-content:flex-start}.spine-modal-controls .left-controls,.spine-modal-controls .right-controls{width:100%;justify-content:center}.spine-modal-controls .left-controls{order:1;margin-bottom:.5rem}.spine-modal-controls .right-controls{order:2;border-top:1px solid var(--border-color);padding-top:.75rem}.spine-modal-controls .animation-selector,.spine-modal-controls .background-color-selector,.spine-modal-controls .background-image-selector,.spine-modal-controls .scale-inputs{width:100%}.spine-modal-controls .play-pause-button,.spine-modal-controls .reset-position-button{align-self:center;width:48px;height:48px}.spine-modal-controls .scale-inputs{justify-content:space-between;flex-direction:row}.spine-modal-controls .background-image-selector{justify-content:space-between}.spine-modal-controls .scale-input{width:50px!important;color:#000!important;background:hsla(0,0%,100%,.9)!important;border:1px solid rgba(0,0,0,.3)!important}.fullscreen-button{width:40px;height:40px;bottom:10px;right:10px}.drag-hint{bottom:15px;font-size:.8rem;padding:.4rem .8rem}}@media (max-width:480px){.spine-modal-content{width:100vw;height:100vh;border-radius:0}.spine-modal-controls,.spine-modal-header{padding:.5rem .75rem}.spine-modal-controls .scale-input{width:45px!important;color:#000!important;background:hsla(0,0%,100%,.9)!important;border:1px solid rgba(0,0,0,.3)!important}.spine-modal-controls .reset-position-button{width:40px;height:40px}.fullscreen-button{width:36px;height:36px;bottom:8px;right:8px}.drag-hint{bottom:10px;font-size:.75rem;padding:.3rem .6rem}}.spine-modal-overlay.closing{animation:modalOverlayFadeOut .2s ease-in}.spine-modal-content.closing{animation:modalContentSlideOut .2s ease-in}@keyframes modalOverlayFadeOut{0%{opacity:1;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}to{opacity:0;-webkit-backdrop-filter:blur(0);backdrop-filter:blur(0)}}@keyframes modalContentSlideOut{0%{opacity:1;transform:scale(1) translateY(0)}to{opacity:0;transform:scale(.9) translateY(20px)}}.fullscreen-button svg{pointer-events:none;flex-shrink:0}.spine-modal-controls .animation-selector select{min-width:200px}.spine-modal-controls .background-color-selector{margin-left:auto}.scale-inputs{display:flex;align-items:center;gap:1rem}.scale-input-group{display:flex;align-items:center;gap:.3rem}.scale-input-group label{font-weight:600;font-size:.9rem;min-width:15px}.scale-input{width:60px;padding:4px 6px;border-radius:4px;font-size:.85rem;text-align:center;transition:all .2s ease}.spine-modal-controls .scale-input-group label{color:#000!important}.spine-modal-controls .scale-input{border:1px solid rgba(0,0,0,.3)!important;background:hsla(0,0%,100%,.9)!important;color:#000!important;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.spine-modal-controls .scale-input:focus{outline:none!important;border-color:#4a8bfa!important;background:#fff!important;color:#000!important;box-shadow:0 0 0 2px rgba(74,139,250,.3)!important}.spine-modal-controls .scale-input:hover{background:#fff!important;color:#000!important;border-color:rgba(0,0,0,.5)!important}.spine-modal-controls .scale-input::placeholder{color:rgba(0,0,0,.5)!important}.spine-controls .scale-input-group label{color:var(--text-color)}.spine-controls .scale-input{border:1px solid var(--border-color);background:#fff;color:var(--text-color)}.spine-controls .scale-input:focus{outline:none;border-color:var(--primary-color);background:#fff;box-shadow:0 0 0 2px rgba(74,139,250,.2)}.spine-controls .scale-input:hover{border-color:var(--primary-hover)}.spine-controls .scale-input::placeholder{color:var(--light-text)}.reset-position-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:50%;background-color:#28a745;color:#fff;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px rgba(40,167,69,.3)}.reset-position-button:hover{background-color:#218838;transform:scale(1.05);box-shadow:0 3px 6px rgba(40,167,69,.4)}.reset-position-button:active{transform:scale(.95)}.drag-hint{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.8);color:#fff;padding:.5rem 1rem;border-radius:20px;font-size:.85rem;pointer-events:none;z-index:15;animation:dragHintFadeIn .5s ease-out,dragHintFadeOut .5s ease-in 3s;animation-fill-mode:both;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.drag-hint p{margin:0;text-align:center;font-weight:500}@keyframes dragHintFadeIn{0%{opacity:0;transform:translateX(-50%) translateY(10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}@keyframes dragHintFadeOut{0%{opacity:1;transform:translateX(-50%) translateY(0)}to{opacity:0;transform:translateX(-50%) translateY(10px)}}.spine-modal-player-container canvas{background-color:transparent!important;background:none!important}.spine-modal-player-container[style*=background-image] canvas{background-color:transparent!important;background:transparent!important}.update-notification-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.6);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:updateOverlayFadeIn .3s ease-out;padding:20px}@keyframes updateOverlayFadeIn{0%{opacity:0}to{opacity:1}}.update-notification-modal{background:#fff;border-radius:16px;box-shadow:0 20px 40px rgba(0,0,0,.3);max-width:600px;width:100%;max-height:80vh;overflow:hidden;animation:updateModalSlideIn .4s ease-out;display:flex;flex-direction:column}@keyframes updateModalSlideIn{0%{opacity:0;transform:translateY(-30px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}.update-notification-header{display:flex;justify-content:space-between;align-items:center;padding:24px 24px 16px;border-bottom:1px solid #e9ecef;background:linear-gradient(135deg,#4a8bfa,#c471ed);color:#fff}.update-notification-header h2{margin:0;font-size:1.5rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.1)}.update-notification-close{background:transparent;border:none;color:#fff;cursor:pointer;padding:8px;border-radius:8px;display:flex;align-items:center;justify-content:center;transition:background-color .2s ease}.update-notification-close:hover{background-color:hsla(0,0%,100%,.2)}.update-notification-content{flex:1 1;padding:24px;overflow-y:auto;max-height:50vh}.update-content-markdown{color:#333;line-height:1.6}.update-content-markdown h1{color:#333;font-size:1.8rem;margin-bottom:1rem;font-weight:700;background:none;-webkit-text-fill-color:unset}.update-content-markdown h2{color:#4a8bfa;font-size:1.4rem;margin:1.5rem 0 1rem;font-weight:600}.update-content-markdown h3{color:#666;font-size:1.2rem;margin:1.2rem 0 .8rem;font-weight:600}.update-content-markdown ul{margin:1rem 0;padding-left:2rem}.update-content-markdown li{margin:.5rem 0;color:#555}.update-content-markdown a{color:#4a8bfa;text-decoration:none;font-weight:500}.update-content-markdown a:hover{text-decoration:underline}.update-content-markdown br{line-height:1.8}.update-content-markdown .markdown-image{display:inline-block;max-width:48px;max-height:48px;vertical-align:middle;margin:0 4px;object-fit:contain;transition:transform .2s ease}.update-content-markdown .markdown-image:hover{transform:scale(1.2)}.update-content-markdown img[alt*=\5145\7535]{animation:chargeGlow 2s infinite alternate;filter:drop-shadow(0 2px 4px rgba(255,193,7,.3));cursor:pointer}.update-content-markdown a img[alt*=\5145\7535]{transition:all .3s ease}.update-content-markdown a:hover img[alt*=\5145\7535]{transform:scale(1.3);filter:drop-shadow(0 4px 12px rgba(255,193,7,.8))}@keyframes chargeGlow{0%{filter:drop-shadow(0 2px 4px rgba(255,193,7,.3))}to{filter:drop-shadow(0 2px 8px rgba(255,193,7,.6))}}.update-notification-footer{padding:16px 24px 24px;border-top:1px solid #e9ecef;display:flex;justify-content:flex-end;background-color:#f8f9fa}.update-notification-confirm{background:linear-gradient(135deg,#4a8bfa,#3b7de6);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 12px rgba(74,139,250,.3)}.update-notification-confirm:hover{background:linear-gradient(135deg,#3b7de6,#2968d9);box-shadow:0 6px 16px rgba(74,139,250,.4);transform:translateY(-1px)}.update-notification-confirm:active{transform:translateY(0);box-shadow:0 2px 8px rgba(74,139,250,.3)}@media (max-width:768px){.update-notification-overlay{padding:16px}.update-notification-modal{max-width:100%;max-height:90vh}.update-notification-header{padding:20px 20px 12px}.update-notification-header h2{font-size:1.3rem}.update-notification-content{padding:20px;max-height:60vh}.update-content-markdown h1{font-size:1.5rem}.update-content-markdown h2{font-size:1.3rem}.update-content-markdown h3{font-size:1.1rem}.update-notification-footer{padding:12px 20px 20px}.update-notification-overlay.update-mobile{padding:12px}.update-notification-modal.update-mobile{border-radius:12px}}@media (max-width:480px){.update-notification-overlay{padding:12px}.update-notification-modal{border-radius:12px}.update-notification-header{padding:16px 16px 8px}.update-notification-header h2{font-size:1.2rem}.update-notification-content{padding:16px}.update-notification-footer{padding:8px 16px 16px}.update-notification-confirm{padding:10px 20px;font-size:.9rem}}