*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0a0a0a;--surface:#1a1a1a;--surface-elevated:#252525;--primary:#6366f1;--accent:#22d3ee;--text:#f5f5f5;--text-secondary:#a1a1aa;--border:#3f3f46}body{font-family:"IBM Plex Sans",system-ui,sans-serif;background:var(--bg);color:var(--text);min-height:100vh;display:flex;flex-direction:column}.header{background:var(--surface);padding:12px 20px;display:flex;align-items:center;gap:24px;border-bottom:1px solid var(--border)}.lang-toggle{padding:6px 12px;border:1px solid var(--border);border-radius:4px;background:var(--surface);color:var(--text);cursor:pointer;font-size:.85rem}.lang-toggle:hover{background:var(--hover)}.changelog-badge{margin-left:auto;padding:5px 10px;border:1px solid var(--border);border-radius:12px;background:var(--surface);color:var(--text-secondary);cursor:pointer;font-size:.7rem;text-decoration:none;letter-spacing:.4px;transition:.2s}.changelog-badge:hover{border-color:var(--accent);color:var(--accent);background:var(--surface-elevated)}.header h1{font-size:1.2rem;font-weight:600;background:linear-gradient(135deg,var(--primary),var(--accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.tabs{display:flex;gap:4px;background:var(--surface);padding:0 20px 10px;border-bottom:1px solid var(--border)}.tab{padding:8px 16px;background:0 0;border:none;color:var(--text-secondary);cursor:pointer;border-radius:6px;font-size:.9rem;transition:.2s}.tab:hover{background:var(--surface-elevated);color:var(--text)}.tab.active{background:var(--primary);color:#fff}.main{flex:1;display:flex;flex-direction:column;padding:16px 20px;gap:16px;overflow-y:auto}.card-area{background:var(--surface);border-top:1px solid var(--border);padding:16px}.card-area h4{font-size:.8rem;color:var(--text-secondary);margin-bottom:12px;text-transform:uppercase;letter-spacing:.5px}.cards{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;min-height:110px;align-items:flex-start}.cards.drag-over{border-color:var(--accent);background:rgba(34,211,238,.05);border-radius:8px}.card{width:100px;height:100px;aspect-ratio:1;background:var(--surface-elevated);border:2px solid var(--border);border-radius:8px;cursor:grab;overflow:hidden;position:relative;transition:.2s;flex-shrink:0;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.card:hover{border-color:var(--accent);transform:translateY(-2px)}.card.dragging{opacity:.5}.card img{width:100%;height:100%;object-fit:cover;border-radius:6px;-webkit-touch-callout:none;-webkit-user-select:none;user-select:none}.card-add{width:100px;height:100px;aspect-ratio:1;background:var(--surface-elevated);border:2px dashed var(--border);border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:36px;color:var(--text-secondary);transition:.2s;flex-shrink:0}.card-add:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-2px)}.card .remove-btn{position:absolute;top:-8px;right:-8px;width:20px;height:20px;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:14px;line-height:1;display:none;z-index:10}.card:hover .remove-btn{display:block}.empty-cards{color:var(--text-secondary);font-size:.85rem;padding:30px;text-align:center;border:2px dashed var(--border);border-radius:8px;width:100%}.tab-content{display:none;flex-direction:column;gap:16px}.tab-content.active{display:flex}.controls{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:16px}.controls h3{font-size:.95rem;margin-bottom:12px;color:var(--accent)}.slider-group{display:flex;align-items:center;gap:12px;margin-bottom:10px}.slider-group label{min-width:90px;font-size:.85rem;color:var(--text-secondary)}.slider-group input[type=range]{flex:1;height:6px;-webkit-appearance:none;background:var(--border);border-radius:3px;outline:0}.slider-group input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:16px;height:16px;background:var(--primary);border-radius:50%;cursor:pointer}.slider-group .value{min-width:40px;text-align:right;font-family:"IBM Plex Mono",monospace;font-size:.85rem}.radio-group{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:12px;align-items:center}.radio-group label{display:flex;align-items:center;gap:6px;cursor:pointer;font-size:.85rem;color:var(--text-secondary)}.radio-group input[type=radio]{accent-color:var(--primary)}.buttons{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px;align-items:center}.buttons label{min-width:90px;font-size:.85rem;color:var(--text-secondary)}.buttons-right{justify-content:space-between}.btn{padding:8px 16px;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:.2s}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:#4f46e5}.btn-secondary{background:var(--surface-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--border)}.canvas-area{background:var(--surface);border-radius:12px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;padding:20px;min-height:300px}#generateCanvas{max-width:100%;max-height:360px}.comparison{display:grid;grid-template-columns:1fr 1fr;gap:16px;background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:16px}.comparison-side{display:flex;flex-direction:column;gap:8px}.comparison-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;text-align:center}.squash-half-result{margin-top:16px;display:none}.squash-half-result .drop-zone{min-height:unset;max-height:110px}.squash-half-result.visible{display:block}.drop-zone{border:2px dashed var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;min-height:200px;position:relative;transition:.2s;background:var(--surface-elevated)}.drop-zone.drag-over{border-color:var(--accent);background:rgba(34,211,238,.1)}.drop-zone.filled{border-style:solid;border-color:var(--primary)}.drop-zone img{max-width:100%;max-height:200px;object-fit:contain;border-radius:6px}.drop-zone .placeholder{color:var(--text-secondary);font-size:.85rem}.drop-zone .clear-btn{position:absolute;top:8px;right:8px;width:24px;height:24px;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:16px;line-height:1;display:none}.drop-zone:hover .clear-btn{display:block}.drop-grid{display:grid;gap:4px;background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:8px;justify-content:center}.drop-grid-1x2{grid-template-columns:repeat(2,auto)}.drop-grid-1x3{grid-template-columns:repeat(3,auto)}.drop-grid-1x4{grid-template-columns:repeat(4,auto)}.drop-grid-1x5{grid-template-columns:repeat(5,auto)}.drop-grid-2x1{grid-template-columns:auto;grid-template-rows:repeat(2,auto)}.drop-grid-3x1{grid-template-columns:auto;grid-template-rows:repeat(3,auto)}.drop-grid-4x1{grid-template-columns:auto;grid-template-rows:repeat(4,auto)}.drop-grid-5x1{grid-template-columns:auto;grid-template-rows:repeat(5,auto)}.drop-grid-2x2{grid-template-columns:repeat(2,auto)}.drop-grid-2x3{grid-template-columns:repeat(3,auto)}.drop-grid-2x4{grid-template-columns:repeat(4,auto)}.drop-grid-2x5{grid-template-columns:repeat(5,auto)}.drop-grid-3x2{grid-template-columns:repeat(2,auto);grid-template-rows:repeat(3,auto)}.drop-grid-3x3{grid-template-columns:repeat(3,auto)}.drop-grid-3x4{grid-template-columns:repeat(4,auto)}.drop-grid-3x5{grid-template-columns:repeat(5,auto)}.drop-grid-4x2{grid-template-columns:repeat(2,auto);grid-template-rows:repeat(4,auto)}.drop-grid-4x3{grid-template-columns:repeat(3,auto);grid-template-rows:repeat(4,auto)}.drop-grid-4x4{grid-template-columns:repeat(4,auto)}.drop-grid-4x5{grid-template-columns:repeat(5,auto)}.drop-grid-5x2{grid-template-columns:repeat(2,auto);grid-template-rows:repeat(5,auto)}.drop-grid-5x3{grid-template-columns:repeat(3,auto);grid-template-rows:repeat(5,auto)}.drop-grid-5x4{grid-template-columns:repeat(4,auto);grid-template-rows:repeat(5,auto)}.drop-grid-5x5{grid-template-columns:repeat(5,auto)}.multiway-preview,.split-preview,.tile-preview{margin-top:16px;background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:16px;display:flex;align-items:center;justify-content:center;min-height:200px}.multiway-preview canvas,.split-preview canvas,.tile-preview canvas{max-width:100%;max-height:380px;margin:0 auto}.preview-wrapper{position:relative;display:inline-block}.preview-wrapper canvas{display:block}.btn-icon{position:absolute;top:8px;right:8px;width:32px;height:32px;border-radius:50%;background:var(--primary);color:#fff;border:none;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;z-index:10}.btn-icon:hover{background:var(--accent)}@media (max-width:768px){.btn-icon{top:8px;left:8px;right:auto}}.split-show{margin-top:16px;display:flex;gap:16px;align-items:stretch;box-sizing:border-box;height:300px}.split-show .split-source{flex:1;background:var(--surface);border-radius:12px;border:2px dashed var(--border);padding:16px;display:flex;align-items:center;justify-content:center;box-sizing:border-box;overflow:hidden}.split-show .split-source.drag-over{border-color:var(--primary);background:var(--hover)}.split-show .split-source img{max-width:100%;height:100%;object-fit:contain;box-sizing:border-box}.split-show .split-source .placeholder{color:var(--text-secondary);font-size:.85rem}.split-show .split-grid{flex:1;display:grid;gap:4px;background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:8px;box-sizing:border-box;overflow:hidden;place-content:center}.split-show .split-grid.split-2x2{grid-template-columns:repeat(2,auto);justify-content:center}.split-show .split-grid.split-3x3{grid-template-columns:repeat(3,auto);justify-content:center}.split-show .split-grid.split-2x1{grid-template-columns:repeat(1,auto);grid-template-rows:repeat(2,auto);justify-content:center}.split-show .split-grid.split-3x1{grid-template-columns:repeat(1,auto);grid-template-rows:repeat(3,auto);justify-content:center}.split-show .split-grid.split-1x2{grid-template-columns:repeat(2,auto);grid-template-rows:repeat(1,auto);justify-content:center}.split-show .split-grid.split-4x4{grid-template-columns:repeat(4,auto);justify-content:center}.split-show .split-grid.split-custom{grid-template-columns:repeat(auto-fill,minmax(80px,auto));justify-content:center}.split-grid{margin-top:0;gap:4px;box-sizing:border-box}.split-cell{border:2px dashed var(--border);border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:grab;background:var(--surface);position:relative;box-sizing:border-box}.split-cell img{object-fit:cover;width:100%;height:100%;object-fit:cover;pointer-events:none}.split-cell:active{cursor:grabbing}.split-cell.dragging{opacity:.5;border-color:var(--primary)}.split-cell.drag-over{border-color:var(--primary);background:var(--hover)}.split-cell.selected{border-color:var(--accent);border-style:solid;box-shadow:0 0 8px var(--accent)}.split-grid.split-2x2{max-width:60%;margin:0 auto}.split-grid.split-1x2,.split-grid.split-2x1,.split-grid.split-3x3,.split-grid.split-custom{max-width:80%;margin:0 auto}.split-grid.split-4x4{max-width:90%;margin:0 auto}.split-cell .cell-label{position:absolute;bottom:4px;left:50%;transform:translateX(-50%);font-size:10px;color:var(--text-secondary)}.grid-cell{border:2px dashed var(--border);border-radius:8px;width:100px;height:100px;aspect-ratio:1;display:flex;align-items:center;justify-content:center;position:relative;transition:.2s;background:var(--surface-elevated);overflow:hidden}.grid-cell.drag-over{border-color:var(--accent);background:rgba(34,211,238,.1)}.grid-cell.filled{border-style:solid;border-color:var(--primary)}.grid-cell img{width:100%;height:100%;object-fit:cover;border-radius:6px;transition:transform .3s}.grid-cell .cell-label{color:var(--text-secondary);font-size:.75rem}.grid-cell .clear-btn{position:absolute;top:4px;right:4px;width:20px;height:20px;background:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;font-size:12px;line-height:1;display:none}.grid-cell:hover .clear-btn{display:block}.checkbox-group{display:flex;align-items:center;gap:8px;margin-top:10px}.checkbox-group label{font-size:.85rem;cursor:pointer}.checkbox-group input{accent-color:var(--primary)}.color-row{display:flex;align-items:center;gap:12px;margin-top:12px}.color-label,.color-row>label{font-size:.85rem;color:var(--text-secondary)}.color-swatches{display:flex;gap:12px;flex-wrap:wrap}.color-swatch-group{display:flex;align-items:center;gap:6px}.color-input{width:0;height:0;opacity:0;position:absolute}.color-preview{width:24px;height:24px;border-radius:4px;border:1px solid var(--border);cursor:pointer}.custom-layers-panel{margin-top:12px}.custom-layer-inputs{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:12px}.custom-layer-inputs label{font-size:.85rem;color:var(--text-secondary)}.custom-layer-inputs input[type=number]{padding:6px 8px;border:1px solid var(--border);border-radius:4px;width:50px}.custom-layer-inputs select{padding:6px 8px;border:1px solid var(--border);border-radius:4px}.custom-layers-list{display:flex;flex-wrap:wrap;gap:8px}.custom-layer-tag{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;background:var(--hover);border:1px solid var(--border);border-radius:4px;font-size:.85rem}.custom-layer-tag .remove-layer{cursor:pointer;color:var(--text-secondary);font-weight:700;margin-left:4px}.custom-layer-tag .remove-layer:hover{color:var(--primary)}.hidden{display:none!important}.crop-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.85);z-index:1000;display:flex;flex-direction:column;align-items:center;justify-content:center}.crop-container{position:relative;max-width:90%;max-height:80%}.crop-container img{max-width:100%;max-height:70vh;display:block}.crop-box{position:absolute;border:2px dashed #0ff;background:0 0;cursor:move}.crop-box::before{content:'';position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(0,255,255,.1)}.crop-corner{position:absolute;width:12px;height:12px;background:#0ff;border-radius:2px}.crop-corner.nw{top:-6px;left:-6px;cursor:nw-resize}.crop-corner.ne{top:-6px;right:-6px;cursor:ne-resize}.crop-corner.sw{bottom:-6px;left:-6px;cursor:sw-resize}.crop-corner.se{bottom:-6px;right:-6px;cursor:se-resize}.crop-actions{margin-top:16px;display:flex;gap:12px}.param-display{margin-top:12px;display:flex;align-items:center;gap:8px;background:var(--surface-elevated);border-radius:6px;padding:8px 12px}.param-display label{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.param-display .param-text{flex:1;font-family:"IBM Plex Mono",monospace;font-size:.75rem;color:var(--accent);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;background:var(--bg);padding:4px 8px;border-radius:4px;border:1px solid var(--border);min-width:200px;max-width:400px}.param-display .copy-btn{padding:4px 12px;border:none;border-radius:4px;cursor:pointer;font-size:.75rem;background:var(--primary);color:#fff;transition:background .2s}.param-display .copy-btn:hover{background:#4f46e5}.param-display .copy-btn.copied{background:#22c55e}.crop-actions button{padding:8px 20px;border:none;border-radius:6px;cursor:pointer;font-size:14px}.crop-actions .crop-confirm{background:var(--primary);color:#fff}.crop-actions .crop-cancel{background:#666;color:#fff}.fab-menu{display:none}@media (max-width:768px){.header{padding:10px 12px;gap:8px}.header h1{font-size:1rem}.tab{padding:6px 10px;font-size:.8rem;white-space:nowrap;flex-shrink:0}.main{padding:10px 12px;gap:12px}.controls{padding:12px}.controls h3{font-size:.85rem}.slider-group{flex-wrap:wrap;gap:4px}.slider-group label{min-width:70px;font-size:.8rem}.slider-group input[type=range]{min-width:0}.slider-group .value{font-size:.8rem}.radio-group{gap:8px}.radio-group label{font-size:.8rem}.buttons{gap:6px}.btn{padding:6px 10px;font-size:.8rem}.comparison{grid-template-columns:1fr;gap:12px}.canvas-area{padding:12px;min-height:200px}#generateCanvas{max-height:280px}.card-area{padding:10px 12px}.cards{gap:8px;padding-bottom:6px}.card,.card-add{width:70px;height:70px}.drop-zone{min-height:120px}.drop-zone img{max-height:120px}.split-show{flex-direction:column;height:auto;gap:10px}.split-show .split-source{min-height:120px}.grid-cell{width:70px;height:70px}.crop-corner{width:20px;height:20px}.crop-corner.nw{top:-10px;left:-10px}.crop-corner.ne{top:-10px;right:-10px}.crop-corner.sw{bottom:-10px;left:-10px}.crop-corner.se{bottom:-10px;right:-10px}.crop-actions button{padding:10px 16px;font-size:14px}.param-display .param-text{min-width:120px;max-width:200px;font-size:.7rem}.color-row{flex-wrap:wrap;gap:8px}.color-swatches{gap:8px}.custom-layer-inputs{gap:6px}.custom-layer-inputs input[type=number]{width:40px}.multiway-preview canvas,.split-preview canvas,.tile-preview canvas{max-height:260px}.tabs{display:none}.fab-menu{display:flex;flex-direction:column;align-items:center;gap:10px;position:fixed;right:20px;z-index:200}.fab-toggle{width:52px;height:52px;border-radius:50%;border:none;background:var(--primary);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 16px rgba(99,102,241,.4);transition:transform .35s cubic-bezier(.34, 1.56, .64, 1),background .25s,box-shadow .25s;order:99}.fab-menu.open .fab-toggle{transform:rotate(135deg) scale(1.05);background:var(--surface-elevated);box-shadow:0 4px 20px rgba(99,102,241,.25)}.fab-item{width:48px;height:48px;border-radius:50%;border:none;background:#fff;color:#000;font-size:.65rem;cursor:pointer;box-shadow:0 2px 8px rgba(0,0,0,.3);display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.1;transform:scale(0) translateY(10px);opacity:0;pointer-events:none;transition:transform .3s cubic-bezier(.34, 1.56, .64, 1),opacity .25s}.fab-menu.open .fab-item{transform:scale(1) translateY(0);opacity:1;pointer-events:auto}.fab-item.active{background:var(--primary);color:#fff;box-shadow:0 2px 12px rgba(99,102,241,.5)}.fab-menu.open .fab-item:nth-child(2){transition-delay:0s}.fab-menu.open .fab-item:nth-child(3){transition-delay:40ms}.fab-menu.open .fab-item:nth-child(4){transition-delay:80ms}.fab-menu.open .fab-item:nth-child(5){transition-delay:120ms}.fab-menu.open .fab-item:nth-child(6){transition-delay:160ms}.fab-menu.open .fab-item:nth-child(7){transition-delay:0.2s}.fab-menu.open .fab-item:nth-child(8),.fab-menu:not(.open) .fab-item:nth-child(2){transition-delay:240ms}.fab-menu:not(.open) .fab-item:nth-child(3){transition-delay:0.2s}.fab-menu:not(.open) .fab-item:nth-child(4){transition-delay:160ms}.fab-menu:not(.open) .fab-item:nth-child(5){transition-delay:120ms}.fab-menu:not(.open) .fab-item:nth-child(6){transition-delay:80ms}.fab-menu:not(.open) .fab-item:nth-child(7){transition-delay:40ms}.fab-menu:not(.open) .fab-item:nth-child(8){transition-delay:0s}}