: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:"📦 "}.cropper-container{direction:ltr;font-size:0;line-height:0;position:relative;-ms-touch-action:none;touch-action:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.cropper-container img{backface-visibility:hidden;display:block;height:100%;image-orientation:0deg;max-height:none!important;max-width:none!important;min-height:0!important;min-width:0!important;width:100%}.cropper-canvas,.cropper-crop-box,.cropper-drag-box,.cropper-modal,.cropper-wrap-box{bottom:0;left:0;position:absolute;right:0;top:0}.cropper-canvas,.cropper-wrap-box{overflow:hidden}.cropper-drag-box{background-color:#fff;opacity:0}.cropper-modal{background-color:#000;opacity:.5}.cropper-view-box{display:block;height:100%;outline:1px solid #39f;outline-color:rgba(51,153,255,.75);overflow:hidden;width:100%}.cropper-dashed{border:0 dashed #eee;display:block;opacity:.5;position:absolute}.cropper-dashed.dashed-h{border-bottom-width:1px;border-top-width:1px;height:33.33333%;left:0;top:33.33333%;width:100%}.cropper-dashed.dashed-v{border-left-width:1px;border-right-width:1px;height:100%;left:33.33333%;top:0;width:33.33333%}.cropper-center{display:block;height:0;left:50%;opacity:.75;position:absolute;top:50%;width:0}.cropper-center:after,.cropper-center:before{background-color:#eee;content:" ";display:block;position:absolute}.cropper-center:before{height:1px;left:-3px;top:0;width:7px}.cropper-center:after{height:7px;left:0;top:-3px;width:1px}.cropper-face,.cropper-line,.cropper-point{display:block;height:100%;opacity:.1;position:absolute;width:100%}.cropper-face{background-color:#fff;left:0;top:0}.cropper-line{background-color:#39f}.cropper-line.line-e{cursor:ew-resize;right:-3px;top:0;width:5px}.cropper-line.line-n{cursor:ns-resize;height:5px;left:0;top:-3px}.cropper-line.line-w{cursor:ew-resize;left:-3px;top:0;width:5px}.cropper-line.line-s{bottom:-3px;cursor:ns-resize;height:5px;left:0}.cropper-point{background-color:#39f;height:5px;opacity:.75;width:5px}.cropper-point.point-e{cursor:ew-resize;margin-top:-3px;right:-3px;top:50%}.cropper-point.point-n{cursor:ns-resize;left:50%;margin-left:-3px;top:-3px}.cropper-point.point-w{cursor:ew-resize;left:-3px;margin-top:-3px;top:50%}.cropper-point.point-s{bottom:-3px;cursor:s-resize;left:50%;margin-left:-3px}.cropper-point.point-ne{cursor:nesw-resize;right:-3px;top:-3px}.cropper-point.point-nw{cursor:nwse-resize;left:-3px;top:-3px}.cropper-point.point-sw{bottom:-3px;cursor:nesw-resize;left:-3px}.cropper-point.point-se{bottom:-3px;cursor:nwse-resize;height:20px;opacity:1;right:-3px;width:20px}@media (min-width:768px){.cropper-point.point-se{height:15px;width:15px}}@media (min-width:992px){.cropper-point.point-se{height:10px;width:10px}}@media (min-width:1200px){.cropper-point.point-se{height:5px;opacity:.75;width:5px}}.cropper-point.point-se:before{background-color:#39f;bottom:-50%;content:" ";display:block;height:200%;opacity:0;position:absolute;right:-50%;width:200%}.cropper-invisible{opacity:0}.cropper-bg{background-image:url("data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAAA3NCSVQICAjb4U/gAAAABlBMVEXMzMz////TjRV2AAAACXBIWXMAAArrAAAK6wGCiw1aAAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAABFJREFUCJlj+M/AgBVhF/0PAH6/D/HkDxOGAAAAAElFTkSuQmCC")}.cropper-hide{display:block;height:0;position:absolute;width:0}.cropper-hidden{display:none!important}.cropper-move{cursor:move}.cropper-crop{cursor:crosshair}.cropper-disabled .cropper-drag-box,.cropper-disabled .cropper-face,.cropper-disabled .cropper-line,.cropper-disabled .cropper-point{cursor:not-allowed}body.editor-active .editor .image-container{flex:1;min-height:200px}body.editor-active .cropper-container{max-height:100%!important;height:100%!important}@media(max-width:767px){.toolbar{display:flex;flex-wrap:wrap;justify-content:center;gap:.5rem}.toolbar .toolbar-group{display:inline;text-align:center}.toolbar .toolbar-group:first-child{width:100%;order:-1}}