@import"https://fonts.googleapis.com/css2?family=Outfit:wght@300;400;500;600;700&display=swap";:root{font-family:Outfit,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;--color-main-background: #e9ecef;--color-sub-background: #ffffff;--color-accent: #1db954;--color-accent-hover: #19a64c;--color-text-primary: #121417;--color-text-secondary: #5a6470;--color-border: #d7dde4;--color-success: #4CAF50;--color-error: #F44336;--color-warning: #FFC107;--color-canvas-background: #f6f8fa;--color-playhead: var(--color-accent);--color-checkerboard-light: #f0f3f6;--color-checkerboard-dark: #e8edf2;color:var(--color-text-primary);background-color:var(--color-main-background);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:var(--color-accent);text-decoration:inherit}a:hover{color:var(--color-accent-hover)}html,body,#root{height:100%;margin:0;padding:0;overflow:hidden}body{min-width:320px;background:radial-gradient(circle at 12% 10%,#fff,#fff0 35%),radial-gradient(circle at 88% 85%,#d8e0ea,#d8e0ea00 40%),var(--color-main-background);color:var(--color-text-primary);font-size:16px}h1,h2,h3,h4,h5,h6{margin:0;padding:0;font-weight:600}h1{font-size:2rem;font-weight:700}h2{font-size:1.5rem;font-weight:600}h3{font-size:1.25rem;font-weight:500}p,span,div{font-size:1rem}small{font-size:.875rem}button{border-radius:10px;border:1px solid var(--color-border);padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background:linear-gradient(180deg,#fff,#f5f7fa);color:var(--color-text-primary);cursor:pointer;transition:all .25s}button:hover{border-color:var(--color-accent);transform:translateY(-1px)}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}.app{height:100vh;display:flex;flex-direction:column;background-color:var(--color-main-background);overflow:hidden}.app-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;background-color:var(--color-sub-background);border-bottom:1px solid var(--color-border);flex-shrink:0;height:60px}.header-section{display:flex;align-items:center;gap:1rem}.app-title{font-size:1.25rem;font-weight:600}.header-actions button,.primary-action{background-color:var(--color-accent);color:var(--color-text-primary);border:none}.header-actions button:hover,.primary-action:hover{background-color:var(--color-accent-hover);border-color:var(--color-accent-hover)}.header-toggle-btn{background:transparent;border:none;color:var(--color-text-secondary);font-size:1.5rem;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:color .2s,background-color .2s}.header-toggle-btn:hover{color:var(--color-text-primary);background-color:var(--color-main-background)}.app-body{display:flex;flex:1;overflow:hidden}.left-panel,.right-panel{width:300px;background-color:var(--color-sub-background);overflow-y:auto;transition:width .3s ease,padding .3s ease;flex-shrink:0;padding:1.5rem;display:flex;flex-direction:column;gap:1.5rem}.left-panel{border-right:1px solid var(--color-border)}.right-panel{border-left:1px solid var(--color-border)}.left-panel.closed,.right-panel.closed{width:0;padding:0;overflow:hidden}.panel-toggle{color:var(--color-text-secondary);cursor:pointer;font-size:1.5rem;transition:color .2s}.panel-toggle:hover{color:var(--color-text-primary)}.center-panel{flex:1;display:flex;flex-direction:column;background-color:var(--color-main-background);min-width:0}.image-library h2{margin-bottom:1rem}.library-section{padding:.8rem;border:1px solid var(--color-border);border-radius:12px;background:#111e288c;margin-bottom:1rem}.library-section h3{margin-bottom:.75rem;font-size:.95rem;letter-spacing:.02em;text-transform:uppercase;color:var(--color-text-secondary)}.text-section{border-color:color-mix(in srgb,var(--color-accent) 45%,var(--color-border))}.upload-area{border:2px dashed var(--color-border);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;margin-bottom:1rem;transition:border-color .3s,background-color .3s}.upload-area:hover{border-color:var(--color-accent);background-color:var(--color-main-background)}.upload-area svg{font-size:2.5rem;color:var(--color-text-secondary);margin-bottom:.5rem}.images-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:1rem}.image-item{position:relative;aspect-ratio:1;border-radius:4px;overflow:hidden;cursor:pointer;border:2px solid transparent;transition:border-color .2s}.image-item:hover{border-color:var(--color-accent)}.image-item img{width:100%;height:100%;object-fit:cover}.image-canvas-container{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem;overflow:hidden;position:relative;min-height:0}.image-canvas{position:relative;border-radius:8px;overflow:hidden;background-color:var(--color-checkerboard-dark);background-image:linear-gradient(45deg,var(--color-checkerboard-light) 25%,transparent 25%),linear-gradient(-45deg,var(--color-checkerboard-light) 25%,transparent 25%),linear-gradient(45deg,transparent 75%,var(--color-checkerboard-light) 75%),linear-gradient(-45deg,transparent 75%,var(--color-checkerboard-light) 75%);background-size:24px 24px;background-position:0 0,0 12px,12px -12px,-12px 0px;box-shadow:0 0 0 1px var(--color-border);max-width:100%;max-height:100%}.slide-item .selected{border:2px solid var(--color-accent);box-shadow:0 0 12px var(--color-accent)}.control-panel h2{margin-bottom:1rem}.property-group{margin-bottom:1.5rem}.property-group h3{margin-bottom:1rem;border-bottom:1px solid var(--color-border);padding-bottom:.75rem}.property-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem}.input-group{display:flex;gap:.5rem;align-items:center}.property-group input,.property-group select{width:100%;padding:.75rem;border:1px solid var(--color-border);border-radius:4px;font-size:.9rem;background-color:var(--color-main-background);color:var(--color-text-primary);transition:border-color .2s,box-shadow .2s}.property-group input:focus,.property-group select:focus{outline:none;border-color:var(--color-accent);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-accent) 25%,transparent)}.timeline-container{height:250px;flex-shrink:0;overflow:auto;background-color:var(--color-sub-background);border-top:1px solid var(--color-border);position:relative;width:100%}.time-ruler{position:sticky;top:0;height:24px;background-color:color-mix(in srgb,var(--color-sub-background) 50%,black);border-bottom:1px solid var(--color-border);z-index:20}.timeline{background-color:var(--color-main-background);position:relative;min-width:100%}.playhead{background-color:var(--color-playhead)}.timeline-slide{background-color:var(--color-accent);border-radius:4px;border:1px solid var(--color-accent-hover);color:var(--color-text-primary)}.timeline-slide.selected{border-color:var(--color-accent-hover);box-shadow:0 0 0 2px var(--color-accent);z-index:50!important}.slide-info input{background-color:#0000004d;color:var(--color-text-primary)}.preview-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:2000}.preview-modal{background-color:var(--color-sub-background);border:1px solid var(--color-border);width:80vw;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 30px #0003}.preview-header{display:flex;justify-content:space-between;align-items:center;padding:1rem;border-bottom:1px solid var(--color-border)}.close-btn{color:var(--color-text-secondary)}.preview-canvas{flex:1;min-height:0;display:flex;align-items:center;justify-content:center;padding:1rem;overflow:hidden}.preview-canvas-viewport{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.preview-canvas-inner{position:relative;max-width:100%;max-height:100%;margin:0 auto}.preview-canvas-viewport:fullscreen{width:100vw;height:100vh;background:#0b0f14;padding:0;box-sizing:border-box}.preview-canvas-viewport:fullscreen .preview-canvas-inner{box-shadow:0 0 0 1px #ffffff2e,0 24px 50px #00000059;border-radius:12px;overflow:hidden}.preview-controls{display:flex;align-items:center;gap:1rem;padding:1rem;border-top:1px solid var(--color-border)}.preview-controls button{background-color:var(--color-main-background)}.preview-controls button:hover{border-color:var(--color-accent);background-color:var(--color-sub-background)}.toolbar{justify-content:center}.mobile-warning-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:var(--color-main-background);display:flex;align-items:center;justify-content:center;z-index:9999;padding:2rem;text-align:center}.mobile-warning-content{display:flex;flex-direction:column;align-items:center;gap:1.5rem;color:var(--color-text-primary)}.mobile-warning-content svg{color:var(--color-warning)}.mobile-warning-content h2{font-size:1.5rem}.mobile-warning-content p{font-size:1rem;color:var(--color-text-secondary);max-width:400px;line-height:1.6}.toolbar button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:4px;font-size:.9rem;transition:background-color .2s}.image-overlay{position:absolute;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.image-item:hover .image-overlay{opacity:1}.add-to-timeline-btn{background-color:var(--color-accent);border:none;border-radius:50%;width:30px;height:30px;color:var(--color-text-primary);cursor:pointer;font-size:1rem;display:flex;align-items:center;justify-content:center;padding:0}.slide-item{position:absolute;cursor:move;border:2px solid transparent;border-radius:4px;-webkit-user-select:none;user-select:none;min-width:20px;min-height:20px}.slide-item-transformer{transform-origin:0 0}.slide-controls{position:absolute;inset:-10px;border:1px dashed var(--color-accent);pointer-events:none}.rotate-handle{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);width:16px;height:16px;border-radius:50%;background-color:var(--color-accent);border:2px solid var(--color-sub-background);cursor:alias;pointer-events:all}.slide-item img{border-radius:4px;pointer-events:none}.text-slide-box{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.text-slide-draggable{-webkit-user-select:none;user-select:none}.text-slide-transformer{position:relative}.text-slide-controls{position:absolute;inset:-10px;border:1px dashed var(--color-accent);pointer-events:none}.text-resize-handle{position:absolute;right:-8px;bottom:-8px;width:14px;height:14px;border-radius:3px;background-color:var(--color-accent);cursor:nwse-resize;pointer-events:all}.text-rotate-handle{position:absolute;left:50%;bottom:-20px;transform:translate(-50%);width:16px;height:16px;border-radius:50%;background-color:var(--color-accent);border:2px solid var(--color-sub-background);cursor:alias;pointer-events:all}.text-template-form{display:flex;flex-direction:column;gap:.5rem;margin:1rem 0}.text-template-form input,.text-template-form textarea{width:calc(100% - 5px);box-sizing:border-box;padding:.5rem;border:1px solid var(--color-border);border-radius:4px;background:var(--color-main-background);color:var(--color-text-primary)}.create-template-btn{align-self:flex-end}.text-templates-grid{display:grid;gap:.75rem}.text-template-item{border:1px solid var(--color-border);border-radius:6px;padding:.5rem;background:var(--color-main-background)}.text-template-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.5rem}.text-template-name{font-weight:600}.text-template-preview{margin:0;white-space:pre-wrap;word-break:break-word;color:var(--color-text-secondary);font-size:.85rem}.text-timeline-slide{background-color:#334155;border-color:#475569}.text-thumbnail{display:flex;align-items:center;justify-content:center;font-weight:700}.time-marker{position:absolute;height:100%;border-left:1px solid var(--color-border);padding-left:4px;color:var(--color-text-secondary);font-size:.7rem}.grid-line{position:absolute;background-color:var(--color-border);pointer-events:none;z-index:1}.grid-line.vertical{width:1px;height:100%}.grid-line.horizontal{width:100%;height:1px}.playhead{z-index:1000;pointer-events:none;position:absolute;top:0;bottom:0;width:2px}.timeline-slide{display:flex;align-items:center;padding:.25rem;box-shadow:0 2px 4px #0003;z-index:10}.slide-thumbnail{width:40px;height:100%;margin-right:.5rem;border-radius:2px;overflow:hidden;flex-shrink:0;background-color:var(--color-main-background)}.slide-thumbnail img{width:100%;height:100%;object-fit:cover}.slide-info{flex:1;display:flex;flex-direction:column;justify-content:center;min-width:0;height:100%;padding-right:4px}.slide-name{font-size:.8rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slide-text-input{width:100%;min-width:0;font-size:.8rem;padding:.2rem .35rem;border-radius:6px;border:1px solid rgba(255,255,255,.35);background:#ffffffe6;color:#1b232b}.remove-slide-btn{background:transparent;border:none;color:inherit;padding:.25rem;cursor:pointer;margin-left:.5rem;font-size:.8rem;opacity:.7;transition:opacity .2s}.remove-slide-btn:hover{opacity:1}@media (max-width: 768px){.app-body{flex-direction:column}.left-panel,.right-panel{width:100%;height:auto;max-height:30vh}.center-panel{flex:1}.timeline-container{height:200px}}.preview-header{display:flex;justify-content:space-between;align-items:center}.header-controls{display:flex;gap:8px;align-items:center}.record-btn{background:#dc2626;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;display:flex;align-items:center;gap:4px;font-size:14px;transition:background-color .2s}.record-btn:hover:not(:disabled){background:#b91c1c}.record-btn:disabled{background:#6b7280;cursor:not-allowed}.record-btn.recording{background:#dc2626;animation:pulse 2s infinite}.recording-indicator{color:#fef2f2;font-size:12px;animation:blink 1s infinite}.download-btn{background:#059669;color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer;transition:background-color .2s}.download-btn:hover{background:#047857}.recording-text{color:#dc2626;font-weight:700;margin-left:8px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes blink{0%,50%{opacity:1}51%,to{opacity:0}}.preview-controls button:disabled,.preview-controls input:disabled{opacity:.5;cursor:not-allowed}.app{background:radial-gradient(circle at 15% 15%,#ffffffeb,#fff0 32%),radial-gradient(circle at 78% 82%,#cad6e28c,#cad6e200 34%),#e9ecef}.app-header{margin:.75rem 1rem 0;border-radius:18px;background:#fff9;border:1px solid rgba(255,255,255,.85);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 18px 40px #1018281f}.app-body{padding:1rem;gap:1rem}.left-panel,.right-panel{border-radius:18px;border:1px solid rgba(255,255,255,.85);background:#ffffff94;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 14px 30px #0f172314}.center-panel{border-radius:20px;background:#fff6;border:1px solid rgba(255,255,255,.65);box-shadow:inset 0 1px #ffffffd9}.header-toggle-btn{border-radius:999px}.toolbar button{border-radius:999px;border-color:#dbe2e9;box-shadow:0 6px 14px #12181e14}.toolbar{background:#ffffffad;border:1px solid rgba(220,228,236,.9);border-radius:999px;padding:.35rem .5rem;gap:.4rem}.toolbar .locale-select-wrap{margin:0 .35rem;padding:0 .45rem;border-left:1px solid #dbe2e9;border-right:1px solid #dbe2e9}.toolbar button[title*=Import],.toolbar button[title*=불러오기],.toolbar button[title*=読み込]{margin-left:.2rem}.locale-select-wrap{display:inline-flex;align-items:center;gap:.45rem}.locale-label{display:inline-flex;align-items:center;gap:.35rem;font-size:.82rem;color:var(--color-text-secondary);white-space:nowrap}.locale-select{border:1px solid var(--color-border);border-radius:999px;padding:.35rem .7rem;background:#ffffffeb;color:var(--color-text-primary);font-weight:600}.toolbar button:hover{background:#fff}.primary-action{background:linear-gradient(120deg,#25c75d,#18a64c);color:#f6fff9;border:none;box-shadow:0 8px 18px #1db95452}.library-section{background:#ffffff8f;border:1px solid #dfe6ee;box-shadow:inset 0 1px #ffffffd9}.library-section h3{color:#47505c}.upload-area{border-style:solid;border-width:1px;border-color:#d9e0e7;background:#ffffffb8}.upload-area:hover{background:#fff}.image-item,.text-template-item{border-radius:14px;border:1px solid #e0e6ed;background:#ffffffe6;box-shadow:0 10px 24px #0f172314}.image-name{color:#404854;font-size:.8rem;margin:.35rem 0 0}.add-to-timeline-btn{background:linear-gradient(140deg,#25c75d,#18a64c);color:#f7fff9}.image-canvas-container{padding:1.4rem}.image-canvas{border-radius:18px;box-shadow:0 22px 35px #0f172329,inset 0 1px #ffffffb3}.text-slide-box{box-shadow:0 10px 24px #141c2433}.control-panel p{color:#606a77}.property-group input,.property-group select,.property-group textarea{border-radius:10px;border-color:#d7dee6;background:#ffffffe0}.timeline-container{margin:0 1rem 1rem;width:auto;border-radius:18px;border:1px solid rgba(255,255,255,.85);background:#ffffff94;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 14px 30px #0f17231a}.time-ruler{background:#f8fafcf2}.timeline{background:#f4f7fae6}.timeline-slide{border-radius:12px;border-color:#25c75d66;background:linear-gradient(120deg,#25c75df2,#18a64cf2)}.text-timeline-slide{background:linear-gradient(120deg,#6f7f91,#5d6c7f);border-color:#738397}.preview-modal{border-radius:18px;overflow:hidden;border:1px solid rgba(255,255,255,.75);background:#ffffffb3;backdrop-filter:blur(15px);-webkit-backdrop-filter:blur(15px)}.preview-canvas-inner{border-radius:14px;overflow:hidden;box-shadow:inset 0 0 0 1px #dbe3eb}.record-btn{background:#e24646}.download-btn{background:#1eaa54}.player-main-btn,.preview-play-btn{position:relative}.player-main-btn.active,.preview-play-btn.active{background:linear-gradient(135deg,#28d161,#18a64c);color:#f8fff9;border-color:#1aa54d;box-shadow:0 8px 18px #1db95459}.player-main-btn.active:after,.preview-play-btn.active:after{content:"";position:absolute;inset:-2px;border-radius:inherit;border:1px solid rgba(29,185,84,.45);animation:pulse-ring 1.4s ease-out infinite;pointer-events:none}.mini-visualizer{display:inline-flex;align-items:flex-end;gap:4px;height:24px;padding:0 6px;opacity:.5}.mini-visualizer .bar{width:3px;height:6px;border-radius:999px;background:#7b8793;transform-origin:bottom}.mini-visualizer.active{opacity:1}.mini-visualizer.active .bar{background:linear-gradient(180deg,#2ad868,#189e49);animation:equalize .95s ease-in-out infinite}.mini-visualizer.active .bar:nth-child(2){animation-delay:.12s}.mini-visualizer.active .bar:nth-child(3){animation-delay:.28s}.mini-visualizer.active .bar:nth-child(4){animation-delay:.42s}.mini-visualizer.active .bar:nth-child(5){animation-delay:.56s}.mini-visualizer.preview{margin-right:.35rem}.playhead{width:3px!important;border-radius:999px;background:linear-gradient(180deg,#33d86d,#1ca54f);box-shadow:0 0 0 1px #ffffff80,0 0 18px #1db95473}.playhead:after{content:"";position:absolute;top:-8px;left:50%;width:12px;height:12px;transform:translate(-50%);border-radius:50%;background:#1db954;box-shadow:0 0 0 3px #1db95447;animation:playhead-bob 1s ease-in-out infinite}.time-slider{accent-color:#1db954}@keyframes equalize{0%{transform:scaleY(.35)}20%{transform:scaleY(1)}45%{transform:scaleY(.52)}70%{transform:scaleY(.88)}to{transform:scaleY(.35)}}@keyframes pulse-ring{0%{transform:scale(.92);opacity:.55}70%{transform:scale(1.18);opacity:0}to{transform:scale(1.18);opacity:0}}@keyframes playhead-bob{0%,to{transform:translate(-50%) translateY(0)}50%{transform:translate(-50%) translateY(-1px)}}
