@font-face{font-family:Agbalumo;src:url(/fonts/Agbalumo.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Lovely Valentine Script;src:url(/fonts/LovelyValentineScript.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Valen Valentine Script;src:url(/fonts/ValenValentineScript.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Gabarito;src:url(/fonts/Gabarito.ttf) format("truetype");font-weight:400;font-style:normal;font-display:swap}@font-face{font-family:Fields Bold;src:url(/fonts/FieldsBold.otf) format("opentype");font-weight:400;font-style:normal;font-display:swap}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f3f4f6;color:#1f2937;line-height:1.5}.app{max-width:1100px;margin:0 auto;padding:20px}.app-header{display:flex;flex-direction:column;align-items:center;margin-bottom:20px;padding:0;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden}.app-logo{height:150px;width:auto}.header-phone{margin:-15px 0 8px;padding:0;color:#6b7280;font-size:.95rem}.app-header h1{font-size:2rem;color:#111827}.app-header p{color:#6b7280;font-size:1.1rem;margin:0}.wizard-layout{display:flex;gap:30px;align-items:stretch}.wizard-main{flex:1;background:#fff;border-radius:12px;padding:24px;box-shadow:0 1px 3px #0000001a}.step-indicators{display:flex;gap:4px;margin-bottom:28px;padding-bottom:20px;border-bottom:1px solid #e5e7eb}.step-indicator{flex:1;display:flex;align-items:center;gap:6px;font-size:.85rem;color:#9ca3af}.step-indicator.current{color:#2563eb;font-weight:600}.step-indicator.done{color:#16a34a}.step-num{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;background:#e5e7eb;color:#6b7280;flex-shrink:0}.step-indicator.current .step-num{background:#2563eb;color:#fff}.step-indicator.done .step-num{background:#16a34a;color:#fff}.step h2{font-size:1.3rem;margin-bottom:6px}.step-desc{color:#6b7280;margin-bottom:16px;font-size:.9rem}.field-group{margin-bottom:20px}.field-group label{display:block;font-weight:600;font-size:.9rem;margin-bottom:8px;color:#374151}.color-swatches{display:flex;gap:10px;flex-wrap:wrap}.swatch{width:42px;height:42px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:border-color .15s,transform .15s;box-shadow:0 1px 3px #00000026}.swatch:hover{transform:scale(1.1)}.swatch.active{border-color:#2563eb;box-shadow:0 0 0 2px #2563eb}.size-buttons{display:flex;gap:8px}.size-btn{padding:8px 18px;border:2px solid #d1d5db;border-radius:8px;background:#fff;cursor:pointer;font-weight:600;font-size:.9rem;transition:all .15s}.size-btn:hover{border-color:#2563eb}.size-btn.active{border-color:#2563eb;background:#2563eb;color:#fff}.neck-style-buttons{display:flex;gap:12px}.neck-style-btn{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 12px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;font-size:.9rem;font-weight:500;color:#374151;transition:all .15s}.neck-style-btn:hover{border-color:#93c5fd}.neck-style-btn.active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.neck-icon{width:40px;height:50px}.price-display{display:flex;justify-content:space-between;align-items:center;margin-top:20px;padding:16px;background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #86efac;border-radius:12px}.price-label{font-size:1rem;font-weight:600;color:#166534}.price-value{font-size:1.5rem;font-weight:700;color:#16a34a}.print-price-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding:12px 16px;background:linear-gradient(135deg,#eff6ff,#dbeafe);border:2px solid #93c5fd;border-radius:10px}.print-price-label{font-size:.95rem;font-weight:600;color:#1e40af;text-transform:capitalize}.print-price-value{font-size:1.25rem;font-weight:700;color:#2563eb}.layout-options{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:12px}.layout-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:12px 8px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;transition:all .15s;font-size:.8rem;font-weight:500}.layout-card:hover{border-color:#93c5fd}.layout-card.active{border-color:#2563eb;background:#eff6ff}.layout-thumb{width:50px;height:66px}.upload-area{display:flex;align-items:center;gap:12px}.file-input{display:none}.upload-btn{display:inline-block;padding:10px 20px;background:#2563eb;color:#fff;border-radius:8px;cursor:pointer;font-weight:600;font-size:.9rem;transition:background .15s}.upload-btn:hover{background:#1d4ed8}.upload-status{color:#16a34a;font-weight:600;font-size:.9rem}.custom-image-preview{margin-top:12px;padding:10px;background:#f9fafb;border:1px dashed #d1d5db;border-radius:8px;display:inline-block}.custom-image-preview img{max-width:100px;max-height:100px;object-fit:contain;display:block}.clipart-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}.clipart-loading,.clipart-empty{padding:20px;text-align:center;color:#6b7280;font-size:.9rem}.clipart-loading{color:#2563eb}.clipart-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:90px;height:100px;padding:8px 4px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;transition:all .15s;font-size:.7rem;font-weight:500;overflow:hidden}.clipart-btn:hover{border-color:#93c5fd}.clipart-btn.active{border-color:#2563eb;background:#eff6ff}.clipart-pagination{display:flex;justify-content:center;align-items:center;gap:12px;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.pagination-btn{padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.pagination-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{font-size:.85rem;color:#6b7280;min-width:50px;text-align:center}.clipart-icon{width:44px;height:44px;object-fit:contain}.clipart-btn span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center}.no-frame-btn{width:100%;padding:14px 20px;border:2px dashed #d1d5db;border-radius:10px;background:#f9fafb;cursor:pointer;font-size:1rem;font-weight:600;color:#6b7280;transition:all .15s}.no-frame-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.no-frame-btn.active{border-color:#2563eb;border-style:solid;background:#eff6ff;color:#2563eb}.clear-btn{padding:8px 16px;border:1px solid #d1d5db;border-radius:8px;background:#fff;cursor:pointer;font-size:.85rem;color:#6b7280;transition:all .15s}.clear-btn:hover{border-color:#ef4444;color:#ef4444}.text-input{width:100%;padding:10px 12px;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;font-family:inherit;resize:vertical;transition:border-color .15s}.text-input:focus{outline:none;border-color:#2563eb}.text-hints{display:flex;justify-content:space-between;margin-top:4px}.hint,.char-count{font-size:.8rem;color:#9ca3af}.category-tabs{display:flex;gap:6px;margin-bottom:10px}.category-tab{padding:6px 14px;border:1px solid #d1d5db;border-radius:20px;background:#fff;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .15s}.category-tab:hover{border-color:#93c5fd}.category-tab.active{border-color:#2563eb;background:#2563eb;color:#fff}.category-select{width:100%;padding:10px 12px;border:2px solid #d1d5db;border-radius:8px;background:#fff;font-size:.95rem;color:#374151;cursor:pointer;margin-bottom:10px;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.category-select:focus{outline:none;border-color:#2563eb}.template-buttons{display:flex;flex-wrap:wrap;gap:8px}.template-btn{padding:8px 14px;border:1px solid #d1d5db;border-radius:20px;background:#fff;cursor:pointer;font-size:.85rem;transition:all .15s}.template-btn:hover{border-color:#2563eb;background:#eff6ff}.template-btn.active{border-color:#2563eb;background:#2563eb;color:#fff}.template-btn-wrapper{display:inline-flex;align-items:center;position:relative}.template-btn-wrapper .template-btn{padding-right:28px}.template-delete-btn{position:absolute;right:6px;top:50%;transform:translateY(-50%);width:18px;height:18px;border:none;border-radius:50%;background:#fecaca;color:#dc2626;font-size:14px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.7;transition:all .15s}.template-delete-btn:hover{opacity:1;background:#dc2626;color:#fff}.font-options{display:flex;gap:10px;flex-wrap:wrap}.font-btn{padding:10px 16px;border:2px solid #d1d5db;border-radius:8px;background:#fff;cursor:pointer;font-size:1.1rem;transition:all .15s}.font-btn:hover{border-color:#2563eb}.font-btn.active{border-color:#2563eb;background:#eff6ff}.color-picker-row{display:flex;align-items:center;gap:12px}input[type=color]{width:48px;height:36px;border:2px solid #d1d5db;border-radius:6px;cursor:pointer;padding:2px}.color-value{font-family:monospace;font-size:.9rem;color:#6b7280}.step-nav{display:flex;justify-content:space-between;margin-top:24px;padding-top:20px;border-top:1px solid #e5e7eb}.nav-btn{padding:10px 24px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.nav-btn.startover{background:#fff;color:#6b7280;border:1px solid #d1d5db}.nav-btn.startover:hover{border-color:#ef4444;color:#ef4444}.nav-btn.back{background:#e5e7eb;color:#374151;margin-left:12px}.nav-btn.back:hover{background:#d1d5db}.nav-btn.next{background:#2563eb;color:#fff;margin-left:auto}.nav-btn.next:hover{background:#1d4ed8}.nav-btn:disabled{opacity:.5;cursor:not-allowed}.confirm-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.confirm-modal{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:90%;box-shadow:0 4px 20px #00000026;animation:scaleIn .2s ease}.confirm-modal h3{margin:0 0 12px;font-size:1.25rem;color:#1f2937}.confirm-modal p{margin:0 0 20px;color:#6b7280;line-height:1.5}.confirm-buttons{display:flex;gap:12px;justify-content:flex-end}.confirm-btn{padding:10px 20px;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:background .2s ease}.confirm-btn.cancel{background:#e5e7eb;color:#374151}.confirm-btn.cancel:hover{background:#d1d5db}.confirm-btn.confirm{background:#ef4444;color:#fff}.confirm-btn.confirm:hover{background:#dc2626}.preview-panel{width:300px;background:#fff;border-radius:12px;padding:20px;box-shadow:0 1px 3px #0000001a;position:sticky;top:20px;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease}.preview-panel h3{font-size:1rem;margin-bottom:12px;color:#374151}.tshirt-svg{width:100%;height:auto;background:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fafafa 0%,#fafafa 50%) 50% / 16px 16px;border-radius:8px}.preview-label{text-align:center;font-size:.85rem;color:#6b7280;margin-top:10px}.preview-panel:hover{transform:scale(1.02);box-shadow:0 4px 12px #00000026}.preview-hint{text-align:center;font-size:.75rem;color:#9ca3af;margin-top:4px}.pricing-summary{width:300px;background:#fff;border-radius:12px;padding:16px 20px;box-shadow:0 1px 3px #0000001a;margin-top:16px}.pricing-summary h4{font-size:.9rem;margin:0 0 12px;color:#374151;font-weight:600}.pricing-rows{display:flex;flex-direction:column;gap:8px}.pricing-row{display:flex;justify-content:space-between;align-items:center;font-size:.85rem}.pricing-row.inactive{opacity:.4}.pricing-row .pricing-item{color:#6b7280}.pricing-row .pricing-amount{color:#374151;font-weight:500}.pricing-row.total{margin-top:8px;padding-top:10px;border-top:2px solid #e5e7eb}.pricing-row.total .pricing-item{font-weight:700;color:#111827}.pricing-row.total .pricing-amount{font-size:1.1rem;font-weight:700;color:#16a34a}.preview-fullscreen-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.preview-fullscreen-content{position:relative;background:#fff;border-radius:16px;padding:24px;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center;animation:scaleIn .2s ease}@keyframes scaleIn{0%{transform:scale(.9);opacity:0}to{transform:scale(1);opacity:1}}.preview-fullscreen-close{position:absolute;top:12px;right:12px;width:36px;height:36px;border:none;background:#f3f4f6;border-radius:50%;font-size:24px;line-height:1;cursor:pointer;color:#6b7280;transition:background .2s ease,color .2s ease}.preview-fullscreen-close:hover{background:#e5e7eb;color:#374151}.tshirt-svg-fullscreen{width:min(500px,80vw);height:auto;background:repeating-conic-gradient(#f0f0f0,#f0f0f0 25%,#fafafa 0%,#fafafa 50%) 50% / 16px 16px;border-radius:12px}.preview-fullscreen-label{text-align:center;font-size:1rem;color:#374151;margin-top:16px;font-weight:500}.order-summary{background:#f9fafb;border-radius:8px;padding:16px;margin:16px 0}.summary-row{display:flex;justify-content:space-between;padding:8px 0;border-bottom:1px solid #e5e7eb;font-size:.9rem}.summary-row:last-child{border-bottom:none}.summary-value{font-weight:600;display:flex;align-items:center;gap:6px}.summary-total{display:flex;justify-content:space-between;padding:16px 0 8px;margin-top:8px;border-top:2px solid #e5e7eb;font-size:1.1rem;font-weight:600}.summary-price{color:#16a34a;font-size:1.25rem;font-weight:700}.mini-swatch{display:inline-block;width:16px;height:16px;border-radius:50%;border:1px solid #d1d5db}.submit-btn{width:100%;padding:14px;background:#16a34a;color:#fff;border:none;border-radius:8px;font-size:1.05rem;font-weight:600;cursor:pointer;transition:background .15s}.submit-btn:hover{background:#15803d}.submit-btn:disabled{opacity:.6;cursor:not-allowed}.success-msg{padding:20px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;color:#166534;font-size:1.1rem;text-align:center;margin-top:16px}.error-msg{color:#dc2626;text-align:center;margin-top:10px;font-size:.9rem}.order-success .success-msg{margin-top:0;margin-bottom:20px;padding:12px 20px}.order-receipt{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:24px;text-align:center}.receipt-header{display:flex;flex-direction:column;align-items:center;gap:12px;padding-bottom:16px;border-bottom:2px dashed #e5e7eb;margin-bottom:16px}.order-qr{border-radius:8px;border:1px solid #e5e7eb}.order-number{font-size:1.4rem;font-weight:700;color:#111827}.receipt-details{text-align:left}.receipt-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f3f4f6;font-size:.9rem}.receipt-row:last-child{border-bottom:none}.receipt-value{font-weight:600;display:flex;align-items:center;gap:6px;color:#374151}.receipt-row.receipt-total{margin-top:8px;padding-top:12px;border-top:2px solid #e5e7eb;border-bottom:none;font-size:1rem}.receipt-value.price{color:#16a34a;font-size:1.15rem;font-weight:700}.screenshot-hint{margin-top:20px;padding:12px;background:#fef3c7;border-radius:8px;color:#92400e;font-size:.85rem;font-weight:500}.status-check-hint{margin-top:16px;padding:12px;background:#e0f2fe;border-radius:8px;color:#0369a1;font-size:.85rem;line-height:1.5}.status-check-hint a{color:#2563eb;font-weight:600;text-decoration:underline}.status-check-hint strong{font-weight:700}@media (max-width: 768px){.app{padding:10px}.app-header h1{font-size:1.5rem}.app-header p{font-size:.85rem}.wizard-layout{flex-direction:column;gap:16px;align-items:stretch}.wizard-main{padding:16px;order:1}.preview-panel{width:100%;position:static;order:2;padding:16px}.preview-panel h3{text-align:center}.pricing-summary{width:100%;order:3}.pricing-summary h4{text-align:center}.tshirt-svg{max-width:250px;margin:0 auto;display:block}.step-indicators{overflow-x:auto;gap:2px}.step-name{display:none}.step h2{font-size:1.1rem;text-align:center}.step-desc{font-size:.85rem;text-align:center}.field-group label{text-align:center}.color-swatches{justify-content:center}.size-buttons{justify-content:center;flex-wrap:wrap}.clipart-grid{gap:8px}.clipart-btn{width:75px;height:85px;font-size:.65rem}.upload-area{flex-direction:column;align-items:stretch}.upload-btn{display:block;width:100%;text-align:center}.custom-image-preview{display:flex;justify-content:center}.clear-btn{width:100%}.template-buttons,.font-options{justify-content:center}.font-size-options{flex-wrap:wrap;justify-content:center}.layout-options{grid-template-columns:repeat(auto-fill,minmax(80px,1fr))}.step-nav{padding-top:16px;margin-top:16px}.nav-btn{padding:10px 18px;font-size:.9rem}.orders-page{padding:12px}.admin-header{flex-direction:column;gap:12px;align-items:flex-start}.admin-header h1{font-size:1.3rem}.orders-nav-links{flex-wrap:wrap;gap:8px;width:100%}.logged-in-user{font-size:.75rem;width:100%;margin-bottom:4px}.logout-btn,.back-link{padding:6px 12px;font-size:.8rem}.admin-tabs{margin-bottom:16px}.admin-tab{padding:8px 12px;font-size:.85rem}.orders-table{display:block}.orders-table thead{display:none}.orders-table tbody{display:flex;flex-direction:column;gap:12px}.orders-table tr{display:block;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:12px;box-shadow:0 1px 3px #0000000d}.orders-table tr:hover{background:#fff}.orders-table td{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid #f3f4f6;white-space:normal}.orders-table td:last-child{border-bottom:none}.orders-table td:before{content:attr(data-label);font-weight:600;color:#6b7280;font-size:.75rem;text-transform:uppercase;flex-shrink:0;margin-right:12px}.orders-text-cell{max-width:none;text-align:right}.orders-font-cell{text-align:right}.status-select{padding:6px 10px;font-size:.8rem;min-width:auto}.download-btn{padding:6px 12px;font-size:.75rem}.download-cell{display:flex;gap:6px;justify-content:flex-end}.order-id-btn{padding:6px 12px;font-size:.85rem;font-weight:600}.order-modal{width:95%;max-width:none;margin:10px;max-height:90vh;overflow-y:auto}.order-details-card{padding:16px}.order-header{flex-direction:column;align-items:center;text-align:center}.order-designs{flex-direction:column}.design-preview img{max-width:100%}.validator-section{padding:12px}.scanner-container{max-width:100%}#qr-reader{width:100%!important}}.header-links{display:flex;gap:10px}.app-footer{display:flex;justify-content:center;gap:10px;margin-top:20px;padding:15px}.admin-link{display:inline-block;font-size:.85rem;color:#6b7280;text-decoration:none;padding:6px 14px;border:1px solid #e5e7eb;border-radius:6px;transition:all .15s}.admin-link:hover{color:#ec4899;border-color:#ec4899;background:#fdf2f8}.admin-page{max-width:800px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.admin-header h1{font-size:1.6rem}.back-link{color:#2563eb;text-decoration:none;font-size:.9rem;font-weight:500}.back-link:hover{text-decoration:underline}.admin-tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:2px solid #e5e7eb}.admin-tab{padding:10px 20px;border:none;background:none;cursor:pointer;font-size:.95rem;font-weight:500;color:#6b7280;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.admin-tab:hover{color:#374151}.admin-tab.active{color:#2563eb;border-bottom-color:#2563eb}.admin-section h2{font-size:1.2rem;margin-bottom:16px}.admin-form{background:#f9fafb;padding:16px;border-radius:10px;margin-bottom:20px;display:flex;flex-direction:column;gap:10px}.admin-form input,.admin-form textarea,.admin-form select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;font-family:inherit}.admin-form input:focus,.admin-form textarea:focus,.admin-form select:focus{outline:none;border-color:#2563eb}.admin-form textarea{resize:vertical}.admin-form-row{display:flex;gap:8px;align-items:center}.admin-form-row select,.admin-form-row input{flex:1}.admin-or{color:#9ca3af;font-size:.85rem;flex-shrink:0}.admin-upload-row{display:flex;align-items:center;gap:10px}.admin-add-btn{align-self:flex-start;padding:8px 18px;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.9rem;font-weight:600;cursor:pointer;transition:background .15s}.admin-add-btn:hover{background:#1d4ed8}.admin-error{color:#dc2626;font-size:.85rem}.admin-preview{display:flex;align-items:center;gap:12px;padding:10px;background:#fff;border:1px dashed #d1d5db;border-radius:8px;margin-bottom:16px;font-size:.85rem;color:#6b7280}.admin-list{display:flex;flex-direction:column;gap:6px}.admin-list-item{display:flex;align-items:center;gap:12px;padding:10px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:8px}.admin-clipart-icon{width:36px;height:36px;object-fit:contain;flex-shrink:0}.admin-item-info{flex:1;display:flex;flex-direction:column}.admin-item-info strong{font-size:.9rem}.admin-item-id{font-size:.75rem;color:#9ca3af}.admin-delete-btn{padding:4px 12px;border:1px solid #fca5a5;border-radius:6px;background:#fff;color:#dc2626;font-size:.8rem;cursor:pointer;transition:all .15s}.admin-delete-btn:hover{background:#fef2f2;border-color:#dc2626}.admin-empty{color:#9ca3af;font-size:.9rem;padding:20px;text-align:center}.role-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:.7rem;font-weight:600;text-transform:uppercase;margin-left:8px}.role-tag.super{background:#fef3c7;color:#b45309}.role-tag.printer{background:#e0e7ff;color:#4338ca}.admin-item-actions{display:flex;align-items:center;gap:8px}.role-select-small{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:.8rem;cursor:pointer}.inline-edit{display:flex;align-items:center;gap:8px}.inline-edit input{padding:6px 10px;border:1px solid #d1d5db;border-radius:4px;font-size:.85rem;width:140px}.admin-edit-btn{padding:4px 10px;border:1px solid #d1d5db;border-radius:4px;background:#fff;color:#4b5563;font-size:.8rem;cursor:pointer}.admin-edit-btn:hover{background:#f3f4f6}.orders-page{max-width:1000px;margin:0 auto;padding:24px}.orders-nav-links{display:flex;gap:16px}.status-filter{display:flex;align-items:center;gap:10px;margin-top:16px;font-size:.9rem}.status-filter select{padding:6px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer}.status-filter select:focus{outline:none;border-color:#2563eb}.orders-table{width:100%;border-collapse:collapse;font-size:.9rem;margin-top:12px}.orders-table th,.orders-table td{padding:10px 12px;text-align:left;border-bottom:1px solid #e5e7eb}.orders-table th{background:#f9fafb;font-weight:600;color:#374151;font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.sortable-th{cursor:pointer;-webkit-user-select:none;user-select:none}.sortable-th:hover{background:#eef0f3}.sortable-th.active-sort{color:#2563eb}.sort-indicator{font-size:.7rem}.orders-table tr:hover{background:#f9fafb}.orders-text-cell{max-width:180px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.orders-font-cell{font-size:.85rem}.orders-price-cell{font-weight:600;color:#16a34a}.download-btn{padding:6px 14px;border:1px solid #2563eb;border-radius:6px;background:#eff6ff;color:#2563eb;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .15s}.download-btn:hover{background:#2563eb;color:#fff}.status-select{padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;background:#fff;font-size:.8rem;cursor:pointer;transition:all .15s}.status-select:focus{outline:none;border-color:#2563eb}.status-select option[value=Processing]{color:#d97706}.status-select option[value=Printing]{color:#2563eb}.status-select option[value="Ready for pickup"]{color:#16a34a}.login-page{display:flex;justify-content:center;align-items:center;min-height:80vh}.login-container{background:#fff;padding:40px;border-radius:12px;box-shadow:0 4px 20px #0000001a;width:100%;max-width:360px;text-align:center}.login-logo{max-width:220px;height:auto;margin-bottom:20px}.login-container h2{font-size:1.3rem;margin-bottom:24px;color:#1f2937}.login-form{display:flex;flex-direction:column;gap:12px}.login-form input{padding:12px 14px;border:1px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#f9fafb;color:#1f2937}.login-form input::placeholder{color:#9ca3af}.login-form input:focus{outline:none;border-color:#ec4899;background:#fff}.login-form button{padding:12px;background:linear-gradient(135deg,#06b6d4,#ec4899,#f59e0b);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:opacity .15s}.login-form button:hover{opacity:.9}.login-form button:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#dc2626;font-size:.9rem;margin:0}.login-container .back-link{display:inline-block;margin-top:20px;color:#6b7280}.login-container .back-link:hover{color:#ec4899}.config-header-right{display:flex;align-items:center;gap:16px}.logged-in-user{font-size:.85rem;color:#6b7280}.logout-btn{padding:6px 14px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;font-size:.85rem;cursor:pointer;transition:all .15s}.logout-btn:hover{border-color:#ef4444;color:#ef4444}.password-edit{display:flex;gap:8px;align-items:center}.password-edit input{padding:6px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:.85rem}.user-actions{display:flex;gap:8px}.admin-edit-btn{padding:4px 12px;border:1px solid #93c5fd;border-radius:6px;background:#fff;color:#2563eb;font-size:.8rem;cursor:pointer;transition:all .15s}.admin-edit-btn:hover{background:#eff6ff;border-color:#2563eb}.role-select{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;background:#fff;cursor:pointer}.role-select:focus{outline:none;border-color:#2563eb}.role-select-inline{padding:4px 8px;border:1px solid #d1d5db;border-radius:4px;font-size:.75rem;background:#f9fafb;cursor:pointer;margin-top:4px}.role-select-inline:focus{outline:none;border-color:#2563eb}.layer-tabs{display:flex;gap:8px;margin-bottom:20px}.layer-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 16px;border:2px solid #e5e7eb;border-radius:10px;background:#fff;cursor:pointer;font-size:.9rem;font-weight:500;color:#6b7280;transition:all .15s}.layer-tab:hover:not(.disabled){border-color:#93c5fd;color:#374151}.layer-tab.active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.layer-tab.disabled{opacity:.5;cursor:not-allowed;background:#f9fafb}.layer-num{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#e5e7eb;color:#6b7280;border-radius:50%;font-size:.8rem;font-weight:600}.layer-tab.active .layer-num{background:#2563eb;color:#fff}.layer-status{color:#16a34a;font-weight:600}.layer-content{animation:fadeIn .2s ease}.layer-disabled-msg{text-align:center;color:#9ca3af;padding:40px 20px;font-size:.95rem}.side-tabs{display:flex;gap:8px;margin-bottom:16px}.side-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 16px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;cursor:pointer;font-size:.9rem;font-weight:600;color:#6b7280;transition:all .15s}.side-tab:hover{border-color:#93c5fd;color:#374151}.side-tab.active{border-color:#2563eb;background:#2563eb;color:#fff}.side-status{font-size:.8rem;color:#16a34a}.side-tab.active .side-status{color:#bbf7d0}.side-tab-icon{width:18px;height:22px;flex-shrink:0}.preview-side-toggle{display:flex;gap:4px;justify-content:center;margin:12px 0 8px}.preview-side-toggle.fullscreen{margin:16px 0}.preview-side-btn{display:flex;align-items:center;gap:4px;padding:6px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;cursor:pointer;font-size:.8rem;font-weight:500;color:#6b7280;transition:all .15s}.preview-side-btn:hover{border-color:#93c5fd;color:#374151}.preview-side-btn.active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.side-dot{color:#16a34a;font-size:1.2rem;line-height:1}.summary-section{margin-top:16px;padding-top:16px;border-top:1px solid #e5e7eb}.summary-section h4{font-size:.9rem;font-weight:600;color:#374151;margin:0 0 12px}.summary-value.muted{color:#9ca3af;font-style:italic}.summary-section.pricing{background:linear-gradient(135deg,#f0fdf4,#dcfce7);border:2px solid #86efac;border-radius:12px;padding:16px;margin-top:20px;border-top:none}.summary-section.pricing h4{color:#166534}.summary-row.muted{opacity:.4}.download-cell{display:flex;gap:4px}.download-cell .download-btn{padding:4px 8px;font-size:.75rem}.image-resizer{background:#f9fafb;border:1px solid #e5e7eb;border-radius:10px;padding:16px;margin-top:16px}.image-resizer>label{display:block;font-weight:600;font-size:.9rem;margin-bottom:12px;color:#374151}.resizer-control{display:flex;align-items:center;gap:12px;margin-bottom:12px}.resizer-control:last-of-type{margin-bottom:16px}.resizer-label{width:60px;font-size:.85rem;color:#6b7280;flex-shrink:0}.resizer-slider{flex:1;height:6px;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:#e5e7eb;border-radius:3px;outline:none;cursor:pointer}.resizer-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2563eb;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px #0003;transition:transform .15s}.resizer-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.resizer-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2563eb;cursor:pointer;border:2px solid #fff;box-shadow:0 1px 3px #0003}.resizer-value{width:50px;text-align:right;font-size:.85rem;font-weight:600;color:#374151;flex-shrink:0}.reset-btn{width:100%;padding:8px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.reset-btn:hover{border-color:#2563eb;color:#2563eb;background:#eff6ff}.inventory-hint{color:#6b7280;font-size:.9rem;margin-bottom:20px}.inventory-neck-tabs{display:flex;gap:8px;margin-bottom:16px}.inventory-neck-tab{flex:1;padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;background:#fff;font-size:.95rem;font-weight:600;color:#374151;cursor:pointer;transition:all .15s}.inventory-neck-tab:hover{border-color:#93c5fd}.inventory-neck-tab.active{border-color:#2563eb;background:#eff6ff;color:#2563eb}.inventory-grid{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.inventory-header,.inventory-row{display:grid;grid-template-columns:120px repeat(5,1fr) 40px;gap:8px;align-items:center}.inventory-header{font-weight:600;color:#374151;font-size:.9rem;padding-bottom:8px;border-bottom:1px solid #e5e7eb}.inventory-size-label{text-align:center}.inventory-color-label{display:flex;align-items:center;gap:8px;font-size:.9rem}.inventory-swatch{width:24px;height:24px;border-radius:4px;border:2px solid rgba(0,0,0,.15);flex-shrink:0}.inventory-input{width:60px;padding:6px 8px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;text-align:center}.inventory-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.inventory-save-btn{margin-top:10px}.size-pricing-section{background:#f0fdf4;border:1px solid #86efac;border-radius:8px;padding:16px;margin-bottom:20px}.size-pricing-section h4{margin:0 0 12px;font-size:.95rem;color:#166534}.size-pricing-row{display:flex;gap:12px;flex-wrap:wrap}.size-pricing-cell{display:flex;flex-direction:column;align-items:center;gap:4px}.size-pricing-cell label{font-size:.8rem;font-weight:600;color:#374151}.size-price-input{display:flex;align-items:center;gap:2px}.size-price-input .price-symbol{font-size:.85rem;color:#16a34a;font-weight:600}.size-price-input .inventory-input.price{width:70px}.print-pricing-row{display:flex;gap:24px;flex-wrap:wrap}.print-pricing-cell{display:flex;flex-direction:column;align-items:center;gap:4px}.print-pricing-cell label{font-size:.85rem;font-weight:600;color:#374151}.inventory-cell{display:flex;flex-direction:column;align-items:center;gap:4px}.inventory-price-input{display:flex;align-items:center;gap:2px}.inventory-price-input .price-symbol{font-size:.75rem;color:#6b7280}.inventory-input.price{width:55px;font-size:.8rem;padding:4px 6px}.add-color-section{background:#f9fafb;border:1px solid #e5e7eb;border-radius:8px;padding:16px;margin-bottom:24px}.add-color-section h3{margin:0 0 12px;font-size:1rem;color:#374151}.add-color-form{display:flex;flex-direction:column;gap:8px}.add-color-inputs{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.color-name-input{padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;width:160px}.color-name-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.color-picker-group{display:flex;align-items:center;gap:8px}.color-picker-input{width:40px;height:36px;padding:2px;border:1px solid #d1d5db;border-radius:6px;cursor:pointer}.hex-input{width:90px;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem;font-family:monospace}.hex-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb33}.color-error{color:#dc2626;font-size:.85rem;margin:4px 0 0}.delete-color-btn{width:28px;height:28px;border:1px solid #fecaca;background:#fef2f2;color:#dc2626;border-radius:4px;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center}.delete-color-btn:hover{background:#fee2e2;border-color:#f87171}.swatch.out-of-stock{opacity:.4;cursor:not-allowed;position:relative}.swatch.out-of-stock:after{content:"";position:absolute;top:50%;left:0;right:0;height:2px;background:#ef4444;transform:rotate(-45deg)}.size-btn.out-of-stock{opacity:.5;cursor:not-allowed;background:#f3f4f6;color:#9ca3af;position:relative;overflow:hidden}.size-btn.out-of-stock:after{content:"";position:absolute;top:50%;left:-10%;width:120%;height:2px;background:#ef4444;transform:rotate(-20deg)}.size-btn.out-of-stock:hover{background:#f3f4f6;border-color:#d1d5db;color:#9ca3af}.validator-section{text-align:center;padding:20px 0}.validator-hint{color:#6b7280;margin-bottom:24px}.validator-login-hint{background:#fef3c7;color:#92400e;padding:12px 20px;margin:0 20px 20px;border-radius:8px;text-align:center}.validator-login-hint a{color:#2563eb;font-weight:600;text-decoration:underline}.scanner-container{max-width:400px;margin:0 auto 20px;border-radius:12px;overflow:hidden;background:#000}#qr-reader{width:100%}#qr-reader video{border-radius:12px}.start-scanner-btn{padding:16px 32px;background:#2563eb;color:#fff;border:none;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:background .15s}.start-scanner-btn:hover{background:#1d4ed8}.stop-scanner-btn{margin-top:16px;padding:10px 24px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer}.stop-scanner-btn:hover{background:#dc2626}.validator-error{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:16px 20px;border-radius:10px;margin:16px auto;max-width:400px}.validator-loading{padding:40px;color:#6b7280;font-size:1rem}.validator-options{display:flex;flex-direction:column;align-items:center;gap:16px}.validator-divider{color:#9ca3af;font-size:.9rem}.manual-input-form{display:flex;gap:8px;align-items:center}.manual-order-input{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;width:140px;text-align:center}.manual-order-input:focus{outline:none;border-color:#2563eb}.manual-lookup-btn{padding:12px 20px;background:#10b981;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:background .15s}.manual-lookup-btn:hover{background:#059669}.order-details-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:24px;text-align:left;max-width:500px;margin:0 auto}.order-header{display:flex;gap:16px;align-items:center;margin-bottom:20px;padding-bottom:16px;border-bottom:2px solid #e5e7eb}.order-detail-qr{width:80px;height:80px;border-radius:8px;border:1px solid #e5e7eb}.order-header-info{display:flex;flex-direction:column;gap:8px;flex:1}.order-id{font-size:1.4rem;font-weight:700;color:#111827}.order-status-badge{padding:6px 14px;border-radius:20px;font-size:.85rem;font-weight:600}.order-status-badge.unpaid{background:#fee2e2;color:#dc2626}.order-status-badge.processing{background:#fef3c7;color:#b45309}.order-status-badge.printing{background:#dbeafe;color:#1d4ed8}.order-status-badge.ready{background:#dcfce7;color:#166534}.order-status-badge.done{background:#e5e7eb;color:#374151}.order-designs{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin:20px 0}.design-preview{text-align:center}.design-preview img{max-width:100%;height:150px;object-fit:contain;border:1px solid #e5e7eb;border-radius:8px;background:#f9fafb}.design-preview-label{font-size:.85rem;color:#6b7280;margin-top:8px}.order-tshirt-preview{margin:20px 0;text-align:center}.order-tshirt-preview .preview-side-toggle{display:flex;justify-content:center;gap:8px;margin-bottom:12px}.order-tshirt-preview .side-btn{padding:6px 16px;border:1px solid #d1d5db;border-radius:6px;background:#fff;color:#6b7280;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.order-tshirt-preview .side-btn:hover{border-color:#93c5fd;color:#2563eb}.order-tshirt-preview .side-btn.active{background:#2563eb;border-color:#2563eb;color:#fff}.order-tshirt-preview .tshirt-svg{width:180px;height:auto;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.order-tshirt-preview .no-design-label{color:#9ca3af;font-size:.9rem;padding:20px}.scan-another-btn{width:100%;margin-top:20px;padding:12px;background:#f3f4f6;color:#374151;border:1px solid #d1d5db;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .15s}.scan-another-btn:hover{background:#e5e7eb}.order-id-btn{background:none;border:none;color:#2563eb;font-weight:600;cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .15s}.order-id-btn:hover{background:#eff6ff;text-decoration:underline}.order-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.order-modal{background:#fff;border-radius:16px;padding:24px;max-width:520px;width:90%;max-height:90vh;overflow-y:auto}
