: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(--border);border-radius:8px;padding:3rem 2rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s;background:var(--bg)}.upload-zone.dragover,.upload-zone:hover{border-color:var(--primary);background:rgba(74,144,217,.05)}.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}.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}.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}.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:"📦 "}.results-grid{display:flex;flex-wrap:wrap;gap:1rem;margin:1rem 0;justify-content:center}.result-card{border:1px solid var(--border);border-radius:8px;overflow:hidden;width:180px;background:var(--bg)}.result-card img{width:100%;height:140px;object-fit:cover;display:block;background-color:#ccc;background-image:linear-gradient(45deg,#999 25%,transparent 25%),linear-gradient(-45deg,#999 25%,transparent 25%),linear-gradient(45deg,transparent 75%,#999 75%),linear-gradient(-45deg,transparent 75%,#999 75%);background-size:16px 16px;background-position:0 0,0 8px,8px -8px,-8px 0}.result-card .card-info{padding:.5rem}.result-card .card-name{font-size:.75rem;color:var(--primary);font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:.25rem}.result-card .card-size{font-size:.75rem;color:#888;text-align:center;line-height:1.4}.result-card .card-size .size-new{color:var(--primary);font-weight:600}.result-card .card-size .size-nochange{color:#999;font-style:italic}.result-card .btn{width:100%;font-size:.8rem;padding:.3em .5em}.card-loading{width:100%;height:140px;display:flex;align-items:center;justify-content:center;background:var(--bg)}.card-loading .spinner{display:inline-block;width:2rem;height:2rem;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.btn-add::before{content:"+ "}.editor .toolbar{position:sticky;top:0;z-index:10;background:#dcdcdc;padding:.5rem;border-radius:4px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.3rem}.toolbar-left,.toolbar-right{display:flex;align-items:center;flex-wrap:wrap;gap:.3rem}.toolbar-left .toolbar-group,.toolbar-right .toolbar-group{display:inline-flex;align-items:center;text-align:left}.keep-png{font-size:.85rem;cursor:pointer;white-space:nowrap;display:inline-flex;align-items:center}.keep-png input{margin-right:.3em}.rtl .keep-png input{margin-right:0;margin-left:.3em}.toolbar-select{font-size:.85rem;padding:.2em .3em;border:1px solid #ccc;border-radius:4px;background:var(--body-bg);color:var(--body-color)}.toolbar-label{font-size:.85rem;padding:0 .3em}.quality-value{min-width:2.8em;display:inline-block;text-align:right;font-weight:600}.rtl .quality-value{text-align:left}.input-quality-slider{width:8em;vertical-align:middle;cursor:pointer;accent-color:var(--primary)}.btn-preset{font-size:.8rem;padding:.2em .5em;background:#e8f5e9;border-color:#a5d6a7;color:#2e7d32}.btn-quick{font-size:.8rem;padding:.2em .5em;background:#e8f0fe;border-color:#b0c4de;color:#2a5a8a}.target-size-wrap{display:inline-flex;align-items:center;gap:.3em;font-size:.85rem}.input-target-size{width:4.5em;padding:.2em .3em;font-size:.85rem;text-align:center;border:1px solid #ccc;border-radius:4px}.input-unit{font-size:.85rem;padding:.2em .3em;border:1px solid #ccc;border-radius:4px;background:var(--body-bg);color:var(--body-color)}.btn-go{background:#e8f5e9;border-color:#a5d6a7;color:#2e7d32}.btn-go:hover{background:#c8e6c9}.info-bar{display:flex;justify-content:space-between;align-items:center;padding:.4rem .5rem;font-size:.85rem;color:#666}.info-bar .target-q{display:inline-flex;align-items:center;gap:.3em}.info-bar .total-stats{text-align:right;font-weight:600;color:var(--primary)}.rtl .info-bar .total-stats{text-align:left}.converting-overlay{position:absolute;inset:0;background:rgba(0,0,0,.4);display:flex;align-items:center;justify-content:center;border-radius:8px}.converting-overlay .spinner{display:inline-block;width:2rem;height:2rem;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.cross-link{color:#888;font-size:.85rem}.cross-link a{color:var(--primary)}@media(max-width:480px){.hide-mobile{display:none!important}.results-grid{gap:.5rem}.result-card{width:calc(50% - .25rem)}}@keyframes spin{to{transform:rotate(360deg)}}