*{margin:0;padding:0;box-sizing:border-box}body{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:#f5f7fa;color:#2d3748}.app-container,body{overflow:hidden;height:100vh}.app-container,.sidebar{display:flex}.sidebar{width:300px;background:linear-gradient(180deg,#fff,#f8f9fa);border-right:1px solid #e2e8f0;flex-direction:column;overflow-y:auto;box-shadow:4px 0 20px rgba(0,0,0,.08)}.sidebar::-webkit-scrollbar{width:8px}.sidebar::-webkit-scrollbar-track{background:#f8f9fa}.sidebar::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.sidebar-header{padding:30px 20px;border-bottom:1px solid #e2e8f0;background:linear-gradient(135deg,#667eea,#764ba2)}.sidebar-header h1{font-size:1.8em;margin-bottom:5px;color:#fff}.sidebar-header p{font-size:.9em;opacity:.9;color:#e0e0e0}.sidebar-section{padding:20px;border-bottom:1px solid #e2e8f0}body.gallery-view-active .sidebar-section.shirt-style-section,body.view-mode-active .sidebar-section.shirt-style-section{display:none}.sidebar-section h3{font-size:.9em;text-transform:uppercase;letter-spacing:1px;color:#718096;margin-bottom:15px;font-weight:600}.shirt-style-dropdown{width:100%;padding:12px 15px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;font-size:.95em;font-weight:500;cursor:pointer;transition:all .3s;outline:none}.shirt-style-dropdown:hover{border-color:#667eea;background:#f7fafc}.shirt-style-dropdown:focus{border-color:#667eea;box-shadow:0 0 0 3px rgba(102,126,234,.1)}.shirt-style-dropdown option{padding:10px}.filter-list{display:flex;flex-direction:column;gap:8px}.filter-btn{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;cursor:pointer;transition:all .3s;font-size:.95em}.filter-btn .icon{font-size:1.2em;margin-right:10px}.filter-btn .count{background:#e2e8f0;padding:3px 10px;border-radius:12px;font-size:.85em;font-weight:600;color:#2d3748}.filter-btn.active,.filter-btn:hover{border-color:#667eea;background:#f7fafc}.filter-btn.active{color:#667eea}.filter-btn.active .count{background:#667eea;color:#fff}.saved-designs-preview{flex:1 1;overflow-y:auto;max-height:400px}.saved-list{display:flex;flex-direction:column;gap:10px}.saved-item{display:flex;align-items:center;gap:12px;padding:10px;background:#fff;border-radius:8px;cursor:pointer;transition:all .3s;border:1px solid #e2e8f0}.saved-item:hover{background:#f7fafc;border-color:#667eea;transform:translateX(5px)}.saved-item img{width:50px;height:60px;border-radius:5px;object-fit:cover;image-rendering:pixelated}.saved-item-info{flex:1 1}.saved-item-name{font-size:.9em;font-weight:600;color:#2d3748;margin-bottom:3px}.saved-item-date{font-size:.75em;color:#718096}.main-content{flex:1 1;display:flex;flex-direction:column;background:#f5f7fa;overflow:hidden;height:100vh}.top-header{display:flex;justify-content:space-between;align-items:center;padding:25px 40px;background:linear-gradient(180deg,#fff,#f8f9fa);border-bottom:1px solid #e2e8f0;box-shadow:0 4px 12px rgba(0,0,0,.05)}.header-left h2{font-size:1.8em;color:#2d3748;margin-bottom:5px}.header-left p{color:#718096;font-size:.95em}.header-right{display:flex;gap:10px}.btn-icon{width:50px;height:50px;border-radius:12px;background:#fff;border:2px solid #e2e8f0;color:#2d3748;font-size:1.5em;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center}.btn-icon:hover{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);transform:scale(1.05);box-shadow:0 4px 12px rgba(102,126,234,.4)}.canvas-area{flex:1 1;display:none;padding:40px;gap:30px;overflow-y:auto}.canvas-area.active{display:flex}.editor-view{display:flex;flex-direction:row;gap:20px;flex:1 1;overflow:hidden;padding:20px;height:calc(100vh - 120px)}.editor-controls-row{flex:0 0 40%;display:flex;flex-direction:column;gap:20px;overflow-y:auto;height:100%}.editor-controls-row::-webkit-scrollbar{width:8px}.editor-controls-row::-webkit-scrollbar-track{background:#f8f9fa;border-radius:10px}.editor-controls-row::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.editor-canvas-row{flex:0 0 60%;display:flex;align-items:center;justify-content:center;padding:40px;background:linear-gradient(135deg,#f5f7fa,#e9ecef);border-radius:15px;height:100%}.shirt-canvas{max-width:100%;max-height:100%;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;box-shadow:0 20px 60px rgba(0,0,0,.15);border-radius:10px;background:transparent}.gallery-view{flex:1 1;display:flex;flex-direction:column;overflow-y:auto;padding:20px;height:calc(100vh - 120px)}.canvas-wrapper{flex:1 1;display:flex;gap:30px}.shirt-display{flex:1 1;display:flex;align-items:center;justify-content:center;background:transparent;padding:40px}#pixelShirt{max-width:500px;max-height:600px;width:100%;height:auto;display:block;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;cursor:crosshair;background:transparent}#pixelShirt:hover{transform:scale(1.01)}.controls-panel{flex:1 1;background:linear-gradient(145deg,#fff,#f8f9fa);border-radius:15px;padding:25px;box-shadow:0 4px 20px rgba(0,0,0,.05);display:flex;flex-direction:column;gap:20px;min-width:0;border:2px solid #e2e8f0}.controls-panel::-webkit-scrollbar{width:6px}.controls-panel::-webkit-scrollbar-track{background:#f8f9fa;border-radius:10px}.controls-panel::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.controls-panel h3{font-size:.9em;text-transform:uppercase;letter-spacing:1px;color:#718096;margin-bottom:10px;font-weight:600}.color-picker-input{width:100%;height:50px;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .3s}.color-picker-input:hover{border-color:#667eea}.color-grid{display:grid;grid-template-columns:repeat(6,1fr);grid-gap:8px;gap:8px}.color-swatch{aspect-ratio:1;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.1)}.color-swatch:hover{border-color:#667eea;transform:scale(1.15);box-shadow:0 4px 12px rgba(0,0,0,.2)}.control-section{background:#fff;padding:15px;border-radius:12px;border:1px solid #e2e8f0}.control-section h4{font-size:.9em;text-transform:uppercase;letter-spacing:1px;color:#718096;margin-bottom:12px;font-weight:600}.section-buttons{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px}.section-btn{padding:12px 8px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;color:#2d3748;cursor:pointer;transition:all .3s;font-size:.85em;font-weight:600;display:flex;align-items:center;justify-content:center;gap:5px}.section-btn:hover{border-color:#667eea;background:#f7fafc}.section-btn.active{border-color:#667eea;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px rgba(102,126,234,.4)}#colorPicker{width:100%;height:50px;border-radius:10px;cursor:pointer;margin-bottom:15px;border:2px solid #e2e8f0}#colorPicker:hover{border-color:#667eea}.color-section-scrollable{background:transparent;padding:0;border:none}.color-palette-scrollable{max-height:280px;overflow-y:auto;padding-right:5px;margin-top:10px}.color-palette-scrollable::-webkit-scrollbar{width:6px}.color-palette-scrollable::-webkit-scrollbar-track{background:#f8f9fa;border-radius:10px}.color-palette-scrollable::-webkit-scrollbar-thumb{background:#667eea;border-radius:10px}.color-palette-grid{display:flex;flex-direction:column;gap:12px}.palette-category{display:flex;flex-direction:column;gap:6px}.category-label{font-size:.8em;color:#718096;font-weight:600}.color-row{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:6px;gap:6px}.color-preset{width:100%;aspect-ratio:1;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .2s;box-shadow:0 2px 8px rgba(0,0,0,.3)}.color-preset:hover{border-color:#fff;transform:scale(1.15);box-shadow:0 4px 12px rgba(0,0,0,.5)}.color-preset:active{transform:scale(.95)}.current-colors-compact{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:8px;gap:8px}.color-box{width:100%;aspect-ratio:1;border-radius:8px;border:2px solid #e2e8f0;position:relative;box-shadow:0 2px 8px rgba(0,0,0,.08)}.color-box:after{content:attr(data-label);position:absolute;bottom:2px;right:4px;font-size:.7em;font-weight:700;color:rgba(0,0,0,.6);text-shadow:0 1px 2px hsla(0,0%,100%,.8)}.control-section.actions{display:flex;flex-direction:column;gap:8px}.btn-action{padding:12px;font-size:.95em;display:flex}.btn-action,.btn-primary{border:none;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 12px rgba(102,126,234,.3);padding:14px 28px;font-size:1em;display:inline-flex}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(102,126,234,.5)}.btn-secondary{background:#fff;color:#2d3748;border:2px solid #e2e8f0;padding:14px 28px;border-radius:10px;font-size:1em;font-weight:600;cursor:pointer;transition:all .3s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-secondary:hover{border-color:#667eea;background:#f7fafc;transform:translateY(-2px)}.actions-panel{flex:0 0 auto;background:linear-gradient(145deg,#fff,#f8f9fa);border-radius:15px;padding:25px;box-shadow:0 4px 20px rgba(0,0,0,.05);display:flex;flex-direction:column;gap:12px;border:2px solid #e2e8f0}.actions-panel h3{font-size:.9em;text-transform:uppercase;letter-spacing:1px;color:#718096;margin-bottom:10px;font-weight:600}.action-btn{padding:14px 20px;border:none;border-radius:10px;font-size:.95em;font-weight:600;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;gap:8px;color:#fff}.save-btn{background:linear-gradient(135deg,#667eea,#764ba2);box-shadow:0 4px 12px rgba(102,126,234,.3)}.save-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(102,126,234,.5)}.random-btn{background:linear-gradient(135deg,#f093fb,#f5576c);box-shadow:0 4px 12px rgba(245,87,108,.3)}.random-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(245,87,108,.5)}.reset-btn{background:linear-gradient(135deg,#4facfe,#00f2fe);box-shadow:0 4px 12px rgba(79,172,254,.3)}.reset-btn:hover{transform:translateY(-2px);box-shadow:0 6px 16px rgba(79,172,254,.5)}.gallery-container{width:100%}.gallery-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-gap:30px;gap:30px;padding:30px}.gallery-item{position:relative;cursor:pointer;transition:all .4s;animation:pulseGallery 1.2s ease-in-out infinite}.gallery-item:hover{animation-play-state:paused;transform:translateY(-8px) scale(1.03);filter:drop-shadow(0 10px 20px rgba(102,126,234,.3))}.gallery-item canvas{width:100%;height:auto;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;background:transparent;border:none;box-shadow:none;transition:all .3s}.gallery-item:hover canvas{box-shadow:none}.gallery-item-info{position:absolute;top:10px;right:10px;display:flex;align-items:center;gap:10px}.gallery-item-favorite{width:32px;height:32px;border-radius:50%;background:hsla(0,0%,100%,.95);border:2px solid #e2e8f0;color:#2d3748;font-size:1.2em;cursor:pointer;transition:all .3s;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,.1)}.gallery-item-favorite:hover{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea;transform:scale(1.1);box-shadow:0 4px 12px rgba(102,126,234,.4)}@keyframes pulseGallery{0%,to{transform:translate(0);filter:blur(0)}50%{transform:translate(-2px,2px);filter:blur(.8px)}}.empty-gallery{grid-column:1/-1;text-align:center;padding:80px 20px;color:#718096;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px}.empty-gallery-icon{font-size:4em;margin-bottom:20px}.empty-gallery h3{font-size:1.5em;margin-bottom:10px;color:#2d3748}.view-section{flex:1 1;display:flex;flex-direction:row;overflow:hidden;padding:20px;gap:20px;height:calc(100vh - 120px)}.view-canvas-container{flex:0 0 60%;display:flex;align-items:center;justify-content:center;padding:40px;background:linear-gradient(135deg,#f5f7fa,#e9ecef);border-radius:15px}.view-canvas{max-width:100%;max-height:100%;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;box-shadow:0 20px 60px rgba(0,0,0,.15);border-radius:10px;background:transparent}.view-info{flex:0 0 40%;background:linear-gradient(145deg,#fff,#f8f9fa);border-radius:15px;padding:30px;box-shadow:0 4px 20px rgba(0,0,0,.05);overflow-y:auto;border:2px solid #e2e8f0}.view-info h3{font-size:1.5em;color:#2d3748;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #e2e8f0}.view-info h4{font-size:1.1em;color:#2d3748;margin-top:20px;margin-bottom:15px}.info-group{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #e2e8f0}.info-group label{font-weight:600;color:#718096}.info-group span{color:#2d3748}.color-list{display:flex;flex-direction:column;gap:10px}.color-info-item{display:flex;align-items:center;gap:12px;padding:10px;background:#f7fafc;border-radius:8px}.color-preview{width:40px;height:40px;border-radius:8px;border:2px solid #e2e8f0;box-shadow:0 2px 8px rgba(0,0,0,.1)}.view-actions{display:flex;gap:10px;padding-top:20px;border-top:2px solid #e2e8f0}.view-actions button{flex:1 1;padding:12px 20px;border-radius:10px;font-weight:600;cursor:pointer;transition:all .3s;border:none}.view-container{width:100%;max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:40px}.view-display{display:flex;justify-content:center;padding:40px}#viewShirt{max-width:600px;max-height:750px;width:100%;height:auto;display:block;image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;background:transparent}.color-info-panel{background:linear-gradient(145deg,#fff,#f8f9fa);border-radius:20px;padding:30px;box-shadow:0 10px 30px rgba(0,0,0,.08);margin:0 40px 40px}.color-info-panel h3{font-size:1.5em;color:#2d3748;margin-bottom:25px;text-align:center}.color-info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));grid-gap:20px;gap:20px;margin-bottom:30px}.color-info-item{background:#fff;border-radius:15px;padding:20px;border:2px solid #e2e8f0;transition:all .3s}.color-info-item:hover{border-color:#667eea;transform:translateY(-4px);box-shadow:0 8px 20px rgba(102,126,234,.2)}.color-info-header{display:flex;align-items:center;gap:15px;margin-bottom:15px}.color-swatch{width:60px;height:60px;border-radius:12px;border:3px solid #e2e8f0;box-shadow:0 4px 12px rgba(0,0,0,.1)}.color-section-label{font-size:1.1em;font-weight:600;color:#2d3748}.color-details{display:flex;flex-direction:column;gap:8px}.color-detail-row{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:#f7fafc;border-radius:8px}.color-detail-label{font-size:.85em;color:#718096;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.color-detail-value{font-family:Courier New,monospace;font-size:.95em;color:#2d3748;font-weight:600}.view-actions{display:grid;grid-template-columns:1fr 1fr 1fr;grid-gap:15px;gap:15px;margin-top:20px}.btn-delete-design{background:#fff;color:#e63946;border:2px solid #e63946}.btn-delete-design:hover{background:#e63946;color:#fff}@media (max-width:1400px){.gallery-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:1200px){.canvas-wrapper{flex-direction:column}.controls-panel{width:100%;max-height:400px}.shirt-display{min-height:500px}.gallery-grid{grid-template-columns:repeat(2,1fr)}.color-info-grid,.view-actions{grid-template-columns:1fr}}@media (max-width:768px){.sidebar{width:250px}.canvas-area,.top-header{padding:20px}}@media (max-width:600px){.sidebar{position:absolute;left:-300px;height:100%;z-index:1000;transition:left .3s}.sidebar.open{left:0}}