body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}*:focus-visible{outline:3px solid #E91E63;outline-offset:2px}.skip-link{position:absolute;top:-40px;left:0;background:#e91e63;color:#fff;padding:8px 16px;z-index:100000;font-size:14px;text-decoration:none;border-radius:0 0 6px;transition:top .2s}.skip-link:focus{top:0}.app-footer{width:100%;background-color:#2c3e50;color:#ecf0f1;padding:20px 0;margin-top:auto;border-top:1px solid #34495e}.footer-content{max-width:1200px;margin:0 auto;padding:0 20px;text-align:center}.copyright{margin:0 0 8px;font-size:.9rem;font-weight:500}.legal-notice{margin:0;font-size:.75rem;color:#bdc3c7;font-style:italic}@media(max-width:768px){.app-footer{padding:15px 0}.copyright,.legal-notice{font-size:.8rem}.legal-notice{font-size:.7rem}}.language-switcher{display:flex;align-items:center}.language-select{padding:6px 12px;font-size:14px;font-weight:500;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;color:#333;transition:border-color .2s,box-shadow .2s}.language-select:hover{border-color:#e91e63}.language-select:focus{outline:none;border-color:#e91e63;box-shadow:0 0 0 2px #e91e6326}.header{background:#fff;padding:15px 30px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:20px}.logo{height:50px;width:auto}.logo-spacer{height:50px;width:50px}.header h1{flex:1;text-align:center;margin:0;color:#e91e63;font-size:24px;font-weight:700}.skeleton{background:linear-gradient(90deg,#e0e0e0 25%,#f0f0f0,#e0e0e0 75%);background-size:200% 100%;animation:skeleton-pulse 1.5s ease-in-out infinite}@keyframes skeleton-pulse{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:8px}.skeleton-asset-item{display:flex;flex-direction:column;align-items:center;gap:6px;padding:8px;background:#fff;border:2px solid #e0e0e0;border-radius:8px;height:100px;justify-content:center}.skeleton-color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.skeleton-color-swatch{aspect-ratio:1;padding-bottom:100%}@media(max-width:600px){.skeleton-asset-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:6px}}.asset-item-container{width:100%;min-height:100px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;border:2px solid;border-color:#e0e0e0;border-radius:8px;background:#fff;box-sizing:border-box;padding:8px 4px;cursor:pointer;transition:all .2s}.asset-item-container:hover{border-color:#e91e63;background:#fff3f8;transform:translateY(-2px);box-shadow:0 4px 8px #e91e6333}.asset-item-svg{height:60px;width:100%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.asset-item-svg svg{max-height:60px;max-width:100%;height:auto;width:auto;display:block}.asset-item-label{font-size:11px;color:#666;text-align:center;width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.2}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(80px,1fr));gap:8px}@media(max-width:600px){.asset-grid{grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:6px}}.asset-library{background:#fff;padding:12px;border-radius:6px;box-shadow:0 2px 4px #0000001a}.asset-library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px}.asset-library-header h2{margin:0;color:#333;font-size:18px}.asset-library h2{margin:0 0 10px;color:#333;font-size:18px}.color-picker{padding:10px;background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a;min-width:220px}.color-picker h3{margin:0 0 8px;font-size:14px;color:#333}.color-options{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.color-option{width:100%;min-width:30px;aspect-ratio:1;border-radius:8px;cursor:pointer;border:2px solid #ddd;transition:all .2s;box-shadow:inset 0 0 0 2px #fff}.color-option:hover{transform:scale(1.05);border-color:#999}.color-option.selected{border-color:#333;box-shadow:inset 0 0 0 2px #fff,0 0 0 2px #fff,0 0 0 4px #333}.pattern-options{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.pattern-option{width:100%;min-width:30px;aspect-ratio:1;border-radius:8px;cursor:pointer;border:2px solid #ddd;transition:all .2s}.pattern-option:hover{transform:scale(1.05);border-color:#999}.pattern-option.selected{border-color:#333;box-shadow:inset 0 0 0 2px #fff,0 0 0 2px #fff,0 0 0 4px #333}.search-box{text-align:center;margin-bottom:12px;padding:10px;background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a;position:relative;display:flex;justify-content:center}.search-input{width:100%;max-width:400px;padding:8px 35px 8px 12px;font-size:14px;border:2px solid #ddd;border-radius:6px;transition:border-color .2s}.search-input:focus{outline:none;border-color:#e91e63}.search-clear-btn{position:absolute;right:calc(50% - 182px);top:50%;transform:translateY(-50%);width:24px;height:24px;background:#999;color:#fff;border:none;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;display:none;align-items:center;justify-content:center;transition:all .2s}.search-clear-btn.visible{display:flex}.search-clear-btn:hover{background:#666;transform:translateY(-50%) scale(1.1)}@media(max-width:600px){.search-input{font-size:16px;max-width:none}.search-clear-btn{right:18px}}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000}.modal-content{background:#fff;padding:30px;border-radius:12px;box-shadow:0 4px 20px #0000004d;max-width:500px;text-align:center}.modal-content p{margin:0 0 20px;color:#333;font-size:16px;line-height:1.5}.modal-content a{color:#4caf50;text-decoration:underline}.modal-button{background:#4caf50;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;transition:background .2s}.modal-button:hover{background:#45a049}.edit-area{background:#fff;border:2px dashed #ccc;border-radius:6px;padding:50px 20px 20px;min-height:120px;margin-bottom:15px;display:flex;gap:0;row-gap:30px;flex-wrap:wrap;align-items:flex-end;justify-content:center;position:relative;--item-size: 80px;--item-margin: -10px}.edit-area.empty:before{content:"Klik op de letters, cijfers en tussenstukjes hieronder om je slinger samen te stellen";color:#999;font-size:14px;width:100%;text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.add-space-btn{position:absolute;top:8px;left:8px;width:30px;height:30px;background:#4caf50;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.add-space-btn:hover{background:#45a049;transform:scale(1.1)}.clear-all-btn{position:absolute;top:8px;right:8px;width:30px;height:30px;background:#f44;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:18px;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.clear-all-btn:hover{background:#c00;transform:scale(1.1)}.clear-all-btn.hidden{display:none}.delete-selected-btn{position:absolute;top:8px;right:46px;width:30px;height:30px;background:#ff9800;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:10}.delete-selected-btn:hover{background:#f57c00;transform:scale(1.1)}.delete-selected-btn.hidden{display:none}.selected-item{position:relative;cursor:move;padding:calc(var(--item-size) * .06);margin:0 var(--item-margin);background:transparent;transition:transform .2s;z-index:2;min-width:calc(var(--item-size) * .75);min-height:var(--item-size);max-height:calc(var(--item-size) * 1.5);display:inline-flex;align-items:flex-end;justify-content:center;vertical-align:bottom}.selected-item.space-item{align-items:flex-start}.selected-item:hover{transform:translateY(2px);z-index:10}.selected-item.active:before{content:"";position:absolute;inset:0;background:transparent;border:3px solid #E91E63;border-radius:6px;pointer-events:none;z-index:-1}.selected-item.active{transform:translateY(-2px);z-index:5}.selected-item.active:has(+.selected-item.active):before{border-right:none;border-top-right-radius:0;border-bottom-right-radius:0}.selected-item.active+.selected-item.active:before{border-left:none;border-top-left-radius:0;border-bottom-left-radius:0}.selected-item.dragging{opacity:.3;transform:scale(.95);box-shadow:0 4px 12px #e91e6366}.drag-count-badge{position:fixed;background:#e91e63;color:#fff;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;pointer-events:none;z-index:10000;box-shadow:0 2px 8px #0000004d;border:2px solid white}.selected-item img,.selected-item svg{width:auto;object-fit:contain;display:block}.selected-item svg{height:calc(var(--item-size, 80px) * var(--svg-height-multiplier, .88))}.selected-item img{max-height:calc(var(--item-size) * .88)}.selected-item .remove-btn{position:absolute;top:calc(var(--item-size) * -.1);right:calc(var(--item-size) * -.1);width:calc(var(--item-size) * .36);height:calc(var(--item-size) * .36);background:#f44;color:#fff;border:2px solid white;border-radius:50%;cursor:pointer;font-weight:700;line-height:1;font-size:calc(var(--item-size) * .22);box-shadow:0 2px 4px #0003;z-index:10;opacity:0;transition:opacity .2s,transform .2s,background .2s}.selected-item:hover .remove-btn{opacity:1}.selected-item .remove-btn:hover{background:#c00;transform:scale(1.1)}.selected-item .color-btn{position:absolute;bottom:calc(var(--item-size) * -.1);right:calc(var(--item-size) * -.1);width:calc(var(--item-size) * .36);height:calc(var(--item-size) * .36);background:#e91e63;color:#fff;border:2px solid white;border-radius:50%;cursor:pointer;font-size:calc(var(--item-size) * .18);line-height:1;box-shadow:0 2px 4px #0003;z-index:10;opacity:0;transition:opacity .2s,transform .2s,background .2s}.selected-item:hover .color-btn{opacity:1}.selected-item .color-btn:hover{background:#c2185b;transform:scale(1.1)}.color-popup{position:absolute;top:100%;left:50%;transform:translate(-50%);background:#fff;border:2px solid #333;border-radius:6px;padding:10px;box-shadow:0 4px 12px #0000004d;z-index:1000;display:none}.color-popup.active{display:block}.color-popup h4{margin:0 0 8px;font-size:12px}.color-popup .color-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}.color-popup .color-choice{width:32px;height:32px;border-radius:6px;cursor:pointer;border:2px solid #ddd;transition:all .2s}.color-popup .color-choice:hover{transform:scale(1.1);border-color:#333}.color-popup .color-choice.selected{border-color:#e91e63;box-shadow:0 0 0 2px #e91e63}.color-popup .pattern-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;margin-top:10px}.color-popup .pattern-choice{width:32px;height:32px;border-radius:6px;cursor:pointer;border:2px solid #ddd;background-size:cover;background-position:center;transition:all .2s}.color-popup .pattern-choice:hover{transform:scale(1.1);border-color:#333}.color-popup .pattern-choice.selected{border-color:#e91e63;box-shadow:0 0 0 2px #e91e63}.undo-redo-btns{position:absolute;top:8px;left:46px;display:flex;gap:4px;z-index:10}.undo-btn,.redo-btn{width:30px;height:30px;background:#607d8b;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s}.undo-btn:hover:not(:disabled),.redo-btn:hover:not(:disabled){background:#455a64;transform:scale(1.1)}.undo-btn:disabled,.redo-btn:disabled{background:#ccc;cursor:not-allowed;opacity:.5}.selection-box{position:absolute;border:2px dashed #E91E63;background:#e91e631a;pointer-events:none;z-index:1000}@media(max-width:600px){.edit-area{padding:44px 10px 10px;min-height:100px}.add-space-btn,.clear-all-btn,.delete-selected-btn,.undo-btn,.redo-btn{width:36px;height:36px;font-size:20px}.delete-selected-btn{right:50px}.undo-redo-btns{left:50px}.selected-item .remove-btn,.selected-item .color-btn{opacity:.85;width:calc(var(--item-size) * .42);height:calc(var(--item-size) * .42)}.selection-box{display:none}}@media(pointer:coarse){.selected-item .remove-btn,.selected-item .color-btn{opacity:.85}}.text-input-box{text-align:center;margin-bottom:12px;padding:10px;background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a;display:flex;gap:8px;align-items:center}.text-input-wrapper{flex:1;position:relative;display:flex;align-items:center}.text-input-box input{flex:1;padding:8px 32px 8px 12px;font-size:14px;border:2px solid #ddd;border-radius:6px;transition:border-color .2s}.text-input-box input:focus{outline:none;border-color:#e91e63}.text-clear-btn{position:absolute;right:8px;background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s,color .2s}.text-clear-btn.visible{opacity:1;pointer-events:auto}.text-clear-btn:hover{color:#333}.insert-btn{padding:8px 16px;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.insert-btn:hover{background:#45a049;transform:translateY(-1px)}.insert-btn:active{transform:translateY(0)}@media(max-width:600px){.text-input-box input{font-size:16px}}.tooltip-wrapper{position:relative;display:inline-flex;align-items:center;margin-left:6px}.tooltip-icon{display:inline-flex;align-items:center;justify-content:center;color:#999;font-size:14px;cursor:help;transition:color .2s}.tooltip-icon:hover,.tooltip-icon:focus{color:#607d8b;outline:none}.tooltip-content{position:absolute;background:#333;color:#fff;padding:8px 12px;border-radius:6px;font-size:13px;font-weight:400;line-height:1.4;white-space:normal;min-width:150px;max-width:250px;text-align:left;z-index:1000;opacity:0;visibility:hidden;transition:opacity .2s,visibility .2s;pointer-events:none;box-shadow:0 2px 8px #0003}.tooltip-content:after{content:"";position:absolute;border:6px solid transparent}.tooltip-top{bottom:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-top:after{top:100%;left:50%;transform:translate(-50%);border-top-color:#333}.tooltip-bottom{top:calc(100% + 8px);left:50%;transform:translate(-50%)}.tooltip-bottom:after{bottom:100%;left:50%;transform:translate(-50%);border-bottom-color:#333}.tooltip-left{right:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-left:after{left:100%;top:50%;transform:translateY(-50%);border-left-color:#333}.tooltip-right{left:calc(100% + 8px);top:50%;transform:translateY(-50%)}.tooltip-right:after{right:100%;top:50%;transform:translateY(-50%);border-right-color:#333}.tooltip-wrapper:hover .tooltip-content,.tooltip-icon:focus+.tooltip-content{opacity:1;visibility:visible}.price-display{background:#fff;border-radius:6px;padding:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:12px}.price-display h3{margin:0 0 8px;color:#333;font-size:14px}.price-breakdown{margin-bottom:8px}.price-line{display:flex;justify-content:space-between;padding:4px 0;color:#666;font-size:12px;gap:6px}.price-line .description{flex:1;min-width:0}.price-line .amount{font-weight:500;color:#333;white-space:nowrap}.price-line.count-line{font-weight:600;padding-bottom:8px;border-bottom:1px solid #e0e0e0;margin-bottom:4px}.price-total{border-top:2px solid #333;padding-top:8px;margin-top:4px;display:flex;justify-content:space-between;font-size:14px;font-weight:700;color:#333}.price-display.empty{opacity:.6}.addons-section{background:#fff;border-radius:6px;padding:10px;box-shadow:0 2px 4px #0000001a;margin-bottom:12px;display:flex;flex-direction:column;gap:8px}.addon-option{display:flex;align-items:center;gap:8px;font-size:13px;color:#333;cursor:pointer}.addon-option input[type=checkbox]{margin:0;cursor:pointer}.addon-label{flex:1}.addon-price{color:#666;font-size:12px}.add-to-cart-btn{width:100%;padding:12px 20px;background:#e91e63;color:#fff;border:none;border-radius:6px;font-size:16px;font-weight:700;cursor:pointer;transition:all .2s;box-shadow:0 2px 4px #e91e634d}.add-to-cart-btn:hover:not(:disabled){background:#c2185b;transform:translateY(-2px);box-shadow:0 4px 8px #e91e6366}.add-to-cart-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 4px #e91e634d}.add-to-cart-btn:disabled{background:#ccc;cursor:not-allowed;transform:none;box-shadow:none}.design-actions{padding:10px;background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a}.design-actions h3{margin:0 0 8px;font-size:14px;color:#333}.design-save-section{margin-bottom:10px}.design-save-btn{width:100%;padding:8px 12px;background:#607d8b;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.design-save-btn:hover:not(:disabled){background:#455a64}.design-save-btn:disabled{background:#ccc;cursor:not-allowed}.design-code-display{margin-top:8px;text-align:center}.design-code-label{font-size:11px;color:#666;display:block;margin-bottom:4px}.design-code-row{display:flex;align-items:center;justify-content:center;gap:6px}.design-code{font-size:20px;font-weight:700;letter-spacing:3px;color:#e91e63;background:#fff3f8;padding:6px 14px;border-radius:6px;border:2px solid #E91E63}.design-copy-btn{width:32px;height:32px;background:#e91e63;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .2s}.design-copy-btn:hover{background:#c2185b}.design-load-section{border-top:1px solid #e0e0e0;padding-top:10px}.design-load-row{display:flex;gap:6px}.design-load-input{flex:1;padding:8px 10px;font-size:14px;font-family:monospace;letter-spacing:2px;text-transform:uppercase;border:2px solid #ddd;border-radius:6px;text-align:center;transition:border-color .2s;width:50%}.design-load-input:focus{outline:none;border-color:#e91e63}.design-load-btn{padding:8px 14px;background:#4caf50;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.design-load-btn:hover:not(:disabled){background:#45a049}.design-load-btn:disabled{background:#ccc;cursor:not-allowed}.design-error{margin-top:8px;padding:6px 10px;background:#ffebee;color:#c62828;border-radius:6px;font-size:12px;text-align:center}.example-picker{background:#fff;padding:12px;border-radius:6px;box-shadow:0 2px 4px #0000001a;margin-top:12px}.example-picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px}.example-picker-header h2{margin:0;color:#333;font-size:18px}.example-category-select{padding:6px 10px;border:1px solid #ccc;border-radius:4px;font-size:13px;background:#fff;cursor:pointer}.example-category-select:focus{outline:none;border-color:#e91e63}.example-list{display:flex;flex-direction:column;gap:8px;max-height:300px;overflow-y:auto}.example-item{cursor:pointer;padding:10px;border:2px solid #e0e0e0;border-radius:6px;background:#f9f9f9;transition:all .2s}.example-item:hover{border-color:#4caf50;background:#e8f5e9;transform:translateY(-2px);box-shadow:0 4px 8px #4caf5033}.example-name{font-weight:500;color:#333;font-size:13px;margin-bottom:4px}.example-preview-wrapper{display:flex;flex-direction:column;gap:2px}.example-preview-count{font-size:11px;color:#666;font-style:italic}.example-preview-row{display:flex;gap:2px;flex-wrap:nowrap;align-items:center;min-height:24px;overflow-x:auto;overflow-y:hidden;padding-bottom:4px}.example-preview-row::-webkit-scrollbar{height:4px}.example-preview-row::-webkit-scrollbar-track{background:#f1f1f1;border-radius:2px}.example-preview-row::-webkit-scrollbar-thumb{background:#888;border-radius:2px}.example-preview-row::-webkit-scrollbar-thumb:hover{background:#555}.example-preview-asset{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.example-preview-asset img{width:20px;height:20px;max-width:20px;max-height:20px;object-fit:contain;display:block}.example-preview-svg{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.example-preview-svg svg{width:100%;height:100%;max-width:20px;max-height:20px}.example-preview-char{font-size:11px;color:#666;font-weight:500}.example-preview-space{width:8px;height:20px;display:inline-block}.example-preview-more{font-size:12px;color:#999;margin-left:4px}.example-empty{text-align:center;padding:16px;color:#999;font-style:italic;font-size:13px}.garland-builder{width:100%}.main-container{display:flex;gap:15px;align-items:flex-start}.left-column{flex:1;min-width:0}.center-column{flex:2;min-width:0}.right-column{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.loading{text-align:center;padding:40px;font-size:18px;color:#666}@media(max-width:1200px){.main-container{flex-direction:column}.left-column,.center-column,.right-column{width:100%}}@media(max-width:600px){.main-container{gap:10px}.right-column{gap:8px}.font-picker{padding:8px}.asset-selector{font-size:16px}}.font-picker{padding:10px;background:#fff;border-radius:6px;box-shadow:0 2px 4px #0000001a}.font-picker h3{margin:0 0 8px;font-size:14px;color:#333}.asset-selector{padding:6px 10px;font-size:13px;border:2px solid #ddd;border-radius:6px;background:#fff;cursor:pointer;transition:border-color .2s;min-width:120px}.asset-selector:hover{border-color:#e91e63}.asset-selector:focus{outline:none;border-color:#e91e63}.assets-container{display:flex;flex-direction:column;gap:12px}.customer-page{min-height:100vh}.content-wrapper{max-width:1400px;margin:0 auto;padding:0 15px 15px}.admin-panel{max-width:1200px;margin:0 auto;padding:40px 20px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:40px}.back-link{color:#007bff;text-decoration:none;font-size:14px;transition:color .2s}.back-link:hover{color:#0056b3;text-decoration:underline}.logout-btn{padding:8px 16px;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.logout-btn:hover{background:#c82333}.admin-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-top:30px}.admin-card{background:#fff;border:2px solid #e0e0e0;border-radius:12px;padding:32px 24px;text-decoration:none;color:inherit;transition:all .3s ease;display:flex;flex-direction:column;align-items:center;text-align:center;cursor:pointer}.admin-card:hover{border-color:#007bff;box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.card-icon{font-size:48px;margin-bottom:16px}.admin-card h2{font-size:24px;margin:0 0 8px;color:#333}.admin-card p{font-size:14px;color:#666;margin:0}.admin-actions{margin-top:48px;padding-top:32px;border-top:1px solid #e0e0e0}.admin-actions h2{font-size:24px;color:#333;margin:0 0 20px}.action-buttons{display:flex;gap:16px;flex-wrap:wrap}.action-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.action-btn:disabled{background:#6c757d!important;cursor:not-allowed}.btn-icon{font-size:18px}.sync-btn{background:#007bff}.sync-btn:hover:not(:disabled){background:#0056b3}.sync-btn.syncing{background:#6c757d}.backup-btn{background:#28a745}.backup-btn:hover:not(:disabled){background:#218838}.backup-btn.working{background:#6c757d}.action-result{margin-top:20px;padding:16px 20px;border-radius:8px;max-width:600px}.action-result.success{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.action-result.error{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.result-message{margin:0;font-weight:500}.action-result details{margin-top:12px}.action-result summary{cursor:pointer;font-size:14px;color:inherit;opacity:.8}.action-result summary:hover{opacity:1}.result-details-list{margin:12px 0 0;padding-left:20px;font-size:13px;max-height:300px;overflow-y:auto}.result-details-list li{margin-bottom:6px}.detail-item.updated{color:#155724}.detail-item.skipped{color:#856404}.detail-item.error{color:#721c24}.download-btn{margin-top:12px;padding:8px 16px;background:#17a2b8;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.download-btn:hover{background:#138496}.admin-assets{max-width:1600px;margin:0 auto;padding:40px 20px}.header-actions{display:flex;gap:16px;align-items:center}.toolbar-left{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.toolbar-right{display:flex;gap:12px}.bulk-actions{display:flex;gap:8px;align-items:center;padding:6px 12px;background:#f8f9fa;border-radius:6px;border:1px solid #e0e0e0}.bulk-count{font-size:13px;font-weight:600;color:#333;padding:0 8px;border-right:1px solid #dee2e6}.btn-bulk-activate,.btn-bulk-deactivate,.btn-bulk-delete{padding:6px 14px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;transition:all .2s}.btn-bulk-activate{background:#28a745;color:#fff}.btn-bulk-activate:hover{background:#218838}.btn-bulk-deactivate{background:#ffc107;color:#333}.btn-bulk-deactivate:hover{background:#e0a800}.btn-bulk-delete{background:#dc3545;color:#fff}.btn-bulk-delete:hover{background:#c82333}.assets-table{width:100%;border-collapse:collapse;font-size:14px}.assets-table thead{background:#f8f9fa;border-bottom:2px solid #e0e0e0}.assets-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.assets-table th.checkbox-col,.assets-table td.checkbox-col{width:40px;text-align:center;padding:12px 8px}.assets-table th.preview-col,.assets-table td.preview-col{width:60px;text-align:center;padding:8px}.asset-preview-thumbnail{width:40px;height:40px;object-fit:contain;border-radius:4px;background:#f8f9fa;border:1px solid #e0e0e0}.asset-preview-thumbnail.svg-preview{background:#f8f9fa}.asset-preview-thumbnail.svg-preview svg{width:100%;height:100%}.assets-table .checkbox-col input[type=checkbox]{width:16px;height:16px;cursor:pointer}.assets-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s;position:relative;padding-right:24px}.assets-table th.sortable:after{content:"⇅";position:absolute;right:8px;opacity:.3;font-size:12px}.assets-table th.sortable:hover{background:#e9ecef;color:#007bff}.assets-table th.sortable:hover:after{opacity:.6}.assets-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#555}.assets-table tbody tr:last-child td{border-bottom:none}.assets-table tbody tr:hover{background:#f8f9fa}.admin-add-asset{max-width:800px;margin:0 auto;padding:40px 20px}.form-group input[type=text],.form-group input[type=number],.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s}.form-group input[type=file]{width:100%;padding:8px;border:1px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer}.file-preview{margin-top:8px;padding:8px;background:#f8f9fa;border-radius:4px}.file-preview small{color:#666}.btn-cancel:hover{background:#5a6268}.admin-edit-asset{max-width:800px;margin:0 auto;padding:40px 20px}.asset-info{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:24px}.asset-info-content{display:flex;gap:24px;align-items:flex-start}.asset-preview-section{display:flex;flex-direction:column;align-items:center;gap:12px;flex-shrink:0}.asset-preview-image{width:120px;height:120px;object-fit:contain;border-radius:8px;background:#fff;border:1px solid #e0e0e0;padding:8px}.file-upload-section{display:flex;flex-direction:column;align-items:center}.file-input-hidden{display:none}.btn-upload{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:#007bff;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.btn-upload:hover:not(.disabled){background:#0056b3}.btn-upload.disabled{background:#6c757d;cursor:not-allowed}.asset-details-section{flex:1}.info-row .label{font-weight:600;color:#555;min-width:100px}.info-row .file-path{font-family:Courier New,monospace;font-size:13px;color:#666}@media(max-width:600px){.asset-info-content{flex-direction:column;align-items:center}.asset-preview-section,.asset-details-section{width:100%}}.type-select{padding:6px 10px;border:1px solid #ddd;border-radius:6px;font-size:14px;cursor:pointer;transition:border-color .2s}.type-select:focus{outline:none;border-color:#007bff}.form-group input[type=text],.form-group input[type=number],.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input.error,.form-group select.error{border-color:#dc3545}.form-group select[multiple]{height:auto;padding:8px}.selected-categories{margin-top:8px;padding:8px;background:#f8f9fa;border-radius:4px}.selected-categories small{color:#666}.field-hint{display:block;margin-top:4px;color:#6c757d;font-size:12px}.admin-colors{max-width:1400px;margin:0 auto;padding:40px 20px}.colors-table{width:100%;border-collapse:collapse;font-size:14px}.colors-table thead{background:#f8f9fa;border-bottom:2px solid #e0e0e0}.colors-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.colors-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s;position:relative;padding-right:24px}.colors-table th.sortable:after{content:"⇅";position:absolute;right:8px;opacity:.3;font-size:12px}.colors-table th.sortable:hover{background:#e9ecef;color:#007bff}.colors-table th.sortable:hover:after{opacity:.6}.colors-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#555}.colors-table tbody tr:last-child td{border-bottom:none}.colors-table tbody tr:hover{background:#f8f9fa}.hex-value{font-family:Courier New,monospace;font-weight:500;color:#333}.color-preview{width:50px;height:30px;border-radius:4px;border:2px solid #ddd;display:inline-block;cursor:pointer;transition:transform .2s}.color-preview:hover{transform:scale(1.1);border-color:#999}.date-cell{font-size:13px;color:#666}@media(max-width:768px){.admin-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{flex-direction:column}.search-input,.filter-select{width:100%}.table-container{overflow-x:auto}.colors-table{min-width:800px}}.admin-add-color{max-width:700px;margin:0 auto;padding:40px 20px}.form-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:32px;margin-top:24px}.admin-edit-color{max-width:700px;margin:0 auto;padding:40px 20px}.color-info{background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px;padding:20px;margin-bottom:24px}.info-row{display:flex;gap:12px;margin-bottom:12px;align-items:center}.info-row:last-child{margin-bottom:0}.info-row .label{font-weight:600;color:#555;min-width:120px}.info-row .value{color:#333}.form-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:32px}.form-group label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.form-group input[type=text],.form-group input[type=number]{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#007bff}.hex-input-group{display:flex;gap:12px;align-items:center}.hex-input-group input[type=text]{flex:1;font-family:Courier New,monospace;text-transform:uppercase}.admin-color-input{width:60px;height:42px;border:1px solid #ddd;border-radius:6px;cursor:pointer;padding:2px}.admin-color-input:hover{border-color:#007bff}.color-preview-large{width:45px;height:42px;border-radius:6px;border:2px solid #ddd;flex-shrink:0}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-weight:400}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.hint{display:block;margin-top:4px;color:#666;font-size:12px}.error-message{display:block;margin-top:4px;color:#dc3545;font-size:12px}.form-actions{display:flex;gap:12px;margin-top:32px;padding-top:24px;border-top:1px solid #e0e0e0}.btn-submit{padding:12px 24px;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s}.btn-submit:disabled{background:#6c757d;cursor:not-allowed}.btn-cancel{padding:12px 24px;background:#6c757d;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;text-decoration:none;display:inline-block;transition:background .2s;text-align:center}.admin-patterns{padding:20px;max-width:1400px;margin:0 auto}.header-actions{display:flex;gap:10px;align-items:center}.add-btn{background:#4caf50;color:#fff;padding:8px 16px;border-radius:4px;text-decoration:none;font-weight:500}.add-btn:hover{background:#45a049}.filters{display:flex;gap:10px;margin-bottom:20px}.search-input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px}.filter-select{padding:8px 12px;border:1px solid #ddd;border-radius:4px}.patterns-table{width:100%;border-collapse:collapse;background:#fff;box-shadow:0 2px 4px #0000001a}.patterns-table th,.patterns-table td{padding:12px;text-align:left;border-bottom:1px solid #ddd}.patterns-table th{background:#f5f5f5;font-weight:600}.patterns-table tr:hover{background:#f9f9f9}.pattern-preview{width:50px;height:50px;border-radius:4px;border:2px solid #ddd}.badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.badge-success{background:#d4edda;color:#155724}.badge-danger{background:#f8d7da;color:#721c24}.actions{display:flex;gap:8px}.edit-btn{color:#2196f3;text-decoration:none;padding:4px 8px;border-radius:4px}.edit-btn:hover{background:#e3f2fd}.delete-btn{background:#f44336;color:#fff;border:none;padding:4px 8px;border-radius:4px;cursor:pointer}.delete-btn:hover{background:#d32f2f}.admin-add-pattern{padding:20px;max-width:800px;margin:0 auto}.image-preview{margin-top:12px;border:2px solid #ddd;border-radius:4px;padding:10px;display:inline-block}.admin-edit-pattern{padding:20px;max-width:800px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.back-link{color:#666;text-decoration:none}.pattern-info{background:#f5f5f5;padding:15px;border-radius:8px;margin-bottom:20px}.pattern-info p{margin:8px 0;font-size:14px;color:#666}.pattern-info strong{color:#333}.form-container{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 8px #0000001a}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:#333}.form-group input[type=text],.form-group input[type=number],.form-group input[type=file]{width:100%;padding:10px;border:1px solid #ddd;border-radius:4px;font-size:14px}.form-group input.error{border-color:#f44336}.error-message{color:#f44336;font-size:12px;margin-top:4px;display:block}.current-image{border:2px solid #ddd;border-radius:4px;padding:10px;display:inline-block}.current-image img{max-width:200px;max-height:200px;display:block}.image-preview{margin-top:12px;border:2px solid #4CAF50;border-radius:4px;padding:10px;display:inline-block}.image-preview p{margin:0 0 8px;font-size:12px;color:#4caf50;font-weight:500}.image-preview img{max-width:200px;max-height:200px;display:block}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-label input[type=checkbox]{width:auto;cursor:pointer}.hint{display:block;color:#666;font-size:12px;margin-top:4px}.btn-submit{background:#4caf50;color:#fff;border:none;padding:10px 24px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500}.btn-submit:hover:not(:disabled){background:#45a049}.btn-cancel{background:#f5f5f5;color:#333;border:none;padding:10px 24px;border-radius:4px;text-decoration:none;font-size:14px;font-weight:500;display:inline-block}.btn-cancel:hover{background:#e0e0e0}.admin-categories{max-width:1600px;margin:0 auto;padding:40px 20px}.categories-table{width:100%;border-collapse:collapse;font-size:14px}.categories-table thead{background:#f8f9fa;border-bottom:2px solid #e0e0e0}.categories-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.categories-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s;position:relative;padding-right:24px}.categories-table th.sortable:after{content:"⇅";position:absolute;right:8px;opacity:.3;font-size:12px}.categories-table th.sortable:hover{background:#e9ecef;color:#007bff}.categories-table th.sortable:hover:after{opacity:.6}.categories-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#555}.categories-table tbody tr:last-child td{border-bottom:none}.categories-table tbody tr:hover{background:#f8f9fa}@media(max-width:768px){.admin-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{flex-direction:column}.search-input,.filter-select{width:100%}.table-container{overflow-x:auto}.assets-table{min-width:1000px}}.admin-edit-category{max-width:800px;margin:0 auto;padding:40px 20px}.admin-asset-types{max-width:1600px;margin:0 auto;padding:40px 20px}.asset-types-table{width:100%;border-collapse:collapse;font-size:14px}.asset-types-table thead{background:#f8f9fa;border-bottom:2px solid #e0e0e0}.asset-types-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.asset-types-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s;position:relative;padding-right:24px}.asset-types-table th.sortable:after{content:"⇅";position:absolute;right:8px;opacity:.3;font-size:12px}.asset-types-table th.sortable:hover{background:#e9ecef;color:#007bff}.asset-types-table th.sortable:hover:after{opacity:.6}.asset-types-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#555}.asset-types-table tbody tr:last-child td{border-bottom:none}.asset-types-table tbody tr:hover{background:#f8f9fa}.type-badge{display:inline-block;padding:4px 10px;border-radius:4px;font-size:12px;font-weight:500;text-transform:uppercase}.type-icon{background:#e3f2fd;color:#1976d2}.type-letter{background:#f3e5f5;color:#7b1fa2}.type-number{background:#fff3e0;color:#e65100}.categories-cell{max-width:200px}.categories-list{display:flex;flex-wrap:wrap;gap:4px}.category-badge{display:inline-block;padding:3px 8px;border-radius:3px;font-size:11px;font-weight:500;background:#e7f3ff;color:#06c;white-space:nowrap}.file-path{font-family:Courier New,monospace;font-size:12px;color:#666;max-width:250px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.warning-icon{margin-left:8px;font-size:16px;cursor:help}@media(max-width:768px){.admin-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{flex-direction:column}.search-input,.filter-select{width:100%}.table-container{overflow-x:auto}.asset-types-table{min-width:1000px}}.admin-add-category{max-width:800px;margin:0 auto;padding:40px 20px}.back-link{color:#007bff;text-decoration:none;font-size:14px}.error-message{background:#f8d7da;color:#721c24;padding:12px 16px;border-radius:6px;margin-bottom:20px;border:1px solid #f5c6cb}.category-form{background:#fff;padding:30px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.form-group{margin-bottom:24px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#333}.form-group input,.form-group select{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;font-family:inherit}.form-group input.disabled-input{background:#f5f5f5;color:#666;cursor:not-allowed}.checkbox-group label{display:flex;align-items:center;gap:8px;cursor:pointer}.checkbox-group input[type=checkbox]{width:auto}.form-group small{display:block;margin-top:4px;color:#666;font-size:12px}.form-actions{display:flex;gap:12px;margin-top:30px}.btn-submit{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s}.btn-cancel{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;text-decoration:none;display:inline-block;transition:background .2s}.admin-examples{max-width:1400px;margin:0 auto;padding:40px 20px}.admin-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:16px;flex-wrap:wrap}.toolbar-left,.toolbar-right{display:flex;gap:12px}.btn-add{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s;text-decoration:none;display:inline-block}.btn-add:hover{background:#218838;color:#fff}.filter-select,.search-input{padding:10px 16px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff}.filter-select{min-width:150px}.search-input{min-width:250px}.search-input:focus,.filter-select:focus{outline:none;border-color:#007bff}.loading{text-align:center;padding:60px 20px;color:#666;font-size:16px}.table-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;overflow:hidden}.examples-table{width:100%;border-collapse:collapse;font-size:14px}.examples-table thead{background:#f8f9fa;border-bottom:2px solid #e0e0e0}.examples-table th{padding:12px 16px;text-align:left;font-weight:600;color:#333;white-space:nowrap}.examples-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:all .2s;position:relative;padding-right:24px}.examples-table th.sortable:after{content:"⇅";position:absolute;right:8px;opacity:.3;font-size:12px}.examples-table th.sortable:hover{background:#e9ecef;color:#007bff}.examples-table th.sortable:hover:after{opacity:.6}.examples-table td{padding:12px 16px;border-bottom:1px solid #f0f0f0;color:#555}.examples-table tbody tr:last-child td{border-bottom:none}.examples-table tbody tr:hover{background:#f8f9fa}.no-results{text-align:center;padding:60px 20px;color:#999;font-style:italic}.name-cell{font-weight:500;color:#333}.example-preview{display:flex;gap:2px;align-items:center;flex-wrap:wrap;min-height:24px}.preview-item{width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;overflow:hidden}.preview-item img{width:100%;height:100%;object-fit:contain}.preview-char{font-size:11px;color:#666;font-weight:500}.preview-space{width:8px;height:20px}.preview-more{font-size:12px;color:#999;margin-left:4px}.badge{display:inline-block;padding:3px 8px;border-radius:3px;font-size:12px;font-weight:500}.badge-yes{background:#d4edda;color:#155724}.badge-no{background:#f8d7da;color:#721c24}.badge-category{background:#e2e3f1;color:#383d6e}.actions{white-space:nowrap}.btn-edit,.btn-delete{padding:6px 12px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500;margin-right:6px;transition:all .2s;text-decoration:none;display:inline-block}.btn-edit{background:#007bff;color:#fff}.btn-edit:hover{background:#0056b3;color:#fff}.btn-delete{background:#dc3545;color:#fff}.btn-delete:hover{background:#c82333}.table-footer{padding:12px 16px;background:#f8f9fa;border-top:1px solid #e0e0e0;font-size:14px;color:#666}@media(max-width:768px){.admin-toolbar{flex-direction:column;align-items:stretch}.toolbar-left,.toolbar-right{flex-direction:column}.search-input,.filter-select{width:100%}.table-container{overflow-x:auto}.examples-table{min-width:900px}}.admin-add-example{max-width:1200px;margin:0 auto;padding:40px 20px}.form-container{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:30px}.form-row{display:flex;gap:20px;margin-bottom:0}.form-row .form-group{flex:1}.form-group{margin-bottom:20px}.form-group label{display:block;font-weight:600;margin-bottom:6px;color:#333}.form-group input[type=text],.form-group input[type=number],.form-group select{width:100%;padding:10px 14px;border:1px solid #ddd;border-radius:6px;font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:#007bff}.form-group input.error{border-color:#dc3545}.error-message{color:#dc3545;font-size:13px;margin-top:4px;display:block}.hint{color:#999;font-size:12px;margin-top:4px;display:block}.checkbox-label{display:flex!important;align-items:center;gap:8px;cursor:pointer;padding-top:28px}.checkbox-label input[type=checkbox]{width:18px;height:18px}.example-builder-section{margin-top:10px;margin-bottom:20px;padding-top:20px;border-top:2px solid #e0e0e0}.example-builder-section h2{font-size:20px;color:#333;margin:0 0 16px}.example-builder-preview{background:#f8f9fa;border:2px dashed #ddd;border-radius:8px;padding:16px;margin-bottom:16px;min-height:80px}.preview-label{font-size:13px;color:#666;margin-bottom:10px;display:flex;justify-content:space-between;align-items:center}.btn-clear{background:#dc3545;color:#fff;border:none;padding:4px 10px;border-radius:4px;cursor:pointer;font-size:12px}.btn-clear:hover{background:#c82333}.preview-items{display:flex;gap:4px;flex-wrap:nowrap;align-items:center;overflow-x:auto;overflow-y:hidden;padding-bottom:8px}.preview-items::-webkit-scrollbar{height:6px}.preview-items::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.preview-items::-webkit-scrollbar-thumb{background:#888;border-radius:3px}.preview-items::-webkit-scrollbar-thumb:hover{background:#555}.preview-empty{color:#999;font-style:italic;font-size:14px}.example-builder-item{width:44px;height:44px;position:relative;display:inline-flex;align-items:center;justify-content:center;background:#fff;border:1px solid #ddd;border-radius:4px;flex-shrink:0;cursor:pointer;transition:all .15s}.example-builder-item:hover{border-color:#999;transform:translateY(-1px)}.example-builder-item.selected{border-color:#007bff;border-width:2px;box-shadow:0 0 0 2px #007bff33}.example-builder-item.space-item{width:20px;background:#f0f0f0;border-style:dashed}.item-visual{width:32px;height:32px;display:flex;align-items:center;justify-content:center;overflow:hidden}.item-visual img{width:100%;height:100%;object-fit:contain}.item-svg{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.item-svg svg{width:100%;height:100%}.item-char{font-size:14px;font-weight:600;color:#333}.item-space-visual{width:8px;height:32px;background:#ddd;border-radius:2px}.item-remove{position:absolute;top:-6px;right:-6px;width:16px;height:16px;border-radius:50%;background:#dc3545;color:#fff;border:none;cursor:pointer;font-size:10px;line-height:1;display:none;align-items:center;justify-content:center;padding:0}.example-builder-item:hover .item-remove{display:flex}.builder-color-picker{margin-bottom:16px}.builder-color-picker label{display:block;font-weight:600;font-size:14px;margin-bottom:8px;color:#333}.color-swatches{display:flex;gap:6px;flex-wrap:wrap}.color-swatch{width:28px;height:28px;border-radius:50%;border:2px solid #ddd;cursor:pointer;transition:all .15s;padding:0}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{border-color:#333;box-shadow:0 0 0 2px #fff,0 0 0 4px #333}.builder-controls{display:flex;gap:16px;align-items:flex-end;margin-bottom:16px;flex-wrap:wrap}.control-group{display:flex;flex-direction:column;gap:4px}.control-group label{font-size:13px;font-weight:600;color:#555}.control-group select{padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:#fff}.btn-add-space{padding:8px 16px;background:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500}.btn-add-space:hover{background:#5a6268}.builder-asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(70px,1fr));gap:8px;max-height:300px;overflow-y:auto;padding:12px;background:#f8f9fa;border:1px solid #e0e0e0;border-radius:8px}.assets-loading,.assets-empty{grid-column:1 / -1;text-align:center;padding:30px;color:#999}.asset-button{display:flex;flex-direction:column;align-items:center;gap:4px;padding:8px 4px;background:#fff;border:1px solid #e0e0e0;border-radius:6px;cursor:pointer;transition:all .15s}.asset-button:hover{border-color:#e91e63;background:#fff5f8;transform:translateY(-1px)}.asset-preview{width:40px;height:40px;display:flex;align-items:center;justify-content:center;overflow:hidden}.asset-preview img{max-width:100%;max-height:100%;object-fit:contain}.asset-label{font-size:10px;color:#666;text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:60px}.form-actions{display:flex;gap:12px;margin-top:24px;padding-top:20px;border-top:1px solid #e0e0e0}.btn-submit{background:#28a745;color:#fff;border:none;padding:12px 28px;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;transition:background .2s}.btn-submit:hover:not(:disabled){background:#218838}.btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-cancel{background:#6c757d;color:#fff;border:none;padding:12px 28px;border-radius:6px;cursor:pointer;font-size:16px;font-weight:500;text-decoration:none;display:inline-block;transition:background .2s}.btn-cancel:hover{background:#5a6268;color:#fff}@media(max-width:768px){.form-row{flex-direction:column}.builder-controls{flex-direction:column;align-items:stretch}.builder-asset-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr))}}.admin-changelog{max-width:1400px;margin:0 auto;padding:40px 20px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.admin-header h1{font-size:32px;color:#333;margin:0}.back-link{color:#007bff;text-decoration:none;font-weight:500;transition:color .2s}.back-link:hover{color:#0056b3}.changelog-container{display:grid;grid-template-columns:1fr 1fr;gap:30px}.changelog-section,.todo-section,.extra-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:30px}.changelog-section h2,.todo-section h2,.extra-section h2{font-size:24px;color:#333;margin:0 0 20px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.changelog-entry{margin-bottom:25px}.changelog-entry:last-child{margin-bottom:0}.changelog-entry h3{font-size:16px;font-weight:700;color:#007bff;margin:0 0 10px}.changelog-entry ul,.todo-section ul,.extra-section ul{margin:0;padding-left:20px;list-style-type:disc}.changelog-entry li,.todo-section li,.extra-section li{color:#555;line-height:1.6;margin-bottom:6px;font-size:14px}.changelog-entry li:last-child,.todo-section li:last-child,.extra-section li:last-child{margin-bottom:0}@media(max-width:968px){.changelog-container{grid-template-columns:1fr}}@media(max-width:768px){.admin-header{flex-direction:column;align-items:flex-start;gap:15px}.changelog-section,.todo-section,.extra-section{padding:20px}}.admin-settings{padding:2rem;max-width:1200px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e0e0e0}.admin-header h1{margin:0;color:#333}.back-link{color:#007bff;text-decoration:none;font-weight:500}.settings-container{background:#fff;border-radius:8px;padding:2rem;box-shadow:0 2px 4px #0000001a}.settings-section{margin-bottom:2rem;padding-bottom:2rem;border-bottom:1px solid #eee}.settings-section:last-of-type{border-bottom:none}.settings-section h2{margin:0 0 1.5rem;color:#555;font-size:1.3rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;color:#333}.form-group input{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:4px;font-size:1rem;font-family:inherit}.form-group input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.hint{display:block;margin-top:.5rem;font-size:.875rem;color:#666;font-style:italic}.message{padding:1rem;border-radius:4px;margin-bottom:1rem}.message.success{background-color:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background-color:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.form-actions{display:flex;gap:1rem;margin-top:2rem}.btn-submit,.btn-cancel{padding:.75rem 2rem;border:none;border-radius:4px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s}.btn-submit{background-color:#28a745;color:#fff}.btn-submit:hover:not(:disabled){background-color:#218838}.btn-submit:disabled{background-color:#6c757d;cursor:not-allowed}.btn-cancel{background-color:#6c757d;color:#fff}.btn-cancel:hover{background-color:#5a6268}.loading{text-align:center;padding:3rem;color:#666;font-size:1.1rem}.admin-login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-container{background:#fff;border-radius:12px;box-shadow:0 20px 60px #0000004d;padding:48px;width:100%;max-width:420px}.login-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.login-container h1{margin:0;font-size:28px;color:#333}.login-subtitle{margin:0 0 32px;font-size:14px;color:#666;text-align:center}.login-container .form-group{margin-bottom:24px}.login-container label{display:block;margin-bottom:8px;font-weight:600;color:#333;font-size:14px}.login-container input[type=password]{width:100%;padding:12px 16px;border:2px solid #ddd;border-radius:8px;font-size:16px;transition:border-color .2s;box-sizing:border-box}.login-container input[type=password]:focus{outline:none;border-color:#667eea}.login-container input[type=password]:disabled{background:#f5f5f5;cursor:not-allowed}.login-container button{width:100%;padding:14px;background:#667eea;color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s}.login-container button:hover:not(:disabled){background:#5568d3}.login-container button:disabled{background:#ccc;cursor:not-allowed}.error-message{padding:12px 16px;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;font-size:14px;margin-bottom:16px;text-align:center}.back-link-container{margin-top:24px;text-align:center}.back-link{color:#667eea;text-decoration:none;font-size:14px;font-weight:500}.back-link:hover{text-decoration:underline}.feedback-button{position:fixed;bottom:24px;right:24px;z-index:1000;display:flex;align-items:center;gap:8px;padding:12px 20px;background-color:#e91e63;color:#fff;border:none;border-radius:50px;cursor:pointer;font-size:15px;font-weight:600;box-shadow:0 4px 12px #0003;transition:background-color .2s,transform .2s,box-shadow .2s}.feedback-button:hover{background-color:#c2185b;transform:translateY(-2px);box-shadow:0 6px 16px #00000040}.feedback-button:active{transform:translateY(0)}.feedback-button:focus-visible{outline:3px solid #E91E63;outline-offset:3px}.feedback-button-icon{font-size:20px}@media(max-width:600px){.feedback-button-label{display:none}.feedback-button{padding:14px;border-radius:50%}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Arial,sans-serif;background:linear-gradient(180deg,#c8e6c9,#e8f5e9,#fff3f8);min-height:100vh}.App{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1 0 auto}.app-footer{flex-shrink:0}
