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}.mobile-select-trigger{display:inline-flex;align-items:center;justify-content:space-between;gap:6px;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;text-align:left;min-width:0}.mobile-select-trigger:hover{border-color:#e91e63}.mobile-select-trigger:focus{outline:none;border-color:#e91e63;box-shadow:0 0 0 2px #e91e6326}.mobile-select-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.mobile-select-arrow{font-size:10px;color:#888;flex-shrink:0}.mobile-select-overlay{position:fixed;inset:0;background:#00000073;z-index:100000;display:flex;align-items:flex-end;justify-content:center;animation:msel-fade-in .15s ease}@keyframes msel-fade-in{0%{opacity:0}to{opacity:1}}.mobile-select-panel{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:500px;max-height:70vh;display:flex;flex-direction:column;animation:msel-slide-up .2s ease;padding-bottom:env(safe-area-inset-bottom,16px)}@keyframes msel-slide-up{0%{transform:translateY(100%)}to{transform:translateY(0)}}.mobile-select-handle{width:36px;height:4px;background:#ccc;border-radius:2px;margin:10px auto 6px;flex-shrink:0}.mobile-select-title{font-size:15px;font-weight:600;color:#333;text-align:center;padding:4px 16px 10px;border-bottom:1px solid #eee;flex-shrink:0}.mobile-select-options{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:4px 0}.mobile-select-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:14px 20px;font-size:16px;color:#333;background:none;border:none;border-bottom:1px solid #f0f0f0;cursor:pointer;text-align:left;transition:background .1s}.mobile-select-option:last-child{border-bottom:none}.mobile-select-option:active{background:#f5f5f5}.mobile-select-option.selected{color:#e91e63;font-weight:600}.mobile-select-check{color:#e91e63;font-size:18px;flex-shrink:0;margin-left:8px}.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}@media(max-width:768px){.language-select{font-size:16px}}.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-link{display:flex;align-items:center;flex-shrink:0}.logo-link:hover .logo{opacity:.85}.logo{height:50px;width:auto;transition:opacity .15s}.logo--mobile{display:none}.return-btn{flex-shrink:0;padding:6px 14px;border:1.5px solid #E91E63;border-radius:20px;color:#e91e63;font-size:14px;font-weight:500;text-decoration:none;white-space:nowrap;transition:background .15s,color .15s}.return-btn:hover{background:#e91e63;color:#fff}.logo-spacer{height:50px;width:50px}.header h1{flex:1;text-align:center;margin:0;color:#e91e63;font-size:24px;font-weight:700}@media(max-width:768px){.header{padding:8px 15px;margin-bottom:10px}.header-content{display:grid;grid-template-columns:1fr auto 1fr;gap:8px;align-items:center}.header h1{display:none}.logo-link{grid-column:1;justify-self:start}.return-btn{grid-column:2;justify-self:center;font-size:12px;padding:5px 10px}.language-switcher{grid-column:3;justify-self:end}.logo--desktop{display:none}.logo--mobile{display:block;height:34px;width:auto}.logo-spacer{height:34px;width:34px}}.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}@media(max-width:768px){.asset-item-container{min-height:68px;gap:4px;padding:6px 3px}.asset-item-svg{height:38px}.asset-item-svg svg,.asset-item-img{max-height:38px}.asset-item-label{font-size:9px}}.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-img{max-height:60px}.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:768px){.asset-grid{grid-template-columns:repeat(auto-fill,minmax(56px,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;transition:margin-bottom .25s ease}.asset-library.is-collapsed .asset-library-header{margin-bottom:0}.asset-library-header h2{margin:0;color:#333;font-size:18px}.asset-library-header .collapsible-toggle{flex:1;display:flex;align-items:center;justify-content:space-between;gap:8px;background:none;border:none;padding:0;cursor:pointer;text-align:left}.asset-library-header .collapsible-toggle:hover h2{color:#e91e63}.asset-library .collapsible-content{overflow:hidden;max-height:2000px;opacity:1;transition:max-height .3s ease-out,opacity .2s ease}.asset-library .collapsible-content.is-collapsed{max-height:0;opacity:0}.asset-library-header .collapse-icon{display:inline-block;font-size:11px;color:#888;flex-shrink:0;transition:transform .25s ease}.asset-library-header .collapse-icon.is-collapsed{transform:rotate(-90deg)}.asset-library h2{margin:0 0 10px;color:#333;font-size:18px}@media(max-width:600px){.asset-library{padding:10px}.asset-library-header h2{font-size:15px}}.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}.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-category-group{margin-bottom:10px}.color-category-label{font-size:12px;font-weight:600;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.color-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(28px,36px));gap:6px}.color-option{width:100%;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(auto-fill,minmax(28px,36px));gap:6px}.pattern-option{width:100%;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}@media(max-width:600px){.color-picker{min-width:unset}.color-options,.pattern-options{grid-template-columns:repeat(auto-fill,minmax(42px,1fr))}}.color-disclaimer{margin:10px 0 0;font-size:.78rem;color:#999;font-style:italic;line-height:1.4}.color-picker-title{display:flex;align-items:center;margin-bottom:10px}.color-picker-title h3{margin:0}.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-hint{color:#999;font-size:14px;width:100%;text-align:center;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);pointer-events:none}.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:768px){.edit-area{--item-size: 50px;--item-margin: -6px;padding:40px 8px 10px;min-height:110px;row-gap:16px}.edit-area-empty-hint{top:44px;transform:translate(-50%);font-size:13px}.add-space-btn,.clear-all-btn,.delete-selected-btn,.undo-btn,.redo-btn{width:28px;height:28px;font-size:16px}.delete-selected-btn{right:42px}.undo-redo-btns{left:42px}.selected-item .remove-btn,.selected-item .color-btn{display:none!important}.mobile-check-badge{position:absolute;top:-7px;left:-7px;width:22px;height:22px;background:#e91e63;color:#fff;border-radius:50%;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid white;box-shadow:0 1px 4px #00000040;z-index:10;pointer-events:none}.selection-box{display:none}}@media(pointer:coarse){.color-popup.active{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10000;width:calc(100vw - 40px);max-width:320px;max-height:80vh;overflow-y:auto;box-shadow:0 0 0 100vmax #00000073,0 4px 20px #0000004d}.color-popup .color-grid,.color-popup .pattern-grid{grid-template-columns:repeat(auto-fill,minmax(42px,1fr))}.color-popup .color-choice,.color-popup .pattern-choice{width:100%;height:unset;aspect-ratio:1}}.mobile-check-badge,.mobile-action-bar{display:none}@media(max-width:768px){.mobile-action-bar{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;border-radius:8px;box-shadow:0 2px 6px #0000001a;padding:8px 12px;margin-top:8px}.mobile-action-bar button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;border-radius:8px;cursor:pointer;font-size:18px;transition:opacity .15s}.mobile-action-bar button:disabled{opacity:.35;cursor:not-allowed}.mobile-action-btn--move{background:#607d8b;color:#fff}.mobile-action-btn--delete{background:#f44;color:#fff}.mobile-action-btn--color{background:#e91e63;color:#fff}.mobile-action-btn--deselect{background:#eee;color:#555;font-size:14px;width:auto!important;padding:0 14px;font-weight:500}}.mobile-color-overlay{position:fixed;inset:0;background:#00000073;z-index:100000;display:flex;align-items:flex-end;justify-content:center;animation:msel-fade-in .15s ease}.mobile-color-panel{background:#fff;border-radius:16px 16px 0 0;width:100%;max-width:500px;max-height:70vh;display:flex;flex-direction:column;animation:msel-slide-up .2s ease;padding-bottom:env(safe-area-inset-bottom,16px)}.mobile-color-title{font-size:15px;font-weight:600;color:#333;text-align:center;padding:4px 16px 12px;border-bottom:1px solid #eee}.mobile-color-sections{overflow-y:auto;-webkit-overflow-scrolling:touch;padding:8px 0 4px}.mobile-color-category{padding:0 20px 12px}.mobile-color-category-label{font-size:13px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;padding-top:4px}.mobile-color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(48px,1fr));gap:10px}.mobile-color-swatch{aspect-ratio:1;border:2px solid #ddd;border-radius:8px;cursor:pointer;transition:transform .1s,border-color .1s}.mobile-color-swatch:active{transform:scale(.92);border-color:#e91e63}.requires-input-warn-btn{position:absolute;bottom:8px;right:8px;width:30px;height:30px;background:#ffc107;color:#5a3e00;border-radius:6px;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:default;z-index:10}.requires-input-warn-popup{position:absolute;bottom:calc(100% + 6px);right:0;background:#fff;border:1.5px solid #ffc107;border-radius:6px;padding:8px 10px;min-width:220px;max-width:280px;box-shadow:0 2px 8px #00000026;text-align:left;z-index:100}.requires-input-warn-popup ul{margin:0;padding:0;list-style:none;font-size:.8rem;line-height:1.4}.requires-input-warn-popup li+li{margin-top:4px}.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)}.insert-btn-icon{display:none}@media(max-width:600px){.text-input-box input{font-size:16px}.insert-btn-text{display:none}.insert-btn-icon{display:inline;font-size:18px}.insert-btn{padding:8px 10px}}.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}.cart-note{margin:8px 0 0;font-size:.78rem;color:#999;font-style:italic;line-height:1.4;text-align:center}.cart-note-tooltip{display:flex;justify-content:center;margin-top:6px}.max-reached-tooltip .tooltip-icon{color:#f9a825}.max-reached-tooltip .tooltip-icon:hover,.max-reached-tooltip .tooltip-icon:focus{color:#e65100}.extra-input-cart-warning{display:flex;align-items:flex-start;gap:8px;background:#fff3cd;border:1px solid #ffc107;border-radius:6px;padding:10px 12px;margin-bottom:10px;font-size:.82rem;color:#856404}.extra-input-cart-warning-icon{flex-shrink:0;margin-top:2px;color:#e6a817}.extra-input-cart-warning-list{margin:0;padding:0;list-style:none}.extra-input-cart-warning-list li{line-height:1.4}.extra-input-cart-warning-list li+li{margin-top:4px}.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-row{display:flex;gap:6px}.design-save-btn,.design-share-btn{flex:1;padding:8px 12px;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s}.design-save-btn{background:#607d8b}.design-save-btn:hover:not(:disabled){background:#455a64}.design-share-btn{background:#7b1fa2}.design-share-btn:hover:not(:disabled){background:#6a1b9a}.design-save-btn:disabled,.design-share-btn:disabled{background:#ccc;cursor:not-allowed}.design-share-url{font-size:11px;letter-spacing:0;word-break:break-all;max-width:180px}.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}@media(max-width:768px){.design-actions{margin-top:16px}}.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;transition:margin-bottom .25s ease}.example-picker.is-collapsed .example-picker-header{margin-bottom:0}.example-picker-header h2{margin:0;color:#333;font-size:18px}.example-picker-header .collapsible-toggle{flex:1;display:flex;align-items:center;justify-content:space-between;gap:8px;background:none;border:none;padding:0;cursor:pointer;text-align:left}.example-picker-header .collapsible-toggle:hover h2{color:#e91e63}.collapsible-content{overflow:hidden;max-height:2000px;opacity:1;transition:max-height .3s ease-out,opacity .2s ease}.collapsible-content.is-collapsed{max-height:0;opacity:0}.collapse-icon{display:inline-block;font-size:11px;color:#888;flex-shrink:0;transition:transform .25s ease}.collapse-icon.is-collapsed{transform:rotate(-90deg)}.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}@media(max-width:768px){.example-category-select{font-size:16px}}.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}.tutorial-overlay{position:fixed;inset:0;z-index:9500;pointer-events:none}.tutorial-spotlight{position:fixed;inset:0;width:100%;height:100%;pointer-events:all}.tutorial-backdrop{position:fixed;inset:0;background:#000000a6;pointer-events:all}.tutorial-tooltip{position:fixed;background:#fff;border-radius:12px;padding:22px 24px 18px;width:340px;max-width:calc(100vw - 24px);box-shadow:0 8px 32px #00000038;pointer-events:all;z-index:9501}.tutorial-tooltip-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:10px}.tutorial-tooltip-title{margin:0;font-size:1.05rem;font-weight:600;color:#222;line-height:1.3}.tutorial-close-btn{background:none;border:none;cursor:pointer;color:#aaa;font-size:1rem;padding:0;line-height:1;flex-shrink:0;transition:color .15s}.tutorial-close-btn:hover{color:#555}.tutorial-tooltip-content{margin:0 0 18px;font-size:.93rem;color:#555;line-height:1.55}.tutorial-footer{display:flex;align-items:center;justify-content:space-between;gap:8px}.tutorial-skip-btn{background:none;border:none;cursor:pointer;color:#aaa;font-size:.82rem;padding:4px 0;text-decoration:underline;transition:color .15s}.tutorial-skip-btn:hover{color:#777}.tutorial-nav{display:flex;align-items:center;gap:8px}.tutorial-progress{font-size:.78rem;color:#bbb;min-width:36px;text-align:center}.tutorial-back-btn{background:none;border:1px solid #ddd;border-radius:6px;padding:6px 13px;cursor:pointer;font-size:.88rem;color:#555;transition:background .15s}.tutorial-back-btn:hover{background:#f5f5f5}.tutorial-next-btn{background:#e91e63;color:#fff;border:none;border-radius:6px;padding:7px 16px;cursor:pointer;font-size:.9rem;font-weight:500;transition:background .15s}.tutorial-next-btn:hover{background:#c2185b}.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}@media(min-width:769px){.right-column .tab-panel{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:768px){.asset-selector{font-size:16px}}@media(max-width:600px){.main-container{gap:10px}.right-column{gap:8px}.font-picker{padding:8px}}.font-color-section{display:flex;flex-direction:column;gap:12px}.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}.font-disclaimer{margin:0 0 10px;padding:8px 10px;font-size:13px;color:#555;background:#fff8e1;border-left:3px solid #f9a825;border-radius:4px}.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}.font-picker .asset-selector{width:100%;margin-bottom:15px}.asset-selector:hover{border-color:#e91e63}.asset-selector:focus{outline:none;border-color:#e91e63}.assets-container{display:flex;flex-direction:column;gap:12px;margin-top:8px}@media(max-width:768px){.search-panel--hidden-mobile{display:none}}.mobile-tab-bar{display:none}@media(max-width:768px){.main-container{flex-direction:column;align-items:stretch;width:100%}.left-column,.right-column{width:100%;flex-shrink:1}.mobile-tab-bar{display:flex;background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a;margin-bottom:10px}.mobile-tab{flex:1;padding:11px 4px;border:none;background:none;font-size:12px;font-weight:500;color:#888;cursor:pointer;border-bottom:3px solid transparent;transition:color .15s,border-color .15s;line-height:1.2;position:relative}.mobile-tab.active{color:#e91e63;border-bottom-color:#e91e63;font-weight:600}.mobile-tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;font-size:10px;font-weight:700;color:#fff;background:#e91e63;border-radius:9px;margin-left:4px;vertical-align:middle}.tab-panel{display:none}.tab-panel.tab-active{display:block}.tutorial-active .mobile-tab-bar{display:none}.tutorial-active .tab-panel{display:block!important}.mobile-preview-strip{position:sticky;top:0;z-index:50;display:flex;align-items:center;gap:8px;padding:8px 10px;background:#fff;border-radius:0 0 8px 8px;box-shadow:0 2px 6px #0000001f;margin:0 -4px 10px}.mobile-preview-items-wrapper{flex:1;min-width:0;position:relative}.mobile-preview-items{display:flex;align-items:center;gap:1px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}.mobile-preview-items::-webkit-scrollbar{display:none}.preview-scroll-arrow{position:absolute;top:0;bottom:0;width:28px;display:flex;align-items:center;font-size:20px;font-weight:700;color:#888;pointer-events:auto;z-index:1}.preview-scroll-arrow--left{left:0;background:linear-gradient(to right,white 55%,transparent);justify-content:flex-start;padding-left:2px}.preview-scroll-arrow--right{right:0;background:linear-gradient(to left,white 55%,transparent);justify-content:flex-end;padding-right:2px}.mobile-preview-item{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center}.mobile-preview-item.space{width:10px}.mobile-preview-svg{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.mobile-preview-svg svg{width:100%;height:100%}.mobile-preview-count{flex-shrink:0;font-size:12px;font-weight:600;color:#e91e63;padding:2px 8px;background:#e91e6314;border-radius:10px;white-space:nowrap}}.tutorial-help-btn{position:fixed;bottom:24px;left:24px;width:48px;height:48px;border-radius:50%;background:#e91e63;color:#fff;border:none;cursor:pointer;font-size:1.4rem;font-weight:700;line-height:1;box-shadow:0 2px 12px #e91e6373;z-index:900;display:flex;align-items:center;justify-content:center;transition:transform .15s,box-shadow .15s}.tutorial-help-btn:hover{transform:scale(1.1);box-shadow:0 4px 18px #e91e638c}.library-controls{display:none}@media(max-width:768px){.library-controls{display:flex;align-items:center;gap:10px;background:#fff;border-radius:8px;box-shadow:0 2px 6px #0000001a;padding:10px 12px;margin-bottom:8px}.library-font-select{flex:1;min-width:0}.library-color-swatch{flex-shrink:0;width:42px;height:42px;border-radius:8px;border:2px solid #ddd;cursor:pointer;padding:0;transition:transform .1s,border-color .1s}.library-color-swatch:active{transform:scale(.92);border-color:#e91e63}.mobile-add-space-btn{width:100%;padding:10px;background:#4caf50;color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer}.mobile-add-space-btn:active{background:#45a049}.mobile-color-swatch.selected{border-color:#e91e63;box-shadow:0 0 0 2px #e91e63}}.app-footer{width:100%;background-color:#2c3e50;color:#bdc3c7;padding:10px 20px;border-top:1px solid #34495e}.footer-content{max-width:1400px;margin:0 auto;padding:0 15px;display:flex;flex-wrap:wrap;align-items:center;justify-content:flex-start;gap:6px;font-size:.72rem}.footer-no-return{font-style:italic}.footer-sep{color:#4a5e6e}.footer-copyright{color:#7f8c8d}.footer-content a{color:#bdc3c7;text-decoration:none;transition:color .2s}.footer-content a:hover{color:#ecf0f1;text-decoration:underline}.customer-page{min-height:100vh;display:flex;flex-direction:column}.content-wrapper{flex:1;width:100%;max-width:1400px;margin:0 auto;padding:0 15px 15px;box-sizing:border-box}.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}.translation-inputs{display:flex;flex-direction:column;gap:8px}.translation-input-row{display:flex;align-items:center;gap:8px}.translation-input-row input{flex:1;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px}.translation-input-row input.error{border-color:#dc3545}.lang-tag{display:inline-block;padding:2px 7px;border-radius:4px;font-size:11px;font-weight:700;letter-spacing:.04em;background:#e8f5e9;color:#2e7d32;border:1px solid #a5d6a7;min-width:32px;text-align:center;flex-shrink:0}.lang-tag.en{background:#e3f2fd;color:#1565c0;border-color:#90caf9}.lang-tag.de{background:#fff3e0;color:#e65100;border-color:#ffcc80}.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-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:flex;justify-content:center}.changelog-section,.todo-section,.extra-section{background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:30px;width:100%;max-width:900px}.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: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}.garland-preview-lookup{max-width:900px;margin:0 auto;padding:20px}.lookup-form{display:flex;gap:10px;margin-bottom:20px}.lookup-input{flex:1;padding:10px 14px;font-size:16px;border:1px solid #ccc;border-radius:6px;max-width:280px}.lookup-btn{padding:10px 20px;font-size:16px;background:#4a7c59;color:#fff;border:none;border-radius:6px;cursor:pointer}.lookup-btn:disabled{opacity:.6;cursor:not-allowed}.lookup-error{color:#c0392b;margin-bottom:16px}.preview-result{margin-top:24px}.preview-meta{background:#f5f5f5;border-radius:8px;padding:16px;margin-bottom:20px;display:flex;flex-wrap:wrap;gap:8px 32px}.preview-meta p{margin:0}.preview-image-container{margin-bottom:24px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:16px;display:inline-block}.preview-image{max-width:100%;max-height:200px;display:block}.no-image-note{color:#888;font-style:italic;margin-bottom:24px}.garland-preview-row{display:flex;flex-wrap:wrap;align-items:flex-end;gap:4px;padding:16px;background:#fff;border:1px solid #e0e0e0;border-radius:8px;min-height:100px}.garland-preview-item{width:70px;height:70px;display:flex;align-items:flex-end;justify-content:center}.garland-preview-item div,.garland-preview-item img{width:100%;height:100%;object-fit:contain}.garland-item-table{width:100%;border-collapse:collapse;margin-top:8px;font-size:14px}.garland-item-table th,.garland-item-table td{text-align:left;padding:7px 12px;border-bottom:1px solid #e0e0e0}.garland-item-table th{background:#f5f5f5;font-weight:600;color:#555}.garland-item-table tbody tr:hover{background:#fafafa}.garland-item-table td:first-child{color:#888;width:48px;text-align:right;padding-right:16px}.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:13px;font-weight:600;max-width:160px;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:18px;flex-shrink:0}.feedback-button-label{white-space:normal;line-height:1.2;text-align:left}@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}
