*{margin:0;padding:0;box-sizing:border-box}body{background:#fafafa;min-height:100vh;display:flex;align-items:center;justify-content:center;font-family:Inter,sans-serif}#app{position:relative;width:100%;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px 40px;box-sizing:border-box;gap:3px}#canvas{box-shadow:0 4px 24px #00000014;background:#fff}.upload-btn{position:fixed;top:24px;right:24px;background:none;border:none;font-family:Inter,sans-serif;font-size:14px;color:#999;cursor:pointer;transition:color .2s}.upload-btn:hover{color:#1a1a1a}.upload-btn.video-btn{right:80px}.hint{font-family:Inter,sans-serif;font-style:italic;font-size:14px;color:#999;transition:opacity .5s ease;pointer-events:none;text-align:center}.mode-selector{display:flex;flex-direction:column;align-items:center;gap:16px;font-family:Inter,sans-serif;font-size:14px;transition:opacity .5s ease}.controls-secondary{display:flex;gap:48px}.controls-primary{display:flex;align-items:center;gap:24px}.toggle-more{display:none;color:#999;cursor:pointer;-webkit-user-select:none;user-select:none}.modes,.toggles-secondary{display:flex;gap:24px}.mode,.toggle{color:#999;cursor:pointer;transition:color .2s;-webkit-user-select:none;user-select:none}.mode:hover,.toggle:hover{color:#666}.mode.active{color:#1a1a1a;text-decoration:underline;text-underline-offset:4px}.toggle.active{color:#1a1a1a}.toggle[data-toggle=density].active{text-decoration:underline;text-underline-offset:4px}.density-slider-container{display:flex;align-items:center;gap:8px;margin-left:8px;padding-left:16px;border-left:1px solid #ddd}.density-slider{width:180px;height:4px;-webkit-appearance:none;appearance:none;background:#ddd;border-radius:2px;outline:none;cursor:pointer}.density-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:14px;height:14px;background:#1a1a1a;border-radius:50%;cursor:pointer;transition:transform .15s ease}.density-slider::-webkit-slider-thumb:hover{transform:scale(1.2)}.density-slider::-moz-range-thumb{width:14px;height:14px;background:#1a1a1a;border:none;border-radius:50%;cursor:pointer;transition:transform .15s ease}.density-slider::-moz-range-thumb:hover{transform:scale(1.2)}.density-value{font-family:Inter,sans-serif;font-size:12px;color:#666;min-width:45px;text-align:right}.save-btn{position:fixed;top:24px;right:160px;background:none;border:none;font-family:Inter,sans-serif;font-size:14px;color:#999;cursor:pointer;transition:color .2s}.save-btn:hover{color:#1a1a1a}.export-menu{position:fixed;top:48px;right:160px;background:#fff;border:1px solid #eee;padding:8px 0;font-family:Inter,sans-serif;font-size:14px;box-shadow:0 4px 12px #00000014;opacity:0;pointer-events:none;transition:opacity .2s}.export-menu.visible{opacity:1;pointer-events:auto}.export-option{padding:8px 16px;cursor:pointer;color:#666;transition:background .15s,color .15s}.export-option:hover{background:#f5f5f5;color:#1a1a1a}.carousel{display:flex;flex-direction:column;align-items:center;gap:8px;font-family:Inter,sans-serif;font-size:14px}.carousel-dots{display:flex;gap:8px}.carousel-dot{width:8px;height:8px;border-radius:50%;border:1px solid #999;cursor:pointer;transition:background .2s,border-color .2s}.carousel-dot:hover{border-color:#666}.carousel-dot.active{background:#1a1a1a;border-color:#1a1a1a}.carousel-nav{display:flex;align-items:center;gap:12px}.carousel-arrow{color:#999;cursor:pointer;transition:color .2s;-webkit-user-select:none;user-select:none}.carousel-arrow:hover{color:#1a1a1a}.carousel-counter{color:#666;min-width:32px;text-align:center}.video-controls{display:flex;align-items:center;gap:15px;background:#000000b3;padding:10px 20px;border-radius:25px}.video-play-btn{background:none;border:none;color:#fff;font-size:18px;cursor:pointer;width:36px;height:36px;display:flex;align-items:center;justify-content:center}.video-play-btn:hover{color:#4a9eff}.video-progress{width:200px;height:4px;background:#ffffff4d;border-radius:2px;cursor:pointer}.video-progress-bar{height:100%;background:#4a9eff;border-radius:2px;width:0%;transition:width .1s linear}.video-time{color:#fff;font-size:12px;font-family:monospace;min-width:90px}.video-export-status{color:#4a9eff;font-size:12px;font-family:monospace;min-width:100px}.toast{position:fixed;bottom:160px;left:50%;transform:translate(-50%);background:#000c;color:#fff;padding:12px 24px;border-radius:8px;font-family:Inter,sans-serif;font-size:14px;opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:200}.toast.visible{opacity:1}@media(max-width:768px){#app{padding:70px 12px 40px;justify-content:flex-start}.mode-selector{padding:16px;gap:12px;font-size:13px;width:100%}.controls-secondary{display:none;flex-direction:column;gap:12px;align-items:center;width:100%;padding-top:12px;border-top:1px solid #eee}.controls-secondary.expanded{display:flex}.controls-primary{flex-wrap:wrap;justify-content:center;gap:16px}.toggle-more{display:block;color:#999;padding:6px 12px;border:1px solid #ddd;border-radius:4px}.modes,.toggles-secondary{gap:16px;flex-wrap:wrap;justify-content:center}.mode,.toggle{padding:8px 12px}.upload-btn,.save-btn{top:12px;min-height:44px;min-width:44px;padding:10px 14px;background:#fafafae6;border-radius:4px}.upload-btn{right:12px}.upload-btn.video-btn{right:70px}.save-btn{right:128px}.hint{font-size:13px}.export-menu{top:56px;right:128px}.carousel{padding:8px 0}.video-controls{width:100%;padding:12px 16px}.video-play-btn{width:44px;height:44px;font-size:22px}.video-progress{flex:1;width:auto;height:6px}.video-time{font-size:11px;min-width:80px}.toast{bottom:180px;left:16px;right:16px;transform:none;text-align:center}.density-slider-container{margin-left:0;padding-left:0;border-left:none;margin-top:4px;width:100%;justify-content:center}.density-slider{width:120px;height:4px}.density-slider::-webkit-slider-thumb{width:20px;height:20px}.density-slider::-moz-range-thumb{width:20px;height:20px}.density-value{font-size:14px}}
