:root{--nav-height:40px;--bg:#f5f5f5;--body-bg:white;--body-color:#333;--border:#ddd;--primary:#4a90d9;--primary-hover:#3a7bc8}:root.dark-mode{--bg:#1a1a1a;--body-bg:#2d2d2d;--body-color:#eee;--border:#444;--primary:#5a9fe9;--primary-hover:#4a8fd9}*{margin:0;padding:0;box-sizing:border-box}.navbar{height:var(--nav-height);border-bottom:1px solid #d3d3d3;z-index:100;background:var(--body-bg);color:var(--body-color);position:relative}.navbar-container{display:flex;align-items:center;height:100%;padding:0 1rem;max-width:100%}.navbar-brand{color:var(--body-color);text-decoration:none;font-weight:700;display:flex;align-items:center;gap:.5rem;font-size:1rem;white-space:nowrap}.navbar-toggler{display:none;background:0 0;border:1px solid var(--body-color);padding:.25rem .5rem;cursor:pointer;margin-left:auto;border-radius:.25rem}.navbar-toggler-icon{display:block;width:1.5em;height:1.5em;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(0,0,0,0.7)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e");background-repeat:no-repeat;background-position:center;background-size:100%}.dark-mode .navbar-toggler-icon{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(255,255,255,0.9)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3e%3c/svg%3e")}.navbar-collapse{display:flex;align-items:center;flex:1;margin-left:1rem}.navbar-nav{display:flex;list-style:none;margin:0;padding:0;gap:.5rem;flex-wrap:wrap}.nav-item{margin:0;position:relative}.nav-link{color:var(--body-color);text-decoration:none;padding:.25rem .75rem;display:block;white-space:nowrap;opacity:.8;transition:opacity .2s}.nav-link:hover{opacity:1}.dark-mode .navbar{border-bottom-color:#a9a9a9}@media(max-width:991px){.navbar-toggler{display:block}.navbar-collapse{display:none;position:absolute;top:var(--nav-height);right:0;background:var(--body-bg);border-bottom:1px solid #d3d3d3;margin:0;padding:1rem}.navbar-collapse.show{display:block}.navbar-nav{gap:0}.nav-link{padding:.5rem 1rem}.dark-mode .navbar-collapse{border-bottom-color:#a9a9a9}}body{font-family:system-ui,-apple-system,sans-serif;background:var(--body-bg);color:var(--body-color);min-height:100vh}#app{max-width:1200px;margin:0 auto;padding:1rem}.header{text-align:center;margin:2em 0}.header h1{font-size:1.5rem;margin-bottom:.25rem}.header p{color:#666;font-size:.9rem}.dark-mode .header p{color:#aaa}.upload-zone{border:2px dashed var(--primary);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:background .2s,box-shadow .2s;background:var(--bg)}.upload-zone.dragover,.upload-zone:hover{background:rgba(74,144,217,.05);box-shadow:0 0 0 3px rgba(74,144,217,.15)}.upload-zone input{display:none}.upload-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.upload-text{font-size:1.1rem;margin-bottom:.5rem}.upload-hint{font-size:.85rem;color:#888}kbd{font-family:inherit;font-size:.85em;padding:.1em .4em;border:1px solid #ccc;border-radius:3px;background:#f7f7f7;box-shadow:0 1px 0 #bbb;display:inline-block;line-height:1.2em;height:1.4em}.dark-mode kbd{border-color:#555;background:#3a3a3a;box-shadow:0 1px 0 #222}.upload-loading{display:none;font-size:1.1rem;color:var(--primary);margin-top:.5rem}.upload-zone.loading{pointer-events:none;opacity:.6}.upload-zone.loading .upload-hint,.upload-zone.loading .upload-icon,.upload-zone.loading .upload-text{display:none}.upload-zone.loading .upload-loading{display:block}.editor{display:none;padding-top:1rem;position:relative}.drop-overlay{position:absolute;inset:0;z-index:20;background:rgba(74,144,217,.08);border:2px dashed var(--primary);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;color:var(--primary);font-weight:600;pointer-events:none}.editor.active{display:block}.image-container{background:#000;border-radius:8px;margin-top:1rem;margin-bottom:1rem;position:relative;touch-action:none}.image-container canvas,.image-container img{display:block;max-width:100%;margin:0 auto}.toolbar{display:table;width:100%;table-layout:fixed}.toolbar .toolbar-group{display:table-cell;vertical-align:middle;white-space:nowrap}.toolbar .toolbar-group:nth-child(2){text-align:center}.toolbar .toolbar-group:nth-child(3){text-align:right}@media(max-width:480px){.toolbar{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center}.toolbar .toolbar-group{display:block}}.dimensions{font-size:.85rem;color:#666}body.editor-active #app{display:flex;flex-direction:column;height:calc(100vh - var(--nav-height));padding:.5rem 1rem}body.editor-active .header{display:none}body.editor-active .function-tabs{flex-shrink:0}body.editor-active .editor.active{display:flex;flex-direction:column;flex:1;min-height:0}body.editor-active .editor .toolbar{flex-shrink:0}body.editor-active .editor .actions{flex-shrink:0}@media(min-width:768px){body.editor-active #app{max-width:100%;padding:.5rem 2rem}}.btn:disabled{opacity:.4;cursor:not-allowed}.btn{font-size:1rem;padding:.5em 1em;border:1px solid var(--border);background:var(--body-bg);color:var(--body-color);cursor:pointer;border-radius:4px;transition:background .2s}.btn:hover{background:var(--bg)}.btn:active{transform:scale(.98)}.btn.active{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:#dc3545;color:#fff;border-color:#dc3545}.btn-danger:hover{background:#c82333}.btn-sm{font-size:.8rem}.actions{display:flex;justify-content:space-between;align-items:center}.actions>.dimensions,.actions>div:first-child{flex:1}.actions>.dimensions{text-align:right}.btn{margin-right:.3em}.btn:last-child{margin-right:0}.preview-section{margin-top:1rem;text-align:center;display:none}.preview-section.active{display:block}.preview-section h3{font-size:1rem;margin-bottom:.5rem}.preview-canvas{max-width:100%;max-height:300px;border:1px solid var(--border);border-radius:4px}.content{max-width:600px;margin:2rem auto;padding:1rem;line-height:1.6}.content h4{font-size:1.1rem;margin:1.5rem 0 .75rem;color:var(--body-color);text-align:center}.content p{margin-bottom:1rem;color:var(--body-color)}.content p:first-child{margin-top:0}.content strong{font-weight:600}.content table{width:100%;border-collapse:collapse;font-size:.9rem;margin:.5rem 0 1rem}.content td,.content th{padding:.4rem .6rem;border:1px solid var(--border);text-align:left}.content th{background:var(--bg);font-weight:600;font-size:.85rem}.function-tabs{display:flex;gap:.5rem;margin-bottom:.75rem;flex-wrap:wrap;justify-content:center}.function-tabs a{padding:.4rem .8rem;border-radius:4px;text-decoration:none;color:#666;background:0 0;border:1px solid #ccc;font-size:.9rem;transition:border-color .2s,color .2s}.function-tabs a:hover{border-color:#999;color:#333}.function-tabs a.active{border-color:var(--primary);color:var(--primary);background:rgba(74,144,217,.1);border-width:2px;font-weight:600;pointer-events:none;cursor:default}.function-tabs .nav-crop::before{content:"⛶ "}.function-tabs .nav-rotate::before{content:"↻ "}.function-tabs .nav-straighten::before{content:"⭓ "}.function-tabs .nav-flip::before{content:"◧ "}.function-tabs .nav-resize::before{content:"↔ "}.function-tabs .nav-compress::before{content:"📦 "}.rename-toolbar{position:sticky;top:0;z-index:10;background:#dcdcdc;padding:.5rem .75rem;border-radius:4px;display:flex;flex-direction:column;align-items:center;gap:0}.dark-mode .rename-toolbar{background:#3a3a3a}.rename-pattern{display:flex;align-items:center;gap:0;border:1px solid #ccc;border-radius:4px;overflow:hidden;background:var(--body-bg);margin:.4rem auto 0}.dark-mode .rename-pattern{border-color:#555;background:#2a2a2a}.pat-input{border:none;padding:.3em .5em;font-size:.85rem;background:0 0;color:var(--body-color);width:6em;max-width:10em;text-align:center;outline:0}.pat-prefix,.pat-suffix{min-width:5ch}.pat-suffix{width:3em}.pat-input::placeholder{color:#bbb}.dark-mode .pat-input::placeholder{color:#666}.pat-input:focus{background:rgba(74,144,217,.06)}.pat-prefix{border-right:1px solid #e0e0e0}.dark-mode .pat-prefix{border-color:#444}.c-prefix,.pat-prefix{color:#8b6914}.dark-mode .c-prefix,.dark-mode .pat-prefix{color:#c9a84c}.c-suffix,.pat-suffix{color:#32cd32}.dark-mode .c-suffix,.dark-mode .pat-suffix{color:#32cd32}.pat-num{width:4em}.pat-num.invalid{color:#dc3545}.c-num{color:#7b6aad}.dark-mode .c-num{color:#a899d4}.pat-name{display:inline-flex;align-items:center;gap:.2em;padding:.3em .5em;font-size:.85rem;color:var(--body-color);cursor:pointer;border-left:1px solid #e0e0e0;border-right:1px solid #e0e0e0;white-space:nowrap}.dark-mode .pat-name{border-color:#444}.pat-name.unchecked{color:#bbb;text-decoration:line-through}.pat-name input{margin:0}.pat-ext{font-size:.85rem;color:#999;padding:0 .5em 0 .3em;border-left:1px solid #e0e0e0;white-space:nowrap}.dark-mode .pat-ext{border-color:#444}.rename-options{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.rename-field{display:inline-flex;align-items:center;gap:.25em}.rename-field label{font-size:.8rem;color:#666;white-space:nowrap}.dark-mode .rename-field label{color:#aaa}.rename-field input{width:7em;padding:.2em .4em;font-size:.85rem;border:1px solid #ccc;border-radius:4px;background:var(--body-bg);color:var(--body-color)}.dark-mode .rename-field input{background:#2a2a2a;border-color:#555;color:#eee}.rename-field input.num-input{width:3.5em;text-align:right}.rename-field select{font-size:.85rem;padding:.2em .3em;border:1px solid #ccc;border-radius:4px;background:var(--body-bg);color:var(--body-color)}.dark-mode .rename-field select{background:#2a2a2a;border-color:#555;color:#eee}.rename-check{display:inline-flex;align-items:center;gap:.25em;font-size:.8rem;color:#666;cursor:pointer}.dark-mode .rename-check{color:#aaa}.rename-actions{position:sticky;bottom:0;z-index:10;background:#dcdcdc;padding:.5rem .75rem;border-radius:4px;display:flex;gap:.3em;align-items:center;justify-content:center;margin-top:.5rem}.rename-actions.disabled,.rename-toolbar.disabled{opacity:.5;pointer-events:none}.rename-toolbar.disabled{padding:.3rem .75rem;border-radius:4px 4px 0 0;margin-bottom:0}.rename-toolbar.disabled~.upload-zone{margin:0}.rename-actions.disabled{border-radius:0 0 4px 4px;margin-top:0}#app .upload-zone{border-radius:0;padding:1.5rem 1rem;margin:.5em 0}.dark-mode .rename-actions{background:#3a3a3a}.preview-list{margin:1rem auto;margin-bottom:0;border-collapse:collapse}.preview-row{border-bottom:1px solid var(--border);font-size:.85rem;cursor:grab;user-select:none}.preview-row.selected{background:rgba(74,144,217,.1)}.preview-row.drag-over-above{box-shadow:inset 0 2px 0 var(--primary)}.preview-row.drag-over-below{box-shadow:inset 0 -2px 0 var(--primary)}.preview-row.dragging{opacity:.4}.preview-row td{padding:.3rem .4rem;vertical-align:middle}.grip{color:#bbb;cursor:grab;font-size:1rem;padding-right:0!important;user-select:none}.preview-cb{width:1rem;height:1rem;cursor:pointer}.preview-thumb{width:40px;height:40px;object-fit:contain;border-radius:3px;background:#e8e8e8;display:block;pointer-events:none}.preview-icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#e8e8e8;border-radius:3px;font-size:1.2rem;color:#888;pointer-events:none}.dark-mode .preview-icon,.dark-mode .preview-thumb{background:#3a3a3a}.td-names .names-inner{display:flex;align-items:center;gap:0;white-space:nowrap}.preview-orig{color:#888;overflow:hidden;text-overflow:ellipsis;min-width:12em;max-width:40vw}.preview-arrow{color:#b0b0b0;padding:0 .3em;flex-shrink:0}.preview-new{font-weight:600;color:var(--primary);overflow:hidden;text-overflow:ellipsis;min-width:12em;max-width:40vw}.preview-new.unchanged{color:#999;font-weight:400;font-style:italic}.preview-warn{color:#dc3545;font-size:1.1rem}.script-panel{margin:1rem 0;border:1px solid var(--border);border-radius:8px;overflow:hidden}.script-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:var(--bg)}.script-header button{font-size:.8rem}.script-body{position:relative}.script-body textarea{width:100%;min-height:120px;padding:.75rem;font-family:monospace;font-size:.8rem;border:none;background:var(--body-bg);color:var(--body-color);resize:vertical}.script-body .btn-copy{position:absolute;top:.5rem;right:.5rem;font-size:.75rem;padding:.2em .5em}.script-path{flex:1;padding:.2em .4em;font-size:.85rem;border:1px solid #ccc;border-radius:4px;background:var(--body-bg);color:var(--body-color)}.dark-mode .script-path{background:#2a2a2a;border-color:#555;color:#eee}.btn-remove{flex-shrink:0;border:none;background:0 0;color:#bbb;font-size:1.3rem;cursor:pointer;line-height:1;padding:.2em .4em;border-radius:4px;transition:color .2s}.btn-remove:hover{color:#dc3545}.spinner-sm{width:1.2rem;height:1.2rem;border:2px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:480px){.rename-toolbar{flex-direction:column;align-items:stretch}.td-names .names-inner{flex-direction:column;flex:1;min-width:0}.preview-new,.preview-orig{min-width:0;max-width:none}.preview-arrow{display:none}.preview-new::before{content:"→ ";color:#888}}.editor{padding-top:0}.content code{background:var(--bg);padding:.1em .35em;border-radius:3px;font-size:.85em}.content code.empty{color:#999;font-style:italic}