:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#333;background-color:#f5f5f5;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{width:100%;height:100vh;overflow:hidden}.app-header{background:var(--bg-primary);border-bottom:1px solid var(--border-color);padding:0 24px;height:var(--header-height);position:sticky;top:0;z-index:1000;box-shadow:var(--shadow-sm);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.header-content{display:flex;justify-content:space-between;align-items:center;height:100%;max-width:1440px;margin:0 auto;gap:24px}.header-brand{display:flex;align-items:center;flex:1;min-width:0}.logo-link{display:flex;align-items:center;text-decoration:none;transition:transform var(--transition-base);flex-shrink:0}.logo-link:hover{transform:scale(1.05)}.logo-wrapper{height:45px;display:flex;align-items:center;flex-shrink:0}.logo-image{height:100%;height:40px;max-width:120px;object-fit:contain;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.app-name{display:flex;flex-direction:column;margin-left:8px;flex-shrink:0}.app-subtitle{font-size:14px;font-weight:500;color:var(--text-secondary);letter-spacing:.3px;opacity:.9;white-space:nowrap}.header-actions{display:flex;align-items:center;gap:12px;flex-shrink:0}.online-status-indicator{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:6px;font-size:.85em;font-weight:500;transition:all .3s}.online-status-indicator.online{background:var(--success-bg, #d4edda);color:var(--success-text, #155724)}.online-status-indicator.offline{background:var(--danger-bg, #f8d7da);color:var(--danger-text, #721c24)}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;animation:pulse 2s ease-in-out infinite}.online-status-indicator.online .status-dot{background:var(--success-color, #28a745)}.online-status-indicator.offline .status-dot{background:var(--danger-color, #dc3545)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}[data-theme=dark] .online-status-indicator.online{background:var(--success-bg-dark, #1a4a1a);color:var(--success-text-dark, #4caf50)}[data-theme=dark] .online-status-indicator.offline{background:var(--danger-bg-dark, #5a1a1a);color:var(--danger-text-dark, #ff6b6b)}[data-theme=dark] .online-status-indicator.online .status-dot{background:var(--success-color-dark, #4caf50)}[data-theme=dark] .online-status-indicator.offline .status-dot{background:var(--danger-color-dark, #ff6b6b)}.btn-ghost{background:transparent;border:1px solid var(--border-color);color:var(--text-primary);padding:10px 16px;border-radius:var(--radius-lg);font-size:14px;font-weight:500;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:8px;height:44px;flex-shrink:0}.btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-ghost:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--accent-color);color:#fff;border:none;padding:10px 20px;border-radius:var(--radius-lg);font-size:14px;font-weight:600;cursor:pointer;transition:all var(--transition-base);display:flex;align-items:center;gap:8px;height:44px;position:relative;flex-shrink:0}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.btn-theme{min-width:44px;width:90px;height:44px;padding:0;display:flex;align-items:center;justify-content:center}.app-header .btn-theme.btn-ghost{background:#3b82f61f;border:2px solid var(--accent-color);color:var(--accent-color);font-weight:600;box-shadow:0 1px 3px #3b82f633}.app-header .btn-theme.btn-ghost:hover:not(:disabled){background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:0 2px 8px #3b82f666}.theme-icon{font-size:18px}.btn-text{white-space:nowrap}.btn-auth{min-width:100px}.user-dropdown-wrapper{position:relative;flex-shrink:0}.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:8px;display:flex;flex-direction:column;gap:6px;z-index:1100;opacity:0;pointer-events:none;transform:translateY(-6px);transition:opacity .18s ease,transform .18s ease}.user-dropdown-wrapper.open .user-dropdown{opacity:1;pointer-events:auto;transform:translateY(0)}.user-dropdown-info{display:flex;flex-direction:column;padding:6px 10px 8px;border-bottom:1px solid var(--border-color)}.user-dropdown-label{font-size:11px;color:var(--text-secondary);font-weight:400;line-height:1.4}.user-dropdown-name{font-size:14px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-dropdown-change-password{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:var(--radius-md, 6px);font-size:14px;font-weight:500;color:var(--text-primary);cursor:pointer;transition:background .15s ease;text-align:left}.user-dropdown-change-password:hover{background:var(--bg-tertiary, rgba(0, 0, 0, .05))}.user-dropdown-logout{display:flex;align-items:center;gap:8px;width:100%;padding:8px 10px;background:transparent;border:none;border-radius:var(--radius-md, 6px);font-size:14px;font-weight:500;color:var(--danger-color, #e53e3e);cursor:pointer;transition:background .15s ease,color .15s ease;text-align:left}.user-dropdown-logout:hover{background:#e53e3e14}.cp-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:2000}.cp-modal{background:var(--bg-primary, #fff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-lg, 0 20px 60px rgba(0,0,0,.3));width:100%;max-width:380px;padding:24px}.cp-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.cp-modal-header h3{margin:0;font-size:18px;color:var(--text-primary)}.cp-modal-close{background:none;border:none;font-size:22px;line-height:1;cursor:pointer;color:var(--text-secondary);padding:0 4px}.cp-modal-close:hover{color:var(--text-primary)}.cp-modal-form{display:flex;flex-direction:column;gap:14px}.cp-form-group{display:flex;flex-direction:column;gap:4px}.cp-form-group label{font-size:13px;font-weight:500;color:var(--text-secondary)}.cp-form-group input{padding:9px 12px;border:1px solid var(--border-color, #ddd);border-radius:var(--radius-md, 8px);font-size:14px;background:var(--bg-secondary, #f9fafb);color:var(--text-primary);outline:none;transition:border-color .2s}.cp-form-group input:focus{border-color:var(--accent-color, #3b82f6)}.cp-error{background:var(--danger-bg, #fee2e2);color:var(--danger-color, #dc2626);border-radius:var(--radius-md, 8px);padding:8px 12px;font-size:13px}.cp-success{background:var(--success-bg, #d1fae5);color:var(--success-color, #065f46);border-radius:var(--radius-md, 8px);padding:8px 12px;font-size:13px}.cp-form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:4px}.cp-btn-cancel,.cp-btn-submit{padding:9px 18px;border:none;border-radius:var(--radius-md, 8px);font-size:14px;font-weight:500;cursor:pointer;transition:opacity .2s}.cp-btn-cancel{background:var(--bg-tertiary, #e5e7eb);color:var(--text-primary)}.cp-btn-cancel:hover:not(:disabled){opacity:.8}.cp-btn-submit{background:var(--accent-color, #3b82f6);color:#fff}.cp-btn-submit:hover:not(:disabled){opacity:.85}.cp-btn-cancel:disabled,.cp-btn-submit:disabled{opacity:.6;cursor:not-allowed}.btn-icon{font-size:16px}.user-profile{display:flex;align-items:center;gap:8px;padding:0 12px;height:44px;background:transparent;border-radius:var(--radius-lg);border:1px solid var(--border-color);transition:all var(--transition-base);flex-shrink:0;max-width:200px}.user-profile:hover{background:var(--bg-tertiary);border-color:var(--accent-color);transform:translateY(-1px)}.user-avatar{width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;flex-shrink:0}.avatar-icon{font-size:16px;color:#fff}.user-name{font-size:14px;font-weight:500;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.btn-cart{position:relative;min-width:44px;justify-content:center}.cart-icon{font-size:18px}.cart-badge{position:absolute;top:-4px;right:-4px;background:var(--danger-color);color:#fff;font-size:10px;font-weight:700;min-width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-primary);animation:pulse 2s infinite;z-index:1}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}.burger-menu{width:44px;height:44px;background:transparent;border:1px solid var(--border-color);border-radius:var(--radius-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;cursor:pointer;transition:all var(--transition-base);position:relative;z-index:1002;flex-shrink:0}.burger-menu:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}.burger-menu.active{background:var(--accent-color);border-color:var(--accent-color)}.burger-menu.active .burger-line{background:#fff}.burger-line{width:20px;height:2px;background:var(--text-primary);border-radius:1px;transition:all var(--transition-base)}.burger-menu.active .burger-line:nth-child(1){transform:translateY(6px) rotate(45deg)}.burger-menu.active .burger-line:nth-child(2){opacity:0}.burger-menu.active .burger-line:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.tooltip{position:relative}.tooltip:hover:after{content:attr(data-tooltip);position:absolute;top:100%;left:50%;transform:translate(-50%);padding:6px 10px;background:var(--bg-tertiary);color:var(--text-primary);font-size:12px;white-space:nowrap;border-radius:var(--radius-sm);margin-top:8px;z-index:1000;border:1px solid var(--border-color);box-shadow:var(--shadow-sm);pointer-events:none}@media(max-width:1024px){.app-header{padding:0 20px;height:64px}.header-content{gap:16px}.logo-wrapper{height:40px}.logo-image{max-width:120px}.app-subtitle{font-size:13px}.btn-ghost,.btn-primary{height:40px;padding:8px 14px;font-size:13px}.burger-menu{width:40px;height:40px}.btn-theme,.btn-auth,.btn-cart{min-width:40px;height:40px}.btn-auth{min-width:auto;padding:8px}.btn-auth .btn-text{display:none}.user-profile{padding:6px 12px;max-width:150px}.user-name{font-size:13px}}@media(max-width:768px){.app-header{padding:0 16px;height:60px}.header-content{gap:12px}.app-name{display:none}.logo-wrapper{height:36px}.logo-image{max-width:100px}.header-actions{gap:8px}.btn-ghost,.btn-primary{height:36px;padding:6px 10px;font-size:12px}.btn-theme,.btn-auth,.btn-cart,.burger-menu{width:36px;height:36px;min-width:36px}.theme-icon,.cart-icon,.btn-icon{font-size:16px}.user-profile,.btn-text{display:none}.cart-badge{font-size:9px;min-width:16px;height:16px;padding:0 3px;top:-3px;right:-3px}.burger-line{width:18px}}@media(max-width:480px){.app-header{padding:0 12px;height:56px}.logo-wrapper{height:32px}.logo-image{max-width:90px}.header-actions{gap:6px}.btn-theme,.btn-auth,.btn-cart,.burger-menu{width:34px;height:34px;min-width:34px}.theme-icon,.cart-icon,.btn-icon{font-size:15px}.cart-badge{font-size:8px;min-width:14px;height:14px;padding:0 2px;top:-2px;right:-2px}.burger-line{width:16px;height:2px}.burger-menu.active .burger-line:nth-child(1){transform:translateY(5px) rotate(45deg)}.burger-menu.active .burger-line:nth-child(3){transform:translateY(-5px) rotate(-45deg)}}@media(max-width:360px){.app-header{padding:0 8px}.logo-wrapper{height:30px}.logo-image{max-width:80px}.btn-theme,.btn-auth,.btn-cart,.burger-menu{width:32px;height:32px;min-width:32px}.header-actions{gap:4px}}@media(max-width:768px)and (orientation:landscape){.app-header{height:56px}.logo-wrapper{height:34px}.header-actions{gap:10px}}@media(hover:none)and (pointer:coarse){.btn-ghost,.btn-primary,.btn-theme,.btn-auth,.btn-cart,.burger-menu,.user-profile{min-height:44px;min-width:44px}.btn-ghost:active,.btn-primary:active,.burger-menu:active{transform:scale(.95)}.btn-ghost:hover:not(:disabled),.btn-primary:hover:not(:disabled),.burger-menu:hover{transform:none}}[data-theme=dark] .app-header{background:var(--bg-primary);border-bottom-color:var(--border-color);box-shadow:var(--shadow-sm)}[data-theme=dark] .app-subtitle{color:var(--text-secondary)}[data-theme=dark] .btn-ghost{background:transparent;border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .btn-ghost:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color)}[data-theme=dark] .app-header .btn-theme.btn-ghost{background:#60a5fa26;border-color:var(--accent-color);color:var(--accent-color);box-shadow:0 1px 3px #0000004d}[data-theme=dark] .app-header .btn-theme.btn-ghost:hover:not(:disabled){background:var(--accent-color);color:#0f172a;box-shadow:0 2px 8px #60a5fa66}[data-theme=dark] .user-profile{background:transparent;border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .user-profile:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}[data-theme=dark] .user-name{color:var(--text-primary)}[data-theme=dark] .burger-menu{background:transparent;border-color:var(--border-color)}[data-theme=dark] .burger-menu:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}[data-theme=dark] .burger-menu.active{background:var(--accent-color);border-color:var(--accent-color)}[data-theme=dark] .burger-line{background:var(--text-primary)}[data-theme=dark] .tooltip:hover:after{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .btn-ghost:disabled,[data-theme=light] .btn-ghost:disabled{opacity:.5;cursor:not-allowed;border-color:var(--border-color)}[data-theme=dark] .btn-primary:disabled,[data-theme=light] .btn-primary:disabled{opacity:.5;cursor:not-allowed;background:var(--accent-color)}.product-side-selector{margin-bottom:20px}.product-side-header{margin-bottom:12px}.product-side-header h3{margin:0;font-size:14px;font-weight:600;color:var(--text-color, #333)}.product-params{display:flex;flex-direction:column;gap:12px;margin-bottom:16px;padding:12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);position:relative;z-index:1}.param-group{display:flex;flex-direction:column;gap:6px;position:relative;z-index:1}.param-label{font-size:12px;font-weight:500;color:var(--text-color-secondary, #666);margin:0}.custom-dropdown{position:relative;z-index:10;pointer-events:auto}.dropdown-button{width:100%;padding:8px 12px;background:var(--bg-color, #fff);border:1px solid var(--border-color, #ddd);border-radius:6px;font-size:13px;color:var(--text-color, #333);cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:all .2s ease;pointer-events:auto;position:relative;z-index:100}.dropdown-button:hover{border-color:var(--primary-color, #007bff);background:var(--bg-color-hover, #f8f9fa)}.dropdown-button:focus{outline:none;border-color:var(--primary-color, #007bff);box-shadow:0 0 0 2px #007bff40}.dropdown-button.disabled{opacity:.6;cursor:not-allowed}.dropdown-button.disabled:hover{border-color:var(--border-color, #ddd);background:var(--bg-color, #fff)}.dropdown-arrow{font-size:10px;transition:transform .2s ease;color:var(--text-color-secondary, #666)}.dropdown-arrow.open{transform:rotate(180deg)}.dropdown-menu{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--bg-color, #fff);border:1px solid var(--border-color, #ddd);border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:100;margin-top:0;padding:0}.dropdown-item{width:100%;padding:6px 12px;margin:0;background:none;border:none;text-align:left;font-size:13px;color:var(--text-color, #333);cursor:pointer;transition:background-color .2s ease;pointer-events:auto;position:relative;z-index:auto;flex-shrink:0;line-height:1.2;box-sizing:border-box;height:auto;min-height:auto}.dropdown-item:hover{background:var(--bg-color-hover, #f8f9fa)!important;background-color:var(--bg-color-hover, #e3f2fd)!important;color:var(--primary-color, #007bff)!important;font-weight:500;transform:translate(2px);box-shadow:0 2px 4px #0000001a;transition:all .15s ease}.dropdown-item.selected{background:var(--primary-color-light, #e3f2fd)!important;background-color:var(--primary-color-light, #e3f2fd)!important;color:var(--primary-color, #007bff)!important;font-weight:600;border-left:3px solid var(--primary-color, #007bff);padding-left:9px}[data-theme=dark] .dropdown-item.selected{background:#1a4d7a!important;background-color:#1a4d7a!important;color:#4da3ff!important;font-weight:600;border-left:3px solid #4da3ff;padding-left:9px}.side-tabs{display:flex;gap:4px;margin-bottom:8px;flex-wrap:wrap;width:100%}.side-tab{padding:8px 12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;font-size:12px;color:var(--text-primary);cursor:pointer;transition:all .2s ease;flex:1 1 auto;min-width:0;max-width:100%;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-sizing:border-box}.side-tab:hover{background:var(--bg-secondary);border-color:var(--accent-color)}.side-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color);font-weight:500}.product-params-summary{padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--accent-color);border-radius:6px;margin-top:8px}.summary-text{font-size:12px;color:var(--accent-color);font-weight:500;text-align:center}.dropdown-overlay{position:fixed;inset:0;z-index:999;background:transparent;pointer-events:auto}[data-theme=dark] .product-params{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .dropdown-button{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .dropdown-button:hover{background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .dropdown-menu{background:#2d2d2d!important;background-color:#2d2d2d!important;border-color:var(--border-color-dark, #444)}.dropdown-menu.size-menu,.dropdown-menu.quantity-menu{background:#fff!important;background-color:#fff!important;pointer-events:auto!important;padding:0!important;margin:0!important;display:flex!important;flex-direction:column!important;box-sizing:border-box!important;height:fit-content!important;min-height:0!important;max-height:none!important;align-items:stretch!important;z-index:100!important}[data-theme=dark] .dropdown-menu.size-menu,[data-theme=dark] .dropdown-menu.quantity-menu{background:#2d2d2d!important;background-color:#2d2d2d!important;pointer-events:auto!important;padding:0!important;margin:0!important;display:flex!important;flex-direction:column!important;box-sizing:border-box!important;height:fit-content!important;min-height:0!important;max-height:none!important;align-items:stretch!important;z-index:100!important}.dropdown-menu.size-menu .dropdown-item,.dropdown-menu.quantity-menu .dropdown-item{pointer-events:auto!important;position:relative;z-index:auto!important}[data-theme=dark] .dropdown-item{color:var(--text-color-dark, #fff)}[data-theme=dark] .dropdown-item:hover{background:var(--bg-color-hover-dark, #3d3d3d)!important;background-color:#3d3d3d!important;color:#4da3ff!important;font-weight:500;transform:translate(2px);box-shadow:0 2px 4px #0000004d;transition:all .15s ease}[data-theme=dark] .dropdown-item.selected{background:var(--primary-color-dark, #0056b3);color:var(--primary-color-light-dark, #b3d9ff)}[data-theme=dark] .side-tab{background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .side-tab:hover{background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .side-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}[data-theme=dark] .product-params-summary{background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .summary-text{color:var(--accent-color)}@media(max-width:768px){.product-params{gap:8px;padding:8px}.side-tabs{gap:2px}.side-tab{padding:6px 8px;font-size:11px;min-width:50px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dropdown-button,.dropdown-item{padding:6px 10px;font-size:12px}}@keyframes dropdownOpen{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-menu{animation:dropdownOpen .2s ease-out}.dropdown-button:focus-visible{outline:2px solid var(--primary-color, #007bff);outline-offset:2px}.side-tab:focus-visible{outline:2px solid var(--primary-color, #007bff);outline-offset:2px}.dropdown-menu::-webkit-scrollbar{width:6px}.dropdown-menu::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:3px}.dropdown-menu::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.dropdown-menu::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}[data-theme=dark] .dropdown-menu::-webkit-scrollbar-track{background:var(--bg-tertiary)}[data-theme=dark] .dropdown-menu::-webkit-scrollbar-thumb{background:var(--border-color)}[data-theme=dark] .dropdown-menu::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.input-with-arrows{display:flex;align-items:center;gap:4px}.arrow-btn{background:var(--btn-secondary-bg, #f0f0f0);border:1px solid var(--btn-secondary-border, #ccc);color:var(--btn-secondary-text, #333);width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:4px;font-size:12px;transition:all .2s ease}.arrow-btn:hover{background:var(--btn-secondary-hover, #e0e0e0);border-color:var(--btn-secondary-hover-border, #999)}.arrow-btn:active{background:var(--btn-secondary-active, #d0d0d0);transform:scale(.95)}.input-with-arrows .property-input{flex:1;margin:0}.number-input-with-arrows{position:relative;display:flex;align-items:stretch;width:100%}.number-input-with-arrows .property-input{flex:1;padding-right:40px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--input-bg, #fff);color:var(--text-color, #333)}.number-input-with-arrows .custom-arrows{position:absolute;right:1px;top:1px;bottom:1px;width:20px;display:flex;flex-direction:column;border-left:1px solid var(--border-color, #ddd);border-radius:0 4px 4px 0}.number-input-with-arrows .arrow-up,.number-input-with-arrows .arrow-down{flex:1;border:none;background:var(--btn-secondary-bg, #f0f0f0);color:var(--btn-secondary-text, #333);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:8px;line-height:1;transition:all .2s ease;-webkit-user-select:none;user-select:none;padding:0;min-height:16px}.number-input-with-arrows .arrow-up{border-radius:0 4px 0 0;border-bottom:1px solid var(--btn-secondary-border, #ccc)}.number-input-with-arrows .arrow-down{border-radius:0 0 4px}.number-input-with-arrows .property-input{flex:1;padding-right:22px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--input-bg, #fff);color:var(--text-color, #333)}.number-input-with-arrows .arrow-up:hover,.number-input-with-arrows .arrow-down:hover{background:var(--btn-secondary-hover, #e0e0e0)}.number-input-with-arrows .arrow-up:active,.number-input-with-arrows .arrow-down:active{background:var(--btn-secondary-active, #d0d0d0);transform:scale(.95)}.property-input[type=number]{-moz-appearance:auto;appearance:auto;-webkit-appearance:auto}.property-input[type=number]::-webkit-inner-spin-button{-webkit-appearance:inner-spin-button;opacity:1;height:20px;cursor:pointer;background:#f0f0f0;border:1px solid #ccc;border-radius:2px}.property-input[type=number]::-webkit-outer-spin-button{-webkit-appearance:outer-spin-button;opacity:1;cursor:pointer;background:#f0f0f0;border:1px solid #ccc;border-radius:2px}.property-input[type=number]::-moz-number-spin-box{opacity:1;cursor:pointer}.property-input[type=number]{padding-right:20px}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:auto!important;opacity:1!important;height:20px!important;cursor:pointer!important}input[type=number]::-moz-number-spin-box{opacity:1!important}.button-group{display:flex;gap:4px;flex-wrap:wrap}.button-group .btn-secondary{flex:1;min-width:40px;padding:8px 12px}.property-row{display:flex;gap:12px;margin-bottom:12px;align-items:flex-start}.property-input[type=range]{-webkit-appearance:none;appearance:none;background:transparent;cursor:pointer}.property-input[type=range]::-webkit-slider-track{background:var(--border-color, #ddd);height:6px;border-radius:3px}.property-input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--primary-color, #007bff);border-radius:50%;cursor:pointer;margin-top:-5px}.property-input[type=range]::-moz-range-track{background:var(--border-color, #ddd);height:6px;border-radius:3px}.property-input[type=range]::-moz-range-thumb{width:16px;height:16px;background:var(--primary-color, #007bff);border-radius:50%;cursor:pointer;border:none}.property-input[type=color]{width:100%;height:36px;border:1px solid var(--border-color, #ddd);border-radius:4px;cursor:pointer;padding:2px}.property-input[type=select]{width:100%;padding:8px 12px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--input-bg, #fff);color:var(--text-color, #333)}.property-input[rows]{resize:vertical;min-height:60px;font-family:inherit}.btn-secondary.active{background:var(--primary-color, #007bff);color:#fff;border-color:var(--primary-color, #007bff)}.properties-panel .tooltip{position:relative}.properties-panel .tooltip:after{content:attr(data-tooltip);position:absolute;top:100%;left:50%;transform:translate(-50%);background:var(--bg-tertiary);color:var(--text-primary);padding:4px 8px;border-radius:4px;font-size:12px;white-space:nowrap;z-index:1000;margin-top:6px;opacity:0;transition:opacity .2s ease;pointer-events:none;border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.properties-panel .tooltip:hover:after{opacity:1}@media(max-width:768px){.property-row{flex-direction:column;gap:8px}.button-group{flex-direction:column}.input-with-arrows{flex-direction:column;gap:2px}.arrow-btn{width:100%;height:20px}.input-with-arrows .property-input{order:2}}@media(prefers-color-scheme:dark){:root{--bg-color: #1a1a1a;--panel-bg: #2d2d2d;--border-color: #404040;--text-color: #ffffff;--input-bg: #1a1a1a;--btn-secondary-bg: #404040;--btn-secondary-border: #555555;--btn-secondary-hover: #4a4a4a;--btn-secondary-hover-border: #666666;--btn-secondary-active: #353535;--btn-secondary-text: #ffffff;--primary-color: #4a9eff}}.properties-panel.dark,.dark .properties-panel{--bg-color: #1a1a1a;--panel-bg: #2d2d2d;--border-color: #404040;--text-color: #ffffff;--input-bg: #1a1a1a;--btn-secondary-bg: #404040;--btn-secondary-border: #555555;--btn-secondary-hover: #4a4a4a;--btn-secondary-hover-border: #666666;--btn-secondary-active: #353535;--btn-secondary-text: #ffffff;--primary-color: #4a9eff}.properties-panel{background:var(--panel-bg, #ffffff);color:var(--text-color, #333333);border-right:1px solid var(--border-color, #e0e0e0)}.dark .property-input,.properties-panel.dark .property-input{background:var(--input-bg, #ffffff);color:var(--text-color, #333333);border-color:var(--border-color, #dddddd)}.dark .property-input::placeholder,.properties-panel.dark .property-input::placeholder{color:var(--text-color, #333333);opacity:.5}.dark .btn-secondary,.properties-panel.dark .btn-secondary{background:var(--btn-secondary-bg, #f0f0f0);color:var(--btn-secondary-text, #333333);border-color:var(--btn-secondary-border, #cccccc)}.dark .btn-secondary:hover,.properties-panel.dark .btn-secondary:hover{background:var(--btn-secondary-hover, #e0e0e0);border-color:var(--btn-secondary-hover-border, #999999)}.dark .btn-secondary:active,.properties-panel.dark .btn-secondary:active{background:var(--btn-secondary-active, #d0d0d0)}.dark .arrow-up,.dark .arrow-down,.properties-panel.dark .arrow-up,.properties-panel.dark .arrow-down{background:var(--btn-secondary-bg, #f0f0f0);color:var(--btn-secondary-text, #333333)}.dark .arrow-up:hover,.dark .arrow-down:hover,.properties-panel.dark .arrow-up:hover,.properties-panel.dark .arrow-down:hover{background:var(--btn-secondary-hover, #e0e0e0)}.dark .arrow-up:active,.dark .arrow-down:active,.properties-panel.dark .arrow-up:active,.properties-panel.dark .arrow-down:active{background:var(--btn-secondary-active, #d0d0d0)}.dark select.property-input,.properties-panel.dark select.property-input{background:var(--input-bg, #ffffff);color:var(--text-color, #333333);border-color:var(--border-color, #dddddd)}.dark select.property-input option,.properties-panel.dark select.property-input option{background:var(--input-bg, #ffffff);color:var(--text-color, #333333)}.dark textarea.property-input,.properties-panel.dark textarea.property-input{background:var(--input-bg, #ffffff);color:var(--text-color, #333333);border-color:var(--border-color, #dddddd)}.dark .checkbox-label input,.properties-panel.dark .checkbox-label input{background:var(--input-bg, #ffffff);border-color:var(--border-color, #dddddd)}.dark .checkbox-label input:checked,.properties-panel.dark .checkbox-label input:checked{background:var(--primary-color, #007bff);border-color:var(--primary-color, #007bff)}.dark .property-input[type=range],.properties-panel.dark .property-input[type=range]{background:transparent}.dark .property-input[type=range]::-webkit-slider-track,.properties-panel.dark .property-input[type=range]::-webkit-slider-track{background:var(--border-color, #dddddd)}.dark .property-input[type=range]::-moz-range-track,.properties-panel.dark .property-input[type=range]::-moz-range-track{background:var(--border-color, #dddddd)}.dark .property-input[type=range]::-webkit-slider-thumb,.properties-panel.dark .property-input[type=range]::-webkit-slider-thumb{background:var(--primary-color, #4a9eff)}.dark .property-input[type=range]::-moz-range-thumb,.properties-panel.dark .property-input[type=range]::-moz-range-thumb{background:var(--primary-color, #4a9eff)}.dark .property-input[type=color],.properties-panel.dark .property-input[type=color]{border-color:var(--border-color, #dddddd)}.dark .btn-secondary.active,.properties-panel.dark .btn-secondary.active{background:var(--primary-color, #4a9eff);color:#fff;border-color:var(--primary-color, #4a9eff)}.floating-sidebar-toggle{position:fixed;top:50%;transform:translateY(-50%) translateZ(0);width:32px;height:60px;background:var(--bg-primary);border:1px solid var(--border-color);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--text-primary);box-shadow:var(--shadow-md);transition:background .2s ease-in-out,color .2s ease-in-out,transform .2s ease-in-out;z-index:50;margin:0;padding:0;outline:none}.floating-sidebar-toggle.left{left:0;border-radius:0 8px 8px 0;transition:left .3s ease-in-out,background .2s ease-in-out,color .2s ease-in-out,transform .2s ease-in-out}.floating-sidebar-toggle.right{right:0;border-radius:8px 0 0 8px;transition:right .3s ease-in-out,background .2s ease-in-out,color .2s ease-in-out,transform .2s ease-in-out}.floating-sidebar-toggle:hover{background:var(--accent-color);color:#fff;transform:translateY(calc(-50% - 2px)) translateZ(0)}[data-theme=dark] .floating-sidebar-toggle{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .floating-sidebar-toggle:hover{background:var(--accent-color);color:#fff;transform:translateY(calc(-50% - 2px)) translateZ(0)}@media(max-width:767px){.floating-sidebar-toggle{width:28px;height:50px;font-size:12px;z-index:1001;top:50%;transform:translateY(-50%)}.floating-sidebar-toggle.left{transition:left .3s ease-in-out,transform .3s ease-in-out}.floating-sidebar-toggle.right{transition:right .3s ease-in-out,transform .3s ease-in-out}.floating-sidebar-toggle.left,.floating-sidebar-toggle.right{z-index:1001}.sidebar.open+* .floating-sidebar-toggle.left,.properties-panel.open+* .floating-sidebar-toggle.right{z-index:1001}}@media(max-width:479px){.floating-sidebar-toggle{width:24px;height:44px;font-size:11px}}.auth-modal{max-width:450px;width:100%;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;margin:20px}.auth-modal .modal-header{flex-shrink:0}.auth-form{display:flex;flex-direction:column;gap:1rem;padding:1.5rem;overflow-y:auto;flex:1;min-height:0}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:500;color:var(--text-color);font-size:.95rem}.form-group input{padding:.75rem;border:1px solid var(--border-color);border-radius:6px;font-size:1rem;background:var(--bg-color);color:var(--text-color);transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--primary-color)}.form-group input:disabled{opacity:.6;cursor:not-allowed}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.btn-full{width:100%;margin-top:.5rem}.auth-toggle{text-align:center;padding-top:1rem;border-top:1px solid var(--border-color)}.link-btn{background:none;border:none;color:var(--primary-color);cursor:pointer;text-decoration:underline;font-size:.95rem}.link-btn:hover{color:var(--primary-hover)}.link-btn:disabled{opacity:.6;cursor:not-allowed}.error-message{background:var(--error-bg);color:var(--error-color);padding:.75rem;border-radius:6px;text-align:left;font-size:.9rem;white-space:pre-line;line-height:1.5}@media(max-width:600px){.auth-modal{margin:1rem;max-height:calc(100vh - 2rem)}.form-row{grid-template-columns:1fr}.auth-form{padding:1rem;gap:.75rem}}@media(max-height:600px){.auth-modal{max-height:calc(100vh - 2rem);margin:1rem}.auth-form{padding:1rem;gap:.75rem}.form-group{gap:.25rem}.form-group label{font-size:.85rem}.form-group input{padding:.5rem;font-size:.9rem}.modal-header{padding:12px 16px}.modal-header h2{font-size:18px}}@media(max-width:600px)and (max-height:600px){.auth-modal{max-height:calc(100vh - 1rem);margin:.5rem}.auth-form{padding:.75rem;gap:.5rem}}.load-project-modal{max-width:600px;width:100%;max-height:80vh;background:var(--bg-primary);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgb(0 0 0 / .1));overflow:hidden;display:flex;flex-direction:column}.load-project-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0;background:var(--bg-primary)}.load-project-modal .modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.load-project-modal .close-btn{background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm, 6px);transition:background .2s,color .2s}.load-project-modal .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.load-project-modal .modal-body{max-height:60vh;overflow-y:auto;padding:20px 24px;background:var(--bg-primary)}.load-project-modal .loading-message,.load-project-modal .empty-state{text-align:center;padding:2rem;color:var(--text-secondary)}.load-project-modal .projects-list{display:flex;flex-direction:column;gap:.75rem}.load-project-modal .project-item{padding:1rem 1.25rem;border:1px solid var(--border-color);border-radius:var(--radius-lg, 12px);cursor:pointer;transition:border-color .2s,background .2s,box-shadow .2s;background:var(--bg-secondary)}.load-project-modal .project-item:hover{border-color:var(--accent-color);background:var(--bg-tertiary);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1))}.load-project-modal .project-info{display:flex;flex-direction:column;gap:.5rem}.load-project-modal .project-name{font-weight:600;color:var(--text-primary);font-size:1.1rem}.load-project-modal .project-details{display:flex;align-items:center;gap:.5rem;font-size:.9rem;color:var(--text-secondary)}.load-project-modal .separator{color:var(--border-color)}.load-project-modal .element-count{color:var(--accent-color)}.load-project-modal .project-meta{margin-top:.5rem;font-size:.85rem;color:var(--text-secondary)}.load-project-modal .project-date{font-style:italic}.load-project-modal .error-message{background:var(--danger-bg, #fee2e2);color:var(--danger-color, #b91c1c);padding:.75rem 1rem;border-radius:var(--radius-md, 8px);border:1px solid var(--danger-border, #fecaca);text-align:center}.load-project-modal .project-actions{display:flex;gap:.5rem;margin-top:.75rem;justify-content:flex-end;flex-wrap:wrap}.load-project-modal .btn-edit,.load-project-modal .btn-delete,.load-project-modal .btn-save,.load-project-modal .btn-cancel{padding:.5rem 1rem;border:1px solid transparent;border-radius:var(--radius-md, 6px);cursor:pointer;font-size:.9rem;font-weight:500;transition:background .2s,color .2s,border-color .2s}.load-project-modal .btn-edit{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.load-project-modal .btn-edit:hover{background:var(--accent-hover, #2563eb);border-color:var(--accent-hover, #2563eb)}.load-project-modal .btn-delete{background:var(--danger-color);color:#fff;border-color:var(--danger-color)}.load-project-modal .btn-delete:hover{opacity:.9;filter:brightness(1.1)}.load-project-modal .project-edit-form{padding:.5rem 0}.load-project-modal .form-group{margin-bottom:1rem}.load-project-modal .form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.load-project-modal .form-group input,.load-project-modal .form-group textarea{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-md, 6px);font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary)}.load-project-modal .form-group input:focus,.load-project-modal .form-group textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 2px #3b82f633}.load-project-modal .form-group textarea{min-height:60px;resize:vertical}.load-project-modal .form-group input[type=checkbox]{width:auto;margin-right:.5rem;accent-color:var(--accent-color)}.load-project-modal .form-actions{display:flex;gap:.5rem;justify-content:flex-end;margin-top:1rem}.load-project-modal .btn-save{background:var(--success-color, #10b981);color:#fff;border-color:var(--success-color, #10b981)}.load-project-modal .btn-save:hover{opacity:.9;filter:brightness(1.1)}.load-project-modal .btn-cancel{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}.load-project-modal .btn-cancel:hover{background:var(--border-color)}.load-project-modal .delete-confirm-inline{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--text-primary)}.load-project-modal .btn-confirm-yes,.load-project-modal .btn-confirm-no{padding:4px 10px;border:none;border-radius:var(--radius-sm, 4px);cursor:pointer;font-size:13px;font-weight:500;transition:opacity .2s}.load-project-modal .btn-confirm-yes{background:var(--danger-color);color:#fff}.load-project-modal .btn-confirm-yes:hover{opacity:.9}.load-project-modal .btn-confirm-no{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.load-project-modal .btn-confirm-no:hover{opacity:.9}@media(max-width:600px){.load-project-modal{margin:1rem}.load-project-modal .project-actions{flex-direction:column}.load-project-modal .btn-edit,.load-project-modal .btn-delete{width:100%}}.save-project-modal{max-width:500px;width:100%;background:var(--bg-primary);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgb(0 0 0 / .1));overflow:hidden;display:flex;flex-direction:column}.save-project-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.save-project-modal .modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.save-project-modal .close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm, 6px);transition:all var(--transition-fast, .15s)}.save-project-modal .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.save-project-form{padding:24px;display:flex;flex-direction:column;gap:0}.save-project-modal .form-group{margin-bottom:1rem}.save-project-modal .form-group:last-of-type{margin-bottom:0}.save-project-modal .form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.95rem;color:var(--text-primary)}.save-project-modal .form-group input[type=text],.save-project-modal .form-group textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.save-project-modal .form-group input[type=text]:focus,.save-project-modal .form-group textarea:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f626}.save-project-modal .form-group textarea{resize:vertical;min-height:80px}.save-project-modal .form-group.checkbox-group{padding:14px 16px;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);margin-top:4px}.save-project-modal .checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:500;color:var(--text-primary)}.save-project-modal .checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-color)}.save-project-modal .checkbox-hint{margin:8px 0 0 28px;font-size:.875rem;color:var(--text-secondary);line-height:1.4}.save-project-modal .form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:1.5rem;padding-top:4px}.save-project-modal .form-actions .btn-secondary{padding:10px 18px;border-radius:var(--radius-md, 8px);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color)}.save-project-modal .form-actions .btn-secondary:hover{background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color)}.save-project-modal .form-actions .btn-primary{padding:10px 18px;border:none;border-radius:var(--radius-md, 8px);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;background:var(--accent-color);color:#fff}.save-project-modal .form-actions .btn-primary:hover{background:var(--accent-hover);box-shadow:0 2px 8px #3b82f659}@media(max-width:600px){.save-project-modal{margin:1rem;max-width:calc(100vw - 2rem)}.save-project-form{padding:16px}.save-project-modal .form-actions{flex-direction:column-reverse;margin-top:1.25rem}.save-project-modal .form-actions button{width:100%}}.buy-modal{max-width:900px;width:90vw;padding:0;max-height:90vh;box-sizing:border-box;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgb(0 0 0 / .1))}.buy-modal .modal-header{padding:20px 25px;border-bottom:1px solid var(--border-color);flex-shrink:0;background:var(--bg-primary)}.buy-modal .modal-header h2{color:var(--text-primary)}.buy-modal .close-btn{color:var(--text-secondary)}.buy-modal .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.buy-modal-content{display:grid;grid-template-columns:1fr 1fr;gap:30px;padding:25px 30px;flex:1;min-height:0;overflow-y:auto;overflow-x:hidden}@media(max-width:768px){.buy-modal-content{grid-template-columns:1fr;gap:20px;padding:20px 15px}.buy-modal{max-width:95vw;max-height:95vh}.buy-modal .modal-header{padding:15px 20px}.buy-modal-preview{padding:15px;gap:12px;max-width:100%;overflow:hidden}.buy-modal-preview .preview-container{min-height:250px;max-height:350px}.buy-modal-preview .preview-image{max-height:300px;max-width:100%}.buy-modal-preview .preview-arrow{width:35px;height:35px;font-size:18px}.buy-modal-preview .preview-arrow-left{left:5px}.buy-modal-preview .preview-arrow-right{right:5px}.buy-modal-product-info{padding:20px 15px;min-height:auto}.buy-modal-form{padding:0}.buy-modal-form .form-actions{padding:15px 0 0;flex-wrap:wrap}.buy-modal-form .form-actions button{flex:1;min-width:120px}}@media(max-width:480px){.buy-modal{max-width:100vw;max-height:100vh;margin:0;border-radius:0}.buy-modal-content{padding:15px 10px;gap:15px}.buy-modal-preview{padding:12px;gap:10px}.buy-modal-preview .preview-header{flex-wrap:wrap;gap:8px}.buy-modal-preview .preview-header h3{font-size:1em}.buy-modal-preview .preview-container{min-height:200px;max-height:300px}.buy-modal-preview .preview-image{max-height:250px}.buy-modal-preview .preview-arrow{width:30px;height:30px;font-size:16px}.buy-modal-preview .preview-arrow-left{left:3px}.buy-modal-preview .preview-arrow-right{right:3px}.buy-modal-product-info{padding:15px 12px}.buy-modal-product-info h3{font-size:1.1em}.buy-modal-product-info .product-info-item{padding:8px 10px;flex-direction:row;align-items:center;gap:8px}.buy-modal-product-info .product-info-item .info-label{min-width:auto;font-size:.75em;white-space:nowrap;flex-shrink:0}.buy-modal-product-info .product-info-item .info-value{text-align:left;font-size:.75em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.buy-modal-form .form-actions{flex-direction:column;gap:10px}.buy-modal-form .form-actions button{width:100%}}.buy-modal-preview{background:var(--bg-secondary);border-radius:var(--radius-lg, 12px);padding:20px;display:flex;flex-direction:column;gap:15px;max-width:100%;box-sizing:border-box;overflow:hidden;border:1px solid var(--border-color)}.buy-modal-preview .preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.buy-modal-preview .preview-header h3{margin:0;font-size:1.1em;color:var(--text-primary)}.buy-modal-preview .preview-side-counter{font-size:.9em;color:var(--text-secondary);font-weight:500}.buy-modal-preview .preview-container{position:relative;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-primary);border-radius:var(--radius-md, 8px);overflow:hidden;border:2px solid var(--border-color);box-sizing:border-box;align-self:center}.buy-modal-preview .preview-image-wrapper{display:flex;align-items:center;justify-content:center}.buy-modal-preview .preview-image{max-width:100%;max-height:450px;width:auto;height:auto;object-fit:contain;display:block}.buy-modal-preview .preview-arrow{position:absolute;top:50%;transform:translateY(-50%);background:var(--bg-primary);border:2px solid var(--border-color);border-radius:50%;width:45px;height:45px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:22px;font-weight:700;color:var(--text-primary);transition:all .2s;z-index:10;box-shadow:var(--shadow-sm, 0 2px 4px rgba(0, 0, 0, .1))}.buy-modal-preview .preview-arrow:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color);box-shadow:0 4px 12px #3b82f666;transform:translateY(-50%) scale(1.1)}.buy-modal-preview .preview-arrow:disabled{display:none}.buy-modal-preview .preview-arrow-left{left:15px}.buy-modal-preview .preview-arrow-right{right:15px}.buy-modal-preview .preview-loading,.buy-modal-preview .preview-placeholder{text-align:center;color:var(--text-secondary);padding:40px 20px;font-size:.9em}.buy-modal-preview .preview-dots{display:flex;justify-content:center;gap:8px;margin-top:10px}.buy-modal-preview .preview-dot{width:12px;height:12px;border-radius:50%;border:2px solid var(--text-tertiary, #94a3b8);background:var(--bg-tertiary);cursor:pointer;transition:all .2s;padding:0}.buy-modal-preview .preview-dot:hover{background:var(--text-secondary);border-color:var(--text-secondary);transform:scale(1.2)}.buy-modal-preview .preview-dot.active{background:var(--accent-color);border-color:var(--accent-color);transform:scale(1.3)}.buy-modal-preview .preview-side-name{text-align:center;font-size:.9em;color:var(--text-secondary);font-weight:500;margin-top:5px}.buy-modal-product-info{background:var(--bg-secondary);padding:25px;border-radius:var(--radius-lg, 12px);margin-bottom:25px;border:1px solid var(--border-color);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .1));min-height:180px;display:flex;flex-direction:column;justify-content:space-between}.buy-modal-product-info .product-info-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid var(--border-color)}.buy-modal-product-info h3{margin:0;font-size:1.3em;font-weight:700;color:var(--text-primary);flex:1}.buy-modal-product-info .product-category{background:var(--accent-color);color:#fff;padding:4px 12px;border-radius:20px;font-size:.75em;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.buy-modal-product-info .product-info-details{display:flex;flex-direction:column;gap:12px;flex:1}.buy-modal-product-info .product-info-item{display:flex;align-items:center;justify-content:space-between;padding:12px 15px;background:var(--bg-primary);border-radius:var(--radius-md, 8px);border:1px solid var(--border-color);border-left:4px solid var(--accent-color);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0, 0, 0, .05));transition:all .2s}.buy-modal-product-info .product-info-item:hover{box-shadow:var(--shadow-md, 0 2px 6px rgba(0, 0, 0, .1));transform:translate(2px)}.buy-modal-product-info .product-info-item .info-label{font-weight:600;color:var(--text-secondary);font-size:.9em;min-width:100px}.buy-modal-product-info .product-info-item .info-value{color:var(--text-primary);font-weight:500;font-size:.95em;text-align:right;flex:1}.buy-modal-product-info .product-variant{border-left-color:var(--warning-color, #f59e0b)}.buy-modal-product-info .product-size{border-left-color:var(--success-color, #10b981)}.buy-modal-product-info .product-quantity{border-left-color:var(--danger-color, #ef4444)}.buy-modal-warning{background:var(--warning-bg, #fef3c7);color:var(--warning-text, #92400e);padding:12px;border-radius:var(--radius-md, 8px);margin-bottom:20px;border:1px solid var(--warning-border, #f59e0b)}.buy-modal-error{background:var(--danger-bg, #fee2e2);color:var(--danger-color, #dc2626);padding:12px;border-radius:var(--radius-md, 8px);margin-bottom:20px;border:1px solid var(--danger-border, #fecaca)}.quantity-options{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.quantity-btn{padding:8px 16px;border:2px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s;font-size:.9em}.quantity-btn:hover{border-color:var(--accent-color);background:var(--bg-tertiary);color:var(--accent-color)}.quantity-btn.active{border-color:var(--accent-color);background:var(--accent-color);color:#fff}.buy-modal-form .form-group{margin-bottom:20px}.buy-modal-form label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary)}.buy-modal-form input[type=number],.buy-modal-form select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:1em;box-sizing:border-box;background:var(--bg-primary);color:var(--text-primary)}.buy-modal-form input[type=number]:focus,.buy-modal-form select:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f626}.buy-modal-form{display:flex;flex-direction:column;gap:20px;padding:0}.buy-modal-form .form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding:20px 0 0;border-top:1px solid var(--border-color)}.selected-info{color:var(--text-secondary)}.cart-modal{max-width:900px;width:90vw;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);position:relative}[data-theme=dark] .modal-overlay{background:#000000bf}.cart-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0;background:var(--bg-primary)}.cart-modal .modal-header h2{margin:0;color:var(--text-primary);font-size:1.5em;font-weight:600}.cart-modal .close-btn{background:none;border:none;font-size:1.8em;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.cart-modal .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.cart-add-current-bar{padding:12px 24px;border-bottom:1px solid var(--border-color);background:var(--bg-secondary, #f8fafc);flex-shrink:0}[data-theme=dark] .cart-add-current-bar{background:var(--bg-tertiary, #1e293b)}.btn-add-current-project{display:inline-flex;align-items:center;gap:10px;padding:10px 18px;background:#3b82f61f;color:var(--accent-color, #3b82f6);border:2px solid var(--accent-color, #3b82f6);border-radius:var(--radius-md, 8px);font-size:.95em;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #3b82f633}.btn-add-current-project:hover{background:var(--accent-color, #3b82f6);color:#fff;box-shadow:0 2px 8px #3b82f666}[data-theme=dark] .btn-add-current-project{background:#60a5fa26;border-color:var(--accent-color, #60a5fa);color:var(--accent-color, #60a5fa)}[data-theme=dark] .btn-add-current-project:hover{background:var(--accent-color, #60a5fa);color:#0f172a}.btn-add-current-icon{font-size:1.1em}.cart-modal .modal-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:0;background:var(--bg-primary)}.cart-loading,.cart-empty{padding:40px;text-align:center;color:var(--text-secondary)}.cart-error{color:var(--danger-color);background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius-md);padding:12px 16px;margin:16px 20px;font-size:.9em;flex-shrink:0}.cart-empty{padding:60px 20px}.cart-empty p{font-size:1.1em;color:var(--text-tertiary)}.cart-items{padding:20px;overflow-y:auto;flex:1;min-height:0}.cart-item{display:flex;align-items:center;padding:15px;border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:15px;background:var(--bg-primary);gap:15px}.cart-item-preview{width:80px;height:80px;object-fit:contain;border-radius:6px;border:1px solid var(--border-color);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);box-shadow:var(--shadow-sm);flex-shrink:0;padding:2px}.cart-item-info{flex:1;min-width:0}.cart-item-info h3{margin:0 0 5px;font-size:1em;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.cart-item-size,.cart-item-variant,.cart-item-images{margin:5px 0 0;font-size:.85em;color:var(--text-secondary)}.cart-item-quantity{display:flex;align-items:center;gap:10px;flex-shrink:0}.quantity-btn{width:30px;height:30px;border:2px solid var(--accent-color);background:var(--bg-tertiary);color:var(--accent-color);border-radius:var(--radius-md);cursor:pointer;font-size:1.2em;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.quantity-btn:hover:not(:disabled){background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:var(--shadow-md);transform:translateY(-1px)}.quantity-btn:not(:disabled){background:var(--bg-tertiary)}.quantity-btn:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-sm)}.quantity-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--bg-tertiary);border-color:var(--border-color)}.quantity-value{min-width:30px;text-align:center;font-weight:600;font-size:1em;color:var(--text-primary)}.cart-item-remove{width:35px;height:35px;border:2px solid var(--danger-color);background:var(--bg-tertiary);color:var(--danger-color);cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all var(--transition-fast);flex-shrink:0;box-shadow:var(--shadow-sm)}.cart-item-remove:hover{background:var(--danger-color);color:#fff;box-shadow:var(--shadow-md);transform:translateY(-1px)}.cart-item-remove:active{transform:translateY(0);box-shadow:var(--shadow-sm)}.cart-footer{border-top:1px solid var(--border-color);padding:20px;background:var(--bg-secondary);flex-shrink:0}.cart-summary{margin-bottom:15px}.cart-total-items,.cart-total-quantity,.cart-total-price{margin:5px 0;font-weight:600;color:var(--text-primary)}.cart-total-price{font-size:1.2em;margin-top:10px}.cart-actions{display:flex;gap:10px}.cart-actions button{flex:1}.cart-actions .btn-secondary{border:2px solid var(--border-color);background:var(--bg-primary);font-weight:500}.cart-actions .btn-secondary:hover:not(:disabled){border-color:var(--accent-color);background:var(--bg-tertiary)}.cart-info{background:var(--success-bg);color:var(--success-color);border:1px solid var(--success-border);border-radius:var(--radius-md);padding:12px 16px;margin:16px 20px;font-size:.9em;flex-shrink:0}.order-form{padding:30px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex:1;overflow-y:auto;display:flex;flex-direction:column;min-height:0}.order-form h3{margin:0 0 20px;font-size:1.2em;color:var(--text-primary)}.order-form .form-group{margin-bottom:20px}.order-form label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary);font-size:.9em}.order-form input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1em;background:var(--bg-primary);color:var(--text-primary);transition:all var(--transition-fast);box-sizing:border-box}.order-form input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f61a}[data-theme=dark] .order-form input:focus{box-shadow:0 0 0 3px #60a5fa33}.order-form input::placeholder{color:var(--text-tertiary)}.order-form .cart-total{margin:20px 0;padding:15px;background:var(--bg-tertiary);border-radius:var(--radius-md);text-align:center;font-size:1.2em;color:var(--text-primary)}.order-form .form-actions{display:flex;gap:10px;margin-top:auto;padding-top:20px}.order-form .form-actions button{flex:1}.order-form .form-actions .btn-secondary{background:var(--bg-primary);color:var(--text-primary);border:2px solid var(--border-color);font-weight:500}.order-form .form-actions .btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color)}[data-theme=dark] .order-form .form-actions .btn-secondary{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .order-form .form-actions .btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color)}[data-theme=dark] .cart-modal .modal-header{background:var(--bg-primary);border-bottom-color:var(--border-color)}[data-theme=dark] .cart-modal .modal-header h2{color:var(--text-primary)}[data-theme=dark] .cart-modal .close-btn{color:var(--text-secondary)}[data-theme=dark] .cart-modal .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}[data-theme=dark] .cart-modal .modal-body{background:var(--bg-primary)}[data-theme=dark] .order-form{background:var(--bg-secondary);border-top-color:var(--border-color)}[data-theme=dark] .cart-item{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .cart-item-info h3{color:var(--text-primary)}[data-theme=dark] .cart-item-size,[data-theme=dark] .cart-item-variant,[data-theme=dark] .cart-item-images{color:var(--text-secondary)}[data-theme=dark] .quantity-btn{background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color);box-shadow:var(--shadow-sm)}[data-theme=dark] .quantity-btn:hover:not(:disabled){background:var(--accent-color);color:#fff;border-color:var(--accent-color);box-shadow:var(--shadow-md)}[data-theme=dark] .quantity-btn:disabled{background:var(--bg-tertiary);border-color:var(--border-color);opacity:.4}[data-theme=dark] .cart-item-remove{background:var(--bg-tertiary);border-color:var(--danger-color);color:var(--danger-color);box-shadow:var(--shadow-sm)}[data-theme=dark] .cart-item-remove:hover{background:var(--danger-color);color:#fff;box-shadow:var(--shadow-md)}[data-theme=dark] .cart-footer{background:var(--bg-secondary);border-top-color:var(--border-color)}[data-theme=dark] .cart-actions .btn-secondary{border:2px solid var(--border-color);background:var(--bg-primary)}[data-theme=dark] .cart-actions .btn-secondary:hover:not(:disabled){border-color:var(--accent-color);background:var(--bg-tertiary)}[data-theme=dark] .cart-total-items,[data-theme=dark] .cart-total-quantity,[data-theme=dark] .cart-total-price{color:var(--text-primary)}[data-theme=dark] .cart-loading,[data-theme=dark] .cart-empty{color:var(--text-secondary)}[data-theme=dark] .cart-item-preview{border-color:var(--border-color);background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);box-shadow:var(--shadow-sm)}@media(max-width:480px){.cart-modal{max-width:100vw;max-height:100vh;margin:0;border-radius:0}.cart-items{padding:15px}.cart-item{padding:12px;gap:10px}.cart-item-info h3{font-size:.9em}.cart-item-size,.cart-item-variant,.cart-item-images{font-size:.75em;margin:2px 0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:inline-block;max-width:100%}.quantity-btn{width:28px;height:28px;font-size:1em}.cart-item-remove{width:32px;height:32px}.cart-footer{padding:15px}}.order-form-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2100;animation:orderFormFadeIn .2s}[data-theme=dark] .order-form-modal-overlay{background:#000000bf}@keyframes orderFormFadeIn{0%{opacity:0}to{opacity:1}}.order-form-modal{background:var(--bg-primary);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px -5px rgb(0 0 0 / .1));width:100%;max-width:440px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;animation:orderFormSlideUp .25s}@keyframes orderFormSlideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.order-form-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);flex-shrink:0}.order-form-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary)}.order-form-modal-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-secondary);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm, 6px);transition:all var(--transition-fast, .15s)}.order-form-modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.order-form-modal-form{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.order-form-modal-error{margin:16px 24px 0;padding:12px 16px;background:var(--danger-bg, #fee2e2);color:var(--danger-color, #dc2626);border-radius:var(--radius-md, 8px);font-size:.9rem}.order-form-modal-body{padding:24px;overflow-y:auto}.order-form-modal-body .form-group{margin-bottom:1rem}.order-form-modal-body .form-group:last-of-type{margin-bottom:0}.order-form-modal-body .form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.95rem;color:var(--text-primary)}.order-form-modal-body .form-group input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:var(--radius-md, 8px);font-size:1rem;font-family:inherit;background:var(--bg-primary);color:var(--text-primary);transition:border-color .2s,box-shadow .2s}.order-form-modal-body .form-group input:focus{outline:none;border-color:var(--accent-color);box-shadow:0 0 0 3px #3b82f626}.order-form-modal-body .form-group input:disabled{opacity:.7;cursor:not-allowed}.order-form-modal-summary{margin-top:20px;padding-top:16px;border-top:1px solid var(--border-color)}.order-form-modal-summary-row{margin:0 0 6px;display:flex;justify-content:space-between;font-size:.95rem;color:var(--text-primary)}.order-form-modal-summary-total{margin:12px 0 0;padding-top:12px;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;font-size:1.1rem;color:var(--text-primary)}.order-form-modal-summary-total strong{color:var(--accent-color)}.order-form-modal-actions{display:flex;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color);background:var(--bg-secondary);flex-shrink:0}.order-form-modal-actions .btn-secondary{padding:10px 18px;border-radius:var(--radius-md, 8px);font-size:.95rem;font-weight:500;cursor:pointer;transition:all .2s;background:var(--bg-primary);color:var(--text-primary);border:1px solid var(--border-color)}.order-form-modal-actions .btn-secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-color);color:var(--accent-color)}.order-form-modal-actions .btn-primary{flex:1;padding:10px 18px;border:none;border-radius:var(--radius-md, 8px);font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;background:var(--accent-color);color:#fff}.order-form-modal-actions .btn-primary:hover:not(:disabled){background:var(--accent-hover);box-shadow:0 2px 8px #3b82f659}.order-form-modal-actions .btn-primary:disabled,.order-form-modal-actions .btn-secondary:disabled{opacity:.6;cursor:not-allowed}.product-grid-selector{width:100%;max-width:900px;background:#fff;border-radius:12px;box-shadow:0 4px 20px #0000001a;overflow:hidden}.product-grid-selector .products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.category-filter{background:#f8f9fa;border-bottom:1px solid #e9ecef;padding:16px 20px}.filter-tabs{display:flex;gap:8px;overflow-x:auto;scrollbar-width:thin;scrollbar-color:#dee2e6 #f8f9fa}.filter-tabs::-webkit-scrollbar{height:4px}.filter-tabs::-webkit-scrollbar-track{background:#f8f9fa}.filter-tabs::-webkit-scrollbar-thumb{background:#dee2e6;border-radius:2px}.filter-tab{padding:8px 16px;background:#fff;border:1px solid #dee2e6;border-radius:20px;font-size:14px;font-weight:500;color:#495057;cursor:pointer;transition:all .2s ease;white-space:nowrap;flex-shrink:0}.filter-tab:hover{background:#e9ecef;border-color:#adb5bd}.filter-tab.active{background:#007bff;border-color:#007bff;color:#fff}.products-section{padding:24px 20px}.products-section:not(:last-child){border-bottom:1px solid #e9ecef}.section-title{margin:0 0 20px;font-size:18px;font-weight:600;color:#212529}.product-grid-selector .product-card{background:#fff;border:2px solid #e9ecef;border-radius:12px;padding:16px;cursor:pointer;transition:all .3s ease;position:relative;overflow:hidden;text-align:left}.product-card:hover:not(.future){border-color:#007bff;box-shadow:0 4px 12px #007bff26;transform:translateY(-2px)}.product-card.selected{border-color:#28a745;box-shadow:0 4px 12px #28a74533;background:#f8fff9}.product-card.future{opacity:.7;cursor:not-allowed;background:#f8f9fa}.product-card.future:hover{transform:none;box-shadow:none}.product-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.product-icon{width:40px;height:40px;background:#f8f9fa;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:20px;border:1px solid #e9ecef}.product-icon.future{background:#e9ecef;filter:grayscale(.5)}.product-category{font-size:12px;color:#6c757d;font-weight:500;text-align:right;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.product-name{font-size:16px;font-weight:600;color:#212529;margin-bottom:8px;line-height:1.3;min-height:42px;display:flex;align-items:center}.product-card.future .product-name{color:#6c757d}.product-variants{margin-bottom:12px}.variants-info{font-size:13px;color:#6c757d;background:#f8f9fa;padding:4px 8px;border-radius:6px;display:inline-block}.product-status{font-size:12px;font-weight:600;padding:6px 12px;border-radius:6px;text-align:center}.product-status.ready{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.product-status.future{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.no-products{text-align:center;padding:60px 20px;color:#6c757d}.no-products-icon{font-size:48px;margin-bottom:16px;opacity:.5}.no-products-text{font-size:16px;font-weight:500}@media(max-width:768px){.product-grid-selector{max-width:100%;border-radius:0}.category-filter{padding:12px 16px}.filter-tabs{gap:6px}.filter-tab{padding:6px 12px;font-size:13px}.products-section{padding:20px 16px}.product-grid-selector .products-grid{grid-template-columns:repeat(2,1fr);gap:12px}.product-card{padding:12px}.product-icon{width:36px;height:36px;font-size:18px}.product-name{font-size:14px;min-height:36px}.section-title{font-size:16px}}@media(max-width:480px){.product-grid-selector .products-grid{grid-template-columns:1fr}.product-card-header{flex-direction:column;align-items:flex-start;gap:8px}.product-category{text-align:left;max-width:none}}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.product-card{animation:fadeIn .3s ease-out}.product-card.selected:before{content:"✓";position:absolute;top:8px;right:8px;width:24px;height:24px;background:#28a745;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;z-index:1}.product-card:not(.future):hover{background:linear-gradient(135deg,#fff,#f8f9ff)}.product-card:not(.future):hover .product-icon{background:#e7f3ff;border-color:#007bff}.product-card:not(.future):hover .product-name{color:#007bff}[data-theme=dark] .product-grid-selector{background:var(--bg-primary);box-shadow:var(--shadow-md)}[data-theme=dark] .category-filter{background:var(--bg-secondary);border-bottom-color:var(--border-color)}[data-theme=dark] .filter-tabs{scrollbar-color:var(--border-color) var(--bg-secondary)}[data-theme=dark] .filter-tabs::-webkit-scrollbar-track{background:var(--bg-secondary)}[data-theme=dark] .filter-tabs::-webkit-scrollbar-thumb{background:var(--border-color)}[data-theme=dark] .filter-tab{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .filter-tab:hover{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .filter-tab.active{background:var(--accent-color);border-color:var(--accent-color);color:#fff}[data-theme=dark] .products-section{border-bottom-color:var(--border-color)}[data-theme=dark] .section-title{color:var(--text-primary)}[data-theme=dark] .product-grid-selector .product-card{background:var(--bg-primary);border-color:var(--border-color)}[data-theme=dark] .product-card:hover:not(.future){border-color:var(--accent-color);box-shadow:var(--shadow-md)}[data-theme=dark] .product-card.selected{border-color:var(--accent-color);background:var(--bg-tertiary)}[data-theme=dark] .product-card.future{background:var(--bg-secondary)}[data-theme=dark] .product-icon{background:var(--bg-secondary);border-color:var(--border-color)}[data-theme=dark] .product-icon.future{background:var(--bg-tertiary)}[data-theme=dark] .product-category{color:var(--text-secondary)}[data-theme=dark] .product-name{color:var(--text-primary)}[data-theme=dark] .product-card.future .product-name{color:var(--text-secondary)}[data-theme=dark] .variants-info{background:var(--bg-secondary);color:var(--text-secondary)}[data-theme=dark] .no-products{color:var(--text-secondary)}[data-theme=dark] .product-card:not(.future):hover{background:var(--bg-tertiary)}[data-theme=dark] .product-card:not(.future):hover .product-icon{background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .product-card:not(.future):hover .product-name{color:var(--accent-color)}*{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--border-color: #e2e8f0;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #94a3b8;--accent-color: #3b82f6;--accent-hover: #2563eb;--danger-color: #ef4444;--danger-bg: #fee2e2;--danger-border: #fecaca;--success-color: #10b981;--success-bg: #d1fae5;--success-border: #6ee7b7;--warning-color: #f59e0b;--gradient-primary: linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--gradient-secondary: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);--shadow-sm: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--header-height: 70px;--footer-height: 60px;--sidebar-width: 280px;--properties-width: 300px}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--border-color: #475569;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-tertiary: #94a3b8;--accent-color: #60a5fa;--accent-hover: #3b82f6;--danger-bg: #7f1d1d;--danger-border: #991b1b;--success-bg: #064e3b;--success-border: #059669;--gradient-secondary: linear-gradient(135deg, #1e293b 0%, #334155 100%);--shadow-sm: 0 2px 4px rgba(0, 0, 0, .3);--shadow-md: 0 2px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 4px 20px rgba(0, 0, 0, .7);--footer-bg: var(--bg-primary);--footer-text: var(--text-primary);--footer-border: var(--border-color);--sidebar-width: 280px;--properties-width: 300px;--bg-color: #1a1a1a;--bg-color-secondary: #2a2a2a;--bg-color-tertiary: #1a2f4a;--bg-color-hover: #2a2a2a;--text-color: #ffffff;--text-color-secondary: #b0b0b0;--primary-color: #4da3ff;--primary-color-light: #1a2f4a;--primary-color-hover: #0056b3;--bg-color-dark: #1a1a1a;--bg-color-secondary-dark: #2a2a2a;--bg-color-tertiary-dark: #1a2f4a;--bg-color-hover-dark: #2a2a2a;--text-color-dark: #ffffff;--text-color-secondary-dark: #b0b0b0;--border-color-dark: #444444;--primary-color-dark: #4da3ff;--primary-color-light-dark: #b3d9ff}body{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;background:var(--bg-secondary);color:var(--text-primary);transition:background-color .3s,color .3s;overflow:hidden;height:100vh}#root,.app{height:100%}.app{display:flex;flex-direction:column;height:100vh;background:var(--bg-secondary);position:relative}.app-content{flex:1;display:flex;overflow:hidden;min-height:0;padding-bottom:var(--footer-height);box-sizing:border-box}.sidebar{width:280px;background:var(--bg-primary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;transition:margin-left .3s ease-in-out,opacity .3s ease-in-out,visibility .3s ease-in-out,transform .3s ease-in-out;opacity:1;visibility:visible;position:relative;z-index:10}.sidebar:not(.open){margin-left:-280px;opacity:0;visibility:hidden}.sidebar-backdrop{display:none}@media(max-width:767px){.sidebar-backdrop{display:block;position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out;pointer-events:none}.sidebar-backdrop.active{opacity:1;visibility:visible;pointer-events:auto}}.sidebar-section{padding:20px;border-bottom:1px solid var(--border-color)}.sidebar-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.sidebar .variant-colors{display:flex;gap:8px;flex-wrap:wrap}.sidebar .color-option{width:40px;height:40px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s}.sidebar .color-option:hover{transform:scale(1.1)}.sidebar .color-option.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--accent-color)}.sidebar .stock-images-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px}.sidebar .stock-image-btn{background:none;border:2px solid var(--border-color);border-radius:8px;padding:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:60px}.sidebar .stock-image-btn:hover{border-color:var(--accent-color);background:var(--bg-secondary);transform:scale(1.05)}.sidebar .stock-image-preview{max-width:100%;max-height:50px;object-fit:contain;border-radius:4px}.canvas-container{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--bg-secondary);position:relative;cursor:grab;transition:margin-left .3s ease-in-out,margin-right .3s ease-in-out;z-index:1;min-height:0}.canvas-container.panning{cursor:grabbing}.canvas-container canvas{cursor:inherit}.properties-panel{width:300px;background:var(--bg-primary);border-left:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;transition:margin-right .3s ease-in-out,opacity .3s ease-in-out,visibility .3s ease-in-out,transform .3s ease-in-out;opacity:1;visibility:visible;position:relative;z-index:10}.properties-panel:not(.open){margin-right:-300px;opacity:0;visibility:hidden}.properties-backdrop{display:none}@media(max-width:767px){.properties-backdrop{display:block;position:fixed;inset:0;background:#00000080;z-index:999;opacity:0;visibility:hidden;transition:opacity .3s ease-in-out,visibility .3s ease-in-out;pointer-events:none}.properties-backdrop.active{opacity:1;visibility:visible;pointer-events:auto}}.properties-section{padding:20px;border-bottom:1px solid var(--border-color)}.properties-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.properties-panel .color-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-top:8px}.properties-panel .color-swatch{width:32px;height:32px;border-radius:50%;border:2px solid var(--border-color);cursor:pointer;transition:all .2s;position:relative}.properties-panel .color-swatch:hover{transform:scale(1.1);border-color:var(--accent-color)}.properties-panel .color-swatch.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--accent-color)}.properties-panel .layer-item{display:flex;align-items:center;gap:8px;padding:10px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s}.properties-panel .layer-item:hover,.properties-panel .layer-item.selected{background:var(--bg-secondary);border-color:var(--accent-color)}.properties-panel .layer-thumbnail{width:40px;height:40px;border-radius:4px;object-fit:contain;background:var(--bg-primary);border:1px solid var(--border-color);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;color:#fff}.properties-panel .layer-info{flex:1;min-width:0}.properties-panel .layer-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.properties-panel .layer-actions{display:flex;gap:4px}.properties-panel .text-thumbnail{background:linear-gradient(135deg,#667eea,#764ba2)}.properties-panel .shape-thumbnail{background:linear-gradient(135deg,#ff6b6b,#ee5a6f)}.properties-panel .empty-state{text-align:center;padding:40px 20px;color:var(--text-tertiary)}.properties-panel .empty-state-icon{font-size:48px;margin-bottom:12px}.properties-panel .empty-state-text{font-size:14px}.properties-panel .btn-small{padding:4px 8px;font-size:12px;min-width:auto;border-radius:4px;border:1px solid var(--border-color);background:var(--bg-tertiary);color:var(--text-primary);cursor:pointer;transition:all .2s}.properties-panel .btn-small:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color)}.properties-panel .btn-small:disabled{opacity:.5;cursor:not-allowed}.properties-panel .btn-small.btn-danger{background:#e74c3c;color:#fff;border-color:#e74c3c}.properties-panel .btn-small.btn-danger:hover:not(:disabled){background:#c0392b;border-color:#c0392b}.properties-panel input[type=range].property-input{width:100%;height:6px;background:var(--bg-tertiary);border-radius:3px;outline:none;padding:0;border:none}.properties-panel input[type=range].property-input::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--accent-color);cursor:pointer;border-radius:50%;border:2px solid var(--bg-primary);box-shadow:0 2px 4px #0003}.properties-panel input[type=range].property-input::-moz-range-thumb{width:16px;height:16px;background:var(--accent-color);cursor:pointer;border-radius:50%;border:2px solid var(--bg-primary);box-shadow:0 2px 4px #0003}.properties-panel input[type=range].property-input::-webkit-slider-thumb:hover{background:var(--accent-hover)}.properties-panel input[type=range].property-input::-moz-range-thumb:hover{background:var(--accent-hover)}.properties-panel input[type=number].property-input{-moz-appearance:textfield}.properties-panel input[type=number].property-input::-webkit-outer-spin-button,.properties-panel input[type=number].property-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.property-group{margin-bottom:16px}.property-label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:6px;font-weight:500}.property-input{width:100%;padding:8px 12px;border:1px solid var(--border-color);border-radius:4px;font-size:13px;outline:none;transition:border-color .2s;background:var(--bg-primary);color:var(--text-primary)}.property-input:focus{border-color:var(--accent-color)}.property-row{display:flex;gap:12px}.property-row .property-group{flex:1}button:not(.sidebar-toggle){padding:10px 16px;border:none;border-radius:6px;font-size:14px;font-weight:500;display:inline-flex;align-items:center;justify-content:center;text-align:center;cursor:pointer;transition:all .2s;outline:none}button:not(.sidebar-toggle):hover{transform:translateY(-1px);box-shadow:0 2px 8px #00000026}button:not(.sidebar-toggle):active{transform:translateY(0)}button:not(.sidebar-toggle):disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--accent-color);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover)}.cart-btn{position:relative}.mobile-only{display:none!important}@media(min-width:768px){.mobile-only{display:none!important}}.cart-badge{background:#dc3545;color:#fff;border-radius:10px;padding:2px 6px;font-size:.75em;font-weight:600;margin-left:5px}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color)}.btn-ai{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s;box-shadow:0 2px 4px #667eea4d}.btn-ai:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 8px #667eea66}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover:not(:disabled){background:#c0392b}.btn-icon{padding:8px;display:flex;align-items:center;justify-content:center;min-width:36px}.product-icon{font-size:32px;margin-bottom:8px}.variant-colors{display:flex;gap:8px;flex-wrap:wrap}.color-option{width:40px;height:40px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:all .2s}.color-option:hover{transform:scale(1.1)}.color-option.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--accent-color)}.layers-list{display:flex;flex-direction:column;gap:8px}.layer-item{display:flex;align-items:center;gap:8px;padding:10px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;cursor:pointer;transition:all .2s}.layer-item:hover{background:var(--bg-secondary)}.layer-item.selected{background:var(--bg-secondary);border-color:var(--accent-color)}.layer-thumbnail{width:40px;height:40px;border-radius:4px;object-fit:contain;background:var(--bg-primary);border:1px solid var(--border-color)}.layer-info{flex:1;min-width:0}.layer-name{font-size:13px;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layer-actions{display:flex;gap:4px}.btn-small{padding:4px 8px;font-size:12px;min-width:auto}.empty-state{text-align:center;padding:40px 20px;color:var(--text-tertiary)}.empty-state-icon{font-size:48px;margin-bottom:12px}.empty-state-text{font-size:14px}.tooltip{position:relative;display:inline-block}.tooltip:hover:after{content:attr(data-tooltip);position:absolute;top:100%;left:50%;transform:translate(-50%);padding:6px 10px;background:#333;color:#fff;font-size:12px;white-space:nowrap;border-radius:4px;margin-top:5px;z-index:1000}.canvas-controls{position:absolute;bottom:20px;left:50%;transform:translate(-50%);display:flex;gap:8px;background:var(--bg-primary);padding:8px;border-radius:8px;box-shadow:var(--shadow-md);z-index:1001;border:1px solid var(--border-color)}.zoom-display{padding:8px 12px;font-size:13px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center}.text-thumbnail{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.button-group{display:flex;gap:4px}.button-group button{flex:1;min-width:40px;padding:8px}.button-group button.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}textarea.property-input{resize:vertical;font-family:inherit;line-height:1.5}input[type=color].property-input{height:36px;padding:2px;border:2px solid var(--border-color);border-radius:4px;cursor:pointer;background:var(--bg-primary);box-sizing:border-box}input[type=color].property-input::-webkit-color-swatch-wrapper{padding:0;border:none;border-radius:2px}input[type=color].property-input::-webkit-color-swatch{border:1px solid var(--border-color);border-radius:2px;width:100%;height:100%}input[type=color].property-input::-moz-color-swatch{border:1px solid var(--border-color);border-radius:2px;width:100%;height:100%}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-color)}.checkbox-label input[type=checkbox]:disabled{cursor:not-allowed;opacity:.5}.checkbox-label span{font-size:14px;color:var(--text-primary)}.stock-images-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:8px}.stock-image-btn{background:none;border:2px solid var(--border-color);border-radius:8px;padding:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;min-height:60px}.stock-image-btn:hover{border-color:var(--accent-color);background:var(--bg-secondary);transform:scale(1.05)}.stock-image-preview{max-width:100%;max-height:50px;object-fit:contain;border-radius:4px}.ai-generator-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000}.ai-generator-modal{background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);width:90%;max-width:600px;max-height:90vh;overflow-y:auto}.ai-generator-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color)}.ai-generator-header h3{margin:0;color:var(--text-primary);font-size:18px}.close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-secondary);padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s}.close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.ai-generator-content{padding:20px}.form-group{margin-bottom:16px}.form-group label{display:block;margin-bottom:6px;font-weight:500;color:var(--text-primary)}.form-group textarea,.form-group select{width:100%;padding:10px;border:1px solid var(--border-color);border-radius:6px;font-size:14px;font-family:inherit;background:var(--bg-primary);color:var(--text-primary)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.preset-prompts{margin-bottom:20px}.preset-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-top:8px}.preset-btn{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;font-size:12px;cursor:pointer;transition:all .2s;text-align:left;color:var(--text-primary)}.preset-btn:hover{background:var(--bg-secondary);border-color:var(--accent-color)}.error-message{background:#fee;color:#c33;padding:10px;border-radius:6px;margin-bottom:16px;font-size:14px}.ai-generator-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.ai-generator-actions button{min-width:120px}.templates-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s}.templates-modal{background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);width:90%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s}.templates-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color)}.templates-header h2{margin:0;color:var(--text-primary);font-size:24px}.templates-categories{display:flex;gap:8px;padding:16px 20px;border-bottom:1px solid var(--border-color);overflow-x:auto;flex-wrap:wrap}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;padding:20px;overflow-y:auto;flex:1}.template-card{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:12px;overflow:hidden;cursor:pointer;transition:all .2s}.template-card:hover{border-color:var(--accent-color);transform:translateY(-4px);box-shadow:var(--shadow-md)}.template-preview{height:150px;background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);display:flex;align-items:center;justify-content:center;border-bottom:1px solid var(--border-color);position:relative;overflow:hidden}.template-preview-image{width:100%;height:100%;object-fit:cover;object-position:center}.template-icon,.template-icon-fallback{font-size:64px;opacity:.6;position:absolute;display:flex;align-items:center;justify-content:center;width:100%;height:100%}.template-icon-fallback.hidden{display:none}.template-info{padding:16px}.template-name{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.template-description{font-size:13px;color:var(--text-secondary);margin:0 0 12px;line-height:1.4}.template-meta{display:flex;flex-wrap:wrap;gap:8px 12px;font-size:12px;color:var(--text-tertiary)}.template-author{color:var(--text-secondary)}.template-elements{display:flex;align-items:center;gap:4px}.template-date{color:var(--text-tertiary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--text-secondary)}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top:4px solid var(--accent-color);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.app-notification{position:fixed;top:20px;right:20px;padding:15px 20px;border-radius:8px;color:#fff;z-index:10000;box-shadow:0 4px 12px #00000026;max-width:400px;animation:slideInRight .3s ease-out;display:flex;align-items:center;gap:15px}.app-notification-success{background-color:#4caf50}.app-notification-error{background-color:#f44336}.app-notification-warning{background-color:#ff9800}.app-notification-info{background-color:#2196f3}.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px;color:var(--text-secondary)}.error-icon{font-size:48px;opacity:.7}.error-text{font-size:14px;text-align:center;color:var(--text-primary)}.theme-toggle-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-color);padding:8px 12px;border-radius:6px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;font-size:14px}.theme-toggle-btn:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}.autosave-indicator{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-tertiary);padding:6px 12px;background:var(--bg-secondary);border-radius:4px}.autosave-indicator.saving{color:var(--accent-color)}.autosave-indicator.saved{color:#27ae60}.shape-thumbnail{background:linear-gradient(135deg,#ff6b6b,#ee5a6f);color:#fff;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s}.modal-content{background:var(--bg-primary);border-radius:12px;box-shadow:var(--shadow-lg);width:90%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;color:var(--text-primary);font-size:20px}.modal-body{padding:20px;overflow-y:auto;flex:1}.modal-footer{padding:16px 20px;border-top:1px solid var(--border-color);display:flex;gap:12px;justify-content:flex-end}.confirmation-modal{max-width:500px;width:90%}.confirmation-info{display:flex;flex-direction:column;gap:20px}.confirmation-description{color:var(--text-primary);line-height:1.5;margin:0}.email-info{background:var(--bg-tertiary);padding:15px;border-radius:8px;border-left:4px solid var(--accent-color)}.email-label{font-size:12px;color:var(--text-secondary);margin:0 0 5px;text-transform:uppercase;letter-spacing:.5px}.email-value{font-size:16px;color:var(--text-primary);margin:0;font-weight:500;word-break:break-all}.url-preview{display:flex;flex-direction:column;gap:8px;padding:15px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.url-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.url-link{color:var(--accent-color);text-decoration:none;font-size:14px;word-break:break-all;line-height:1.4;transition:color .2s;cursor:default}.url-link:hover{color:var(--accent-hover);text-decoration:underline}.warning-message{background:#fff3cd;color:#856404;padding:12px 15px;border-radius:6px;border:1px solid #ffeaa7;font-size:14px;line-height:1.4;margin:10px 0 0}[data-theme=dark] .warning-message{background:#fff3cd1a;color:gold;border-color:#ffeaa74d}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px;border-top:1px solid var(--border-color)}.modal-footer .btn-primary,.modal-footer .btn-secondary{min-width:120px;padding:10px 20px}@media(max-width:767px){.confirmation-modal{width:95%;max-width:95%}.confirmation-info{gap:15px}.email-info{padding:12px}.email-value{font-size:14px}.url-preview{padding:12px}.url-link{font-size:13px}.warning-message{padding:10px 12px;font-size:13px}.modal-footer{flex-direction:column;gap:10px}.modal-footer .btn-primary,.modal-footer .btn-secondary{min-width:100%;width:100%}}@media(max-width:480px){.confirmation-modal{width:100%;max-width:100%;border-radius:0;max-height:100vh;height:100vh}.modal-header h2{font-size:18px}.confirmation-description{font-size:14px}.email-value{font-size:13px}.url-link{font-size:12px}}.text-style-selector .style-categories{margin-bottom:24px}.text-style-selector .style-categories h3{margin:0 0 12px;color:var(--text-primary);font-size:16px;font-weight:600}.category-tabs{display:flex;gap:8px;flex-wrap:wrap}.category-tab{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:20px;font-size:13px;cursor:pointer;transition:all .2s;color:var(--text-primary)}.category-tab:hover{background:var(--bg-secondary);border-color:var(--accent-color)}.category-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.category-icon{font-size:14px}.text-style-selector .styles-grid h3{margin:0 0 16px;color:var(--text-primary);font-size:16px;font-weight:600}.styles-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;margin-bottom:24px}.style-item{background:var(--bg-tertiary);border:2px solid var(--border-color);border-radius:8px;padding:16px;cursor:pointer;transition:all .2s;position:relative}.style-item:hover{border-color:var(--accent-color);transform:translateY(-2px);box-shadow:var(--shadow-md)}.style-item.hovered{border-color:var(--accent-color);background:var(--bg-secondary)}.style-preview{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:6px;padding:12px;margin-bottom:12px;min-height:60px;display:flex;align-items:center;justify-content:center}.style-info{margin-bottom:8px}.style-name{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.style-details{display:flex;gap:8px;font-size:12px;color:var(--text-secondary)}.style-font{font-weight:500}.style-size{color:var(--text-tertiary)}.style-badge{position:absolute;top:8px;right:8px;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase}.style-badge.shadow{background:#0000001a;color:var(--text-secondary);border:1px solid var(--border-color)}.style-badge.glow{background:#ff03;color:#f39c12;border:1px solid #f39c12}.style-badge.outline{background:#3498db1a;color:#3498db;border:1px solid #3498db}.text-style-selector .current-style h3{margin:0 0 12px;color:var(--text-primary);font-size:16px;font-weight:600}.current-style-preview{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:16px}.color-palette .palette-tabs{display:flex;gap:8px;margin-bottom:20px;border-bottom:1px solid var(--border-color)}.color-palette .tab{padding:8px 16px;background:none;border:none;border-bottom:2px solid transparent;font-size:14px;cursor:pointer;transition:all .2s;color:var(--text-secondary)}.color-palette .tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}.color-palette .tab.active{color:var(--accent-color);border-bottom-color:var(--accent-color)}.color-palette .current-color-section,.color-palette .recent-colors-section,.color-palette .preset-colors-section,.color-palette .custom-color-section{margin-bottom:24px}.color-palette h3{margin:0 0 12px;color:var(--text-primary);font-size:14px;font-weight:600}.current-color-display{display:flex;align-items:center;gap:12px;padding:12px;background:var(--bg-tertiary);border-radius:6px}.color-preview{width:40px;height:40px;border-radius:50%;border:2px solid var(--border-color)}.color-hex{font-family:Courier New,monospace;font-size:14px;font-weight:600;color:var(--text-primary)}.color-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(40px,1fr));gap:8px}.color-swatch{width:40px;height:40px;border-radius:50%;border:2px solid var(--border-color);cursor:pointer;transition:all .2s;position:relative}.color-swatch:hover{transform:scale(1.1);border-color:var(--accent-color)}.color-swatch.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--accent-color)}.custom-color-input{display:flex;gap:12px;align-items:center}.color-picker{width:50px;height:40px;border:2px solid var(--border-color);border-radius:6px;cursor:pointer;background:var(--bg-primary)}.color-hex-input{flex:1;padding:8px 12px;border:1px solid var(--border-color);border-radius:6px;font-family:Courier New,monospace;font-size:14px;background:var(--bg-primary);color:var(--text-primary)}.gradient-colors .gradient-info{margin-bottom:16px}.gradient-colors .gradient-info p{margin:0;color:var(--text-secondary);font-size:14px}.gradient-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.gradient-swatch{display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s}.gradient-swatch:hover{border-color:var(--accent-color);transform:translateY(-2px)}.gradient-preview{width:100%;height:40px;border-radius:6px;border:1px solid var(--border-color)}.gradient-name{font-size:12px;color:var(--text-primary);font-weight:500}[data-theme=dark] .sidebar{background:var(--bg-primary);border-right-color:var(--border-color)}[data-theme=dark] .sidebar-section{border-bottom-color:var(--border-color)}[data-theme=dark] .sidebar-section-title{color:var(--text-secondary)}[data-theme=dark] .canvas-container{background:var(--bg-secondary)}[data-theme=dark] .canvas-controls{background:var(--bg-primary);border:1px solid var(--border-color)}[data-theme=dark] .canvas-controls .zoom-display{color:var(--text-secondary)}[data-theme=dark] .properties-panel{background:var(--bg-primary);border-left-color:var(--border-color)}[data-theme=dark] .properties-section{border-bottom-color:var(--border-color)}[data-theme=dark] .properties-title,[data-theme=dark] .property-label{color:var(--text-secondary)}[data-theme=dark] .property-input{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .property-input:focus{border-color:var(--accent-color)}[data-theme=dark] .btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .layer-item{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .layer-item:hover{background:var(--bg-secondary)}[data-theme=dark] .layer-item.selected{background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .layer-name{color:var(--text-primary)}[data-theme=dark] .layer-thumbnail{background:var(--bg-primary);border-color:var(--border-color)}[data-theme=dark] .empty-state{color:var(--text-tertiary)}[data-theme=dark] .tooltip:hover:after{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}[data-theme=dark] .stock-image-btn{background:none;border-color:var(--border-color)}[data-theme=dark] .stock-image-btn:hover{border-color:var(--accent-color);background:var(--bg-secondary)}[data-theme=dark] .ai-generator-modal{background:var(--bg-primary)}[data-theme=dark] .ai-generator-header{border-bottom-color:var(--border-color)}[data-theme=dark] .ai-generator-header h3{color:var(--text-primary)}[data-theme=dark] .close-btn{color:var(--text-secondary)}[data-theme=dark] .close-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}[data-theme=dark] .form-group label{color:var(--text-primary)}[data-theme=dark] .form-group textarea,[data-theme=dark] .form-group select{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .preset-btn{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .preset-btn:hover{background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .ai-generator-actions{border-top-color:var(--border-color)}[data-theme=dark] .templates-modal{background:var(--bg-primary)}[data-theme=dark] .templates-header{border-bottom-color:var(--border-color)}[data-theme=dark] .templates-header h2{color:var(--text-primary)}[data-theme=dark] .templates-categories{border-bottom-color:var(--border-color)}[data-theme=dark] .category-btn{background:var(--bg-tertiary);color:var(--text-secondary);border-color:var(--border-color)}[data-theme=dark] .category-btn:hover{background:var(--bg-secondary);border-color:var(--accent-color);color:var(--text-primary)}[data-theme=dark] .category-btn.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}[data-theme=dark] .template-card{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .template-card:hover{border-color:var(--accent-color);box-shadow:var(--shadow-md)}[data-theme=dark] .template-preview{background:linear-gradient(135deg,var(--bg-secondary) 0%,var(--bg-tertiary) 100%);border-bottom-color:var(--border-color)}[data-theme=dark] .template-name{color:var(--text-primary)}[data-theme=dark] .template-description{color:var(--text-secondary)}[data-theme=dark] .template-meta{color:var(--text-tertiary)}[data-theme=dark] .theme-toggle-btn{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .theme-toggle-btn:hover{background:var(--bg-tertiary);border-color:var(--accent-color)}[data-theme=dark] .autosave-indicator{background:var(--bg-secondary);color:var(--text-tertiary)}[data-theme=dark] .autosave-indicator.saving{color:var(--accent-color)}[data-theme=dark] .autosave-indicator.saved{color:#27ae60}[data-theme=dark] .modal-content{background:var(--bg-primary)}[data-theme=dark] .modal-header{border-bottom-color:var(--border-color)}[data-theme=dark] .modal-header h2{color:var(--text-primary)}[data-theme=dark] .modal-footer{border-top-color:var(--border-color)}[data-theme=dark] .text-style-selector .style-categories h3{color:var(--text-primary)}[data-theme=dark] .category-tab{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .category-tab:hover{background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .category-tab.active{background:var(--accent-color);color:#fff;border-color:var(--accent-color)}[data-theme=dark] .text-style-selector .styles-grid h3{color:var(--text-primary)}[data-theme=dark] .style-item{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .style-item:hover{border-color:var(--accent-color);box-shadow:var(--shadow-md)}[data-theme=dark] .style-item.hovered{border-color:var(--accent-color);background:var(--bg-secondary)}[data-theme=dark] .style-preview{background:var(--bg-primary);border-color:var(--border-color)}[data-theme=dark] .style-name{color:var(--text-primary)}[data-theme=dark] .style-details{color:var(--text-secondary)}[data-theme=dark] .style-size{color:var(--text-tertiary)}[data-theme=dark] .style-badge.shadow{background:#ffffff1a;color:var(--text-secondary);border-color:var(--border-color)}[data-theme=dark] .text-style-selector .current-style h3{color:var(--text-primary)}[data-theme=dark] .current-style-preview{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .color-palette .tab{color:var(--text-secondary)}[data-theme=dark] .color-palette .tab:hover{color:var(--text-primary);background:var(--bg-tertiary)}[data-theme=dark] .color-palette .tab.active{color:var(--accent-color);border-bottom-color:var(--accent-color)}[data-theme=dark] .color-palette h3{color:var(--text-primary)}[data-theme=dark] .current-color-display{background:var(--bg-tertiary)}[data-theme=dark] .color-hex{color:var(--text-primary)}[data-theme=dark] .color-swatch{border-color:var(--border-color)}[data-theme=dark] .color-swatch:hover{border-color:var(--accent-color)}[data-theme=dark] .color-swatch.selected{border-color:var(--accent-color);box-shadow:0 0 0 2px var(--bg-primary),0 0 0 4px var(--accent-color)}[data-theme=dark] .color-picker{border-color:var(--border-color);background:var(--bg-primary)}[data-theme=dark] .color-hex-input{background:var(--bg-primary);color:var(--text-primary);border-color:var(--border-color)}[data-theme=dark] .gradient-colors .gradient-info p{color:var(--text-secondary)}[data-theme=dark] .gradient-swatch{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .gradient-swatch:hover{border-color:var(--accent-color)}[data-theme=dark] .gradient-preview{border-color:var(--border-color)}[data-theme=dark] .gradient-name{color:var(--text-primary)}[data-theme=dark] .sidebar-toggle{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}[data-theme=dark] .sidebar-toggle:hover{background:var(--accent-color);color:#fff}@media(min-width:1440px){:root{--sidebar-width: 320px;--properties-width: 350px}.header-content{max-width:1920px}.sidebar{width:320px}.properties-panel{width:350px}}@media(max-width:1023px){:root{--sidebar-width: 260px;--properties-width: 280px;--header-height: 64px}.header-content{flex-wrap:wrap;gap:8px}.header-title{font-size:18px}.header-actions{flex-wrap:wrap;gap:8px}.header-actions button{padding:8px 12px;font-size:13px}.sidebar{width:260px}.sidebar:not(.open){margin-left:-260px}.properties-panel{width:280px}.properties-panel:not(.open){margin-right:-280px}.sidebar-section,.properties-section{padding:16px}}@media(max-width:767px){:root{--sidebar-width: 80%;--properties-width: 80%}.stock-images-grid,.sidebar .stock-images-grid{grid-template-columns:repeat(2,1fr)!important;gap:6px}.app-header{padding:8px;min-height:auto;max-height:55px;height:auto;flex-shrink:0}.header-content{flex-direction:row;align-items:center;gap:4px;flex-wrap:nowrap;height:100%;padding:0 2px}.header-title{font-size:13px;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex-shrink:1;min-width:0;max-width:110px;line-height:1.2}.header-actions{flex:1;display:flex;gap:3px;flex-wrap:nowrap;overflow-x:auto;overflow-y:visible;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;justify-content:flex-end;align-items:center;padding-right:2px}.header-actions::-webkit-scrollbar{display:none}.header-actions button{padding:6px;font-size:11px;flex-shrink:0;min-width:auto;white-space:nowrap}.header-actions .btn-icon{min-width:28px;width:28px;padding:6px;font-size:12px}.header-actions .mobile-hidden{display:none!important}.header-actions .mobile-only{display:inline-flex!important}.header-actions .user-info,.header-actions .theme-toggle-btn,.header-actions .btn-icon,.header-actions .cart-btn,.header-actions .add-to-cart-btn,.header-actions .btn-primary,.header-actions .btn-secondary:not(.mobile-hidden){display:inline-flex!important}.header-actions button:not(.btn-icon):not(.mobile-hidden) span,.header-actions .add-to-cart-btn span{display:none}.header-actions button:not(.btn-icon):not(.mobile-hidden){font-size:14px;line-height:1;padding:6px;min-width:32px;text-align:center}.header-actions .theme-toggle-btn{font-size:14px;padding:6px;min-width:32px;line-height:1}.header-actions .theme-toggle-btn span{display:none}.header-actions .btn-secondary:not(.mobile-hidden):not(.btn-icon):not(.theme-toggle-btn){font-size:14px;line-height:1;padding:6px;min-width:32px}.header-actions .btn-secondary:not(.mobile-hidden):not(.btn-icon):not(.theme-toggle-btn) span{display:none}.header-actions .user-info{font-size:11px;padding:5px 6px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:70px;display:inline-flex;align-items:center;line-height:1.2}.header-actions>*{height:auto;max-height:38px;display:inline-flex;align-items:center;justify-content:center}.header-actions .cart-btn{padding:6px;font-size:11px;min-width:32px;max-width:50px;overflow:hidden;text-overflow:ellipsis;position:relative;background:var(--accent-color);color:#fff;border-color:var(--accent-color)}.header-actions .cart-btn:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.header-actions .cart-btn>span:not(.cart-badge){display:none}.header-actions .cart-btn .cart-badge{position:absolute;top:-2px;right:-2px;font-size:.6em;padding:1px 3px;min-width:12px;height:12px;line-height:10px;background:#f44;border:1px solid white}.header-actions .add-to-cart-btn{padding:6px;font-size:11px;min-width:32px;max-width:45px;background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.header-actions .add-to-cart-btn:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color)}.header-actions .add-to-cart-btn:disabled{opacity:.5}.header-actions .add-to-cart-btn>span{display:none}.cart-badge{font-size:.7em;padding:1px 4px;min-width:14px;height:14px;line-height:12px}@media(max-width:479px){.app-header{padding:6px;max-height:48px}.header-title{font-size:11px;max-width:90px}.header-content{gap:4px}.header-actions{gap:2px}.header-actions>*{height:auto;max-height:36px}.header-actions button{padding:5px;font-size:14px;min-width:30px}.header-actions .btn-icon{min-width:26px;width:26px;padding:5px;font-size:11px}.header-actions .user-info{font-size:9px;padding:4px 5px;max-width:55px;height:auto}.header-actions .cart-btn{padding:5px;font-size:10px;min-width:28px;max-width:42px;background:var(--accent-color);color:#fff}.header-actions .add-to-cart-btn{padding:5px;font-size:10px;min-width:28px;max-width:40px;background:var(--bg-tertiary)}.header-actions .cart-btn .cart-badge{font-size:.55em;padding:1px 2px;min-width:10px;height:10px;line-height:8px;top:-1px;right:-1px}.cart-badge{font-size:.65em;padding:1px 3px;min-width:12px;height:12px;line-height:10px}}.sidebar{position:fixed;top:0;left:0;bottom:0;width:80%;max-width:300px;z-index:1000;box-shadow:2px 0 8px #00000026;margin-left:0;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.sidebar:not(.open){opacity:0;visibility:hidden}.properties-panel{position:fixed;top:0;right:0;bottom:0;width:80%;max-width:300px;z-index:1000;box-shadow:-2px 0 8px #00000026;margin-right:0;transform:translate(100%)}.properties-panel.open{transform:translate(0)}.properties-panel:not(.open){opacity:0;visibility:hidden}.canvas-container{margin-left:0!important;margin-right:0!important;width:100%}@media(max-width:400px){:root{--sidebar-width: 70%;--properties-width: 70%}.sidebar{width:70%;max-width:260px;left:0}.sidebar-backdrop{left:0}.properties-panel{width:70%;max-width:260px;right:0}.properties-backdrop{right:0}.app-header{padding:5px 4px;max-height:46px;min-height:46px}.header-title{font-size:10px;max-width:80px;line-height:1.1}.header-content{gap:3px;padding:0 1px}.header-actions{gap:2px;padding-right:1px}.header-actions>*{height:auto;max-height:36px}.header-actions button{padding:4px;font-size:13px;min-width:28px}.header-actions .btn-icon{min-width:24px;width:24px;padding:4px;font-size:10px}.header-actions .theme-toggle-btn{font-size:13px;padding:4px;min-width:28px}.header-actions .user-info{font-size:8px;padding:4px;max-width:50px;height:auto}.header-actions .cart-btn{padding:4px;font-size:9px;min-width:26px;max-width:38px;background:var(--accent-color);color:#fff}.header-actions .add-to-cart-btn{padding:4px;font-size:9px;min-width:26px;max-width:36px;background:var(--bg-tertiary)}.header-actions .cart-btn .cart-badge{font-size:.5em;padding:1px 2px;min-width:9px;height:9px;line-height:7px;top:-1px;right:-1px}.header-menu-toggle{width:28px;height:26px;font-size:16px}}.sidebar-section{padding:12px}.sidebar-section-title{font-size:13px}.properties-section{padding:12px}.properties-title{font-size:13px}.sidebar button,.properties-panel button{padding:8px 12px;font-size:13px}.form-row{flex-direction:column}.sidebar .stock-images-grid{grid-template-columns:repeat(2,1fr);gap:6px}.properties-panel .color-grid,.sidebar .variant-colors{gap:6px}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;padding:12px}.ai-generator-modal{width:95%;max-width:none}.ai-generator-content{padding:16px}.modal-content{width:95%;max-width:none}.modal-body{padding:16px}}@media(max-width:479px){.app-header{padding:8px 10px}.header-title{font-size:14px}.header-actions button{padding:5px 8px;font-size:11px}.sidebar,.properties-panel{width:100%;max-width:100%}.sidebar-section,.properties-section{padding:10px}.sidebar-section-title,.properties-title{font-size:12px}.sidebar .stock-images-grid{grid-template-columns:1fr}.templates-grid{grid-template-columns:1fr;gap:10px}.sidebar button,.properties-panel button{padding:6px 10px;font-size:12px}.sidebar .color-option,.properties-panel .color-swatch{width:32px;height:32px}.property-input{padding:6px 10px;font-size:12px}.canvas-controls{bottom:10px;padding:6px;gap:4px}.zoom-display{padding:6px 8px;font-size:12px}}@media(max-width:767px)and (orientation:landscape){:root{--sidebar-width: 70%;--properties-width: 70%}.app-header{padding:6px 10px}.header-title{font-size:14px}.sidebar,.properties-panel{width:70%;max-width:400px}.canvas-controls{bottom:10px}}@media(-webkit-min-device-pixel-ratio:2),(min-resolution:192dpi){.sidebar,.properties-panel{border-width:.5px}}@media print{.app-header,.sidebar,.properties-panel,.floating-sidebar-toggle{display:none!important}.canvas-container{width:100%!important;height:100%!important;margin:0!important}.app-content{display:block!important}}@media(hover:none)and (pointer:coarse){button{min-height:44px;min-width:44px}.sidebar .color-option,.properties-panel .color-swatch{width:44px;height:44px}.sidebar .color-option:hover,.properties-panel .color-swatch:hover,.stock-image-btn:hover{transform:none}button:active{opacity:.7;transform:scale(.95)}}@media(prefers-reduced-motion:reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.sidebar,.properties-panel{transition:none}}@media(max-width:360px){.app-header{padding:6px 8px}.header-title{font-size:13px}.header-actions{gap:4px}.header-actions button{padding:4px 6px;font-size:10px;min-width:32px}.sidebar,.properties-panel{width:100%}.sidebar-section,.properties-section{padding:8px}.property-input{padding:5px 8px;font-size:11px}.canvas-controls{bottom:5px;padding:4px;gap:3px}.zoom-display{padding:4px 6px;font-size:11px}}@media(max-width:767px){.form-group{margin-bottom:12px}.form-group label{font-size:13px;margin-bottom:4px}.form-group input,.form-group textarea,.form-group select{padding:8px 10px;font-size:14px}.modal-content,.ai-generator-modal,.templates-modal{width:95%;max-height:95vh;margin:10px}.modal-header{padding:12px 16px}.modal-header h2{font-size:18px}.modal-body{padding:12px 16px}.modal-footer{padding:12px 16px;flex-wrap:wrap;gap:8px}.modal-footer button{flex:1;min-width:calc(50% - 4px);padding:10px;font-size:14px}.header-actions .cart-btn{position:relative}.cart-badge{font-size:.7em;padding:1px 5px;min-width:16px;height:16px;line-height:14px}.sidebar-section-title,.properties-title{font-size:12px;margin-bottom:10px}.stock-images-grid,.sidebar .stock-images-grid{grid-template-columns:repeat(2,1fr)!important;gap:6px}.stock-image-btn{min-height:50px}.stock-image-preview{max-height:40px}.color-grid{grid-template-columns:repeat(4,1fr);gap:6px}.color-swatch,.color-option{width:36px;height:36px}.layer-item{padding:8px;gap:6px}.layer-thumbnail{width:36px;height:36px;font-size:16px}.layer-name{font-size:12px}.templates-categories{padding:12px 16px;gap:6px;overflow-x:auto;-webkit-overflow-scrolling:touch}.templates-grid{grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px;padding:12px}.template-card{border-radius:8px}.template-preview{height:120px}.template-info{padding:12px}.template-name{font-size:14px}.template-description{font-size:12px}.ai-generator-content{padding:12px}.preset-grid{grid-template-columns:repeat(2,1fr);gap:6px}.preset-btn{padding:6px 10px;font-size:11px}.styles-list{grid-template-columns:1fr;gap:12px}.style-item{padding:12px}.style-preview{min-height:50px;padding:10px}.category-tabs{gap:6px;flex-wrap:wrap}.category-tab{padding:6px 12px;font-size:12px}.color-palette .palette-tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.color-palette .tab{padding:8px 12px;font-size:13px;white-space:nowrap}.gradient-grid{grid-template-columns:repeat(2,1fr);gap:8px}.gradient-swatch{padding:8px}.gradient-preview{height:30px}.gradient-name{font-size:11px}}@media(max-width:767px)and (orientation:portrait){.app{height:100vh;height:100dvh}.app-content{flex-direction:column}.canvas-container{flex:1;min-height:50vh}.header-actions .theme-toggle-btn span{display:none}}@media(max-width:767px)and (orientation:landscape){.app-header{padding:6px 10px}.header-title{font-size:14px}.header-actions button{padding:5px 8px;font-size:11px}.sidebar,.properties-panel{width:70%;max-width:350px}.canvas-container{min-height:calc(100vh - 60px)}.canvas-controls{bottom:8px;padding:5px}}@media(hover:none)and (pointer:coarse){button,.sidebar-toggle,.color-option,.color-swatch,.stock-image-btn,.template-card,.style-item,.preset-btn{min-height:44px;min-width:44px}button:active,.color-option:active,.color-swatch:active,.stock-image-btn:active{transform:scale(.95);opacity:.8}.sidebar .color-option:hover,.properties-panel .color-swatch:hover,.stock-image-btn:hover,.template-card:hover{transform:none}.sidebar,.properties-panel,.modal-body{-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.sidebar-section,.properties-section{padding:16px 12px}.property-group{margin-bottom:20px}.form-group{margin-bottom:16px}.form-group input,.form-group textarea,.form-group select{padding:12px;font-size:16px;border-radius:8px}button{padding:12px 16px;font-size:16px;border-radius:8px}.btn-small{padding:8px 12px;font-size:14px;min-height:44px}input[type=checkbox],input[type=radio]{width:24px;height:24px;min-width:24px;min-height:24px}input[type=range]{height:8px;-webkit-appearance:none}input[type=range]::-webkit-slider-thumb{width:24px;height:24px}input[type=range]::-moz-range-thumb{width:24px;height:24px}}@supports (-webkit-touch-callout: none){@media(max-width:767px){input,textarea,select{font-size:16px!important}.sidebar,.properties-panel{-webkit-overflow-scrolling:touch}.app{height:100vh;height:-webkit-fill-available}.canvas-container{min-height:50vh;min-height:-webkit-fill-available}}}@media(max-width:767px){*{-webkit-overflow-scrolling:touch}button,.sidebar-toggle,.color-option,.color-swatch{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}button:active,.color-option:active{-webkit-tap-highlight-color:rgba(0,0,0,.1)}}@media(max-width:320px){.header-actions{flex-wrap:wrap}.header-actions button{flex:1 1 calc(50% - 3px);min-width:calc(50% - 3px);max-width:calc(50% - 3px)}.modal-content{width:100%;margin:0;border-radius:0;max-height:100vh}.templates-grid,.stock-images-grid{grid-template-columns:1fr}.color-grid{grid-template-columns:repeat(3,1fr)}}.app-footer{height:var(--footer-height);min-height:var(--footer-height);background:var(--footer-bg);color:var(--footer-text);border-top:1px solid var(--footer-border);box-shadow:0 -2px 10px #0000000d;position:fixed;bottom:0;left:0;right:0;z-index:999;display:flex;align-items:center}.footer-content{display:flex;justify-content:space-between;align-items:center;max-width:1800px;width:100%;margin:0 auto;padding:0 15px;gap:15px;height:100%}.footer-left{flex:0 0 auto}.footer-left .logo-placeholder{width:90px;height:30px;background:var(--accent-color);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;border-radius:var(--border-radius-sm);font-size:14px}.footer-center{flex:1;display:flex;align-items:center;justify-content:center;gap:15px;flex-wrap:wrap}.footer-link{background:none;border:none;color:var(--footer-text);font-size:12px;cursor:pointer;padding:4px 0;transition:all .2s;opacity:.8;text-decoration:none;font-family:inherit;white-space:nowrap}.footer-link:hover{color:var(--accent-color);opacity:1;transform:translateY(-1px)}.footer-divider{color:var(--text-tertiary);font-size:12px;opacity:.5}.footer-right{flex:0 0 auto;display:flex;align-items:center}.footer-social{display:flex;gap:8px}.social-btn{width:28px;height:28px;border:none;border-radius:50%;background:var(--bg-tertiary);color:var(--text-secondary);font-size:10px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s}.social-btn:hover{background:var(--accent-color);color:#fff;transform:translateY(-1px)}@media(max-width:767px){.footer-center{gap:10px}.footer-link{font-size:11px;padding:3px 0}}@media(max-width:480px){.footer-center{gap:8px}.footer-link{font-size:10px}.footer-divider{display:none}}@media(max-width:1024px){.footer-content{padding:0 10px;gap:10px}.footer-left .logo-placeholder{width:80px;height:28px;font-size:13px}.footer-link{font-size:11px}.social-btn{width:26px;height:26px;font-size:9px}}@media(max-width:767px){.app-footer{height:50px;min-height:50px}.footer-content{flex-direction:column;justify-content:center;gap:5px;padding:0 10px}.footer-left{display:none}.footer-center{gap:8px;order:2}.footer-right{order:1}.footer-link{font-size:10px}.footer-divider{display:none}.social-btn{width:24px;height:24px;font-size:8px}}@media(max-width:480px){.app-footer{height:45px;min-height:45px}.footer-center{gap:5px}.footer-link{font-size:9px;padding:2px 0}.footer-social{gap:5px}.social-btn{width:22px;height:22px}}.dropdown-menu{position:fixed;top:var(--header-height, 70px);left:0;right:0;bottom:0;z-index:9999;display:flex;pointer-events:none;opacity:0;visibility:hidden;transition:opacity .2s ease,visibility .2s ease;background:transparent!important}.dropdown-menu.active{pointer-events:auto;opacity:1;visibility:visible;min-height:calc(100vh - var(--header-height, 70px) - var(--footer-height, 60px));background:transparent!important}.menu-overlay{position:absolute;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);pointer-events:auto;min-height:calc(100vh - var(--header-height, 70px) - var(--footer-height, 60px))}.menu-content{position:absolute;top:0;right:0;bottom:0;width:320px;background:var(--bg-primary);border-left:1px solid var(--border-color);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;overflow:hidden;pointer-events:auto;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);min-height:calc(100vh - var(--header-height, 70px) - var(--footer-height, 60px));max-height:calc(100vh - var(--header-height, 70px))}.dropdown-menu.active .menu-content{transform:translate(0)}.menu-item{background:none;border:none;font-family:inherit;cursor:pointer;text-align:left;width:100%;padding:12px 16px;display:flex;align-items:flex-start;gap:12px;transition:all .2s ease;border-radius:8px}.menu-header{padding:20px 24px;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:var(--bg-primary)}.menu-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;display:flex;align-items:center}.menu-title-icon{margin-right:8px;font-size:20px}.menu-close{width:32px;height:32px;background:var(--bg-tertiary);border:none;border-radius:50%;font-size:20px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.menu-close:hover{background:var(--accent-color);color:#fff}.menu-grid{flex:1;overflow-y:auto;padding:16px 20px;scrollbar-width:thin;scrollbar-color:var(--border-color) transparent}.menu-grid::-webkit-scrollbar{width:6px}.menu-grid::-webkit-scrollbar-track{background:transparent}.menu-grid::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.menu-section{margin-bottom:24px}.menu-section:last-child{margin-bottom:0}.menu-section-title{font-size:14px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px;padding-left:4px}.menu-items-grid{display:flex;flex-direction:column;gap:8px}.menu-item{background:var(--bg-tertiary);border:1px solid var(--border-color)}.menu-item:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color);transform:translate(4px)}.menu-item:disabled{opacity:.5;cursor:not-allowed}.menu-item:disabled:hover{transform:none;border-color:var(--border-color);background:var(--bg-tertiary)}.menu-item-content{flex:1;min-width:0}.menu-text{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:4px}.menu-description{display:block;font-size:12px;color:var(--text-secondary);line-height:1.4}.menu-icon{font-size:18px;width:24px;display:flex;align-items:center;justify-content:center;margin-top:2px;flex-shrink:0}.menu-shortcut{font-size:12px;color:var(--text-tertiary);font-family:Courier New,monospace;background:var(--bg-secondary);padding:4px 8px;border-radius:4px;align-self:flex-start;margin-top:2px;flex-shrink:0;white-space:nowrap}.menu-item.btn-add-to-cart{background:var(--success-color);border-color:var(--success-color);color:#fff}.menu-item.btn-add-to-cart .menu-text,.menu-item.btn-add-to-cart .menu-description,.menu-item.btn-add-to-cart .menu-icon{color:#fff}.menu-item.btn-add-to-cart:hover:not(:disabled){background:#059669;border-color:#059669}.menu-footer{padding:16px 24px;border-top:1px solid var(--border-color);flex-shrink:0;background:var(--bg-primary)}.menu-footer-info{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--bg-tertiary);border-radius:8px;border:1px solid var(--border-color)}.footer-icon{font-size:16px;flex-shrink:0;margin-top:1px}.footer-text{font-size:12px;color:var(--text-secondary);line-height:1.4}[data-theme=dark] .menu-content{background:var(--bg-primary);border-left-color:var(--border-color)}[data-theme=dark] .menu-header{border-bottom-color:var(--border-color);background:var(--bg-primary)}[data-theme=dark] .menu-title{color:var(--text-primary)}[data-theme=dark] .menu-close{background:var(--bg-tertiary);color:var(--text-secondary)}[data-theme=dark] .menu-close:hover{background:var(--accent-color);color:#fff}[data-theme=dark] .menu-section-title{color:var(--text-secondary)}[data-theme=dark] .menu-item{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .menu-item:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color)}[data-theme=dark] .menu-text{color:var(--text-primary)}[data-theme=dark] .menu-description{color:var(--text-secondary)}[data-theme=dark] .menu-shortcut{color:var(--text-tertiary);background:var(--bg-secondary)}[data-theme=dark] .menu-footer{border-top-color:var(--border-color);background:var(--bg-primary)}[data-theme=dark] .menu-footer-info{background:var(--bg-tertiary);border-color:var(--border-color)}[data-theme=dark] .footer-text{color:var(--text-secondary)}@media(max-width:1023px){.dropdown-menu{top:64px}}@media(max-width:767px){.dropdown-menu{top:60px}.menu-content{width:100%;max-width:320px}.menu-header{padding:16px 20px}.menu-title{font-size:17px}.menu-grid{padding:12px 16px}.menu-item{padding:10px 12px}.menu-text{font-size:13px}.menu-description{font-size:11px}.menu-close{width:28px;height:28px;font-size:18px}}@media(max-width:479px){.dropdown-menu{top:56px}.menu-content{width:100%;max-width:none}.menu-header{padding:14px 16px}.menu-title{font-size:16px}.menu-grid{padding:12px}.menu-item{padding:8px 10px}.menu-footer{padding:12px 16px}}@media(max-width:400px){.dropdown-menu{top:46px}}@media(max-width:360px){.dropdown-menu{top:46px}.menu-header{padding:12px 14px}.menu-item{padding:6px 8px}.menu-icon{font-size:16px;width:20px}}@media(max-width:767px)and (orientation:landscape){.dropdown-menu{top:56px}}@media(hover:none)and (pointer:coarse){.menu-item{min-height:48px}.menu-close{min-width:44px;min-height:44px}.menu-item:hover:not(:disabled){transform:none}.menu-item:active:not(:disabled){background:var(--bg-secondary);border-color:var(--accent-color)}}.orders-statistics{background:var(--bg-primary, white);border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;margin-bottom:20px}.dark-theme .orders-statistics{background:var(--bg-secondary, #2d2d2d);box-shadow:0 2px 4px #0000004d}.statistics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.statistics-header h3{margin:0;font-size:1.2em;color:var(--text-primary, #333)}.dark-theme .statistics-header h3{color:var(--text-primary, #e0e0e0)}.period-select{padding:6px 12px;border:1px solid var(--border-color, #ddd);border-radius:6px;background:var(--bg-primary, white);color:var(--text-primary, #333);font-size:.9em;cursor:pointer}.dark-theme .period-select{background:var(--bg-tertiary, #2a2a2a);border-color:var(--border-color, #444);color:var(--text-primary, #e0e0e0)}.statistics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px;margin-bottom:20px}.stat-card{background:var(--bg-secondary, #f8f9fa);border-radius:6px;padding:15px;text-align:center;border:1px solid var(--border-color, #e0e0e0)}.dark-theme .stat-card{background:var(--bg-tertiary, #2a2a2a);border-color:var(--border-color, #404040)}.stat-label{font-size:.85em;color:var(--text-secondary, #666);margin-bottom:8px}.dark-theme .stat-label{color:var(--text-secondary, #a0a0a0)}.stat-value{font-size:1.5em;font-weight:700;color:var(--text-primary, #333)}.dark-theme .stat-value{color:var(--text-primary, #e0e0e0)}.stat-value.status-pending{color:#ffc107}.stat-value.status-in-progress{color:#17a2b8}.stat-value.status-completed{color:#28a745}.stat-value.status-cancelled{color:#dc3545}.stat-value.revenue{color:#007bff}.statistics-chart{margin-top:20px}.statistics-chart h4{margin:0 0 15px;font-size:1em;color:var(--text-primary, #333)}.dark-theme .statistics-chart h4{color:var(--text-primary, #e0e0e0)}.chart-container{display:flex;align-items:flex-end;justify-content:space-between;gap:4px;height:180px;padding:10px;background:var(--bg-secondary, #f8f9fa);border-radius:6px;overflow:hidden;width:100%;box-sizing:border-box}.dark-theme .chart-container{background:var(--bg-tertiary, #2a2a2a)}.chart-bar-container{display:flex;flex-direction:column;align-items:center;flex:1;min-width:0;max-width:100%}.chart-bar{width:100%;background:linear-gradient(to top,var(--accent-color, #3b82f6),var(--accent-hover-color, #60a5fa));border-radius:4px 4px 0 0;position:relative;min-height:4px;transition:all .3s ease;cursor:pointer}.chart-bar:hover{opacity:.8;transform:scaleY(1.05)}.chart-bar-value{position:absolute;top:-20px;left:50%;transform:translate(-50%);font-size:.75em;color:var(--text-primary, #333);font-weight:500;white-space:nowrap;opacity:0;transition:opacity .2s}.chart-bar:hover .chart-bar-value{opacity:1}.dark-theme .chart-bar-value{color:var(--text-primary, #e0e0e0)}.chart-bar-label{margin-top:5px;font-size:.7em;color:var(--text-secondary, #666);text-align:center;white-space:nowrap;width:100%;overflow:hidden;text-overflow:ellipsis}.dark-theme .chart-bar-label{color:var(--text-secondary, #a0a0a0)}.statistics-loading,.statistics-error{padding:20px;text-align:center;color:var(--text-secondary, #666)}.dark-theme .statistics-loading,.dark-theme .statistics-error{color:var(--text-secondary, #a0a0a0)}.statistics-error{color:var(--danger-color, #dc3545)}.dark-theme .statistics-error{color:var(--danger-color, #ff6b6b)}.hub-page{min-height:100vh;background:var(--bg-secondary, #f8fafc);padding:20px;transition:background-color .3s ease;overflow-y:auto;height:100vh}.hub-page.dark-theme,.dark-theme.hub-page{background:var(--bg-primary, #0f172a)}.hub-header{max-width:1200px;margin:0 auto 40px;display:flex;justify-content:space-between;align-items:center;padding:20px 0}.btn-back{padding:10px 18px;background:#3b82f61f;color:var(--accent-color, #3b82f6);border:2px solid var(--accent-color, #3b82f6);border-radius:var(--radius-md, 8px);cursor:pointer;font-size:.95em;font-weight:600;transition:all .2s ease;box-shadow:0 1px 3px #3b82f633}.btn-back:hover{background:var(--accent-color, #3b82f6);color:#fff;box-shadow:0 2px 8px #3b82f666}.dark-theme .btn-back{background:#60a5fa26;border-color:var(--accent-color, #60a5fa);color:var(--accent-color, #60a5fa);box-shadow:0 1px 3px #0000004d}.dark-theme .btn-back:hover{background:var(--accent-color, #60a5fa);color:#0f172a;box-shadow:0 2px 8px #60a5fa66}.hub-header h1{font-size:2.5em;font-weight:700;color:var(--text-primary, #1e293b);margin:0}.dark-theme .hub-header h1{color:var(--text-primary, #f1f5f9)}.header-actions{display:flex;gap:10px}.btn-theme-toggle{background:var(--bg-secondary, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:8px;padding:10px 15px;font-size:1.2em;cursor:pointer;transition:all .2s ease}.dark-theme .btn-theme-toggle{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569)}.hub-content{max-width:1200px;margin:0 auto}.hub-statistics-section{margin-bottom:40px}.hub-cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px;margin-bottom:40px}.hub-card{background:var(--bg-primary, #ffffff);border:2px solid var(--border-color, #e2e8f0);border-radius:16px;padding:24px;cursor:pointer;transition:all .3s ease;display:flex;flex-direction:column;gap:16px;position:relative;overflow:hidden}.hub-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:var(--accent-color, #3b82f6);transform:scaleX(1);transition:transform .3s ease}.hub-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001f;border-color:var(--accent-color, #3b82f6)}.hub-card:hover:before{height:6px}.dark-theme .hub-card{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569)}.dark-theme .hub-card:hover{box-shadow:0 8px 24px #00000080}.hub-card-icon{font-size:3em;line-height:1}.hub-card-content{flex:1}.hub-card-title{font-size:1.5em;font-weight:600;color:var(--text-primary, #1e293b);margin:0 0 8px}.dark-theme .hub-card-title{color:var(--text-primary, #f1f5f9)}.hub-card-description{font-size:.95em;color:var(--text-secondary, #64748b);margin:0;line-height:1.5}.dark-theme .hub-card-description{color:var(--text-secondary, #94a3b8)}.hub-card-arrow{font-size:1.5em;color:var(--text-secondary, #64748b);transition:transform .3s ease;align-self:flex-end}.hub-card:hover .hub-card-arrow{transform:translate(4px);color:var(--accent-color, #3b82f6)}.hub-card-blue{background:linear-gradient(to bottom,rgba(59,130,246,.05) 0%,var(--bg-primary, #ffffff) 100%)}.hub-card-blue:before{background:#3b82f6}.hub-card-blue:hover{border-color:#3b82f6;background:linear-gradient(to bottom,rgba(59,130,246,.1) 0%,var(--bg-primary, #ffffff) 100%)}.dark-theme .hub-card-blue{background:linear-gradient(to bottom,rgba(59,130,246,.1) 0%,var(--bg-secondary, #1e293b) 100%)}.dark-theme .hub-card-blue:hover{background:linear-gradient(to bottom,rgba(59,130,246,.15) 0%,var(--bg-secondary, #1e293b) 100%)}.hub-card-green{background:linear-gradient(to bottom,rgba(16,185,129,.05) 0%,var(--bg-primary, #ffffff) 100%)}.hub-card-green:before{background:#10b981}.hub-card-green:hover{border-color:#10b981;background:linear-gradient(to bottom,rgba(16,185,129,.1) 0%,var(--bg-primary, #ffffff) 100%)}.dark-theme .hub-card-green{background:linear-gradient(to bottom,rgba(16,185,129,.1) 0%,var(--bg-secondary, #1e293b) 100%)}.dark-theme .hub-card-green:hover{background:linear-gradient(to bottom,rgba(16,185,129,.15) 0%,var(--bg-secondary, #1e293b) 100%)}.hub-card-purple{background:linear-gradient(to bottom,rgba(139,92,246,.05) 0%,var(--bg-primary, #ffffff) 100%)}.hub-card-purple:before{background:#8b5cf6}.hub-card-purple:hover{border-color:#8b5cf6;background:linear-gradient(to bottom,rgba(139,92,246,.1) 0%,var(--bg-primary, #ffffff) 100%)}.dark-theme .hub-card-purple{background:linear-gradient(to bottom,rgba(139,92,246,.1) 0%,var(--bg-secondary, #1e293b) 100%)}.dark-theme .hub-card-purple:hover{background:linear-gradient(to bottom,rgba(139,92,246,.15) 0%,var(--bg-secondary, #1e293b) 100%)}.hub-card-orange{background:linear-gradient(to bottom,rgba(245,158,11,.05) 0%,var(--bg-primary, #ffffff) 100%)}.hub-card-orange:before{background:#f59e0b}.hub-card-orange:hover{border-color:#f59e0b;background:linear-gradient(to bottom,rgba(245,158,11,.1) 0%,var(--bg-primary, #ffffff) 100%)}.dark-theme .hub-card-orange{background:linear-gradient(to bottom,rgba(245,158,11,.1) 0%,var(--bg-secondary, #1e293b) 100%)}.dark-theme .hub-card-orange:hover{background:linear-gradient(to bottom,rgba(245,158,11,.15) 0%,var(--bg-secondary, #1e293b) 100%)}.hub-card-teal{background:linear-gradient(to bottom,rgba(20,184,166,.05) 0%,var(--bg-primary, #ffffff) 100%)}.hub-card-teal:before{background:#14b8a6}.hub-card-teal:hover{border-color:#14b8a6;background:linear-gradient(to bottom,rgba(20,184,166,.1) 0%,var(--bg-primary, #ffffff) 100%)}.dark-theme .hub-card-teal{background:linear-gradient(to bottom,rgba(20,184,166,.1) 0%,var(--bg-secondary, #1e293b) 100%)}.dark-theme .hub-card-teal:hover{background:linear-gradient(to bottom,rgba(20,184,166,.15) 0%,var(--bg-secondary, #1e293b) 100%)}.hub-card-red{background:linear-gradient(to bottom,rgba(239,68,68,.05) 0%,var(--bg-primary, #ffffff) 100%)}.hub-card-red:before{background:#ef4444}.hub-card-red:hover{border-color:#ef4444;background:linear-gradient(to bottom,rgba(239,68,68,.1) 0%,var(--bg-primary, #ffffff) 100%)}.dark-theme .hub-card-red{background:linear-gradient(to bottom,rgba(239,68,68,.1) 0%,var(--bg-secondary, #1e293b) 100%)}.dark-theme .hub-card-red:hover{background:linear-gradient(to bottom,rgba(239,68,68,.15) 0%,var(--bg-secondary, #1e293b) 100%)}.hub-card-gray{background:linear-gradient(to bottom,rgba(107,114,128,.05) 0%,var(--bg-primary, #ffffff) 100%)}.hub-card-gray:before{background:#6b7280}.hub-card-gray:hover{border-color:#6b7280;background:linear-gradient(to bottom,rgba(107,114,128,.1) 0%,var(--bg-primary, #ffffff) 100%)}.dark-theme .hub-card-gray{background:linear-gradient(to bottom,rgba(107,114,128,.1) 0%,var(--bg-secondary, #1e293b) 100%)}.dark-theme .hub-card-gray:hover{background:linear-gradient(to bottom,rgba(107,114,128,.15) 0%,var(--bg-secondary, #1e293b) 100%)}.hub-info{text-align:center;padding:24px;background:var(--bg-secondary, #ffffff);border-radius:12px;border:1px solid var(--border-color, #e2e8f0)}.dark-theme .hub-info{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569)}.hub-info p{color:var(--text-secondary, #64748b);margin:0;font-size:1.1em}.dark-theme .hub-info p{color:var(--text-secondary, #94a3b8)}@media(max-width:768px){.hub-cards-grid{grid-template-columns:1fr;gap:16px}.hub-header h1{font-size:2em}.hub-card{padding:20px}}.pagination{display:flex;flex-direction:column;align-items:center;gap:16px;padding:20px;margin-top:20px}.pagination-info{font-size:.9em;color:var(--text-secondary, #666)}[data-theme=dark] .pagination-info,.dark-theme .pagination-info{color:var(--text-secondary, #a0a0a0)}.pagination-controls{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:center}.pagination-btn{padding:8px 16px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--bg-primary, #fff);color:var(--text-primary, #333);cursor:pointer;font-size:.9em;transition:all .2s ease;min-width:100px}.pagination-btn:hover:not(:disabled){background:var(--bg-secondary, #f5f5f5);border-color:var(--accent-color, #007bff);color:var(--accent-color, #007bff)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .pagination-btn,.dark-theme .pagination-btn{background:var(--bg-secondary, #2d2d2d);border-color:var(--border-color, #404040);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .pagination-btn:hover:not(:disabled),.dark-theme .pagination-btn:hover:not(:disabled){background:var(--bg-tertiary, #3d3d3d);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.pagination-pages{display:flex;align-items:center;gap:4px}.pagination-page{min-width:36px;height:36px;padding:0 8px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--bg-primary, #fff);color:var(--text-primary, #333);cursor:pointer;font-size:.9em;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.pagination-page:hover:not(.active){background:var(--bg-secondary, #f5f5f5);border-color:var(--accent-color, #007bff)}.pagination-page.active{background:var(--accent-color, #007bff);color:#fff;border-color:var(--accent-color, #007bff);font-weight:600}[data-theme=dark] .pagination-page,.dark-theme .pagination-page{background:var(--bg-secondary, #2d2d2d);border-color:var(--border-color, #404040);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .pagination-page:hover:not(.active),.dark-theme .pagination-page:hover:not(.active){background:var(--bg-tertiary, #3d3d3d);border-color:var(--accent-color, #3b82f6)}[data-theme=dark] .pagination-page.active,.dark-theme .pagination-page.active{background:var(--accent-color, #3b82f6);color:#fff;border-color:var(--accent-color, #3b82f6)}.pagination-ellipsis{padding:0 8px;color:var(--text-secondary, #666);-webkit-user-select:none;user-select:none}[data-theme=dark] .pagination-ellipsis,.dark-theme .pagination-ellipsis{color:var(--text-secondary, #a0a0a0)}@media(max-width:768px){.pagination-controls{flex-direction:column;width:100%}.pagination-btn{width:100%;max-width:200px}.pagination-pages{flex-wrap:wrap;justify-content:center}}.skeleton-line{background:linear-gradient(90deg,var(--skeleton-bg, #f0f0f0) 0%,var(--skeleton-shine, #e0e0e0) 50%,var(--skeleton-bg, #f0f0f0) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite;border-radius:4px;height:1em;margin-bottom:8px}[data-theme=dark] .skeleton-line{background:linear-gradient(90deg,var(--skeleton-bg-dark, #2a2a2a) 0%,var(--skeleton-shine-dark, #3a3a3a) 50%,var(--skeleton-bg-dark, #2a2a2a) 100%);background-size:200% 100%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-short{width:60px}.skeleton-medium{width:120px}.skeleton-title{height:1.2em;width:80%;margin-bottom:12px}.skeleton-text{height:.9em;width:100%}.skeleton-badge{height:1.5em;width:100px;border-radius:12px}.skeleton-price{height:1.3em;width:100px}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;padding:20px 0}.skeleton-order-card{background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a}[data-theme=dark] .skeleton-order-card{background:var(--bg-secondary, #2d2d2d);border-color:var(--border-color, #404040)}.skeleton-order-card .skeleton-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.skeleton-order-card .skeleton-body{margin-bottom:12px}.skeleton-order-card .skeleton-footer{display:flex;justify-content:flex-end;padding-top:12px;border-top:1px solid var(--border-color, #e0e0e0)}[data-theme=dark] .skeleton-order-card .skeleton-footer{border-top-color:var(--border-color, #404040)}.skeleton-table{background:var(--bg-primary, #ffffff);border-radius:8px;padding:20px;overflow-x:auto}[data-theme=dark] .skeleton-table{background:var(--bg-secondary, #2d2d2d)}.skeleton-table-content{width:100%;border-collapse:collapse}.skeleton-table-content thead th{padding:12px;text-align:left;border-bottom:2px solid var(--border-color, #e0e0e0)}[data-theme=dark] .skeleton-table-content thead th{border-bottom-color:var(--border-color, #404040)}.skeleton-table-content tbody td{padding:12px;border-bottom:1px solid var(--border-color, #e0e0e0)}[data-theme=dark] .skeleton-table-content tbody td{border-bottom-color:var(--border-color, #404040)}.skeleton-table-content tbody tr:last-child td{border-bottom:none}.skeleton-templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;padding:20px 0}.skeleton-template-card{background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}[data-theme=dark] .skeleton-template-card{background:var(--bg-secondary, #2d2d2d);border-color:var(--border-color, #404040)}.skeleton-preview{width:100%;height:150px;background:linear-gradient(90deg,var(--skeleton-bg, #f0f0f0) 0%,var(--skeleton-shine, #e0e0e0) 50%,var(--skeleton-bg, #f0f0f0) 100%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}[data-theme=dark] .skeleton-preview{background:linear-gradient(90deg,var(--skeleton-bg-dark, #2a2a2a) 0%,var(--skeleton-shine-dark, #3a3a3a) 50%,var(--skeleton-bg-dark, #2a2a2a) 100%);background-size:200% 100%}.skeleton-content{padding:16px}.skeleton-content .skeleton-line:last-child{margin-bottom:0}.error-details{background:var(--bg-primary, white);border:2px solid var(--danger-color, #dc3545);border-radius:8px;padding:20px;margin:20px 0;box-shadow:0 2px 8px #dc354533}.dark-theme .error-details{background:var(--bg-secondary, #2d2d2d);border-color:var(--danger-color, #ff6b6b);box-shadow:0 2px 8px #ff6b6b4d}.error-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:15px}.error-icon{font-size:1.5em;flex-shrink:0}.error-message-text{flex:1;font-size:1.1em;font-weight:500;color:var(--danger-color, #dc3545);line-height:1.4}.dark-theme .error-message-text{color:var(--danger-color, #ff6b6b)}.error-close-btn{background:none;border:none;font-size:1.5em;color:var(--text-secondary, #666);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s;flex-shrink:0}.error-close-btn:hover{background:var(--bg-tertiary, #f0f0f0);color:var(--text-primary, #333)}.dark-theme .error-close-btn{color:var(--text-secondary, #a0a0a0)}.dark-theme .error-close-btn:hover{background:var(--bg-primary, #3d3d3d);color:var(--text-primary, #e0e0e0)}.error-suggestions{margin-top:15px;padding:15px;background:var(--bg-secondary, #f8f9fa);border-radius:6px;border-left:4px solid var(--accent-color, #3b82f6)}.dark-theme .error-suggestions{background:var(--bg-tertiary, #2a2a2a);border-left-color:var(--accent-color, #4a9eff)}.error-suggestions h4{margin:0 0 10px;font-size:.95em;color:var(--text-primary, #333);font-weight:600}.dark-theme .error-suggestions h4{color:var(--text-primary, #e0e0e0)}.error-suggestions ul{margin:0;padding-left:20px;list-style-type:disc}.error-suggestions li{margin:8px 0;color:var(--text-secondary, #666);font-size:.9em;line-height:1.5}.dark-theme .error-suggestions li{color:var(--text-secondary, #a0a0a0)}.error-actions{display:flex;gap:10px;margin-top:15px;flex-wrap:wrap}.error-toggle-details,.error-copy-btn{padding:8px 16px;border:1px solid var(--border-color, #ddd);border-radius:6px;background:var(--bg-primary, white);color:var(--text-primary, #333);cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s}.dark-theme .error-toggle-details,.dark-theme .error-copy-btn{background:var(--bg-tertiary, #2a2a2a);border-color:var(--border-color, #444);color:var(--text-primary, #e0e0e0)}.error-toggle-details:hover,.error-copy-btn:hover{background:var(--bg-tertiary, #f0f0f0);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6)}.dark-theme .error-toggle-details:hover,.dark-theme .error-copy-btn:hover{background:var(--bg-primary, #3d3d3d);border-color:var(--accent-color, #4a9eff);color:var(--accent-color, #60a5fa)}.error-stack{margin-top:15px;padding:15px;background:var(--bg-secondary, #f8f9fa);border-radius:6px;border:1px solid var(--border-color, #ddd);max-height:400px;overflow:auto}.dark-theme .error-stack{background:var(--bg-tertiary, #2a2a2a);border-color:var(--border-color, #404040)}.error-stack h4{margin:0 0 10px;font-size:.95em;color:var(--text-primary, #333);font-weight:600}.dark-theme .error-stack h4{color:var(--text-primary, #e0e0e0)}.error-stack pre{margin:0;padding:10px;background:var(--bg-primary, white);border-radius:4px;font-size:.8em;color:var(--text-primary, #333);white-space:pre-wrap;word-wrap:break-word;font-family:Courier New,monospace;overflow-x:auto}.dark-theme .error-stack pre{background:var(--bg-primary, #1e1e1e);color:var(--text-primary, #e0e0e0)}.printer-orders-page{min-height:100vh;padding:24px;padding-bottom:calc(24px + var(--footer-height, 60px));background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #0f172a);transition:background-color .3s,color .3s;box-sizing:border-box;width:100%;max-width:100%}.printer-orders-page.dark-theme,[data-theme=dark] .printer-orders-page{background:var(--bg-primary, #0f172a);color:var(--text-primary, #f1f5f9)}[data-theme=dark] .loading-message,.printer-orders-page.dark-theme .loading-message{color:var(--text-secondary, #a0a0a0)}.printer-orders-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--border-color, #e2e8f0);transition:background-color .3s,color .3s,box-shadow .3s}[data-theme=dark] .printer-orders-header,.printer-orders-page.dark-theme .printer-orders-header{border-bottom-color:var(--border-color, #475569);background:var(--bg-primary, #0f172a)}.printer-orders-header h1{margin:0;font-size:2em;font-weight:600;color:var(--text-primary, #0f172a);transition:color .3s}[data-theme=dark] .printer-orders-header h1,.printer-orders-page.dark-theme .printer-orders-header h1{color:var(--text-primary, #f1f5f9)}[data-theme=dark] .btn-back,.printer-orders-page.dark-theme .btn-back{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}[data-theme=dark] .btn-back:hover,.printer-orders-page.dark-theme .btn-back:hover{background:var(--bg-tertiary, #334155);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.btn-refresh{padding:8px 14px;background:var(--bg-secondary, #ffffff);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0);border-radius:6px;cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s}.btn-refresh:hover{background:var(--bg-tertiary, #f1f5f9);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6)}.btn-export-pdf{padding:8px 14px;background:var(--bg-secondary, #ffffff);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0);border-radius:6px;cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s;margin-left:8px}.btn-export-pdf:hover:not(:disabled){background:var(--bg-tertiary, #f1f5f9);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6)}.btn-export-pdf:disabled{opacity:.5;cursor:not-allowed}[data-theme=dark] .btn-export-pdf,.printer-orders-page.dark-theme .btn-export-pdf{background:var(--bg-primary, #2d2d2d);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .btn-export-pdf:hover:not(:disabled),.printer-orders-page.dark-theme .btn-export-pdf:hover:not(:disabled){background:var(--bg-secondary, #3d3d3d);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.btn-theme-toggle{padding:8px 12px;border:1px solid #ddd;border-radius:4px;background:#fff;cursor:pointer;font-size:1.2em;transition:all .2s}.btn-theme-toggle:hover{background:#f0f0f0;transform:scale(1.05)}[data-theme=dark] .btn-theme-toggle,.printer-orders-page.dark-theme .btn-theme-toggle{background:var(--bg-secondary, #1e1e1e);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .btn-theme-toggle:hover,.printer-orders-page.dark-theme .btn-theme-toggle:hover{background:var(--bg-tertiary, #252525)}.btn-secondary{padding:10px 20px;cursor:pointer;border:1px solid #ddd;border-radius:4px;background:#fff;transition:all .2s}.btn-secondary:hover{background:#f0f0f0}[data-theme=dark] .btn-secondary,.printer-orders-page.dark-theme .btn-secondary{background:var(--bg-secondary, #1e1e1e);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .btn-secondary:hover,.printer-orders-page.dark-theme .btn-secondary:hover{background:var(--bg-tertiary, #252525)}[data-theme=dark] .error-banner,.printer-orders-page.dark-theme .error-banner{background:var(--danger-bg-dark, #3a1a1a);color:var(--danger-text-dark, #e07070)}[data-theme=dark] .error-banner button,.printer-orders-page.dark-theme .error-banner button{color:var(--danger-text-dark, #e07070)}[data-theme=dark] .success-banner,.printer-orders-page.dark-theme .success-banner{background:var(--success-bg-dark, #1a4a1a);color:var(--success-text-dark, #4caf50);border-color:var(--success-border-dark, #2d5a2d)}[data-theme=dark] .success-banner button,.printer-orders-page.dark-theme .success-banner button{color:var(--success-text-dark, #4caf50)}.printer-orders-content{display:flex;flex-direction:column;gap:20px;width:100%;max-height:calc(100vh - var(--header-height, 70px));overflow-y:auto}.orders-list{width:100%;display:flex;flex-direction:column}.orders-header{background:var(--bg-primary, #ffffff);padding:16px 20px!important;margin-bottom:16px;border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));border:1px solid var(--border-color, #e2e8f0);border-bottom:none;transition:background-color .3s;box-sizing:border-box}.printer-orders-page .orders-header{position:static;top:auto}.printer-orders-page .orders-list{max-height:none;overflow-y:visible}[data-theme=dark] .orders-header,.printer-orders-page.dark-theme .orders-header{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);border-bottom:none;box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}.orders-header h2{margin-top:0;margin-bottom:12px;color:var(--text-primary, #0f172a);font-size:1.3em;font-weight:600;transition:color .3s}[data-theme=dark] .orders-header h2,.printer-orders-page.dark-theme .orders-header h2{color:var(--text-primary, #f1f5f9)}.orders-search{position:relative;display:flex;align-items:center;margin-bottom:12px}.orders-search-input{width:100%;padding:8px 36px 8px 12px;border:1px solid var(--border-color, #ddd);border-radius:6px;font-size:14px;background:var(--bg-primary, #fff);color:var(--text-primary, #333);outline:none;transition:border-color .2s}.orders-search-clear{position:absolute;right:8px;background:none;border:none;font-size:18px;line-height:1;cursor:pointer;color:var(--text-secondary, #888);padding:0}[data-theme=dark] .orders-search-input,.printer-orders-page.dark-theme .orders-search-input{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary, #e0e0e0);border-color:var(--border-color, #444)}.date-filters{margin-bottom:12px}.date-filter-controls{display:flex;flex-direction:column;gap:8px}.date-filter-label{display:flex;align-items:center;gap:8px;font-size:.85em;color:var(--text-primary, #0f172a);font-weight:500}[data-theme=dark] .date-filter-label,.printer-orders-page.dark-theme .date-filter-label{color:var(--text-primary, #f1f5f9)}.date-field-select{padding:5px 8px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);font-size:.85em;cursor:pointer;outline:none;transition:border-color .2s}[data-theme=dark] .date-field-select,.printer-orders-page.dark-theme .date-field-select{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9);border-color:var(--border-color, #475569)}.date-inputs{display:flex;align-items:center;gap:6px}[data-theme=dark] .date-input,.printer-orders-page.dark-theme .date-input{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9);border-color:var(--border-color, #475569)}[data-theme=dark] .date-separator,.printer-orders-page.dark-theme .date-separator{color:var(--text-secondary, #a0a0a0)}.quick-date-filters{display:flex;gap:6px;flex-wrap:wrap}[data-theme=dark] .quick-date-btn,.printer-orders-page.dark-theme .quick-date-btn{background:var(--bg-primary, #0f172a);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}[data-theme=dark] .quick-date-btn:hover,.printer-orders-page.dark-theme .quick-date-btn:hover{background:var(--bg-secondary, #1e293b);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.select-all-container{padding:12px 20px;background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));margin-bottom:15px}[data-theme=dark] .select-all-container,.printer-orders-page.dark-theme .select-all-container{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}[data-theme=dark] .select-all-checkbox,.printer-orders-page.dark-theme .select-all-checkbox{color:var(--text-primary, #e0e0e0)}[data-theme=dark] .bulk-actions-panel,.printer-orders-page.dark-theme .bulk-actions-panel{background:var(--bg-secondary, #2d2d2d);border-color:var(--accent-color, #4a9eff);box-shadow:0 2px 8px #0000004d}[data-theme=dark] .bulk-actions-info,.printer-orders-page.dark-theme .bulk-actions-info{color:var(--text-primary, #e0e0e0)}[data-theme=dark] .bulk-actions-clear:hover,.printer-orders-page.dark-theme .bulk-actions-clear:hover{background:var(--bg-primary, #3d3d3d)}.bulk-actions-buttons .btn-primary,.bulk-actions-buttons .btn-danger{min-width:200px;height:44px;box-sizing:border-box;display:inline-flex;align-items:center;justify-content:center}[data-theme=dark] .bulk-confirm,.printer-orders-page.dark-theme .bulk-confirm{background:var(--warning-bg-dark, #3a2a00);color:var(--warning-text-dark, #ffc107)}.bulk-status-change{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.bulk-status-select{padding:8px 12px;border:1px solid var(--border-color, #ddd);border-radius:6px;background:var(--bg-primary, white);color:var(--text-primary, #333);font-size:.9em;cursor:pointer;min-width:200px}[data-theme=dark] .bulk-status-select,.printer-orders-page.dark-theme .bulk-status-select{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary, #e0e0e0);border-color:var(--border-color, #444)}[data-theme=dark] .order-card.selected,.printer-orders-page.dark-theme .order-card.selected{background:var(--bg-tertiary, #1a2a3a);border-color:var(--accent-color, #4a9eff)}.status-filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:0}[data-theme=dark] .status-filter-btn,.printer-orders-page.dark-theme .status-filter-btn{background:var(--bg-primary, #0f172a);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}[data-theme=dark] .status-filter-btn:hover,.printer-orders-page.dark-theme .status-filter-btn:hover{background:var(--bg-tertiary, #334155);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}[data-theme=dark] .status-filter-btn.active,.printer-orders-page.dark-theme .status-filter-btn.active{background:var(--accent-color, #3b82f6);border-color:var(--accent-color, #3b82f6);color:#fff}.orders-by-status{display:flex;flex-direction:column;gap:30px;width:100%;padding-bottom:120px}.status-group{margin-bottom:30px;width:100%;display:flex;flex-direction:column}.status-group-title{padding:12px 20px;border-radius:8px 8px 0 0;margin:0 0 15px;font-size:1.1em;font-weight:600;transition:all .3s}.status-pending-bg{background:#fff3cd;color:#856404}.status-in-progress-bg{background:#d1ecf1;color:#0c5460}.status-completed-bg{background:#d4edda;color:#155724}.status-cancelled-bg{background:#f8d7da;color:#721c24}[data-theme=dark] .status-pending-bg,.printer-orders-page.dark-theme .status-pending-bg{background:#4a3a1a;color:gold}[data-theme=dark] .status-in-progress-bg,.printer-orders-page.dark-theme .status-in-progress-bg{background:#1a3a4a;color:#5ac8fa}[data-theme=dark] .status-completed-bg,.printer-orders-page.dark-theme .status-completed-bg{background:#1a4a2a;color:#5afa7a}[data-theme=dark] .status-cancelled-bg,.printer-orders-page.dark-theme .status-cancelled-bg{background:#4a1a1a;color:#ff6b6b}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary, #475569);background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));border:1px solid var(--border-color, #e2e8f0);font-size:1.1em;margin:24px;transition:all .3s}[data-theme=dark] .empty-state,.printer-orders-page.dark-theme .empty-state{background:var(--bg-secondary, #1e293b);color:var(--text-secondary, #cbd5e1);border-color:var(--border-color, #475569);box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}.orders-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:15px;width:100%;align-content:start}.status-goto-btn{min-height:120px;display:flex;align-items:center;justify-content:center;padding:20px;border:2px dashed var(--border-color, #e2e8f0);border-radius:var(--radius-lg, 12px);background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #0f172a);font-size:1rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast, .15s);box-sizing:border-box}.status-goto-btn:hover{border-color:var(--accent-color, #3b82f6);background:var(--bg-tertiary, #f1f5f9);color:var(--accent-color, #3b82f6)}.printer-orders-page.dark-theme .status-goto-btn{background:var(--bg-tertiary, #334155);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.printer-orders-page.dark-theme .status-goto-btn:hover{border-color:var(--accent-color, #60a5fa);background:var(--bg-secondary, #1e293b);color:var(--accent-color, #60a5fa)}.order-card{background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);padding:20px;cursor:pointer;transition:all var(--transition-fast, .15s);border:1px solid var(--border-color, #e2e8f0);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));position:relative}[data-theme=dark] .order-card,.printer-orders-page.dark-theme .order-card{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}.order-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md, 0 4px 6px rgba(0,0,0,.1));border-color:var(--accent-color, #3b82f6)}[data-theme=dark] .order-card:hover,.printer-orders-page.dark-theme .order-card:hover{box-shadow:var(--shadow-lg, 0 4px 12px rgba(0,0,0,.7));border-color:var(--accent-color, #3b82f6)}.order-card.active{border-color:#007bff;box-shadow:0 4px 12px #007bff4d}[data-theme=dark] .order-card.active,.printer-orders-page.dark-theme .order-card.active{border-color:var(--accent-color, #5a9ee8);box-shadow:0 4px 12px #5a9ee84d}.order-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;gap:10px}.order-number{font-weight:700;font-size:1.1em;color:#007bff}[data-theme=dark] .order-number,.printer-orders-page.dark-theme .order-number{color:var(--accent-color, #5a9ee8)}.order-delete-btn{background:#f44;color:#fff;border:none;border-radius:50%;width:24px;height:24px;cursor:pointer;font-size:18px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;transition:all .2s;flex-shrink:0}.order-delete-btn:hover{background:#c00;transform:scale(1.1)}.status-badge{padding:4px 12px;border-radius:12px;font-size:.85em;font-weight:500;flex-shrink:0}.status-pending{background:#fff3cd;color:#856404}.status-in-progress{background:#d1ecf1;color:#0c5460}.status-completed{background:#d4edda;color:#155724}.status-cancelled{background:#f8d7da;color:#721c24}[data-theme=dark] .status-pending,.printer-orders-page.dark-theme .status-pending{background:#4a3a1a;color:gold}[data-theme=dark] .status-in-progress,.printer-orders-page.dark-theme .status-in-progress{background:#1a3a4a;color:#5ac8fa}[data-theme=dark] .status-completed,.printer-orders-page.dark-theme .status-completed{background:#1a4a2a;color:#5afa7a}[data-theme=dark] .status-cancelled,.printer-orders-page.dark-theme .status-cancelled{background:#4a1a1a;color:#ff6b6b}.order-card-body h3{margin:0 0 10px;color:#333;transition:color .3s}[data-theme=dark] .order-card-body h3,.printer-orders-page.dark-theme .order-card-body h3{color:var(--text-primary, #e0e0e0)}.order-card-body p{margin:5px 0;color:#666;font-size:.9em;transition:color .3s}[data-theme=dark] .order-card-body p,.printer-orders-page.dark-theme .order-card-body p{color:var(--text-secondary, #b0b0b0)}.printer-orders-page.dark-theme .order-details-modal,[data-theme=dark] .printer-orders-page .order-details-modal{background:var(--bg-primary, #2d2d2d);box-shadow:0 20px 25px #000000b3}.order-details-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color, #e0e0e0);flex-shrink:0;gap:15px}.order-details-header-left{display:flex;align-items:center;gap:15px;flex:1}.order-status-badge{padding:6px 12px;border-radius:6px;font-size:.9em;font-weight:500;display:inline-block;pointer-events:none;-webkit-user-select:none;user-select:none}.order-status-badge.status-pending{background:#fff3cd;color:#856404}.order-status-badge.status-in-progress{background:#d1ecf1;color:#0c5460}.order-status-badge.status-completed{background:#d4edda;color:#155724}.order-status-badge.status-cancelled{background:#f8d7da;color:#721c24}.printer-orders-page.dark-theme .order-status-badge.status-pending,[data-theme=dark] .printer-orders-page .order-status-badge.status-pending{background:#4a3a1a;color:gold}.printer-orders-page.dark-theme .order-status-badge.status-in-progress,[data-theme=dark] .printer-orders-page .order-status-badge.status-in-progress{background:#1a3a4a;color:#5ac8fa}.printer-orders-page.dark-theme .order-status-badge.status-completed,[data-theme=dark] .printer-orders-page .order-status-badge.status-completed{background:#1a4a2a;color:#5afa7a}.printer-orders-page.dark-theme .order-status-badge.status-cancelled,[data-theme=dark] .printer-orders-page .order-status-badge.status-cancelled{background:#4a1a1a;color:#ff6b6b}.printer-orders-page.dark-theme .order-details-header,[data-theme=dark] .printer-orders-page .order-details-header{border-bottom-color:var(--border-color, #444)}.printer-orders-page.dark-theme .order-details-header h2,[data-theme=dark] .printer-orders-page .order-details-header h2{color:var(--text-primary, #e0e0e0)}.printer-orders-page.dark-theme .order-details-close,[data-theme=dark] .printer-orders-page .order-details-close{color:var(--text-secondary, #b0b0b0)}.printer-orders-page.dark-theme .order-details-close:hover,[data-theme=dark] .printer-orders-page .order-details-close:hover{background:var(--bg-tertiary, #3d3d3d);color:var(--text-primary, #e0e0e0)}.order-details-body .order-actions{display:flex;justify-content:space-between;align-items:center;gap:15px;margin-bottom:20px;flex-wrap:wrap;padding:15px;background:var(--bg-secondary, #f9f9f9);border-radius:8px;border:1px solid var(--border-color, #e0e0e0)}.printer-orders-page.dark-theme .order-details-body .order-actions,[data-theme=dark] .printer-orders-page .order-details-body .order-actions{background:var(--bg-secondary, #1e1e1e);border-color:var(--border-color, #444)}.order-actions-left{display:flex;gap:10px;flex-wrap:wrap}.order-details-body .status-buttons{display:flex;gap:8px;flex-wrap:wrap}.order-details-body .order-info{display:grid;grid-template-columns:1fr 1fr;gap:20px}.order-details-body .info-section-preview{grid-column:1 / -1}@media(max-width:1024px){.order-details-body .order-info{grid-template-columns:1fr}.order-details-body .info-section-preview{grid-column:1}}.printer-orders-page.dark-theme .order-details-body .info-section,[data-theme=dark] .printer-orders-page .order-details-body .info-section{background:var(--bg-secondary, #1e1e1e);border-color:var(--border-color, #444)}.printer-orders-page.dark-theme .order-details-body .info-section h3,[data-theme=dark] .printer-orders-page .order-details-body .info-section h3{color:var(--text-primary, #e0e0e0)}.order-actions{display:flex;gap:10px}.btn-primary{padding:10px 20px;border:none;border-radius:4px;background:#007bff;color:#fff;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#0056b3}.btn-primary:disabled{background:#ccc;cursor:not-allowed}[data-theme=dark] .btn-primary,.printer-orders-page.dark-theme .btn-primary{background:var(--accent-color, #5a9ee8)}[data-theme=dark] .btn-primary:hover,.printer-orders-page.dark-theme .btn-primary:hover{background:var(--accent-hover, #4a8dd7)}.btn-danger{padding:10px 20px;border:none;border-radius:4px;background:#dc3545;color:#fff;cursor:pointer;transition:all .2s}.btn-danger:hover{background:#c82333}[data-theme=dark] .btn-danger,.printer-orders-page.dark-theme .btn-danger{background:#dc3545}[data-theme=dark] .btn-danger:hover,.printer-orders-page.dark-theme .btn-danger:hover{background:#c82333}.info-section{margin-bottom:25px}.info-section h3{margin:0 0 15px;color:#333;font-size:1.1em;transition:color .3s}[data-theme=dark] .info-section h3,.printer-orders-page.dark-theme .info-section h3{color:var(--text-primary, #e0e0e0)}.info-section p{margin:8px 0;color:#666;line-height:1.6;transition:color .3s}[data-theme=dark] .info-section p,.printer-orders-page.dark-theme .info-section p{color:var(--text-secondary, #b0b0b0)}.order-details-body .info-section a{color:#007bff;text-decoration:none;font-weight:500;border-bottom:1px solid transparent;transition:all .2s}.order-details-body .info-section a:hover{color:#0056b3;border-bottom-color:#0056b3}.printer-orders-page.dark-theme .order-details-body .info-section a,[data-theme=dark] .printer-orders-page .order-details-body .info-section a{color:#5a9ee8}.printer-orders-page.dark-theme .order-details-body .info-section a:hover,[data-theme=dark] .printer-orders-page .order-details-body .info-section a:hover{color:#7bb3f0;border-bottom-color:#7bb3f0}.btn-status{padding:8px 16px;border:2px solid transparent;border-radius:6px;cursor:pointer;transition:all .2s;font-size:.9em;font-weight:500;white-space:nowrap}.btn-status:disabled{cursor:not-allowed;opacity:.8;pointer-events:none}.btn-status-pending{background:#fff3cd;color:#856404;border-color:#ffc107}.btn-status-pending:hover{background:#ffe69c;border-color:#ffb300}.btn-status-pending.active{background:#ffc107;color:#000;border-color:#ffb300}.btn-status-in-progress{background:#d1ecf1;color:#0c5460;border-color:#17a2b8}.btn-status-in-progress:hover{background:#bee5eb;border-color:#138496}.btn-status-in-progress.active{background:#17a2b8;color:#fff;border-color:#138496}.btn-status-completed{background:#d4edda;color:#155724;border-color:#28a745}.btn-status-completed:hover{background:#c3e6cb;border-color:#218838}.btn-status-completed.active{background:#28a745;color:#fff;border-color:#218838}.btn-status-cancelled{background:#f8d7da;color:#721c24;border-color:#dc3545}.btn-status-cancelled:hover{background:#f5c6cb;border-color:#c82333}.btn-status-cancelled.active{background:#dc3545;color:#fff;border-color:#c82333}.printer-orders-page.dark-theme .btn-status-pending,[data-theme=dark] .printer-orders-page .btn-status-pending{background:#664d03;color:#ffc107;border-color:#ffc107}.printer-orders-page.dark-theme .btn-status-pending:hover,[data-theme=dark] .printer-orders-page .btn-status-pending:hover{background:#856404}.printer-orders-page.dark-theme .btn-status-pending.active,[data-theme=dark] .printer-orders-page .btn-status-pending.active{background:#ffc107;color:#000}.printer-orders-page.dark-theme .btn-status-in-progress,[data-theme=dark] .printer-orders-page .btn-status-in-progress{background:#0c5460;color:#17a2b8;border-color:#17a2b8}.printer-orders-page.dark-theme .btn-status-in-progress:hover,[data-theme=dark] .printer-orders-page .btn-status-in-progress:hover{background:#0d6674}.printer-orders-page.dark-theme .btn-status-in-progress.active,[data-theme=dark] .printer-orders-page .btn-status-in-progress.active{background:#17a2b8;color:#fff}.printer-orders-page.dark-theme .btn-status-completed,[data-theme=dark] .printer-orders-page .btn-status-completed{background:#155724;color:#28a745;border-color:#28a745}.printer-orders-page.dark-theme .btn-status-completed:hover,[data-theme=dark] .printer-orders-page .btn-status-completed:hover{background:#1e7e34}.printer-orders-page.dark-theme .btn-status-completed.active,[data-theme=dark] .printer-orders-page .btn-status-completed.active{background:#28a745;color:#fff}.printer-orders-page.dark-theme .btn-status-cancelled,[data-theme=dark] .printer-orders-page .btn-status-cancelled{background:#721c24;color:#dc3545;border-color:#dc3545}.printer-orders-page.dark-theme .btn-status-cancelled:hover,[data-theme=dark] .printer-orders-page .btn-status-cancelled:hover{background:#8b2635}.printer-orders-page.dark-theme .btn-status-cancelled.active,[data-theme=dark] .printer-orders-page .btn-status-cancelled.active{background:#dc3545;color:#fff}.btn-status.active{border-color:#007bff;background:#007bff;color:#fff}[data-theme=dark] .btn-status.active,.printer-orders-page.dark-theme .btn-status.active{border-color:var(--accent-color, #5a9ee8);background:var(--accent-color, #5a9ee8);color:#fff}.loading{text-align:center;padding:40px;font-size:1.2em;color:#666;transition:color .3s}[data-theme=dark] .loading,.printer-orders-page.dark-theme .loading{color:var(--text-secondary, #b0b0b0)}.order-preview{margin-top:20px}.preview-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding-bottom:10px;border-bottom:1px solid #eee}[data-theme=dark] .preview-header,.printer-orders-page.dark-theme .preview-header{border-bottom-color:var(--border-color, #3d3d3d)}.preview-side-name{font-weight:600;color:#333}[data-theme=dark] .preview-side-name,.printer-orders-page.dark-theme .preview-side-name{color:var(--text-primary, #e0e0e0)}.preview-side-counter{font-size:.9em;color:#666}[data-theme=dark] .preview-side-counter,.printer-orders-page.dark-theme .preview-side-counter{color:var(--text-secondary, #b0b0b0)}.preview-container{position:relative;display:flex;align-items:center;justify-content:center;gap:10px;min-height:300px;background:#f9f9f9;border-radius:8px;border:1px solid #ddd;overflow:hidden}[data-theme=dark] .preview-container,.printer-orders-page.dark-theme .preview-container{background:var(--bg-secondary, #1e1e1e);border-color:var(--border-color, #3d3d3d)}.preview-arrow{background:#ffffffe6;border:1px solid #ddd;border-radius:50%;width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:20px;transition:all .2s;z-index:10;flex-shrink:0}.preview-arrow:hover:not(:disabled){background:#fff;border-color:#007bff;transform:scale(1.1)}.preview-arrow:disabled{opacity:.3;cursor:not-allowed}[data-theme=dark] .preview-arrow,.printer-orders-page.dark-theme .preview-arrow{background:var(--bg-primary, #2d2d2d);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .preview-arrow:hover:not(:disabled),.printer-orders-page.dark-theme .preview-arrow:hover:not(:disabled){background:var(--bg-tertiary, #252525);border-color:var(--accent-color, #5a9ee8)}.preview-image-wrapper{flex:1;display:flex;align-items:center;justify-content:center;min-height:300px;max-width:100%}.preview-image{max-width:100%;max-height:400px;object-fit:contain;border-radius:4px}.preview-loading,.preview-placeholder{padding:40px;text-align:center;color:#999}.preview-error{padding:20px;text-align:center}.preview-error .preview-placeholder{color:#dc3545;font-weight:600}[data-theme=dark] .preview-loading,[data-theme=dark] .preview-placeholder,.printer-orders-page.dark-theme .preview-loading,.printer-orders-page.dark-theme .preview-placeholder{color:var(--text-secondary, #b0b0b0)}.preview-dots{display:flex;justify-content:center;gap:8px;margin-top:15px}.preview-dot{width:12px;height:12px;border-radius:50%;border:2px solid #999;background:#ccc;cursor:pointer;transition:all .2s;padding:0}.preview-dot:hover{background:#aaa;border-color:#777;transform:scale(1.2)}.preview-dot.active{background:#007bff;border-color:#007bff;transform:scale(1.3)}[data-theme=dark] .preview-dot,.printer-orders-page.dark-theme .preview-dot{border-color:#666;background:#555}[data-theme=dark] .preview-dot:hover,.printer-orders-page.dark-theme .preview-dot:hover{background:#777;border-color:#888}[data-theme=dark] .preview-dot.active,.printer-orders-page.dark-theme .preview-dot.active{background:var(--accent-color, #5a9ee8);border-color:var(--accent-color, #5a9ee8)}@media(max-width:1024px){.printer-orders-content{grid-template-columns:1fr}.preview-container,.preview-image-wrapper{min-height:250px}.preview-image{max-height:300px}}@media(max-width:768px){.printer-orders-page{padding:10px}.printer-orders-header{flex-direction:column;align-items:flex-start;gap:15px}.printer-orders-header h1{font-size:1.5em}.orders-grid{grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:10px}.order-card{padding:15px}.status-filters{gap:8px}.status-filter-btn{padding:6px 12px;font-size:.85em}.printer-orders-header{padding:15px}}@media(max-width:480px){.printer-orders-page{padding:5px}.printer-orders-header{padding:10px;border-radius:0}.printer-orders-header h1{font-size:1.3em}.orders-grid{grid-template-columns:1fr;gap:8px}.order-card{padding:12px}.status-filters{gap:6px}.status-filter-btn{padding:6px 10px;font-size:.8em}.order-info{grid-template-columns:1fr}.order-details-modal{width:95%;max-width:95%}.preview-container,.preview-image-wrapper{min-height:200px}.preview-image{max-height:200px}}.my-orders-page{min-height:100vh;padding:24px;padding-bottom:calc(24px + var(--footer-height, 60px));background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #0f172a);transition:background-color .3s,color .3s;width:100%;max-width:100%;box-sizing:border-box;display:flex;flex-direction:column}.my-orders-page.dark-theme,[data-theme=dark] .my-orders-page{background:var(--bg-primary, #0f172a);color:var(--text-primary, #f1f5f9)}.loading-page{min-height:100vh;padding:20px;display:flex;align-items:center;justify-content:center}.loading-message{text-align:center;padding:40px;font-size:1.2em;color:var(--text-secondary, #666)}.my-orders-page.dark-theme .loading-message,[data-theme=dark] .my-orders-page .loading-message{color:var(--text-secondary, #a0a0a0)}.my-orders-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--border-color, #e2e8f0);transition:background-color .3s,color .3s;flex-shrink:0}[data-theme=dark] .my-orders-header,.my-orders-page.dark-theme .my-orders-header{border-bottom-color:var(--border-color, #475569)}.my-orders-header h1{margin:0;font-size:2em;font-weight:600;color:var(--text-primary, #0f172a);transition:color .3s}[data-theme=dark] .my-orders-header h1,.my-orders-page.dark-theme .my-orders-header h1{color:var(--text-primary, #f1f5f9)}.my-orders-header .header-actions{display:flex;gap:10px;align-items:center}.my-orders-header .btn-back{padding:8px 16px;background:var(--bg-secondary, #ffffff);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);cursor:pointer;font-size:.95em;font-weight:500;transition:all var(--transition-fast, .15s)}.my-orders-header .btn-back:hover{background:var(--bg-tertiary, #f1f5f9);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6)}.my-orders-page.dark-theme .my-orders-header .btn-back,[data-theme=dark] .my-orders-page .my-orders-header .btn-back{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.my-orders-page.dark-theme .my-orders-header .btn-back:hover,[data-theme=dark] .my-orders-page .my-orders-header .btn-back:hover{background:var(--bg-tertiary, #334155);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.my-orders-content{display:flex;flex-direction:column;gap:20px;width:100%;flex:1;min-height:0;max-height:calc(100vh - var(--header-height, 70px));overflow-y:auto;overflow-x:hidden;padding-bottom:120px}.orders-list{width:100%;min-width:0;display:flex;flex-direction:column}.my-orders-page .orders-list{max-height:none;overflow-y:visible}.orders-header{width:100%;box-sizing:border-box;display:flex;flex-direction:column;gap:8px;padding:16px 20px;margin-bottom:16px;background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));border:1px solid var(--border-color, #e2e8f0);border-bottom:none;transition:background-color .3s;position:static;top:auto;z-index:10}.my-orders-page.dark-theme .orders-header,[data-theme=dark] .my-orders-page .orders-header{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}.orders-header h2{width:100%;margin:0 0 12px;padding-left:0;font-size:1.3em;font-weight:600;color:var(--text-primary, #0f172a);transition:color .3s}.my-orders-page.dark-theme .orders-header h2,[data-theme=dark] .my-orders-page .orders-header h2{color:var(--text-primary, #f1f5f9)}.orders-search{width:100%;box-sizing:border-box;position:relative;display:flex;align-items:center;margin-bottom:8px;margin-left:0;padding-left:0}.orders-search-input{width:100%;padding:6px 30px 6px 10px;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:13px;background:var(--bg-primary, #fff);color:var(--text-primary, #333);outline:none;transition:border-color .2s}.orders-search-input:focus{border-color:var(--accent-color, #3b82f6)}.orders-search-clear{position:absolute;right:8px;background:none;border:none;font-size:16px;line-height:1;cursor:pointer;color:var(--text-secondary, #888);padding:0}.orders-search-clear:hover{color:var(--danger-color, #dc3545)}.date-filters{width:100%;box-sizing:border-box;margin-bottom:8px;margin-left:0;padding-left:0}.status-filters{width:100%;box-sizing:border-box;display:flex;gap:6px;flex-wrap:wrap;margin-top:8px;margin-left:0;padding-left:0}.status-filter-btn{padding:6px 12px;border:2px solid var(--border-color, #e2e8f0);background:var(--bg-primary, #ffffff);border-radius:var(--radius-md, 8px);cursor:pointer;transition:all .2s;font-size:.85em;color:var(--text-primary, #0f172a)}.status-filter-btn:hover{border-color:var(--accent-color, #3b82f6);background:var(--bg-tertiary, #f1f5f9);color:var(--accent-color, #3b82f6)}.status-filter-btn.active{border-color:var(--accent-color, #3b82f6);background:var(--accent-color, #3b82f6);color:#fff}.my-orders-page.dark-theme .status-filter-btn,[data-theme=dark] .my-orders-page .status-filter-btn{background:var(--bg-primary, #2d2d2d);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}.my-orders-page.dark-theme .status-filter-btn:hover,[data-theme=dark] .my-orders-page .status-filter-btn:hover{background:var(--bg-tertiary, #252525);border-color:var(--accent-color, #5a9ee8)}.my-orders-page.dark-theme .status-filter-btn.active,[data-theme=dark] .my-orders-page .status-filter-btn.active{background:var(--accent-color, #5a9ee8);border-color:var(--accent-color, #5a9ee8);color:#fff}.order-info{width:100%;min-width:0}.order-details-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:2000;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.order-details-modal{background:var(--bg-primary, white);border-radius:12px;box-shadow:0 20px 25px #0000004d;width:90%;max-width:1200px;max-height:90vh;display:flex;flex-direction:column;animation:slideUp .3s;overflow:hidden}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.my-orders-page.dark-theme .order-details-modal,[data-theme=dark] .my-orders-page .order-details-modal{background:var(--bg-primary, #2d2d2d);box-shadow:0 20px 25px #000000b3}.order-details-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color, #e0e0e0);flex-shrink:0}.my-orders-page.dark-theme .order-details-header,[data-theme=dark] .my-orders-page .order-details-header{border-bottom-color:var(--border-color, #444)}.order-details-header h2{margin:0;color:var(--text-primary, #333);font-size:1.5em}.my-orders-page.dark-theme .order-details-header h2,[data-theme=dark] .my-orders-page .order-details-header h2{color:var(--text-primary, #e0e0e0)}.order-details-close{background:none;border:none;font-size:2em;cursor:pointer;color:var(--text-secondary, #666);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s;line-height:1}.order-details-close:hover{background:var(--bg-tertiary, #f1f5f9);color:var(--text-primary, #333)}.my-orders-page.dark-theme .order-details-close,[data-theme=dark] .my-orders-page .order-details-close{color:var(--text-secondary, #b0b0b0)}.my-orders-page.dark-theme .order-details-close:hover,[data-theme=dark] .my-orders-page .order-details-close:hover{background:var(--bg-tertiary, #3d3d3d);color:var(--text-primary, #e0e0e0)}.order-details-body{padding:20px;overflow-y:auto;flex:1;min-height:0}.order-details-body .order-actions{display:flex;gap:10px;margin-bottom:20px;flex-wrap:wrap}.order-details-body .order-info{display:flex;flex-direction:column;gap:20px}.order-details-body .info-section{background:var(--bg-secondary, #f9f9f9);padding:15px;border-radius:8px;border:1px solid var(--border-color, #e0e0e0)}.my-orders-page.dark-theme .order-details-body .info-section,[data-theme=dark] .my-orders-page .order-details-body .info-section{background:var(--bg-secondary, #1e1e1e);border-color:var(--border-color, #444)}.order-details-body .info-section h3{margin:0 0 15px;color:var(--text-primary, #333);font-size:1.1em}.my-orders-page.dark-theme .order-details-body .info-section h3,[data-theme=dark] .my-orders-page .order-details-body .info-section h3{color:var(--text-primary, #e0e0e0)}.order-details-body .info-section p{margin:8px 0;color:var(--text-primary, #333);font-size:.95em}.my-orders-page.dark-theme .order-details-body .info-section p,[data-theme=dark] .my-orders-page .order-details-body .info-section p{color:var(--text-primary, #e0e0e0)}.my-orders-page.dark-theme .orders-search-input,[data-theme=dark] .my-orders-page .orders-search-input{background:var(--bg-primary, #2d2d2d);border-color:var(--border-color, #555);color:var(--text-primary, #e0e0e0)}.date-filter-controls{display:flex;flex-direction:column;gap:6px}.my-orders-page.dark-theme .date-filter-label,[data-theme=dark] .my-orders-page .date-filter-label{color:var(--text-primary, #e0e0e0)}.date-field-select{padding:5px 8px;border:1px solid var(--border-color, #ddd);border-radius:4px;background:var(--bg-primary, #fff);color:var(--text-primary, #333);font-size:.85em;cursor:pointer;outline:none;transition:border-color .2s}.date-field-select:focus{border-color:var(--accent-color, #3b82f6)}.my-orders-page.dark-theme .date-field-select,[data-theme=dark] .my-orders-page .date-field-select{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary, #e0e0e0);border-color:var(--border-color, #444)}.date-input:focus{border-color:var(--accent-color, #3b82f6)}.my-orders-page.dark-theme .date-input,[data-theme=dark] .my-orders-page .date-input{background:var(--bg-tertiary, #2a2a2a);color:var(--text-primary, #e0e0e0);border-color:var(--border-color, #444)}.date-separator{color:var(--text-secondary, #666);font-weight:500}.my-orders-page.dark-theme .date-separator,[data-theme=dark] .my-orders-page .date-separator{color:var(--text-secondary, #a0a0a0)}.date-clear-btn{padding:6px 10px;background:var(--danger-color, #dc3545);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;line-height:1;transition:background-color .2s}.quick-date-btn:hover{border-color:var(--accent-color, #3b82f6);background:var(--bg-tertiary, #e9ecef);color:var(--accent-color, #3b82f6)}.my-orders-page.dark-theme .quick-date-btn,[data-theme=dark] .my-orders-page .quick-date-btn{background:var(--bg-primary, #2d2d2d);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}.my-orders-page.dark-theme .quick-date-btn:hover,[data-theme=dark] .my-orders-page .quick-date-btn:hover{background:var(--bg-secondary, #3d3d3d);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}[data-theme=dark] .btn-refresh,[data-theme=dark] .btn-export-csv,.my-orders-page.dark-theme .btn-refresh,.my-orders-page.dark-theme .btn-export-csv{background:var(--bg-primary, #2d2d2d);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .btn-refresh:hover,[data-theme=dark] .btn-export-csv:hover:not(:disabled),.my-orders-page.dark-theme .btn-refresh:hover,.my-orders-page.dark-theme .btn-export-csv:hover:not(:disabled){background:var(--bg-secondary, #3d3d3d);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.select-all-container{padding:10px 15px;background:var(--bg-secondary, #f8f9fa);border-bottom:1px solid var(--border-color, #ddd);margin-bottom:15px}.my-orders-page.dark-theme .select-all-container,[data-theme=dark] .my-orders-page .select-all-container{background:var(--bg-tertiary, #2a2a2a);border-bottom-color:var(--border-color, #404040)}.my-orders-page.dark-theme .select-all-checkbox,[data-theme=dark] .my-orders-page .select-all-checkbox{color:var(--text-primary, #e0e0e0)}.my-orders-page.dark-theme .bulk-actions-panel,[data-theme=dark] .my-orders-page .bulk-actions-panel{background:var(--bg-secondary, #2d2d2d);border-color:var(--accent-color, #4a9eff);box-shadow:0 2px 8px #0000004d}.my-orders-page.dark-theme .bulk-actions-info,[data-theme=dark] .my-orders-page .bulk-actions-info{color:var(--text-primary, #e0e0e0)}.my-orders-page.dark-theme .bulk-actions-clear:hover,[data-theme=dark] .my-orders-page .bulk-actions-clear:hover{background:var(--bg-primary, #3d3d3d)}.my-orders-page.dark-theme .bulk-confirm,[data-theme=dark] .my-orders-page .bulk-confirm{background:var(--warning-bg-dark, #3a2a00);color:var(--warning-text-dark, #ffc107)}.order-checkbox{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-color, #3b82f6);margin-right:8px}.order-card.selected{border:2px solid var(--accent-color, #3b82f6);background:var(--bg-tertiary, #f0f8ff)}.my-orders-page.dark-theme .order-card.selected,[data-theme=dark] .my-orders-page .order-card.selected{background:var(--bg-tertiary, #1a2a3a);border-color:var(--accent-color, #4a9eff)}.btn-cancel-order{margin-top:10px;width:100%;padding:6px 12px;background:var(--danger-color, #dc3545);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:opacity .2s}.btn-cancel-order:hover{opacity:.85}.btn-danger{padding:8px 16px;background:var(--danger-color, #dc3545);color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:opacity .2s}.btn-danger:hover{opacity:.85}.order-cancel-area{margin-top:8px}.error-banner{background:var(--danger-bg, #f8d7da);color:var(--danger-text, #721c24);padding:15px;border-radius:6px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.error-banner button{background:none;border:none;color:var(--danger-text, #721c24);font-size:20px;cursor:pointer;padding:0 10px}.my-orders-page.dark-theme .error-banner,[data-theme=dark] .my-orders-page .error-banner{background:var(--danger-bg-dark, #3a1a1a);color:var(--danger-text-dark, #e07070)}.my-orders-page.dark-theme .error-banner button,[data-theme=dark] .my-orders-page .error-banner button{color:var(--danger-text-dark, #e07070)}.success-banner{background:var(--success-bg, #d4edda);color:var(--success-text, #155724);padding:15px;border-radius:6px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--success-border, #c3e6cb)}[data-theme=dark] .success-banner,.my-orders-page.dark-theme .success-banner{background:var(--success-bg-dark, #1a4a1a);color:var(--success-text-dark, #4caf50);border-color:var(--success-border-dark, #2d5a2d)}.success-banner button{background:none;border:none;color:var(--success-text, #155724);font-size:20px;cursor:pointer;padding:0 10px}[data-theme=dark] .success-banner button,.my-orders-page.dark-theme .success-banner button{color:var(--success-text-dark, #4caf50)}.designer-templates-page{min-height:100vh;padding:24px;padding-bottom:calc(24px + var(--footer-height, 60px));background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #0f172a);box-sizing:border-box;width:100%;max-width:100%;transition:background-color .3s,color .3s}.designer-templates-content{max-height:calc(100vh - var(--header-height, 70px));overflow-y:auto;overflow-x:hidden;padding-bottom:120px;display:flex;flex-direction:column;gap:16px}.designer-templates-page.dark-theme{background:var(--bg-primary, #0f172a);color:var(--text-primary, #f1f5f9)}.templates-list{background:var(--bg-primary, #ffffff);border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a;flex:1;display:flex;flex-direction:column}.dark-theme .templates-list{background:var(--bg-secondary, #1e293b)}.templates-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.template-card{border:1px solid var(--border-color, #ddd);border-radius:8px;overflow:hidden;background:var(--bg-primary, #ffffff)}.template-card-clickable{cursor:pointer;transition:box-shadow .2s,border-color .2s,transform .2s}.template-card-clickable:hover{border-color:var(--accent-color, #3b82f6);box-shadow:0 4px 12px #3b82f633;transform:translateY(-2px)}.dark-theme .template-card-clickable:hover{border-color:var(--accent-color, #60a5fa);box-shadow:0 4px 12px #60a5fa4d}.dark-theme .template-card{background:var(--bg-tertiary, #334155)}.template-thumbnail{width:100%;height:200px;object-fit:cover}.template-preview-placeholder{width:100%;height:140px;background:var(--bg-secondary, #f1f5f9);display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}.dark-theme .template-preview-placeholder{background:var(--bg-primary, #1e293b)}.template-preview-image{width:100%;height:100%;object-fit:cover;display:block}.template-icon-fallback{font-size:3rem;opacity:.6}.template-icon-fallback.hidden{display:none!important}.template-info{padding:15px}.template-info h3{margin:0 0 10px}.template-description{color:var(--text-secondary, #666);margin-bottom:10px}.template-meta{display:flex;flex-direction:column;gap:5px;margin-bottom:10px;font-size:.9em;color:var(--text-secondary, #666)}.template-card-actions{margin-top:10px;padding-top:10px;border-top:1px solid var(--border-color, #e2e8f0)}.btn-delete-template{padding:6px 12px;font-size:.85em;font-weight:500;border:2px solid var(--danger-color, #dc3545);border-radius:var(--radius-md, 6px);background:#dc354514;color:var(--danger-color, #dc3545);cursor:pointer;transition:background .2s,color .2s,border-color .2s,box-shadow .2s;box-shadow:0 0 0 1px #dc354526}.btn-delete-template:hover{background:var(--danger-color, #dc3545);color:#fff;border-color:var(--danger-color, #dc3545);box-shadow:0 2px 8px #dc354559}.dark-theme .template-card-actions{border-top-color:var(--border-color, #475569)}.dark-theme .btn-delete-template{border:2px solid var(--danger-color, #ef4444);background:#ef444426;color:#f87171;box-shadow:0 0 0 1px #ef444440}.dark-theme .btn-delete-template:hover{background:var(--danger-color, #ef4444);color:#fff;border-color:var(--danger-color, #ef4444);box-shadow:0 2px 10px #ef444480}.status-badge{padding:4px 8px;border-radius:4px;font-size:.9em;display:inline-block}.status-badge.public{background:var(--success-bg, #d4edda);color:var(--success-color, #155724)}.status-badge.private{background:var(--danger-bg, #f8d7da);color:var(--danger-text, #721c24)}.action-buttons{display:flex;gap:10px}.btn-edit,.btn-delete{padding:8px 15px;border:none;border-radius:4px;cursor:pointer;font-size:.9em}.btn-edit{background:var(--warning-color, #ffc107);color:var(--warning-text, #000)}.btn-edit:hover{opacity:.85}.btn-delete{background:var(--danger-color, #dc3545);color:#fff}.btn-delete:hover{opacity:.85}.header-actions{display:flex;align-items:center;gap:12px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color, #e2e8f0);flex-shrink:0}.modal-body{padding:24px;overflow-y:auto;flex:1;min-height:0}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);font-size:1em;background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);transition:all var(--transition-fast, .15s);font-family:inherit;box-sizing:border-box}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid var(--border-color, #e2e8f0);margin-top:24px;flex-shrink:0}.delete-confirm-inline{display:inline-flex;align-items:center;gap:4px;font-size:13px}.designer-projects-page{height:100vh;max-height:100vh;padding:24px;background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #0f172a);box-sizing:border-box;width:100%;max-width:100%;display:flex;flex-direction:column;overflow:hidden}.designer-projects-content{flex:1;min-height:0;overflow-y:auto;overflow-x:hidden;padding-bottom:120px;display:flex;flex-direction:column;gap:16px;background:var(--bg-secondary, #f8fafc)}.dark-theme .designer-projects-content{background:var(--bg-primary, #0f172a)}.designer-projects-page.dark-theme{background:var(--bg-primary, #0f172a);color:var(--text-primary, #f1f5f9)}.filters{display:flex;gap:10px;margin-bottom:16px;padding:12px 16px;background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));border:1px solid var(--border-color, #e2e8f0)}.filter-input,.filter-select{padding:8px;border:1px solid var(--border-color, #ddd);border-radius:4px;font-size:1em}.filter-input{flex:1}.date-filters{margin-bottom:16px;margin-left:0;padding-left:0}.date-filter-controls{display:flex;flex-direction:column;gap:8px;margin-left:0;padding-left:0}.date-filter-label{display:flex;align-items:center;gap:8px;font-size:.85em;color:var(--text-primary, #0f172a);font-weight:500;margin-left:0;padding-left:0}.dark-theme .date-filter-label{color:var(--text-primary, #f1f5f9)}.date-field-select{padding:6px 10px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);font-size:.9em;cursor:pointer;outline:none;transition:border-color .2s}.date-field-select:focus{border-color:var(--accent-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.dark-theme .date-field-select{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9);border-color:var(--border-color, #475569)}.date-inputs{display:flex;align-items:center;gap:6px;margin-left:0;padding-left:0}.date-input{padding:6px 10px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);font-size:13px;background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);outline:none;transition:border-color .2s;flex:1}.date-input:focus{border-color:var(--accent-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.dark-theme .date-input{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9);border-color:var(--border-color, #475569)}.date-separator{color:var(--text-secondary, #475569);font-weight:500}.dark-theme .date-separator{color:var(--text-secondary, #cbd5e1)}.date-clear-btn{padding:8px 12px;background:var(--danger-color, #dc3545);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:16px;line-height:1;transition:background-color .2s}.date-clear-btn:hover{background:var(--danger-hover-color, #c82333)}.quick-date-filters{display:flex;gap:6px;flex-wrap:wrap;margin-left:0;padding-left:0}.quick-date-btn{padding:4px 10px;border:1px solid var(--border-color, #e2e8f0);background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #0f172a);border-radius:var(--radius-md, 8px);cursor:pointer;font-size:.8em;transition:all .2s}.quick-date-btn:hover{border-color:var(--accent-color, #3b82f6);background:var(--bg-tertiary, #f1f5f9);color:var(--accent-color, #3b82f6)}.dark-theme .quick-date-btn{background:var(--bg-primary, #0f172a);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.dark-theme .quick-date-btn:hover{background:var(--bg-secondary, #1e293b);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.projects-list{background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);padding:20px;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));border:1px solid var(--border-color, #e2e8f0);display:block;flex-shrink:0}.dark-theme .projects-list{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}.projects-table{width:100%;border-collapse:collapse}.projects-table th,.projects-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border-color, #e2e8f0)}.projects-table th{background:var(--bg-tertiary, #f1f5f9);color:var(--text-primary, #0f172a);font-weight:600;font-size:.9em;text-transform:uppercase;letter-spacing:.5px;position:sticky;top:0;z-index:50;box-shadow:0 2px 8px #0000001a;border-bottom:2px solid var(--border-color, #e2e8f0);isolation:isolate}.projects-table th.sortable{-webkit-user-select:none;user-select:none;transition:background-color .2s ease,color .2s ease;cursor:pointer}.projects-table th.sortable:hover{background:var(--bg-secondary, #f8fafc);color:var(--accent-color, #3b82f6)}.dark-theme .projects-table th{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9);box-shadow:0 2px 8px #00000080;border-bottom-color:var(--border-color, #475569)}.dark-theme .projects-table th.sortable:hover{background:var(--bg-secondary, #1e293b);color:var(--accent-color, #60a5fa)}.select-all-container{padding:10px 15px;background:var(--bg-secondary, #f8f9fa);border-bottom:1px solid var(--border-color, #ddd);margin-bottom:15px;position:relative;z-index:1}.dark-theme .select-all-container{background:var(--bg-tertiary, #2a2a2a);border-bottom-color:var(--border-color, #404040)}.select-all-checkbox{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:.95em;color:var(--text-primary, #333);-webkit-user-select:none;user-select:none}.select-all-checkbox input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-color, #3b82f6)}.dark-theme .select-all-checkbox{color:var(--text-primary, #e0e0e0)}.bulk-actions-panel{background:var(--bg-primary, white);border:2px solid var(--accent-color, #3b82f6);border-radius:8px;padding:15px;margin-bottom:20px;box-shadow:0 2px 8px #0000001a}.dark-theme .bulk-actions-panel{background:var(--bg-secondary, #2d2d2d);border-color:var(--accent-color, #4a9eff);box-shadow:0 2px 8px #0000004d}.bulk-actions-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;font-weight:500;color:var(--text-primary, #333)}.dark-theme .bulk-actions-info{color:var(--text-primary, #e0e0e0)}.bulk-actions-clear{background:none;border:none;color:var(--text-secondary, #666);cursor:pointer;font-size:.9em;padding:4px 8px;border-radius:4px;transition:all .2s}.bulk-actions-clear:hover{background:var(--bg-tertiary, #e9ecef);color:var(--danger-color, #dc3545)}.dark-theme .bulk-actions-clear:hover{background:var(--bg-primary, #3d3d3d)}.bulk-actions-buttons{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.bulk-confirm{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--warning-bg, #fff3cd);border-radius:6px;color:var(--warning-text, #856404)}.dark-theme .bulk-confirm{background:var(--warning-bg-dark, #3a2a00);color:var(--warning-text-dark, #ffc107)}.projects-table input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:var(--accent-color, #3b82f6)}.projects-table tr.selected{background:var(--bg-tertiary, #f0f8ff)}.dark-theme .projects-table tr.selected{background:var(--bg-tertiary, #1a2a3a)}.status-badge.public{background:#d4edda;color:#155724}.status-badge.private{background:#f8d7da;color:#721c24}.dark-theme .status-badge.public{background:#1a3a2a;color:#6abf7b}.dark-theme .status-badge.private{background:#3a1a1a;color:#e07070}.page-header{flex-shrink:0;display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--border-color, #e2e8f0)}.header-actions{display:flex;gap:10px;align-items:center}.btn-refresh,.btn-export-csv{padding:8px 14px;background:var(--bg-secondary, #ffffff);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0);border-radius:6px;cursor:pointer;font-size:.9em;font-weight:500;transition:all .2s}.btn-refresh:hover,.btn-export-csv:hover:not(:disabled){background:var(--bg-tertiary, #f1f5f9);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6)}.btn-export-csv:disabled{opacity:.5;cursor:not-allowed}.dark-theme .btn-refresh,.dark-theme .btn-export-csv{background:var(--bg-primary, #2d2d2d);border-color:var(--border-color, #3d3d3d);color:var(--text-primary, #e0e0e0)}.dark-theme .btn-refresh:hover,.dark-theme .btn-export-csv:hover:not(:disabled){background:var(--bg-secondary, #3d3d3d);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.dark-theme .btn-refresh{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.dark-theme .btn-refresh:hover{background:var(--bg-tertiary, #334155);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.btn-toggle{padding:8px 12px;border:2px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);cursor:pointer;font-size:1.2em;transition:all .2s;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));min-width:44px;display:inline-flex;align-items:center;justify-content:center}.btn-toggle:hover{background:var(--bg-tertiary, #f1f5f9);border-color:var(--accent-color, #3b82f6);box-shadow:var(--shadow-md, 0 4px 6px rgba(0,0,0,.1));transform:translateY(-1px)}.dark-theme .btn-toggle{background:var(--bg-primary, #0f172a);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.3))}.dark-theme .btn-toggle:hover{background:var(--bg-tertiary, #334155);border-color:var(--accent-color, #3b82f6);box-shadow:var(--shadow-md, 0 4px 6px rgba(0,0,0,.3))}.delete-confirm-inline{display:inline-flex;align-items:center;gap:4px;font-size:13px;white-space:nowrap}.btn-confirm-no{background:var(--bg-tertiary, #e9ecef);color:var(--text-primary)}.designer-products-page{min-height:100vh;padding:24px;padding-bottom:calc(24px + var(--footer-height, 60px));background:var(--bg-secondary, #f8fafc);color:var(--text-primary, #0f172a);box-sizing:border-box;width:100%;max-width:100%;transition:background-color .3s,color .3s}.designer-products-content{max-height:calc(100vh - var(--header-height, 70px));overflow-y:auto;overflow-x:hidden;padding-bottom:120px;display:flex;flex-direction:column;gap:16px}.designer-products-page.dark-theme{background:var(--bg-primary, #0f172a);color:var(--text-primary, #f1f5f9)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;border-bottom:2px solid var(--border-color, #e2e8f0)}.header-left{display:flex;align-items:center;gap:16px}.dark-theme .page-header{border-bottom-color:var(--border-color, #475569)}.page-header h1{margin:0;font-size:2em;font-weight:600;color:var(--text-primary, #0f172a)}.dark-theme .page-header h1{color:var(--text-primary, #f1f5f9)}.header-actions{display:flex;gap:12px;align-items:center}.btn-back{padding:8px 16px;background:var(--bg-secondary, #ffffff);color:var(--text-primary, #1e293b);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);cursor:pointer;font-size:.95em;font-weight:500;transition:all var(--transition-fast, .15s);display:flex;align-items:center;gap:6px}.btn-back:hover{background:var(--bg-tertiary, #f1f5f9);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6)}.dark-theme .btn-back{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.dark-theme .btn-back:hover{background:var(--bg-tertiary, #334155);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #60a5fa)}.btn-primary{padding:10px 20px;background:var(--accent-color, #3b82f6);color:#fff;border:none;border-radius:var(--radius-md, 8px);cursor:pointer;font-size:1em;font-weight:500;transition:all var(--transition-fast, .15s);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1))}.btn-primary:hover{background:var(--accent-hover, #2563eb);transform:translateY(-1px);box-shadow:var(--shadow-md, 0 4px 6px rgba(0,0,0,.1))}.btn-primary:active{transform:translateY(0)}.btn-theme-toggle{padding:10px 14px;background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);cursor:pointer;font-size:1.2em;transition:all var(--transition-fast, .15s);color:var(--text-primary, #0f172a)}.dark-theme .btn-theme-toggle{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.btn-theme-toggle:hover{background:var(--bg-tertiary, #f1f5f9);border-color:var(--accent-color, #3b82f6)}.dark-theme .btn-theme-toggle:hover{background:var(--bg-tertiary, #334155)}.error-message{background:#fef2f2;color:#991b1b;padding:16px;border-radius:var(--radius-md, 8px);margin-bottom:20px;display:flex;justify-content:space-between;align-items:center;border:1px solid #fecaca}.dark-theme .error-message{background:#7f1d1d;color:#fecaca;border-color:#991b1b}.error-message button{background:none;border:none;font-size:1.5em;cursor:pointer;color:inherit;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s}.error-message button:hover{background:#0000001a}.dark-theme .error-message button:hover{background:#ffffff1a}.filters{display:flex;gap:12px;margin-bottom:24px;padding:16px;background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));border:1px solid var(--border-color, #e2e8f0)}.dark-theme .filters{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}.filter-select{padding:10px 14px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);font-size:1em;min-width:200px;background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);cursor:pointer;transition:all var(--transition-fast, .15s)}.dark-theme .filter-select{background:var(--bg-tertiary, #334155);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.filter-select:hover{border-color:var(--accent-color, #3b82f6)}.filter-select:focus{outline:none;border-color:var(--accent-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.products-list{background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));border:1px solid var(--border-color, #e2e8f0);display:flex;flex-direction:column;flex:1;padding:0}.dark-theme .products-list{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569);box-shadow:var(--shadow-md, 0 2px 12px rgba(0,0,0,.5))}.products-list .table-wrapper{flex:1;overflow-x:auto;padding:0;position:relative}.products-table{width:100%;border-collapse:collapse;min-width:900px;margin:0}.products-table thead{position:sticky;top:0;z-index:20;margin:0;width:100%}.products-table thead tr{background:var(--bg-tertiary, #f1f5f9);box-shadow:0 2px 8px #0000001a;display:table-row;width:100%}.dark-theme .products-table thead tr{background:var(--bg-tertiary, #334155);box-shadow:0 2px 8px #00000080}.products-table th,.products-table td{padding:14px 16px;text-align:left;border-bottom:1px solid var(--border-color, #e2e8f0)}.products-table tbody td{background:var(--bg-primary, #ffffff)}.dark-theme .products-table th,.dark-theme .products-table td{border-bottom-color:var(--border-color, #475569)}.dark-theme .products-table tbody td{background:var(--bg-secondary, #1e293b)}.products-table th{background:var(--bg-tertiary, #f1f5f9)!important;font-weight:600;font-size:.9em;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary, #475569);position:sticky;top:0;z-index:21;box-shadow:0 2px 8px #0000001a;border-bottom:2px solid var(--border-color, #e2e8f0);padding:16px;white-space:nowrap}.dark-theme .products-table th{background:var(--bg-tertiary, #334155)!important;color:var(--text-secondary, #cbd5e1);box-shadow:0 2px 8px #00000080;border-bottom-color:var(--border-color, #475569)}.products-table tbody tr{transition:background-color var(--transition-fast, .15s)}.products-table tbody tr:hover{background:var(--bg-tertiary, #f1f5f9)}.dark-theme .products-table tbody tr:hover{background:var(--bg-tertiary, #334155)}.status-select{padding:6px 12px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-sm, 6px);font-size:.9em;background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);cursor:pointer;transition:all var(--transition-fast, .15s)}.dark-theme .status-select{background:var(--bg-tertiary, #334155);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.status-select:hover{border-color:var(--accent-color, #3b82f6)}.status-select.status-implemented{background:#d1fae5;color:#065f46;border-color:#10b981}.dark-theme .status-select.status-implemented{background:#064e3b;color:#6ee7b7;border-color:#10b981}.status-select.status-in-development{background:#fef3c7;color:#92400e;border-color:#f59e0b}.dark-theme .status-select.status-in-development{background:#78350f;color:#fcd34d;border-color:#f59e0b}.status-select.status-planned{background:#dbeafe;color:#1e40af;border-color:#3b82f6}.dark-theme .status-select.status-planned{background:#1e3a8a;color:#93c5fd;border-color:#3b82f6}.status-select.status-later{background:#f3f4f6;color:#374151;border-color:#9ca3af}.dark-theme .status-select.status-later{background:#374151;color:#d1d5db;border-color:#6b7280}.status-select.status-removed{background:#fee2e2;color:#991b1b;border-color:#ef4444}.dark-theme .status-select.status-removed{background:#7f1d1d;color:#fca5a5;border-color:#ef4444}.status-badge{padding:6px 12px;border-radius:var(--radius-sm, 6px);font-size:.9em;font-weight:500;display:inline-block}.status-badge.available{background:#d1fae5;color:#065f46}.dark-theme .status-badge.available{background:#064e3b;color:#6ee7b7}.status-badge.unavailable{background:#fee2e2;color:#991b1b}.dark-theme .status-badge.unavailable{background:#7f1d1d;color:#fca5a5}.action-buttons{display:flex;gap:8px;align-items:center;justify-content:flex-end}.btn-edit{padding:8px 12px;border:2px solid var(--accent-color, #3b82f6);border-radius:var(--radius-md, 8px);background:var(--bg-primary, #ffffff);color:var(--accent-color, #3b82f6);cursor:pointer;font-size:1.2em;transition:all .2s;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));min-width:44px;display:inline-flex;align-items:center;justify-content:center;font-weight:500}.btn-edit:hover{background:var(--accent-color, #3b82f6);color:#fff;border-color:var(--accent-color, #3b82f6);box-shadow:var(--shadow-md, 0 4px 6px rgba(59, 130, 246, .3));transform:translateY(-1px)}.dark-theme .btn-edit{background:var(--bg-primary, #0f172a);border-color:var(--accent-color, #3b82f6);color:var(--accent-color, #3b82f6);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.3))}.dark-theme .btn-edit:hover{background:var(--accent-color, #3b82f6);color:#fff;border-color:var(--accent-color, #3b82f6);box-shadow:var(--shadow-md, 0 4px 6px rgba(59, 130, 246, .4))}.btn-delete{padding:8px 12px;border:2px solid var(--danger-color, #dc3545);border-radius:var(--radius-md, 8px);background:var(--bg-primary, #ffffff);color:var(--danger-color, #dc3545);cursor:pointer;font-size:1.2em;transition:all .2s;box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.1));min-width:44px;display:inline-flex;align-items:center;justify-content:center;font-weight:500}.btn-delete:hover{background:var(--danger-color, #dc3545);color:#fff;border-color:var(--danger-color, #dc3545);box-shadow:var(--shadow-md, 0 4px 6px rgba(220, 53, 69, .3));transform:translateY(-1px)}.dark-theme .btn-delete{background:var(--bg-primary, #0f172a);border-color:var(--danger-color, #ef4444);color:var(--danger-color, #ef4444);box-shadow:var(--shadow-sm, 0 1px 3px rgba(0,0,0,.3))}.dark-theme .btn-delete:hover{background:var(--danger-color, #ef4444);color:#fff;border-color:var(--danger-color, #ef4444);box-shadow:var(--shadow-md, 0 4px 6px rgba(239, 68, 68, .4))}.delete-confirm-inline{display:inline-flex;align-items:center;gap:4px;font-size:12px;white-space:nowrap}.btn-confirm-yes,.btn-confirm-no{padding:3px 8px;border:none;border-radius:4px;cursor:pointer;font-size:12px;font-weight:500}.btn-confirm-yes{background:var(--danger-color, #dc3545);color:#fff}.btn-confirm-yes:hover{opacity:.85}.btn-confirm-no{background:var(--bg-tertiary, #e9ecef);color:var(--text-primary, #333)}.btn-confirm-no:hover{opacity:.85}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary, #475569);font-size:1.1em;margin:24px}.dark-theme .empty-state{color:var(--text-secondary, #cbd5e1)}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.dark-theme .modal-overlay{background:#000000b3}.modal-content{background:var(--bg-primary, #ffffff);border-radius:var(--radius-lg, 12px);box-shadow:var(--shadow-xl, 0 20px 25px rgba(0,0,0,.1));width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.dark-theme .modal-content{background:var(--bg-secondary, #1e293b);box-shadow:var(--shadow-lg, 0 4px 20px rgba(0,0,0,.7))}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color, #e2e8f0)}.dark-theme .modal-header{border-bottom-color:var(--border-color, #475569)}.modal-header h2{margin:0;font-size:1.5em;font-weight:600;color:var(--text-primary, #0f172a)}.dark-theme .modal-header h2{color:var(--text-primary, #f1f5f9)}.close-btn{background:none;border:none;font-size:1.8em;cursor:pointer;color:var(--text-secondary, #475569);padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm, 6px);transition:all var(--transition-fast, .15s)}.close-btn:hover{background:var(--bg-tertiary, #f1f5f9);color:var(--text-primary, #0f172a)}.dark-theme .close-btn{color:var(--text-secondary, #cbd5e1)}.dark-theme .close-btn:hover{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9)}.modal-body{padding:24px;overflow-y:auto;flex:1}.form-section{margin-bottom:32px;padding:20px;background:var(--bg-primary, #ffffff);border-radius:var(--radius-md, 8px);border:1px solid var(--border-color, #e2e8f0)}.dark-theme .form-section{background:var(--bg-secondary, #1e293b);border-color:var(--border-color, #475569)}.form-section-title{margin:0 0 20px;font-size:1.2em;font-weight:600;color:var(--text-primary, #0f172a);padding-bottom:12px;border-bottom:2px solid var(--border-color, #e2e8f0)}.dark-theme .form-section-title{color:var(--text-primary, #f1f5f9);border-bottom-color:var(--border-color, #475569)}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary, #0f172a);font-size:.95em}.dark-theme .form-group label{color:var(--text-primary, #f1f5f9)}.form-group input[type=text],.form-group input[type=number],.form-group textarea,.form-group select{width:100%;padding:10px 14px;border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);font-size:1em;background:var(--bg-primary, #ffffff);color:var(--text-primary, #0f172a);transition:all var(--transition-fast, .15s);font-family:inherit}.dark-theme .form-group input[type=text],.dark-theme .form-group input[type=number],.dark-theme .form-group textarea,.dark-theme .form-group select{background:var(--bg-tertiary, #334155);border-color:var(--border-color, #475569);color:var(--text-primary, #f1f5f9)}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:none;border-color:var(--accent-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.form-group input[type=checkbox]{width:auto;margin-right:8px;cursor:pointer;accent-color:var(--accent-color, #3b82f6)}.form-group label:has(input[type=checkbox]){display:flex;align-items:center;cursor:pointer;font-weight:400}.form-group textarea{resize:vertical;min-height:80px}.form-group small{display:block;margin-top:6px;font-size:.85em;color:var(--text-secondary, #475569)}.dark-theme .form-group small{color:var(--text-secondary, #cbd5e1)}.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:20px}.form-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:20px;border-top:1px solid var(--border-color, #e2e8f0);margin-top:24px}.dark-theme .form-actions{border-top-color:var(--border-color, #475569)}.btn-secondary{padding:10px 20px;background:var(--bg-tertiary, #f1f5f9);color:var(--text-primary, #0f172a);border:1px solid var(--border-color, #e2e8f0);border-radius:var(--radius-md, 8px);cursor:pointer;font-size:1em;font-weight:500;transition:all var(--transition-fast, .15s)}.dark-theme .btn-secondary{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9);border-color:var(--border-color, #475569)}.btn-secondary:hover{background:var(--bg-secondary, #f8fafc);border-color:var(--accent-color, #3b82f6)}.dark-theme .btn-secondary:hover{background:var(--bg-primary, #0f172a)}.loading{text-align:center;padding:40px;color:var(--text-secondary, #475569);font-size:1.1em}.dark-theme .loading{color:var(--text-secondary, #cbd5e1)}@media(max-width:768px){.designer-products-page{padding:16px}.page-header{flex-direction:column;align-items:flex-start;gap:12px}.filters{flex-direction:column}.filter-select{min-width:100%}.form-row{grid-template-columns:1fr}.modal-content{max-width:100%;max-height:95vh;margin:10px}}.not-found-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg-color, #f5f5f5);padding:20px;transition:background-color .3s,color .3s}.not-found-page.dark-theme{background:var(--bg-secondary, #1a1a1a);color:var(--text-primary, #e0e0e0)}.not-found-content{text-align:center;max-width:480px}.not-found-code{font-size:120px;font-weight:800;line-height:1;color:var(--accent-color, #3b82f6);opacity:.15;-webkit-user-select:none;user-select:none;margin-bottom:-20px}.not-found-title{font-size:28px;font-weight:700;margin:0 0 12px;color:var(--text-primary, #1e293b)}.not-found-page.dark-theme .not-found-title{color:var(--text-primary, #f1f5f9)}.not-found-description{font-size:16px;color:var(--text-secondary, #64748b);margin:0 0 32px;line-height:1.6}.not-found-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.btn-home,.btn-back-link{padding:10px 24px;border-radius:8px;font-size:15px;font-weight:500;cursor:pointer;transition:opacity .2s,transform .15s;border:none}.btn-home{background:var(--accent-color, #3b82f6);color:#fff}.btn-home:hover{opacity:.88;transform:translateY(-1px)}.btn-back-link{background:var(--bg-tertiary, #e2e8f0);color:var(--text-primary, #1e293b)}.btn-back-link:hover{opacity:.8;transform:translateY(-1px)}.not-found-page.dark-theme .btn-back-link{background:var(--bg-tertiary, #334155);color:var(--text-primary, #f1f5f9)}.error-boundary{padding:20px;text-align:center;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--bg-primary, #ffffff);color:var(--text-primary, #333)}.error-boundary-title{margin:0 0 16px;font-size:1.5em;font-weight:600;color:var(--text-primary, #333)}.error-boundary-message{margin:0 0 24px;font-size:1em;color:var(--text-secondary, #666);max-width:600px}.error-boundary-button{padding:10px 20px;margin-top:10px;cursor:pointer;background:var(--accent-color, #3b82f6);color:#fff;border:none;border-radius:6px;font-size:1em;font-weight:500;transition:background .2s ease}.error-boundary-button:hover{background:var(--accent-color-hover, #2563eb)}[data-theme=dark] .error-boundary,.dark-theme .error-boundary{background:var(--bg-secondary, #1e1e1e);color:var(--text-primary, #e0e0e0)}[data-theme=dark] .error-boundary-title,.dark-theme .error-boundary-title{color:var(--text-primary, #e0e0e0)}[data-theme=dark] .error-boundary-message,.dark-theme .error-boundary-message{color:var(--text-secondary, #a0a0a0)}
