.sprite-sheet-generator{max-width:var(--tool-container-max-width, 1600px);margin:0 auto;padding:2rem}.sprite-sheet-generator h1{text-align:center;margin-bottom:.5rem;color:#1a1a2e}.sprite-sheet-generator .tool-description{text-align:center;color:#666;margin-bottom:2rem}.generator-layout{display:grid;grid-template-columns:var(--tool-controls-width, 420px) 1fr;gap:var(--tool-content-gap, 2rem)}.config-panel{display:flex;flex-direction:column;gap:1.5rem}.config-section{background:#f8f9fa;border-radius:12px;padding:1.5rem}.config-section h3{font-size:1.15rem;font-weight:700;color:var(--gray-900);margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--primary);letter-spacing:.03em}.config-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;border-bottom:2px solid #e9ecef;padding-bottom:.5rem}.section-header h3{margin:0;border:none;padding:0}.clear-btn{padding:.25rem .75rem;border:1px solid #dc2626;background:transparent;color:#dc2626;border-radius:4px;cursor:pointer;font-size:.75rem}.clear-btn:hover{background:#dc2626;color:var(--white)}.upload-zone{border:2px dashed #ddd;border-radius:12px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}.upload-zone:hover{border-color:#667eea;background:#f0f4ff}.upload-icon{font-size:3rem;color:#667eea;margin-bottom:.5rem}.upload-zone p{margin:0;color:#333;font-weight:500}.upload-zone small{color:#888}.image-list{display:flex;flex-direction:column;gap:.5rem;max-height:300px;overflow-y:auto}.image-item{display:flex;align-items:center;gap:.75rem;padding:.5rem;background:var(--white);border-radius:8px}.image-thumbnail{width:40px;height:40px;object-fit:contain;background:#f0f0f0;border-radius:4px}.image-info{flex:1;display:flex;flex-direction:column}.image-name{font-size:.875rem;font-weight:500;color:#333;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.image-size{font-size:.75rem;color:#888}.image-actions{display:flex;gap:.25rem}.image-actions button{width:24px;height:24px;border:1px solid #ddd;background:var(--white);border-radius:4px;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center}.image-actions button:hover:not(:disabled){border-color:#667eea;color:#667eea}.image-actions button:disabled{opacity:.5;cursor:not-allowed}.image-actions .remove-btn{border-color:#fee2e2;background:#fee2e2;color:#dc2626}.image-actions .remove-btn:hover{background:#fecaca;border-color:#fecaca}.form-row{margin-bottom:1rem}.form-row label{display:block;font-weight:500;margin-bottom:.5rem;color:#333;font-size:.875rem}.form-row input[type=text],.form-row input[type=number]{width:100%;padding:.5rem;border:1px solid #ddd;border-radius:6px;font-size:.875rem}.form-row input[type=range]{width:calc(100% - 50px);vertical-align:middle}.range-value{display:inline-block;width:45px;text-align:right;font-size:.875rem;color:#666}.layout-buttons,.format-buttons{display:flex;gap:.5rem}.layout-btn,.format-btn{flex:1;padding:.5rem;border:2px solid #ddd;background:var(--white);border-radius:6px;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s}.layout-btn:hover,.format-btn:hover{border-color:#667eea}.layout-btn.active,.format-btn.active{background:#667eea;border-color:#667eea;color:var(--white)}.bg-options{display:flex;gap:.5rem;align-items:center}.bg-btn{flex:1;padding:.5rem;border:2px solid #ddd;background:var(--white);border-radius:6px;cursor:pointer;font-size:.75rem}.bg-btn.active{border-color:#667eea;color:#667eea}.bg-options input[type=color]{width:40px;height:36px;border:none;border-radius:6px;cursor:pointer}.download-buttons{display:flex;flex-direction:column;gap:.5rem}.primary-btn{padding:.75rem 1.5rem;background:linear-gradient(135deg,#667eea,#764ba2);color:var(--white);border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:transform .2s,box-shadow .2s}.primary-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.secondary-btn{padding:.75rem 1.5rem;background:var(--white);color:#667eea;border:2px solid #667eea;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s}.secondary-btn:hover{background:#667eea;color:var(--white)}.output-panel{display:flex;flex-direction:column;gap:1.5rem}.preview-section{background:#f8f9fa;border:2px solid #d1d5db;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.preview-section h3{margin:0 0 1rem;color:#1a1a2e}.sprite-preview{background:repeating-conic-gradient(#ddd,#ddd 25%,#fff 0%,#fff 50%) 50% / 20px 20px;border:2px solid #d1d5db;border-radius:8px;min-height:200px;display:flex;align-items:center;justify-content:center;overflow:auto;padding:1rem;box-shadow:0 1px 3px #0000001a}.empty-preview{color:#888;text-align:center}.sprite-canvas{max-width:100%;height:auto}.sprite-info{display:flex;gap:1.5rem;margin-top:1rem;font-size:.875rem;color:#666}.code-section{background:#f8f9fa;border-radius:12px;padding:1.5rem}.code-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.code-header h3{margin:0;color:#1a1a2e}.copy-btn{padding:.25rem .75rem;border:1px solid #667eea;background:transparent;color:#667eea;border-radius:4px;cursor:pointer;font-size:.75rem}.copy-btn:hover{background:#667eea;color:var(--white)}.code-output{background:#1e1e1e;color:#d4d4d4;padding:1rem;border-radius:8px;overflow:auto;max-height:300px;font-size:.8rem;line-height:1.6;margin:0}.code-output code{font-family:Fira Code,Monaco,Consolas,monospace;white-space:pre}.json-output{max-height:200px}.tips-section{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#fef3c7,#fde68a);border-radius:12px}.tips-section h3{margin:0 0 1rem;color:#92400e}.tips-section ul{margin:0;padding-left:1.5rem}.tips-section li{margin-bottom:.5rem;color:#b45309}.tips-section strong{color:#92400e}@media (max-width: 1023px){.generator-layout{grid-template-columns:1fr}}@media (max-width: 640px){.sprite-sheet-generator{padding:1rem}.layout-buttons,.format-buttons{flex-wrap:wrap}.layout-btn,.format-btn{flex:1 1 45%}}
