@font-face{font-family:Slussen;src:url(/fonts/Slussen-Thin-TRIAL.otf) format("opentype");font-weight:100;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Thin-Italic-TRIAL.otf) format("opentype");font-weight:100;font-style:italic}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Extralight-TRIAL.otf) format("opentype");font-weight:200;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Extralight-Italic-TRIAL.otf) format("opentype");font-weight:200;font-style:italic}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Light-TRIAL.otf) format("opentype");font-weight:300;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Light-Italic-TRIAL.otf) format("opentype");font-weight:300;font-style:italic}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Regular-TRIAL.otf) format("opentype");font-weight:400;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Regular-Italic-TRIAL.otf) format("opentype");font-weight:400;font-style:italic}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Medium-TRIAL.otf) format("opentype");font-weight:500;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Medium-Italic-TRIAL.otf) format("opentype");font-weight:500;font-style:italic}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Semibold-TRIAL.otf) format("opentype");font-weight:600;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Semibold-Italic-TRIAL.otf) format("opentype");font-weight:600;font-style:italic}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Bold-TRIAL.otf) format("opentype");font-weight:700;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Bold-Italic-TRIAL.otf) format("opentype");font-weight:700;font-style:italic}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Black-TRIAL.otf) format("opentype");font-weight:900;font-style:normal}@font-face{font-family:Slussen;src:url(/fonts/Slussen-Black-Italic-TRIAL.otf) format("opentype");font-weight:900;font-style:italic}@font-face{font-family:Slussen Extended;src:url(/fonts/Slussen-Extended-Medium-TRIAL.otf) format("opentype");font-weight:500;font-style:normal}@font-face{font-family:Slussen Extended;src:url(/fonts/Slussen-Extended-Regular-TRIAL.otf) format("opentype");font-weight:400;font-style:normal}:root{--fg-base: #18181b;--fg-subtle: #52525b;--fg-muted: #71717a;--fg-disabled: #a1a1aa;--bg-base: #ffffff;--bg-field-component: #ffffff;--border-strong: #d4d4d8;--spacing-4: 4px;--spacing-8: 8px;--radius-12: 12px;--radius-full: 999px}*{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}body{font-family:Slussen,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-base);color:var(--fg-base);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100%}.loading-screen{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:#fff}.loading-spinner{width:40px;height:40px;border:3px solid #e5e5e5;border-top-color:#1a1a2e;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.app{display:flex;flex-direction:column;align-items:center;background-color:#fff;min-height:100vh;max-width:1800px;margin:0 auto}.sticky-header{position:sticky;top:0;z-index:100;background-color:#fff;width:100%;display:flex;flex-direction:column;align-items:center;padding:36px 24px}.header{display:flex;align-items:center;justify-content:space-between;width:100%}.header-left{display:flex;align-items:center;width:200px}.logo{display:flex;align-items:center}.logo-text{font-family:Slussen Extended,Slussen,sans-serif;font-weight:500;font-size:18px;line-height:1.6;color:var(--fg-subtle);white-space:nowrap}.divider{display:flex;align-items:center;align-self:stretch}.divider-line{width:2px;height:100%;background-color:var(--border-strong);border-radius:12px}.design-services-link{display:flex;gap:4px;align-items:center;cursor:pointer}.design-services-text{font-family:Slussen,sans-serif;font-weight:400;font-size:14px;line-height:1.6;color:var(--fg-disabled);white-space:nowrap}.arrow-icon{width:15px;height:15px}.search-wrapper{position:relative;z-index:200;width:423px;height:42px}.search-container{position:absolute;top:0;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:8px;width:423px;height:42px;padding:0 12px;background-color:#fff;border-radius:21px;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;cursor:pointer;transition:width .25s ease,height .25s ease,padding .25s ease,border-radius .25s ease,background-color .25s ease,box-shadow .25s ease}.search-container.has-search{background-color:#18181b0a}.search-container.expanded{width:500px;height:auto;padding:15px;border-radius:30px;background:#fafafa;border:1.25px solid var(--border-strong);box-shadow:0 0 12px #00000026;cursor:default;align-items:flex-start}.search-container.expanded.has-search{background:#fafafa}.search-icon{width:15px;height:15px;flex-shrink:0}.search-input{flex:1;border:none;outline:none;font-family:Slussen,sans-serif;font-weight:400;font-size:13px;line-height:20px;color:var(--fg-base);background:transparent;cursor:pointer}.search-input::placeholder{color:var(--fg-muted)}.keyboard-shortcut{display:flex;align-items:center;justify-content:center;padding:0 4px;height:17px;background-color:var(--bg-field-component);border:.5px solid var(--border-strong);border-radius:var(--radius-full)}.keyboard-shortcut-text{font-family:Slussen,sans-serif;font-weight:500;font-size:11px;line-height:20px;color:var(--fg-subtle);text-align:center;white-space:nowrap}.clear-button{display:flex;align-items:center;justify-content:center;background:none;border:none;padding:0;cursor:pointer;flex-shrink:0;transition:opacity .15s ease}.clear-button:hover{opacity:.7}.search-content{display:flex;flex-direction:column;width:100%;height:100%}.search-container.expanded .search-content{height:auto}.search-input-row{display:flex;align-items:center;gap:8px;width:100%;height:100%}.search-container.expanded .search-input-row{gap:12px;height:auto}.search-icon-wrapper{flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .25s ease}.search-icon-wrapper svg{transition:all .25s ease}.search-container.expanded .search-icon-wrapper svg{width:24px;height:24px}.search-input{flex:1;border:none;outline:none;font-family:Slussen,sans-serif;font-weight:400;font-size:13px;line-height:20px;color:var(--fg-base);background:transparent;cursor:pointer;transition:font-size .25s ease}.search-container.expanded .search-input{font-size:18px;cursor:text}.search-input::placeholder{color:var(--fg-muted);transition:color .25s ease}.search-container.expanded .search-input::placeholder{color:#a1a1aa80}.search-divider{display:none;height:1px;background-color:var(--border-base, #e4e4e7);margin:12px 0}.search-container.expanded .search-divider{display:block}.search-suggestions{display:none;flex-direction:column;gap:0}.search-container.expanded .search-suggestions{display:flex}.search-suggestion{display:flex;align-items:center;gap:12px;padding:8px;cursor:pointer;transition:background-color .15s ease;border-radius:8px;margin:0 -8px}.search-suggestion:hover{background-color:#0000000a}.search-suggestion-text{font-family:Slussen,sans-serif;font-weight:400;font-size:15px;line-height:22px;color:var(--fg-subtle)}.no-results{text-align:center;padding:64px;color:var(--fg-muted);display:flex;flex-direction:column;align-items:center;gap:8px}.no-results-icon{color:var(--fg-muted);opacity:.5;margin-bottom:8px}.no-results-title{font-size:18px;font-weight:500;margin-bottom:4px}.no-results-subtitle{font-size:14px;margin-bottom:16px}.custom-print-empty-btn{display:inline-flex;align-items:center;gap:8px;padding:12px 24px;background:#18181b;color:#fff;border:none;border-radius:10px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s ease}.custom-print-empty-btn:hover{background:#27272a}.custom-print-empty-btn svg{flex-shrink:0}.custom-print-suggestion{margin-top:40px;padding:24px;display:flex;justify-content:center}.custom-print-suggestion-content{display:flex;align-items:center;gap:12px;padding:16px 24px;background:var(--bg-secondary, #fafafa);border:1px dashed var(--border-base, #d4d4d4);border-radius:12px;color:var(--fg-muted);font-family:Slussen,sans-serif;font-size:14px}.custom-print-suggestion-icon{color:var(--fg-muted);opacity:.6}.custom-print-suggestion-btn{padding:8px 16px;background:var(--fg-base, #18181b);color:#fff;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .15s ease}.custom-print-suggestion-btn:hover{opacity:.9;transform:scale(1.02)}.header-right{display:flex;gap:24px;align-items:center;justify-content:flex-end;width:200px}.cart-container{position:relative;cursor:pointer}.cart-icon{width:24px;height:24px}.cart-badge{position:absolute;top:-6px;right:-6px;background:var(--fg-base, #18181b);color:#fff;font-family:Slussen,sans-serif;font-weight:500;font-size:10px;line-height:1;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.user-menu{display:flex;gap:4px;align-items:center;cursor:pointer}.avatar{width:35.226px;height:35.226px;border-radius:var(--radius-full);background-color:var(--bg-base);box-shadow:0 .979px 1.957px #0000001f,0 0 0 1px #00000014;padding:.979px;overflow:hidden}.avatar img{width:100%;height:100%;border-radius:var(--radius-full);object-fit:cover}.dropdown-icon{width:24px;height:24px}.filters{display:flex;gap:12px;align-items:center;padding:36px 64px 16px;width:100%;box-sizing:border-box}.filter-toggles{display:flex;gap:6px;padding:4px;background:var(--bg-subtle, #f4f4f5);border-radius:10px}.filter-toggle{display:flex;align-items:center;gap:6px;height:32px;padding:0 14px;border:none;border-radius:8px;background:transparent;cursor:pointer;transition:all .15s ease;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;color:var(--fg-muted, #71717a)}.filter-toggle:hover{color:var(--fg-base, #18181b)}.filter-toggle.active{background:var(--bg-base, #ffffff);color:var(--fg-base, #18181b);box-shadow:0 1px 2px #0000000f,0 1px 3px #0000001a}.filter-toggle-check{flex-shrink:0;color:currentColor}.filters-divider{width:1px;height:24px;background:var(--border-base, #e4e4e7);margin:0 4px}.create-button{display:flex;align-items:center;gap:6px;height:36px;padding:0 14px;border:1px solid var(--border-base, #e4e4e7);border-radius:10px;background:var(--bg-base, #ffffff);cursor:pointer;transition:all .15s ease;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;color:var(--fg-base, #18181b)}.create-button:hover,.create-button.active{background:var(--bg-subtle, #f4f4f5);border-color:var(--border-base, #d4d4d8)}.create-button-icon{flex-shrink:0;color:currentColor}.create-button-chevron{flex-shrink:0;color:var(--fg-muted, #71717a);margin-left:2px}.sort-button{display:flex;align-items:center;gap:6px;height:36px;padding:0 14px;border:1px solid var(--border-base, #e4e4e7);border-radius:10px;background:var(--bg-base, #ffffff);cursor:pointer;transition:all .15s ease;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;color:var(--fg-base, #18181b)}.sort-button:hover,.sort-button.active{background:var(--bg-subtle, #f4f4f5);border-color:var(--border-base, #d4d4d8)}.sort-button-chevron{flex-shrink:0;color:var(--fg-muted, #71717a);margin-left:2px}.filter-pill{display:flex;align-items:center;justify-content:center;height:36px;padding:0 16px;border-radius:var(--radius-full);cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.filter-pill-text{font-family:Slussen,sans-serif;font-weight:500;font-size:14px;line-height:20px;white-space:nowrap}.filter-pill.active{background-color:var(--bg-base);box-shadow:0 0 0 1px #00000014,0 1px 2px -1px #00000014,0 2px 4px #0000000a}.filter-pill.active .filter-pill-text{color:var(--fg-base)}.filter-pill:not(.active) .filter-pill-text{color:var(--fg-muted)}.filter-pill:not(.active):hover{background-color:#00000005}.masonry-container{width:100%;padding:0 64px 64px}.optimized-image-container{position:relative;width:100%;min-height:150px;overflow:hidden;border-radius:12px;background:#27272a}.image-skeleton{position:absolute;inset:0;background:linear-gradient(90deg,#27272a,#3f3f46,#27272a);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.image-skeleton.hidden{opacity:0;pointer-events:none;transition:opacity .3s ease}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.optimized-image{width:100%;height:auto;display:block;opacity:0;transition:opacity .3s ease}.optimized-image.loaded{opacity:1}.optimized-image-placeholder{pointer-events:none}.media-item .optimized-image-container,.admin-gallery-item .optimized-image-container{width:100%;height:100%;min-height:100%}.media-item .optimized-image-container img,.admin-gallery-item .optimized-image-container img{width:100%;height:100%;object-fit:cover}.media-item{border-radius:12px;overflow:hidden;cursor:pointer;position:relative;background:#f4f4f5;transition:box-shadow .2s,transform .2s}.media-item:hover{box-shadow:0 4px 20px #0000001f;transform:translateY(-2px)}.media-item-skeleton{border-radius:12px;overflow:hidden;position:relative;background:linear-gradient(90deg,#e4e4e7,#f4f4f5,#e4e4e7);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.media-item-skeleton .image-skeleton{display:none}.media-item-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.3) 0%,transparent 40%,transparent 100%);opacity:0;transition:opacity .15s ease;pointer-events:none}.media-item:hover .media-item-overlay{opacity:1}.overlay-buttons{position:absolute;top:8px;right:8px;display:flex;align-items:center;gap:4px;pointer-events:auto;opacity:0;transform:translateY(-4px);transition:opacity .15s,transform .15s}.media-item:hover .overlay-buttons,.overlay-buttons.menu-open{opacity:1;transform:translateY(0)}.overlay-btn{width:32px;height:32px;border-radius:8px;background:#fffffff2;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .12s ease;box-shadow:0 1px 3px #0000001a}.overlay-btn:hover{background:#fff;box-shadow:0 2px 8px #00000026;transform:scale(1.05)}.overlay-btn svg{width:16px;height:16px}.overlay-btn-primary{width:auto;padding:8px 14px;gap:6px;background:var(--fg-base, #18181b);color:#fff;font-family:Slussen,sans-serif;font-size:13px;font-weight:500}.overlay-btn-primary:hover{background:#27272a;transform:scale(1.02)}.overlay-btn-primary svg{width:14px;height:14px}.media-item>img,.media-item>video{width:100%;height:auto;display:block;object-fit:cover}.overlay-btn img{width:14px;height:14px;opacity:.8}.overlay-menu-wrapper{position:relative}.overlay-menu-btn{width:32px;height:32px}.overlay-menu-backdrop{position:fixed;inset:0;z-index:9998}.overlay-menu{position:fixed;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;width:160px;padding:4px;z-index:9999}.overlay-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:none;border:none;border-radius:6px;font-family:Slussen,-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;color:#18181b;cursor:pointer;text-align:left;transition:background-color .15s}.overlay-menu-item:hover{background-color:#f4f4f5}.overlay-menu-item svg{flex-shrink:0;color:#71717a}.overlay-menu-divider{height:1px;background:#e4e4e7;margin:4px 0}.overlay-menu-label{padding:6px 12px 4px;font-family:Slussen,-apple-system,BlinkMacSystemFont,sans-serif;font-size:11px;font-weight:500;color:#71717a;text-transform:uppercase;letter-spacing:.05em}.overlay-menu-checkbox{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;font-family:Slussen,-apple-system,BlinkMacSystemFont,sans-serif;font-size:13px;color:#18181b;cursor:pointer;transition:background-color .15s}.overlay-menu-checkbox:hover{background-color:#f4f4f5}.overlay-menu-checkbox input[type=checkbox]{width:14px;height:14px;accent-color:#18181b}.media-item-meta{position:absolute;bottom:0;left:0;right:0;padding:6px 10px;background:linear-gradient(0deg,rgba(0,0,0,.6) 0%,transparent 100%);display:flex;align-items:center;gap:8px;opacity:0;transform:translateY(4px);transition:opacity .15s ease,transform .15s ease;pointer-events:none}.media-item:hover .media-item-meta{opacity:1;transform:translateY(0)}.media-item-meta span{font-family:Slussen,-apple-system,BlinkMacSystemFont,sans-serif;font-size:10px;color:#ffffffd9;letter-spacing:.02em}.meta-dim{font-variant-numeric:tabular-nums}.meta-date{opacity:.7}@media(max-width:1200px){.sticky-header{padding:24px 32px}.masonry-container{padding:0 32px 32px}.header-left,.header-right{width:auto}.search-wrapper,.search-container{width:300px}.search-container.expanded{width:450px}}@media(max-width:768px){.sticky-header{padding:16px}.masonry-container{padding:0 16px 16px}.header{flex-direction:column;gap:16px}.header-left,.header-right{width:100%;justify-content:center}.search-wrapper,.search-container{width:100%;max-width:400px}.search-container.expanded{width:calc(100vw - 32px);max-width:450px}.search-container.expanded .search-input{font-size:16px}.search-suggestion-text{font-size:14px}.filters{padding:24px 0}}.create-container{position:relative}.create-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #00000014;padding:6px;min-width:200px;z-index:100}.dropdown-item{padding:10px 14px;font-family:Slussen,sans-serif;font-size:14px;color:var(--fg-base);cursor:pointer;border-radius:8px;transition:background-color .15s ease;white-space:nowrap}.dropdown-item:hover{background-color:#0000000a}.dropdown-divider{height:1px;background-color:var(--border-base, #e4e4e7);margin:6px 0}.dropdown-item.selected{background-color:#0000000a;font-weight:500}.dropdown-item.selected:before{content:"✓";margin-right:8px;font-size:12px}.dropdown-section-label{padding:6px 14px 4px;font-family:Slussen,sans-serif;font-size:11px;font-weight:600;color:#a1a1aa;text-transform:uppercase;letter-spacing:.5px}.sort-container{position:relative}.sort-dropdown{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;border-radius:12px;box-shadow:0 4px 16px #0000001f,0 0 0 1px #00000014;padding:6px;min-width:180px;z-index:100}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.modal{background:#fff;border-radius:12px;padding:32px;max-width:480px;width:90%;max-height:90vh;position:relative;box-shadow:0 0 0 1px #00000014,0 8px 16px #00000014,0 16px 32px #00000014;overflow:hidden;display:flex;flex-direction:column}.modal:has(.order-modal){padding:0;max-width:620px}.modal:has(.order-modal)>.modal-close{display:none}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;cursor:pointer;color:var(--fg-muted);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .15s ease}.modal-close:hover{background-color:#0000000a;color:var(--fg-base)}.modal-title{font-family:Slussen,sans-serif;font-size:20px;font-weight:600;color:var(--fg-base);margin:0 0 8px}.modal-subtitle{font-family:Slussen,sans-serif;font-size:14px;color:var(--fg-muted);margin:0 0 24px}.upload-zone{border:2px dashed var(--border-strong, #d4d4d8);border-radius:12px;padding:48px 24px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;cursor:pointer;transition:all .2s ease;background:var(--bg-field-component, #fafafa);margin-bottom:24px}.upload-zone:hover{border-color:var(--fg-muted);background:#00000005}.upload-zone.has-image{padding:12px;border-style:solid}.upload-zone span{font-family:Slussen,sans-serif;font-size:14px;color:var(--fg-muted)}.upload-preview{max-width:100%;max-height:200px;border-radius:8px;object-fit:contain}.modal-submit{width:100%;padding:12px 24px;background:var(--fg-base, #18181b);color:#fff;border:none;border-radius:10px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s ease}.modal-submit:hover:not(:disabled){opacity:.9}.modal-submit:disabled{opacity:.5;cursor:not-allowed}.modal-textarea{width:100%;padding:12px 16px;border:1px solid var(--border-strong, #d4d4d8);border-radius:10px;font-family:Slussen,sans-serif;font-size:14px;resize:none;margin-bottom:24px;background:var(--bg-field-component, #fafafa)}.modal-textarea:focus{outline:none;border-color:var(--fg-muted)}.modal-textarea::placeholder{color:var(--fg-muted)}.order-modal{display:flex;flex-direction:column;width:100%;height:100%;max-height:90vh}.order-modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:#fff}.order-modal-title{font-family:Slussen,sans-serif;font-weight:500;font-size:18px;line-height:28px;color:var(--fg-base, #18181b);margin:0}.order-modal-header-actions{display:flex;align-items:center;gap:8px}.kbd{display:flex;align-items:center;justify-content:center;padding:0 4px;height:16px;background:var(--bg-field-component, #fafafa);border:.5px solid var(--border-strong, #d4d4d8);border-radius:4px;font-family:Slussen,sans-serif;font-weight:500;font-size:11px;line-height:20px;color:var(--fg-subtle, #52525b)}.icon-btn{display:flex;align-items:center;justify-content:center;padding:6.5px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--fg-subtle, #52525b)}.icon-btn:hover{background:#0000000a}.order-modal-divider{height:1px;background:var(--border-base, #e4e4e7);width:100%}.order-modal-content{display:flex;flex-direction:column;gap:16px;padding:16px 24px 24px;background:#fff;overflow-y:auto;flex:1;min-height:0}.order-modal-preview{width:100%;border-radius:8px;overflow:hidden;border:.5px solid rgba(24,24,27,.1)}.order-modal-preview img,.order-modal-preview video{width:100%;max-height:250px;display:block;object-fit:contain}.crop-preview{position:relative;width:100%;border-radius:8px;overflow:hidden;background:#18181b;-webkit-user-select:none;user-select:none;flex-shrink:0}.crop-preview.can-drag{cursor:grab}.crop-preview.dragging{cursor:grabbing}.crop-image{display:block;width:100%;height:auto}.crop-mask{position:absolute;background:#0000008c;pointer-events:none}.crop-box{position:absolute;border:2px solid white;box-shadow:0 0 0 1px #0003,inset 0 0 0 1px #ffffff1a;pointer-events:none}.crop-size-label{position:absolute;top:10px;left:10px;background:#000000b3;color:#fff;font-family:Slussen,sans-serif;font-size:12px;font-weight:600;padding:5px 10px;border-radius:4px;pointer-events:none}.crop-hint{position:absolute;bottom:10px;left:50%;transform:translate(-50%);background:#000000b3;color:#fff;font-family:Slussen,sans-serif;font-size:12px;font-weight:500;padding:5px 12px;border-radius:4px;opacity:0;transition:opacity .15s;pointer-events:none;white-space:nowrap}.crop-preview:hover .crop-hint{opacity:1}.crop-preview.dragging .crop-hint{opacity:0}.border-preview{width:100%;max-width:320px;padding:20px 16px;border:.5px solid rgba(24,24,27,.1);background:#fff;display:flex;flex-direction:column;align-items:center;gap:8px;border-radius:4px}.border-preview-wrapper:not(.has-template) .border-preview{position:relative}.border-preview-header{font-family:Times New Roman,serif;font-size:13px;line-height:20px;color:#000}.border-preview-upload-area{display:flex;align-items:center;justify-content:center;width:100%;flex:1}.border-preview-image{position:relative;border:.35px solid rgba(24,24,27,.1);max-width:70%;overflow:hidden}.border-preview-image img{width:100%;max-height:180px;display:block;object-fit:contain}.border-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:25px 33px;background:var(--bg-field-component, #fafafa);border:1px dashed var(--border-strong, #d4d4d8);border-radius:8px;cursor:pointer;transition:all .2s ease}.border-upload-zone:hover{border-color:var(--fg-muted, #71717a);background:#00000005}.border-upload-header{display:flex;align-items:center;gap:8px}.border-upload-icon{width:15px;height:15px}.border-upload-title{font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:1.6;color:var(--fg-subtle, #52525b)}.border-upload-subtitle{font-family:Slussen,sans-serif;font-weight:400;font-size:13px;line-height:1.6;color:var(--fg-muted, #71717a);text-align:center}.toggle-optional{font-family:Slussen,sans-serif;font-weight:400;font-size:13px;line-height:20px;color:var(--fg-muted, #71717a)}.services-textarea{width:100%;height:70px;padding:6px 8px;background:var(--bg-field-component, #fafafa);border:none;border-radius:6px;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;font-family:Slussen,sans-serif;font-size:13px;line-height:20px;color:var(--fg-base, #18181b);resize:none}.services-textarea::placeholder{color:#18181b4d}.services-textarea:focus{outline:none}.upload-section-header{margin-bottom:16px}.upload-section-title{font-family:Slussen,sans-serif;font-weight:500;font-size:18px;line-height:28px;color:var(--fg-base, #18181b);margin:0}.upload-section-subtitle{font-family:Slussen,sans-serif;font-weight:400;font-size:13px;line-height:1.6;color:var(--fg-subtle, #52525b);margin:0}.services-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;padding:25px 33px;height:89px;background:var(--bg-field-component, #fafafa);border:1px dashed var(--border-strong, #d4d4d8);border-radius:8px;cursor:pointer;transition:all .2s ease}.services-upload-zone:hover{border-color:var(--fg-muted, #71717a);background:#00000005}.services-upload-preview{max-width:100%;max-height:60px;object-fit:contain;border-radius:4px}.success-content{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;flex:1}.success-icon{margin-bottom:24px}.success-title{font-family:Slussen,sans-serif;font-weight:500;font-size:18px;line-height:28px;color:var(--fg-base, #18181b);margin:0 0 8px}.success-message{font-family:Slussen,sans-serif;font-weight:400;font-size:14px;line-height:1.5;color:var(--fg-muted, #71717a);margin:0;max-width:320px}.border-preview-footer{position:relative;width:100%;padding:0 8px;display:flex;justify-content:center}.border-preview-name{font-family:Times New Roman,serif;font-size:13px;line-height:20px;color:#0000004d}.border-preview-signature{position:absolute;right:8px;bottom:0;display:flex;flex-direction:column;align-items:flex-end;gap:1px}.signature-line{font-family:Times New Roman,serif;font-style:italic;font-size:9px;color:#00000026;border-bottom:1px solid rgba(0,0,0,.1);padding-bottom:1px;min-width:50px;text-align:center}.signature-details{display:flex;flex-direction:column;align-items:flex-end;gap:0}.signature-name{font-family:Times New Roman,serif;font-size:8px;line-height:10px;color:#0000004d}.signature-title{font-family:Times New Roman,serif;font-size:7px;line-height:9px;color:#00000040}.color-picker{display:flex;gap:2px}.color-swatch{padding:3px;background:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease}.color-swatch.active{border:1.5px solid var(--fg-base, #18181b);border-radius:7px}.swatch-color{width:16px;height:16px;border-radius:4px;border:.5px solid rgba(24,24,27,.12)}.form-row{display:flex;gap:16px}.form-field-small{width:160px;flex-shrink:0}.form-field-grow{flex:1;min-width:0}.text-input{width:100%;padding:6px 8px;background:var(--bg-field-component, #fafafa);border:none;border-radius:6px;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;font-family:Slussen,sans-serif;font-size:13px;line-height:20px;color:var(--fg-base, #18181b)}.text-input::placeholder{color:#18181b66}.text-input:focus{outline:none}.segmented-control{display:flex;align-items:center;gap:1px;padding:1px;background:var(--bg-disabled, #f4f4f5);border-radius:7px;width:fit-content}.segment{padding:4px 8px;background:transparent;border:none;border-radius:6px;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:20px;color:var(--fg-muted, #71717a);cursor:pointer;transition:all .15s ease}.segment.active{background:#fff;color:var(--fg-base, #18181b);box-shadow:0 0 0 1px #00000014,0 1px 2px -1px #00000014,0 2px 4px #0000000a}.form-field{display:flex;flex-direction:column;gap:8px}.form-label{font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:20px;color:var(--fg-base, #18181b)}.select-wrapper{position:relative;display:flex;align-items:center}.select-wrapper select{width:100%;padding:6px 32px 6px 8px;background:var(--bg-field-component, #fafafa);border:none;border-radius:6px;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;font-family:Slussen,sans-serif;font-size:13px;line-height:20px;color:var(--fg-base, #18181b);appearance:none;cursor:pointer}.select-wrapper svg{position:absolute;right:8px;pointer-events:none}.quantity-input{display:flex;align-items:center;width:fit-content;background:var(--bg-field-component, #fafafa);border-radius:6px;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;overflow:hidden}.quantity-value{flex:1;width:50px;padding:6px 8px;font-family:Slussen,sans-serif;font-size:13px;line-height:20px;color:var(--fg-muted, #71717a);background:transparent;border:none;outline:none;text-align:center;-moz-appearance:textfield}.quantity-value::-webkit-outer-spin-button,.quantity-value::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.quantity-divider{width:1px;height:100%;background:var(--border-base, #e4e4e7);align-self:stretch}.quantity-btn{display:flex;align-items:center;justify-content:center;padding:8.5px;background:transparent;border:none;cursor:pointer}.quantity-btn:hover{background:#0000000a}.order-price{font-family:Slussen,sans-serif;font-weight:500;font-size:18px;line-height:28px;color:var(--fg-base, #18181b);text-align:right;margin-top:16px}.order-modal-footer{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;background:#fff}.btn-secondary{padding:0 8px;height:28px;background:#fff;border:none;border-radius:8px;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:20px;color:var(--fg-base, #18181b);cursor:pointer;min-width:80px}.btn-secondary:hover{background:#fafafa}.btn-primary{padding:0 8px;height:28px;background:var(--fg-base, #27272a);border:none;border-radius:8px;box-shadow:0 1px 2px #0006,0 0 0 1px #18181b;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:20px;color:#fff;cursor:pointer;min-width:80px}.btn-primary:hover{opacity:.9}.profile-container{position:relative}.profile-dropdown{position:absolute;top:calc(100% + 8px);right:0;background:var(--bg-component, #fafafa);border-radius:12px;box-shadow:0 0 0 1px #00000014,0 4px 8px #00000014,0 8px 16px #00000014;padding:4px;min-width:280px;z-index:200}.profile-user-info{display:flex;align-items:center;gap:12px;padding:4px 8px;background:var(--bg-component, #fafafa);border-radius:4px}.profile-avatar{width:28px;height:28px;border-radius:50%;overflow:hidden;background:#fff;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;padding:1px;flex-shrink:0}.profile-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.profile-user-details{display:flex;flex-direction:column;flex:1;min-width:0}.profile-name{font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:20px;color:var(--fg-base, #18181b)}.profile-office{font-family:Slussen,sans-serif;font-weight:400;font-size:12px;line-height:20px;color:var(--fg-subtle, #52525b);white-space:nowrap}.profile-badge{padding:.5px 5.5px;background:var(--tag-neutral-bg, #f4f4f5);border:.5px solid var(--tag-neutral-border, #d4d4d8);border-radius:6px;font-family:Slussen,sans-serif;font-weight:500;font-size:11px;line-height:20px;color:var(--tag-neutral-text, #52525b);flex-shrink:0}.profile-divider{height:8px;position:relative}.profile-divider:before{content:"";position:absolute;left:-4px;right:-4px;top:50%;height:1px;background:var(--border-menu-top, #e4e4e7)}.profile-divider:after{content:"";position:absolute;left:-4px;right:-4px;top:calc(50% + 1px);height:1px;background:#fff}.profile-menu-item{display:flex;align-items:center;gap:8px;padding:4px 8px;border-radius:4px;cursor:pointer;transition:background-color .15s ease}.profile-menu-item:hover{background:#0000000a}.profile-menu-icon{width:15px;height:15px;flex-shrink:0}.profile-menu-item span{font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:20px;color:var(--fg-subtle, #52525b)}.profile-footer{padding:6px 8px;font-family:Slussen,sans-serif;font-weight:400;font-size:12px;line-height:20px;color:var(--fg-muted, #71717a);cursor:pointer;border-radius:4px;transition:background-color .15s ease}.profile-footer:hover{background:#0000000a}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.toggle-checkbox{position:absolute;opacity:0;width:0;height:0}.toggle-switch{position:relative;width:36px;height:20px;background:var(--bg-disabled, #e4e4e7);border-radius:10px;transition:background-color .2s ease;flex-shrink:0}.toggle-switch:after{content:"";position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 2px #0000001f,0 0 0 1px #00000014;transition:transform .2s ease}.toggle-checkbox:checked+.toggle-switch{background:var(--fg-base, #18181b)}.toggle-checkbox:checked+.toggle-switch:after{transform:translate(16px)}.toggle-text{font-family:Slussen,sans-serif;font-weight:500;font-size:13px;line-height:20px;color:var(--fg-base, #18181b)}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f8fafc,#e2e8f0);position:relative;overflow:hidden}.login-container{background:#fff;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;padding:48px;width:100%;max-width:420px;z-index:1}.login-header{text-align:center;margin-bottom:32px}.login-logo{margin-bottom:16px}.login-logo img{width:100px;height:100px;object-fit:contain}.login-title{font-family:Slussen Extended,Slussen,sans-serif;font-weight:600;font-size:28px;color:#1e3a5f;margin:0 0 8px}.login-subtitle{font-family:Slussen,sans-serif;font-size:14px;color:#64748b;margin:0}.login-form{display:flex;flex-direction:column;gap:20px}.login-field{display:flex;flex-direction:column;gap:6px}.login-field label{font-family:Slussen,sans-serif;font-weight:500;font-size:13px;color:#374151}.login-field input{padding:12px 14px;border:1px solid #e5e7eb;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;transition:border-color .15s ease,box-shadow .15s ease}.login-field input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.login-field input::placeholder{color:#9ca3af}.login-field-checkbox{flex-direction:row;align-items:center}.login-field-checkbox .checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-weight:400;color:#52525b}.login-field-checkbox input[type=checkbox]{appearance:none;-webkit-appearance:none;width:18px;height:18px;border:1.5px solid #d4d4d8;border-radius:4px;background:#fff;cursor:pointer;transition:all .15s ease;flex-shrink:0;padding:0}.login-field-checkbox input[type=checkbox]:checked{background:#1e3a5f;border-color:#1e3a5f;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 14 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 7L6 10L11 4' stroke='white' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-size:12px;background-position:center;background-repeat:no-repeat}.login-field-checkbox input[type=checkbox]:focus{outline:none;box-shadow:0 0 0 3px #1e3a5f1a}.login-error{display:flex;align-items:center;gap:8px;padding:12px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#dc2626;font-family:Slussen,sans-serif;font-size:13px}.login-button{padding:12px 24px;background:#1e3a5f;color:#fff;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-weight:500;font-size:14px;cursor:pointer;transition:background-color .15s ease;margin-top:8px}.login-button:hover{background:#1e40af}.login-button:disabled{background:#9ca3af;cursor:not-allowed}.login-demo-buttons{display:flex;gap:12px;margin-bottom:24px}.login-demo-btn{flex:1;display:flex;align-items:center;gap:12px;padding:16px;border:2px solid #e5e7eb;border-radius:12px;background:#fff;cursor:pointer;transition:all .15s ease;text-align:left}.login-demo-btn:hover{border-color:#3b82f6;background:#f0f9ff}.login-demo-btn:disabled{opacity:.6;cursor:not-allowed}.login-demo-btn svg{width:32px;height:32px;flex-shrink:0}.login-demo-staff svg{color:#3b82f6}.login-demo-admin svg{color:#8b5cf6}.login-demo-staff:hover{border-color:#3b82f6;background:#eff6ff}.login-demo-admin:hover{border-color:#8b5cf6;background:#f5f3ff}.login-demo-btn-text{display:flex;flex-direction:column;gap:2px}.login-demo-btn-title{font-family:Slussen,sans-serif;font-weight:600;font-size:14px;color:#111827}.login-demo-btn-desc{font-family:Slussen,sans-serif;font-size:12px;color:#6b7280}.login-divider{display:flex;align-items:center;margin-bottom:20px}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#e5e7eb}.login-divider span{padding:0 16px;font-family:Slussen,sans-serif;font-size:12px;color:#9ca3af}.login-demo-notice{margin-top:24px;padding:12px;background:#f0f9ff;border-radius:8px;text-align:center}.login-demo-notice p{margin:0;font-family:Slussen,sans-serif;font-size:12px;color:#0369a1}.login-footer{margin-top:32px;text-align:center;border-top:1px solid #e5e7eb;padding-top:24px}.login-footer p{margin:0;font-family:Slussen,sans-serif;font-size:12px;color:#9ca3af;line-height:1.6}.login-bg{position:absolute;inset:0;overflow:hidden}.login-bg-pattern{position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(30,58,95,.05) 0%,transparent 70%)}.order-management{width:100%;max-width:1400px;padding:32px 48px;margin:0 auto}.om-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.om-header-left{display:flex;flex-direction:column;gap:4px}.om-title{font-family:Slussen Extended,Slussen,sans-serif;font-weight:600;font-size:28px;color:#18181b;margin:0}.om-subtitle{font-family:Slussen,sans-serif;font-size:14px;color:#71717a;margin:0}.om-create-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:#18181b;color:#fff;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-weight:500;font-size:14px;cursor:pointer;transition:background-color .15s ease}.om-create-btn:hover{background:#3f3f46}.om-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.om-stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px;cursor:pointer;transition:border-color .15s ease,box-shadow .15s ease}.om-stat-card:hover{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.om-stat-value{display:block;font-family:Slussen,sans-serif;font-weight:600;font-size:32px;color:#18181b}.om-stat-label{display:block;font-family:Slussen,sans-serif;font-size:13px;color:#71717a;margin-top:4px}.om-filters{display:flex;gap:12px;margin-bottom:20px}.om-search{flex:1;max-width:400px;display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:8px}.om-search input{flex:1;border:none;outline:none;font-family:Slussen,sans-serif;font-size:14px;color:#18181b}.om-search input::placeholder{color:#9ca3af}.om-search-clear{background:none;border:none;padding:0;cursor:pointer;opacity:.6}.om-search-clear:hover{opacity:1}.om-filter-select{padding:10px 14px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;color:#18181b;cursor:pointer}.om-my-orders-btn{padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#374151;cursor:pointer;transition:all .15s ease}.om-my-orders-btn:hover{background:#f3f4f6}.om-my-orders-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.om-assigned-to{display:block;font-size:11px;color:#3b82f6;margin-top:2px}.om-spinner{animation:om-spin 1s linear infinite}@keyframes om-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.om-action-btn:disabled{opacity:.6;cursor:not-allowed}.om-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.om-table{width:100%;border-collapse:separate;border-spacing:0}.om-table th{padding:14px 16px;text-align:left;font-family:Slussen,sans-serif;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #e5e7eb}.om-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.om-table th.sortable:hover{color:#3b82f6}.sort-icon{margin-left:4px;vertical-align:middle}.om-table td{padding:14px 16px;font-family:Slussen,sans-serif;font-size:14px;color:#374151;vertical-align:middle}.om-row{cursor:pointer;transition:background-color .1s ease}.om-row:hover{background:#f9fafb}.om-order-number{font-weight:500;color:#18181b;display:flex;align-items:center;gap:8px}.om-priority-urgent{display:inline-block;padding:2px 6px;background:#fee2e2;color:#dc2626;font-size:10px;font-weight:600;border-radius:4px;text-transform:uppercase}.om-priority-rush{display:inline-block;padding:2px 6px;background:#fef3c7;color:#d97706;font-size:10px;font-weight:600;border-radius:4px;text-transform:uppercase}.om-customer{display:flex;flex-direction:column;gap:2px}.om-customer-name{font-weight:500;color:#18181b}.om-customer-office{font-size:12px;color:#6b7280}.om-items{display:flex;flex-direction:column;gap:4px}.om-items-thumbnails{display:flex;gap:-8px}.om-item-thumb{width:32px;height:32px;object-fit:cover;border-radius:4px;border:2px solid white;margin-left:-8px}.om-item-thumb:first-child{margin-left:0}.om-items-more{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f3f4f6;border-radius:4px;font-size:11px;color:#6b7280;margin-left:-8px;border:2px solid white}.om-items-count{font-size:12px;color:#6b7280}.om-date{display:flex;flex-direction:column;gap:2px}.om-time{font-size:12px;color:#9ca3af}.om-status-badge{display:inline-block;padding:4px 10px;border-radius:9999px;font-size:12px;font-weight:500}.om-total{font-weight:600;color:#18181b}.om-actions{display:flex;gap:4px}.om-action-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:#f3f4f6;border:none;border-radius:6px;cursor:pointer;color:#6b7280;transition:background-color .15s ease,color .15s ease}.om-action-btn:hover{background:#e5e7eb;color:#374151}.om-action-complete{background:#d1fae5;color:#065f46}.om-action-complete:hover{background:#a7f3d0}.om-empty{padding:48px;text-align:center}.om-empty p{font-family:Slussen,sans-serif;font-size:16px;color:#6b7280;margin:0}.om-empty-hint{font-size:14px!important;color:#9ca3af!important;margin-top:8px!important}.order-detail-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.order-detail{background:#fff;border-radius:16px;width:100%;max-width:900px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.od-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e5e7eb}.od-header-left{display:flex;align-items:center;gap:12px}.od-title{font-family:Slussen,sans-serif;font-weight:600;font-size:20px;color:#18181b;margin:0}.od-status-wrapper{position:relative}.od-status-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:9999px;border:none;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;cursor:pointer}.od-status-dropdown{position:absolute;top:100%;left:0;margin-top:8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 4px 6px -1px #0000001a;padding:4px;min-width:160px;z-index:10}.od-status-option{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;background:none;border:none;border-radius:4px;font-family:Slussen,sans-serif;font-size:13px;color:#374151;cursor:pointer;text-align:left}.od-status-option:hover{background:#f3f4f6}.od-status-option.active{background:#f3f4f6;font-weight:500}.od-status-dot{width:8px;height:8px;border-radius:50%}.od-priority-urgent,.od-priority-rush{padding:4px 8px;font-size:11px;font-weight:600;border-radius:4px;text-transform:uppercase}.od-priority-urgent{background:#fee2e2;color:#dc2626}.od-priority-rush{background:#fef3c7;color:#d97706}.od-header-right{display:flex;align-items:center;gap:8px}.od-btn-secondary{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;color:#374151;cursor:pointer;transition:background-color .15s ease}.od-btn-secondary:hover{background:#f9fafb}.od-close-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;border-radius:8px;cursor:pointer;color:#6b7280}.od-close-btn:hover{background:#f3f4f6}.od-content{flex:1;overflow-y:auto;padding:24px}.od-info-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:24px}.od-info-card{background:#f9fafb;border-radius:12px;padding:16px}.od-info-card h3{font-family:Slussen,sans-serif;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin:0 0 8px}.od-info-primary{font-family:Slussen,sans-serif;font-weight:500;font-size:14px;color:#18181b;margin:0}.od-info-secondary{font-family:Slussen,sans-serif;font-size:13px;color:#6b7280;margin:4px 0 0}.od-timeline-item{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #e5e7eb}.od-timeline-item:last-child{border-bottom:none}.od-timeline-label{font-family:Slussen,sans-serif;font-size:12px;color:#6b7280}.od-timeline-value{font-family:Slussen,sans-serif;font-size:12px;color:#18181b}.od-timeline-highlight{font-weight:600;color:#3b82f6}.od-select{width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;font-family:Slussen,sans-serif;font-size:13px;color:#18181b;background:#fff}.od-notes-section{margin-bottom:24px}.od-notes-section h3{font-family:Slussen,sans-serif;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;margin:0 0 8px}.od-notes{font-family:Slussen,sans-serif;font-size:14px;color:#374151;margin:0}.od-notes-input{width:100%;min-height:80px;padding:12px;border:1px solid #e5e7eb;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;resize:vertical}.od-items-section{margin-bottom:24px}.od-items-section h3{font-family:Slussen,sans-serif;font-weight:500;font-size:14px;color:#18181b;margin:0 0 12px}.od-items-list{display:flex;flex-direction:column;gap:12px}.od-item{display:flex;align-items:center;gap:16px;padding:12px;background:#f9fafb;border-radius:10px}.od-item-image-wrapper{position:relative;width:64px;height:64px;flex-shrink:0}.od-item-image{width:64px;height:64px;object-fit:cover;border-radius:6px}.od-item-crop-badge{position:absolute;bottom:4px;left:4px;background:#000000b3;color:#fff;font-size:9px;font-weight:500;padding:2px 5px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.od-item-info{flex:1}.od-item-name{font-family:Slussen,sans-serif;font-weight:500;font-size:14px;color:#18181b;margin:0}.od-item-specs{font-family:Slussen,sans-serif;font-size:12px;color:#6b7280;margin:4px 0 0}.od-item-customization{font-family:Slussen,sans-serif;font-size:11px;color:#9ca3af;margin:4px 0 0}.od-item-qty{display:flex;flex-direction:column;align-items:center;gap:2px}.od-item-qty-label{font-size:10px;color:#9ca3af;text-transform:uppercase}.od-item-qty-value{font-family:Slussen,sans-serif;font-weight:600;font-size:16px;color:#18181b}.od-item-price{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.od-item-unit{font-size:11px;color:#9ca3af}.od-item-total{font-family:Slussen,sans-serif;font-weight:600;font-size:14px;color:#18181b}.od-total-section{border-top:1px solid #e5e7eb;padding-top:16px}.od-total-row{display:flex;justify-content:space-between;padding:8px 0;font-family:Slussen,sans-serif;font-size:14px;color:#6b7280}.od-total-grand{font-weight:600;font-size:18px;color:#18181b;border-top:1px solid #e5e7eb;padding-top:12px;margin-top:8px}.od-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e5e7eb;background:#f9fafb}.od-btn-primary{padding:10px 20px;background:#18181b;color:#fff;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-weight:500;font-size:14px;cursor:pointer;transition:background-color .15s ease}.od-btn-primary:hover{background:#3f3f46}.od-btn-complete{background:#059669}.od-btn-complete:hover{background:#047857}.od-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;border-radius:8px;cursor:pointer;color:#6b7280;transition:background-color .15s ease}.od-close:hover{background:#f3f4f6}.od-section{margin-bottom:24px}.od-section:last-child{margin-bottom:0}.od-section-title{font-family:Slussen,sans-serif;font-weight:600;font-size:14px;color:#18181b;margin:0 0 12px;text-transform:uppercase;letter-spacing:.05em}.od-info-item{display:flex;flex-direction:column;gap:4px}.od-info-label{font-family:Slussen,sans-serif;font-size:12px;color:#6b7280}.od-info-value{font-family:Slussen,sans-serif;font-size:14px;color:#18181b;font-weight:500}.od-description{font-family:Slussen,sans-serif;font-size:14px;color:#374151;line-height:1.6;margin:0;white-space:pre-wrap;background:#f9fafb;padding:16px;border-radius:8px}.od-attachments{display:flex;gap:12px;flex-wrap:wrap}.od-attachment-img{max-width:200px;max-height:150px;object-fit:cover;border-radius:8px;border:1px solid #e5e7eb}.od-actions{display:flex;gap:8px;flex-wrap:wrap}.analytics{width:100%;max-width:1400px;padding:32px 48px;margin:0 auto}.analytics-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;flex-wrap:wrap;gap:16px}.analytics-header-left{display:flex;flex-direction:column;gap:4px}.analytics-title{font-family:Slussen Extended,Slussen,sans-serif;font-weight:600;font-size:28px;color:#18181b;margin:0}.analytics-subtitle{font-family:Slussen,sans-serif;font-size:14px;color:#71717a;margin:0}.analytics-header-right{display:flex;align-items:center;gap:12px}.analytics-date-picker{display:flex;background:#f3f4f6;border-radius:8px;padding:4px}.date-btn{padding:8px 16px;background:transparent;border:none;border-radius:6px;font-family:Slussen,sans-serif;font-size:13px;color:#6b7280;cursor:pointer;transition:all .15s ease}.date-btn:hover{color:#374151}.date-btn.active{background:#fff;color:#18181b;box-shadow:0 1px 2px #0000000d}.analytics-btn{display:flex;align-items:center;gap:6px;padding:10px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;color:#374151;cursor:pointer;transition:background-color .15s ease}.analytics-btn:hover{background:#f9fafb}.analytics-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}.analytics-metrics-secondary{grid-template-columns:repeat(5,1fr);margin-bottom:24px}.analytics-loading{display:flex;align-items:center;justify-content:center;height:300px;font-family:Slussen,sans-serif;font-size:16px;color:#6b7280}.metric-card-small{padding:16px}.metric-card-small .metric-content{text-align:center;width:100%}.metric-value-pending{color:#92400e}.metric-value-production{color:#1e40af}.metric-value-ready{color:#065f46}.metric-value-completed{color:#374151}.metric-value-time{color:#7c3aed}.metric-card{display:flex;align-items:center;gap:16px;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.metric-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:12px}.metric-icon-orders{background:#dbeafe;color:#2563eb}.metric-icon-revenue{background:#d1fae5;color:#059669}.metric-icon-avg{background:#fef3c7;color:#d97706}.metric-icon-assets{background:#ede9fe;color:#7c3aed}.metric-content{display:flex;flex-direction:column}.metric-value{font-family:Slussen,sans-serif;font-weight:600;font-size:24px;color:#18181b}.metric-label{font-family:Slussen,sans-serif;font-size:13px;color:#6b7280}.analytics-charts{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}.chart-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.chart-card-large{grid-column:span 1}.chart-title{font-family:Slussen,sans-serif;font-weight:500;font-size:16px;color:#18181b;margin:0 0 16px}.chart-container{width:100%}.pie-legend{display:flex;flex-direction:column;gap:8px;margin-top:16px}.pie-legend-item{display:flex;align-items:center;gap:8px;font-family:Slussen,sans-serif;font-size:12px}.pie-legend-dot{width:10px;height:10px;border-radius:50%}.pie-legend-label{flex:1;color:#6b7280}.pie-legend-value{color:#18181b;font-weight:500}.analytics-table-card{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.analytics-table{width:100%;border-collapse:collapse}.analytics-table th{padding:12px 16px;text-align:left;font-family:Slussen,sans-serif;font-weight:500;font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;border-bottom:1px solid #e5e7eb}.analytics-table td{padding:12px 16px;font-family:Slussen,sans-serif;font-size:14px;color:#374151;border-bottom:1px solid #f3f4f6}.analytics-table tr:last-child td{border-bottom:none}.rank-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;background:#f3f4f6;border-radius:50%;font-size:12px;font-weight:500;color:#6b7280;margin-right:12px}.invoice-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1001;padding:24px}.invoice-modal{background:#fff;border-radius:16px;width:100%;max-width:800px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.invoice-actions{display:flex;justify-content:flex-end;gap:8px;padding:16px 24px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.invoice-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;font-family:Slussen,sans-serif;font-weight:500;font-size:13px;color:#374151;cursor:pointer;transition:background-color .15s ease}.invoice-btn:hover{background:#f3f4f6}.invoice-close{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:none;border:none;border-radius:8px;cursor:pointer;color:#6b7280;margin-left:8px}.invoice-close:hover{background:#e5e7eb}.invoice-content{flex:1;overflow-y:auto;padding:32px 40px}.invoice-header{text-align:center;margin-bottom:32px}.invoice-header h1{font-family:Slussen Extended,Slussen,sans-serif;font-weight:600;font-size:32px;color:#18181b;margin:0 0 8px;letter-spacing:.1em}.invoice-company{font-family:Slussen,sans-serif;font-size:14px;color:#6b7280}.invoice-company-name{font-weight:500;color:#374151}.invoice-info-row{display:flex;justify-content:space-between;margin-bottom:32px;padding-bottom:24px;border-bottom:1px solid #e5e7eb}.invoice-info-left,.invoice-info-right{font-family:Slussen,sans-serif;font-size:13px;line-height:1.8}.invoice-info-right{text-align:right}.invoice-label{font-weight:500;color:#6b7280;margin-bottom:4px}.invoice-customer-name{font-weight:500;color:#18181b}.invoice-table{width:100%;border-collapse:collapse;margin-bottom:24px}.invoice-table th{padding:12px 8px;text-align:left;font-family:Slussen,sans-serif;font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:#6b7280;border-bottom:2px solid #e5e7eb}.invoice-table td{padding:16px 8px;font-family:Slussen,sans-serif;font-size:13px;color:#374151;border-bottom:1px solid #f3f4f6;vertical-align:top}.invoice-item-cell{display:flex;align-items:center;gap:12px}.invoice-item-thumb{width:40px;height:40px;object-fit:cover;border-radius:4px}.invoice-item-name{font-weight:500;color:#18181b}.invoice-customization{color:#9ca3af;font-size:11px}.invoice-center{text-align:center}.invoice-right{text-align:right}.invoice-totals{margin-left:auto;width:250px}.invoice-total-row{display:flex;justify-content:space-between;padding:8px 0;font-family:Slussen,sans-serif;font-size:14px;color:#6b7280}.invoice-grand-total{font-weight:600;font-size:18px;color:#18181b;border-top:2px solid #18181b;padding-top:12px;margin-top:8px}.invoice-production{margin-top:32px;padding:16px;background:#f9fafb;border-radius:8px;font-family:Slussen,sans-serif;font-size:13px;color:#6b7280}.invoice-production p{margin:4px 0}.invoice-footer{margin-top:48px;text-align:center;font-family:Slussen,sans-serif;color:#6b7280}.invoice-footer p{margin:4px 0}.invoice-footer-contact{font-size:12px;color:#9ca3af}@media print{.invoice-actions{display:none}.invoice-modal{max-width:none;max-height:none;box-shadow:none;border-radius:0}.invoice-overlay{background:#fff;position:relative}}@media(max-width:1024px){.om-stats,.analytics-metrics{grid-template-columns:repeat(2,1fr)}.analytics-charts,.od-info-grid{grid-template-columns:1fr}}@media(max-width:768px){.order-management,.analytics{padding:16px}.om-stats,.analytics-metrics{grid-template-columns:1fr}.om-filters{flex-direction:column}.om-search{max-width:none}.analytics-header{flex-direction:column}.analytics-header-right{flex-wrap:wrap}.invoice-content{padding:24px}.invoice-info-row{flex-direction:column;gap:24px}.invoice-info-right{text-align:left}}.profile-badge{font-size:10px;font-weight:600;padding:2px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.5px}.profile-badge-admin{background:#dbeafe;color:#1d4ed8}.profile-badge-staff{background:#d1fae5;color:#047857}.header-role-indicator{position:absolute;top:0;left:0;right:0;height:2px}.header-role-indicator.admin{background:#3b82f6}.header-role-indicator.staff{background:#10b981}.my-orders{width:100%;max-width:1000px;padding:32px 48px;margin:0 auto}.my-orders-header{margin-bottom:24px}.my-orders-title{font-family:Slussen Extended,Slussen,sans-serif;font-weight:600;font-size:28px;color:#18181b;margin:0 0 4px}.my-orders-subtitle{font-family:Slussen,sans-serif;font-size:14px;color:#71717a;margin:0}.my-orders-table-container{background:#fff;border:1px solid #e5e7eb;border-radius:12px;overflow:hidden}.my-orders-table{width:100%;border-collapse:collapse}.my-orders-table th{text-align:left;padding:14px 16px;font-family:Slussen,sans-serif;font-weight:500;font-size:12px;color:#71717a;text-transform:uppercase;letter-spacing:.5px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.my-orders-table td{padding:16px;font-family:Slussen,sans-serif;font-size:14px;color:#18181b;border-bottom:1px solid #e5e7eb;vertical-align:middle}.my-orders-table tbody tr{cursor:pointer;transition:background-color .15s ease}.my-orders-table tbody tr:hover{background:#f9fafb}.my-orders-table tbody tr:last-child td{border-bottom:none}.my-orders-order-num{font-weight:600;color:#18181b}.my-orders-items{display:flex;align-items:center;gap:12px}.my-orders-thumbs{display:flex;align-items:center}.my-orders-thumb{width:32px;height:32px;border-radius:6px;object-fit:cover;border:2px solid white;box-shadow:0 1px 2px #0000001a;position:relative}.my-orders-items-count{font-size:13px;color:#71717a}.my-orders-date{color:#71717a;font-size:13px}.my-orders-status{display:inline-block;padding:4px 10px;border-radius:100px;font-size:12px;font-weight:500}.my-orders-total{font-weight:600}.my-orders-view-btn{padding:6px 12px;background:transparent;border:1px solid #e5e7eb;border-radius:6px;font-family:Slussen,sans-serif;font-size:13px;font-weight:500;color:#18181b;cursor:pointer;transition:all .15s ease}.my-orders-view-btn:hover{background:#f4f4f5;border-color:#d4d4d8}.my-orders-empty{padding:64px 24px;text-align:center}.my-orders-empty p{font-family:Slussen,sans-serif;font-size:16px;font-weight:500;color:#18181b;margin:0 0 4px}.my-orders-empty span{font-family:Slussen,sans-serif;font-size:14px;color:#71717a}.my-orders-modal{background:#fff;border-radius:12px;width:100%;max-width:480px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column}.my-orders-modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:24px;border-bottom:1px solid #e5e7eb}.my-orders-modal-header h2{font-family:Slussen,sans-serif;font-size:18px;font-weight:600;color:#18181b;margin:0 0 8px}.my-orders-modal-close{background:none;border:none;padding:4px;cursor:pointer;color:#71717a;border-radius:6px;transition:all .15s ease}.my-orders-modal-close:hover{background:#f4f4f5;color:#18181b}.my-orders-modal-info{padding:20px 24px;background:#f9fafb;border-bottom:1px solid #e5e7eb}.my-orders-modal-info-row{display:flex;justify-content:space-between;padding:4px 0;font-family:Slussen,sans-serif;font-size:13px}.my-orders-modal-info-row span:first-child{color:#71717a}.my-orders-modal-info-row span:last-child{color:#18181b;font-weight:500}.my-orders-modal-items{flex:1;overflow-y:auto;padding:20px 24px}.my-orders-modal-items h3{font-family:Slussen,sans-serif;font-size:13px;font-weight:600;color:#18181b;margin:0 0 16px}.my-orders-modal-item{display:flex;align-items:center;gap:14px;padding:12px 0;border-bottom:1px solid #f4f4f5}.my-orders-modal-item:last-child{border-bottom:none}.my-orders-modal-item img{width:48px;height:48px;border-radius:8px;object-fit:cover}.my-orders-modal-item-image{position:relative;width:48px;height:48px;flex-shrink:0}.my-orders-crop-badge{position:absolute;bottom:3px;left:3px;background:#000000b3;color:#fff;font-size:8px;font-weight:500;padding:2px 4px;border-radius:3px;text-transform:uppercase;letter-spacing:.3px}.my-orders-modal-item-details{flex:1;min-width:0}.my-orders-modal-item-name{display:block;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#18181b;margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.my-orders-modal-item-specs{font-family:Slussen,sans-serif;font-size:12px;color:#71717a}.my-orders-modal-item-price{font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#18181b}.my-orders-modal-total{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-top:1px solid #e5e7eb;font-family:Slussen,sans-serif}.my-orders-modal-total span:first-child{font-size:14px;color:#71717a}.my-orders-modal-total span:last-child{font-size:18px;font-weight:600;color:#18181b}.admin-field{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:16px;margin-top:8px}.admin-field label{color:#92400e}.admin-field input{border-color:#f59e0b}.admin-hint{font-size:11px;color:#92400e;margin:8px 0 0;font-style:italic}.login-admin-toggle{text-align:center;margin-top:16px}.admin-toggle-link{background:none;border:none;color:#a1a1aa;font-size:12px;cursor:pointer;padding:4px 8px;text-decoration:underline;transition:color .15s ease}.admin-toggle-link:hover{color:#71717a}.cart-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.cart-modal{background:#fff;border-radius:16px;width:100%;max-width:600px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040}.cart-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px}.cart-title{font-family:Slussen Extended,Slussen,sans-serif;font-size:18px;font-weight:600;margin:0;color:#18181b}.cart-header-actions{display:flex;align-items:center;gap:12px}.cart-count{font-size:13px;color:#71717a}.cart-close{background:none;border:none;cursor:pointer;padding:4px;color:#71717a;transition:color .15s}.cart-close:hover{color:#18181b}.cart-divider{height:1px;background:#e5e7eb}.cart-items{flex:1;overflow-y:auto;padding:16px 24px;display:flex;flex-direction:column;gap:16px}.cart-item{display:flex;align-items:center;gap:16px;padding:12px;background:#fafafa;border-radius:12px}.cart-item-image{position:relative;width:64px;height:64px;border-radius:8px;overflow:hidden;flex-shrink:0}.cart-item-crop-badge{position:absolute;bottom:4px;left:4px;background:#000000b3;color:#fff;font-size:9px;font-weight:500;padding:2px 5px;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.cart-item-image img{width:100%;height:100%;object-fit:cover}.cart-item-placeholder{width:100%;height:100%;background:#e5e7eb;display:flex;align-items:center;justify-content:center}.cart-item-details{flex:1;min-width:0}.cart-item-name{font-size:14px;font-weight:500;color:#18181b;margin:0 0 4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cart-item-specs{font-size:12px;color:#71717a;margin:0}.cart-item-custom{font-size:11px;color:#a1a1aa;margin:4px 0 0;font-style:italic}.cart-item-quantity{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:4px}.cart-qty-btn{width:28px;height:28px;border:none;background:transparent;cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:6px;color:#71717a;transition:background .15s}.cart-qty-btn:hover{background:#f4f4f5}.cart-qty-value{font-size:14px;font-weight:500;min-width:24px;text-align:center}.cart-item-price{text-align:right;min-width:80px}.cart-item-line-total{display:block;font-size:14px;font-weight:600;color:#18181b}.cart-item-unit{display:block;font-size:11px;color:#a1a1aa}.cart-item-remove{background:none;border:none;cursor:pointer;padding:8px;color:#a1a1aa;transition:color .15s}.cart-item-remove:hover{color:#ef4444}.cart-empty{padding:48px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:12px}.cart-empty-title{font-size:16px;font-weight:500;color:#18181b;margin:0}.cart-empty-subtitle{font-size:13px;color:#71717a;margin:0}.cart-summary{padding:16px 24px;display:flex;flex-direction:column;gap:8px}.cart-summary-row{display:flex;justify-content:space-between;font-size:14px;color:#71717a}.cart-summary-total{font-size:16px;font-weight:600;color:#18181b;padding-top:8px;border-top:1px solid #e5e7eb;margin-top:4px}.cart-footer{display:flex;gap:12px;padding:20px 24px}.cart-footer .btn-secondary,.cart-footer .btn-primary{flex:1}.cart-success{padding:48px 24px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:16px}.cart-success-icon{margin-bottom:8px}.cart-success-title{font-size:18px;font-weight:600;color:#18181b;margin:0}.cart-success-message{font-size:14px;color:#52525b;margin:0}.cart-success-note{font-size:13px;color:#a1a1aa;margin:0}.cart-done-btn{min-width:120px}.create-order-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.create-order-modal{background:#fff;border-radius:16px;width:100%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 25px 50px -12px #00000040}.create-order-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px}.create-order-title{font-family:Slussen Extended,Slussen,sans-serif;font-size:18px;font-weight:600;margin:0;color:#18181b}.create-order-close{background:none;border:none;cursor:pointer;padding:4px;color:#71717a;transition:color .15s}.create-order-close:hover{color:#18181b}.create-order-divider{height:1px;background:#e5e7eb}.create-order-content{flex:1;overflow-y:auto;padding:24px}.create-order-section{margin-bottom:24px}.create-order-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.create-order-section-title{font-size:14px;font-weight:600;color:#18181b;margin:0 0 12px}.create-order-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.create-order-field{display:flex;flex-direction:column;gap:4px}.create-order-field label{font-size:12px;font-weight:500;color:#52525b}.create-order-field input,.create-order-field select,.create-order-field textarea{padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-family:Slussen,sans-serif;transition:border-color .15s}.create-order-field input:focus,.create-order-field select:focus,.create-order-field textarea:focus{outline:none;border-color:#18181b}.create-order-field-full{grid-column:1 / -1}.create-order-add-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:#f4f4f5;border:none;border-radius:6px;font-size:13px;cursor:pointer;transition:background .15s}.create-order-add-btn:hover{background:#e4e4e7}.create-order-item{background:#fafafa;border-radius:12px;padding:16px;margin-bottom:12px}.create-order-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.create-order-item-number{font-size:13px;font-weight:500;color:#71717a}.create-order-item-remove{background:none;border:none;cursor:pointer;padding:4px;color:#a1a1aa;transition:color .15s}.create-order-item-remove:hover{color:#ef4444}.create-order-item-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.create-order-line-total{padding:10px 12px;background:#f4f4f5;border-radius:8px;font-size:14px;font-weight:500;color:#18181b}.create-order-total{display:flex;justify-content:space-between;align-items:center;padding:16px;background:#18181b;border-radius:12px;color:#fff;font-size:16px;font-weight:500}.create-order-total-value{font-size:20px;font-weight:600}.create-order-footer{display:flex;gap:12px;padding:20px 24px;justify-content:flex-end}.border-preview-container{position:relative;margin-bottom:16px;display:flex;justify-content:center}.border-preview-wrapper{position:relative;display:inline-flex;justify-content:center}.border-template-bg{width:100%;max-width:320px;height:auto;display:block}.border-preview-wrapper.has-template .border-preview{position:absolute;inset:0;background:transparent;border:none;padding:28px 20px;min-height:auto}.border-preview-wrapper.template-left-seal .border-preview{padding-left:70px}.border-preview-wrapper.template-right-seal .border-preview{padding-right:70px}.border-preview.has-template{position:relative;background:transparent;z-index:1}.border-custom-branding{position:absolute;top:8px;right:8px;width:48px;height:48px}.border-custom-branding img{width:100%;height:100%;object-fit:contain}.template-picker{display:flex;gap:12px}.template-option{flex:1;display:flex;flex-direction:column;align-items:center;gap:8px;padding:12px;background:#fafafa;border:2px solid transparent;border-radius:12px;cursor:pointer;transition:all .15s}.template-option:hover{background:#f4f4f5}.template-option.active{border-color:#18181b;background:#fff}.template-preview{width:60px;height:80px;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:11px;color:#a1a1aa}.template-preview.template-none{background:#f4f4f5;border:1px dashed #d4d4d8}.template-thumb{width:60px;height:80px;object-fit:cover;border-radius:4px}.template-option span{font-size:12px;color:#52525b}.upload-small-zone{display:flex;align-items:center;gap:12px;padding:12px 16px;background:#fafafa;border:1px dashed #d4d4d8;border-radius:8px;cursor:pointer;transition:all .15s}.upload-small-zone:hover{background:#f4f4f5;border-color:#a1a1aa}.upload-small-zone span{font-size:13px;color:#71717a}.upload-small-preview{position:relative;display:flex;align-items:center;gap:12px;width:100%}.upload-small-preview img{width:48px;height:32px;object-fit:contain;border-radius:4px}.upload-small-remove{position:absolute;right:0;top:50%;transform:translateY(-50%);background:#ef4444;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#fff}.signature-image-preview{height:32px;object-fit:contain}.cr-modal{max-width:800px;width:100%}.cr-modal-content{padding:0}.cr-layout{display:grid;grid-template-columns:280px 1fr;gap:0}.cr-preview-section{background:linear-gradient(145deg,#f8fafc,#f1f5f9);padding:24px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid #e5e7eb;min-height:480px}.cr-document{width:180px;aspect-ratio:8.5 / 11;background:#fffef8;border-radius:4px;box-shadow:0 1px 3px #00000014,0 4px 12px #0000000a;padding:3px;position:relative;transition:all .2s}.cr-document.gold-lined{background:linear-gradient(135deg,#fffef5,#fef9e7)}.cr-document.gold-lined:before{content:"";position:absolute;left:8px;top:8px;bottom:8px;width:2px;background:linear-gradient(180deg,#c9a227,#daa520,#c9a227);border-radius:1px}.cr-document-inner{border:1px solid #d4af37;border-radius:2px;height:100%;padding:12px 8px;display:flex;flex-direction:column;align-items:center}.cr-document.standard .cr-document-inner{border-color:#d1d5db}.cr-doc-header{text-align:center;margin-bottom:6px}.cr-doc-title{font-family:Times New Roman,Georgia,serif;font-size:10px;font-weight:700;color:#1e3a5f;letter-spacing:.3px;margin-bottom:1px}.cr-doc-subtitle{font-family:Times New Roman,Georgia,serif;font-size:6px;font-style:italic;color:#4b5563;margin-bottom:2px}.cr-doc-congress{font-family:Times New Roman,Georgia,serif;font-size:4px;letter-spacing:.5px;color:#6b7280;text-transform:uppercase}.cr-doc-seal{width:40px;height:40px;margin:6px 0;border-radius:50%;overflow:hidden}.cr-doc-seal img{width:100%;height:100%;object-fit:cover}.cr-doc-body{text-align:center;flex:1;display:flex;flex-direction:column;align-items:center;gap:2px}.cr-doc-occasion{font-family:Times New Roman,Georgia,serif;font-size:7px;font-style:italic;color:#4b5563}.cr-doc-recipient{font-family:Times New Roman,Georgia,serif;font-size:9px;font-weight:700;color:#1e3a5f}.cr-doc-message{font-family:Times New Roman,Georgia,serif;font-size:5px;color:#6b7280;max-width:90%;text-align:center;line-height:1.4}.cr-doc-date{font-family:Times New Roman,Georgia,serif;font-size:6px;color:#6b7280;margin-top:auto}.cr-doc-photo{width:36px;height:28px;margin-top:4px;border-radius:2px;overflow:hidden;border:1px solid #d4af37}.cr-doc-photo img{width:100%;height:100%;object-fit:cover}.cr-preview-examples{margin-top:16px}.cr-preview-examples a{display:flex;align-items:center;gap:6px;font-size:12px;color:#6b7280;text-decoration:none;transition:color .15s}.cr-preview-examples a:hover{color:#18181b}.cr-form-section{padding:20px 24px;display:flex;flex-direction:column;gap:14px;overflow-y:auto;max-height:540px}.cr-paper-selector{display:flex;gap:10px}.cr-paper-option{flex:1;display:flex;align-items:center;gap:10px;padding:10px 12px;background:#fafafa;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .15s}.cr-paper-option:hover{background:#f4f4f5}.cr-paper-option.active{border-color:#18181b;background:#fff}.cr-paper-swatch{width:32px;height:40px;border-radius:4px;border:1px solid #e5e7eb;position:relative;flex-shrink:0}.cr-paper-swatch.gold{background:linear-gradient(135deg,#fffef5,#fef9e7);border-color:#d4af37}.cr-paper-swatch.white{background:#fff}.cr-paper-swatch .cr-paper-line{position:absolute;left:3px;top:3px;bottom:3px;width:2px;background:linear-gradient(180deg,#c9a227,#daa520,#c9a227);border-radius:1px}.cr-paper-info{display:flex;flex-direction:column;gap:2px}.cr-paper-name{font-size:13px;font-weight:500;color:#18181b}.cr-paper-tag{font-size:10px;color:#16a34a;font-weight:500}.segment-price{font-size:11px;color:#71717a;font-weight:400;margin-left:4px}.segment.active .segment-price{color:#52525b}.form-label-optional{font-weight:400;color:#a1a1aa}.cr-upload-zone{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;border:1.5px dashed #d4d4d8;border-radius:10px;background:#fafafa;cursor:pointer;transition:all .15s;color:#71717a;font-size:13px}.cr-upload-zone:hover{border-color:#a1a1aa;background:#f4f4f5}.cr-upload-preview{max-height:60px;max-width:100%;object-fit:contain;border-radius:4px}.form-textarea{padding:10px 12px;border:1px solid #e5e7eb;border-radius:8px;font-size:14px;font-family:Slussen,sans-serif;resize:vertical;min-height:60px;width:100%}.form-textarea:focus{outline:none;border-color:#18181b}@media(max-width:700px){.cr-layout{grid-template-columns:1fr}.cr-preview-section{border-right:none;border-bottom:1px solid #e5e7eb;min-height:auto;padding:20px}.cr-form-section{max-height:none}}.success-toast{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:12px 20px;background:#18181b;color:#fff;border-radius:12px;box-shadow:0 10px 40px #0003;cursor:pointer;z-index:1001;animation:slideUp .3s ease}.success-toast svg{width:20px;height:20px}.success-toast span{font-size:14px}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.custom-print-upload{width:100%;aspect-ratio:4/3;border:2px dashed #d4d4d8;border-radius:12px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;background:#fafafa;margin-bottom:16px;overflow:hidden}.custom-print-upload:hover{border-color:#a1a1aa;background:#f4f4f5}.custom-print-upload.has-image{border-style:solid;border-color:#e5e7eb}.custom-print-preview{width:100%;height:100%;object-fit:contain}.custom-print-placeholder{display:flex;flex-direction:column;align-items:center;gap:8px;color:#71717a}.custom-print-upload-title{font-size:15px;font-weight:500;color:#52525b}.custom-print-upload-subtitle{font-size:13px;color:#a1a1aa}.custom-print-preview-wrapper{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.custom-print-change-btn{position:absolute;bottom:12px;right:12px;padding:8px 14px;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;border:none;border-radius:8px;font-size:12px;font-weight:500;font-family:Slussen,sans-serif;cursor:pointer;transition:all .2s ease;opacity:0}.custom-print-upload:hover .custom-print-change-btn{opacity:1}.custom-print-change-btn:hover{background:#000000d9}.border-style-picker{display:flex;gap:10px}.border-style-option{padding:0;background:none;border:2px solid transparent;border-radius:10px;cursor:pointer;transition:all .15s ease}.border-style-option:hover{border-color:#d4d4d8}.border-style-option.active{border-color:#18181b}.border-style-preview{width:56px;height:56px;border-radius:8px;display:flex;align-items:center;justify-content:center;overflow:hidden}.border-style-none{background:#f4f4f5;border:1px dashed #d4d4d8}.border-style-none span{font-size:11px;font-weight:500;color:#a1a1aa}.border-style-white{background:#fff;padding:6px;border:1px solid #e5e7eb}.border-style-black{background:#1a1a1a;padding:6px}.border-style-cream{background:#f5f0e6;padding:6px;border:1px solid #e5e7eb}.border-style-inner{width:100%;height:100%;background:linear-gradient(135deg,#9ca3af,#6b7280);border-radius:2px}.border-width-picker{display:flex;align-items:center;gap:12px;margin-top:12px}.border-width-label{font-size:12px;color:#71717a;font-weight:500}.border-width-options{display:flex;gap:6px}.border-width-option{padding:6px 12px;background:#fafafa;border:1.5px solid transparent;border-radius:6px;font-size:12px;font-family:Slussen,sans-serif;color:#52525b;cursor:pointer;transition:all .15s ease}.border-width-option:hover{background:#f4f4f5;color:#18181b}.border-width-option.active{background:#fff;border-color:#18181b;color:#18181b;font-weight:500}.size-picker{display:flex;flex-wrap:wrap;gap:8px}.size-option{padding:10px 16px;background:#fafafa;border:2px solid transparent;border-radius:8px;font-size:13px;font-family:Slussen,sans-serif;cursor:pointer;transition:all .15s}.size-option:hover{background:#f4f4f5}.size-option.active{border-color:#18181b;background:#fff;font-weight:500}.logo-seal{width:32px;height:32px;border-radius:50%;object-fit:cover;margin-right:10px}.expanded-modal-overlay{position:fixed;inset:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.expanded-modal{position:relative;display:flex;flex-direction:column;max-width:90vw;max-height:90vh;animation:scaleIn .2s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.expanded-close{position:fixed;top:24px;right:24px;background:#ffffff1a;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#fff;transition:background .2s}.expanded-close:hover{background:#fff3}.expanded-media{border-radius:12px;overflow:hidden;display:flex;align-items:center;justify-content:center}.expanded-media img{display:block;max-width:85vw;max-height:70vh;width:auto;height:auto;border-radius:12px}.expanded-media video{display:block;max-width:85vw;max-height:70vh;width:auto;height:auto;border-radius:12px}.expanded-bar{display:flex;justify-content:space-between;align-items:center;padding:16px 0;gap:24px}.expanded-info{display:flex;flex-direction:column;gap:2px;min-width:0}.expanded-name{font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.expanded-type{font-family:Slussen,sans-serif;font-size:12px;color:#ffffff80}.expanded-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;font-family:Slussen,sans-serif;font-size:12px;color:#ffffff80}.expanded-meta .meta-sep{color:#ffffff40;font-size:10px}.expanded-actions{display:flex;gap:10px;flex-shrink:0}.expanded-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s;border:none}.expanded-btn-secondary{background:#ffffff1a;color:#fff}.expanded-btn-secondary:hover{background:#fff3}.expanded-btn-primary{background:#fff;color:#18181b}.expanded-btn-primary:hover{background:#f4f4f5}.gallery-layout{display:flex;width:100%}.gallery-content{flex:1;min-width:0;padding-left:24px}.folder-sidebar{width:220px;flex-shrink:0;background:#fff;display:flex;flex-direction:column;padding-top:16px;position:sticky;top:120px;height:fit-content;max-height:calc(100vh - 140px);overflow-y:auto;z-index:10}.folder-sidebar-header{padding:16px 24px 12px}.folder-sidebar-title{font-family:Slussen,sans-serif;font-size:12px;font-weight:500;color:#71717a}.folder-sidebar-content{flex:1;overflow-y:auto;padding:4px 12px}.folder-item-wrapper{position:relative}.folder-item{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;font-family:Slussen,sans-serif;font-size:14px;color:#3f3f46;text-align:left;transition:background .1s}.folder-item:hover{background:#f7f7f8}.folder-item.active{background:#f0f0f1;color:#18181b}.folder-item svg{color:#a1a1aa;flex-shrink:0}.folder-item.active svg{color:#3f3f46}.folder-item-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.folder-item-more{opacity:0;padding:4px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:#a1a1aa;display:flex;align-items:center;justify-content:center;transition:opacity .1s}.folder-item:hover .folder-item-more{opacity:1}.folder-item-more:hover{background:#e4e4e7;color:#3f3f46}.folder-create-btn{display:flex;align-items:center;gap:12px;width:100%;padding:10px 12px;border:none;background:transparent;border-radius:8px;cursor:pointer;font-family:Slussen,sans-serif;font-size:14px;color:#71717a;margin-top:4px;transition:all .1s}.folder-create-btn:hover{background:#f7f7f8;color:#3f3f46}.folder-create-btn svg{color:#a1a1aa}.folder-create-input,.folder-edit-input{flex:1;border:none;background:transparent;font-family:Slussen,sans-serif;font-size:13px;color:#18181b;outline:none}.folder-create-input::placeholder{color:#a1a1aa}.folder-item.creating,.folder-item.editing{background:#f4f4f5}.folder-context-menu{position:fixed;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;padding:4px;min-width:140px;z-index:9999}.context-menu-item{display:block;width:100%;padding:8px 12px;border:none;background:transparent;border-radius:4px;cursor:pointer;font-family:Slussen,sans-serif;font-size:13px;color:#3f3f46;text-align:left;transition:background .15s}.context-menu-item:hover{background:#f4f4f5}.context-menu-item.danger{color:#dc2626}.context-menu-item.danger:hover{background:#fef2f2}.permissions-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000}.permissions-modal{background:#fff;border-radius:12px;width:100%;max-width:480px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000026}.permissions-modal-header{padding:20px 24px;position:relative}.permissions-modal-title{font-family:Slussen,sans-serif;font-size:18px;font-weight:600;color:#18181b;margin:0}.permissions-modal-subtitle{font-family:Slussen,sans-serif;font-size:13px;color:#71717a;margin-top:4px}.permissions-close-btn{position:absolute;top:16px;right:16px;padding:8px;border:none;background:transparent;border-radius:6px;cursor:pointer;color:#71717a}.permissions-close-btn:hover{background:#f4f4f5}.permissions-modal-divider{height:1px;background:#e4e4e7}.permissions-modal-content{flex:1;overflow-y:auto;padding:20px 24px}.permissions-add-section{margin-bottom:24px}.permissions-add-row{display:flex;gap:8px}.permissions-email-input{flex:1;padding:10px 12px;border:1px solid #e4e4e7;border-radius:8px;font-family:Slussen,sans-serif;font-size:13px;outline:none;transition:border-color .15s}.permissions-email-input:focus{border-color:#18181b}.permissions-select{padding:10px 12px;border:1px solid #e4e4e7;border-radius:8px;font-family:Slussen,sans-serif;font-size:13px;background:#fff;cursor:pointer;outline:none}.permissions-select.small{padding:6px 10px;font-size:12px}.permissions-add-btn{padding:10px 16px;border:none;border-radius:8px;background:#18181b;color:#fff;font-family:Slussen,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.permissions-add-btn:hover:not(:disabled){background:#27272a}.permissions-add-btn:disabled{opacity:.5;cursor:not-allowed}.permissions-list-section{margin-top:16px}.permissions-list-header{font-family:Slussen,sans-serif;font-size:12px;font-weight:600;color:#71717a;margin-bottom:12px}.permissions-empty{font-family:Slussen,sans-serif;font-size:13px;color:#a1a1aa;text-align:center;padding:24px}.permissions-list{display:flex;flex-direction:column;gap:8px}.permissions-list-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#fafafa;border-radius:8px}.permissions-user{display:flex;align-items:center;gap:12px}.permissions-user-avatar{width:32px;height:32px;border-radius:50%;background:#e4e4e7;display:flex;align-items:center;justify-content:center;color:#71717a}.permissions-user-info{display:flex;flex-direction:column}.permissions-user-name{font-family:Slussen,sans-serif;font-size:13px;font-weight:500;color:#18181b}.permissions-user-email{font-family:Slussen,sans-serif;font-size:12px;color:#71717a}.permissions-actions{display:flex;align-items:center;gap:8px}.permissions-remove-btn{padding:6px;border:none;background:transparent;border-radius:4px;cursor:pointer;color:#a1a1aa}.permissions-remove-btn:hover{background:#fef2f2;color:#dc2626}.permissions-modal-footer{padding:16px 24px;display:flex;justify-content:flex-end}.permissions-done-btn{padding:10px 20px;border:none;border-radius:8px;background:#18181b;color:#fff;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.permissions-done-btn:hover{background:#27272a}.move-to-folder-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026,0 0 0 1px #0000000d;padding:4px;min-width:160px;z-index:100}.move-to-folder-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:none;background:transparent;border-radius:4px;cursor:pointer;font-family:Slussen,sans-serif;font-size:13px;color:#3f3f46;text-align:left;transition:background .15s}.move-to-folder-item:hover{background:#f4f4f5}.move-to-folder-item.active{background:#e4e4e7}.image-cropper-container{display:flex;flex-direction:column;gap:12px;flex-shrink:0}.cropper-wrapper{position:relative;width:100%;height:280px;border-radius:8px;overflow:hidden;background:#18181b}.cropper-size-label{position:absolute;top:10px;left:10px;background:#000000b3;color:#fff;font-family:Slussen,sans-serif;font-size:12px;font-weight:600;padding:5px 10px;border-radius:4px;pointer-events:none;z-index:10}.zoom-control{display:flex;align-items:center;gap:10px;padding:0 4px}.zoom-icon{color:#71717a;flex-shrink:0}.zoom-slider{flex:1;height:4px;-webkit-appearance:none;appearance:none;background:#e4e4e7;border-radius:2px;outline:none;cursor:pointer}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:#18181b;border-radius:50%;cursor:pointer;transition:transform .1s}.zoom-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.zoom-slider::-moz-range-thumb{width:16px;height:16px;background:#18181b;border:none;border-radius:50%;cursor:pointer}.cropper-hint{font-family:Slussen,sans-serif;font-size:12px;color:#71717a;text-align:center;margin:0}.custom-print-cropper-section{display:flex;flex-direction:column;gap:12px}.custom-print-change-btn-standalone{font-family:Slussen,sans-serif;font-size:13px;font-weight:500;color:#3b82f6;background:transparent;border:none;cursor:pointer;padding:8px 0;text-align:center;transition:color .15s}.custom-print-change-btn-standalone:hover{color:#2563eb;text-decoration:underline}.border-crop-btn{position:absolute;bottom:8px;right:8px;background:#000000b3;border:none;border-radius:6px;padding:6px;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s;opacity:0}.border-preview-image:hover .border-crop-btn{opacity:1}.border-crop-btn:hover{background:#000000d9}.border-cropper-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.border-cropper-modal{background:#fff;border-radius:12px;padding:20px;width:90%;max-width:500px;display:flex;flex-direction:column;gap:16px;box-shadow:0 20px 40px #0000004d}.border-cropper-header{display:flex;justify-content:space-between;align-items:center}.border-cropper-header h3{font-family:Slussen,sans-serif;font-size:16px;font-weight:600;margin:0;color:#18181b}.border-cropper-footer{display:flex;justify-content:flex-end}.group-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:180px;z-index:100;overflow:hidden}.group-dropdown-header{padding:10px 12px;font-family:Slussen,sans-serif;font-size:12px;font-weight:500;color:#71717a;border-bottom:1px solid #e4e4e7}.group-dropdown-item{display:flex;align-items:center;gap:10px;padding:10px 12px;font-family:Slussen,sans-serif;font-size:14px;color:#18181b;cursor:pointer;transition:background .1s}.group-dropdown-item:hover{background:#f7f7f8}.group-dropdown-item input[type=checkbox]{width:16px;height:16px;accent-color:#18181b;cursor:pointer}.media-select-checkbox{position:absolute;top:10px;left:10px;z-index:10;cursor:pointer}.media-item.selected{outline:3px solid #18181b;outline-offset:-3px}.bulk-action-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:12px 20px;background:#18181b;border-radius:12px;box-shadow:0 8px 24px #00000040;z-index:1000}.bulk-action-count{font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#fff}.bulk-action-btn{padding:8px 16px;background:#fff;color:#18181b;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s}.bulk-action-btn:hover{background:#f4f4f5}.bulk-action-btn.secondary{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.3)}.bulk-action-btn.secondary:hover{background:#ffffff1a}.bulk-group-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:8px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:160px;overflow:hidden}.bulk-group-item{display:block;width:100%;padding:10px 14px;background:transparent;border:none;font-family:Slussen,sans-serif;font-size:14px;color:#18181b;text-align:left;cursor:pointer;transition:background .1s}.bulk-group-item:hover{background:#f7f7f8}.bulk-action-btn.danger{background:#dc2626;color:#fff}.bulk-action-btn.danger:hover{background:#b91c1c}.media-public-icon{position:absolute;bottom:10px;right:10px;z-index:5;width:24px;height:24px;background:#00000080;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:default}.media-public-icon svg{flex-shrink:0}.toast-container{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:14px 20px;border-radius:10px;background:#1f2937;color:#fff;box-shadow:0 4px 16px #0003;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;animation:toastSlideIn .25s ease-out;pointer-events:auto;cursor:pointer}.toast:hover{opacity:.9}.toast-success{background:#059669}.toast-error{background:#dc2626}.toast-info{background:#2563eb}@keyframes toastSlideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.people-filter-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px;background:none;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .15s ease;position:relative}.people-filter-count{position:absolute;top:-4px;right:-4px;background:#18181b;color:#fff;font-size:10px;font-weight:600;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}input[type=text],input[type=email],input[type=password],input[type=search],input[type=number],select,textarea{font-size:16px}.sidebar-toggle{display:none;align-items:center;justify-content:center;width:36px;height:36px;background:#fff;border:1px solid var(--border-base, #e4e4e7);border-radius:10px;cursor:pointer;flex-shrink:0}.sidebar-toggle svg{width:18px;height:18px;color:var(--fg-subtle, #52525b)}.sidebar-overlay,.sidebar-close{display:none}@media(max-width:480px){.sticky-header{padding:12px 16px}.masonry-container{padding:0 12px 12px}.filters{padding:16px;gap:8px;flex-wrap:wrap}.filter-toggle{padding:0 10px;font-size:12px;height:32px}.create-button,.sort-button{height:32px;padding:0 10px;font-size:12px}.create-button span,.sort-button span{display:none}.filter-pill{height:32px;padding:0 10px}.filter-pill-text{font-size:12px}}@media(max-width:375px){.sticky-header{padding:10px 12px}.masonry-container{padding:0 8px 8px}.logo-text{font-size:16px}}@media(max-width:768px){.sidebar-toggle{display:flex}.gallery-layout{position:relative}.folder-sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;max-width:85vw;z-index:200;transform:translate(-100%);transition:transform .3s ease;box-shadow:4px 0 24px #00000026;padding-top:16px;height:100%;max-height:100vh}.folder-sidebar.open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0006;z-index:199;opacity:0;pointer-events:none;transition:opacity .3s ease}.sidebar-overlay.visible{opacity:1;pointer-events:auto}.sidebar-close{display:flex;position:absolute;top:12px;right:12px;width:36px;height:36px;background:none;border:none;cursor:pointer;align-items:center;justify-content:center;border-radius:8px}.sidebar-close:hover{background:#f4f4f5}.sidebar-close svg{width:20px;height:20px;color:#71717a}.gallery-content{padding-left:0}.filters{flex-wrap:wrap}.filters-divider{display:none}.people-filter{overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:0 16px}.people-filter::-webkit-scrollbar{display:none}.people-filter-list{flex-wrap:nowrap;gap:12px;padding:8px 0}.people-filter-item{flex-shrink:0}.face-thumbnail{width:48px;height:48px}.cart-overlay{padding:0;align-items:flex-end}.cart-modal{max-width:100%;max-height:90vh;border-radius:16px 16px 0 0;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cart-items{padding:12px 16px}.cart-item{flex-wrap:wrap;gap:12px;padding:12px;position:relative}.cart-item-details{flex:1 1 calc(100% - 80px);min-width:0}.cart-item-quantity{flex:0 0 auto}.cart-item-price{flex:1;text-align:right}.cart-item-remove{position:absolute;top:8px;right:8px}.cart-footer{flex-direction:column;gap:8px;padding:16px}.cart-footer-total{width:100%;justify-content:space-between}.cart-footer-actions{width:100%;flex-direction:column;gap:8px}.cart-footer-actions button{width:100%;min-height:44px}.expanded-modal-overlay{padding:0}.expanded-modal{max-width:100vw;max-height:100vh;width:100%;height:100%;justify-content:center}.expanded-media img,.expanded-media video{max-width:100vw;max-height:55vh;border-radius:0}.expanded-bar{flex-direction:column;padding:16px;background:#000c;position:fixed;bottom:0;left:0;right:0;gap:12px;border-radius:16px 16px 0 0}.expanded-info{width:100%;text-align:center}.expanded-actions{width:100%;flex-direction:column;gap:8px}.expanded-btn{width:100%;justify-content:center;min-height:44px}.expanded-close{top:16px;right:16px;width:44px;height:44px;z-index:10}.bulk-actions-bar{position:fixed;bottom:0;left:0;right:0;border-radius:16px 16px 0 0;padding:16px;z-index:100;box-shadow:0 -4px 24px #00000026}.bulk-actions-content{flex-direction:column;gap:12px}.bulk-actions-count{text-align:center}.bulk-actions-buttons{width:100%;display:flex;flex-wrap:wrap;gap:8px}.bulk-actions-buttons button{flex:1 1 calc(50% - 4px);min-height:44px}.profile-dropdown{position:fixed;inset:auto 0 0;min-width:100%;border-radius:16px 16px 0 0;padding:8px;max-height:70vh;overflow-y:auto}.profile-menu-item{padding:14px 16px;min-height:48px}.modal-overlay{padding:0;align-items:flex-end}.modal{max-width:100%;max-height:90vh;border-radius:16px 16px 0 0;margin:0}.modal-header{padding:16px}.modal-body{padding:16px;overflow-y:auto;-webkit-overflow-scrolling:touch}.modal-footer{padding:16px;flex-direction:column;gap:8px}.modal-footer button{width:100%;min-height:44px}}@media(max-width:768px){.om-table-container{overflow-x:visible}.om-table{display:block}.om-table thead{display:none}.om-table tbody{display:flex;flex-direction:column;gap:12px}.om-table tr{display:flex;flex-wrap:wrap;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;gap:8px 16px;cursor:pointer}.om-table tr:hover{background:#fafafa}.om-table td{padding:0;border:none}.om-table td:first-child{flex:0 0 100%;font-weight:600;font-size:16px;margin-bottom:4px}.om-table td:nth-child(2){flex:1 1 60%}.om-table td:nth-child(3){flex:0 0 100%;order:5;font-size:13px;color:#71717a}.om-table td:nth-child(4){flex:1}.om-table td:nth-child(5){flex:0 0 auto}.om-table td:nth-child(6){flex:1;text-align:right;font-weight:600}.my-orders-table{display:block}.my-orders-table thead{display:none}.my-orders-table tbody{display:flex;flex-direction:column;gap:12px}.my-orders-table tr{display:flex;flex-wrap:wrap;background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px;gap:8px}.my-orders-table td{padding:0;border:none}.my-orders-table td:first-child{flex:0 0 100%;font-weight:600;margin-bottom:8px}.my-orders-table td:nth-child(2){flex:0 0 100%;font-size:13px;color:#71717a}.my-orders-table td:nth-child(3){flex:1}.my-orders-table td:nth-child(4){flex:0 0 auto}.my-orders-table td:nth-child(5){flex:1;text-align:right;font-weight:500}.my-orders-table td:last-child{flex:0 0 100%;margin-top:8px}.my-orders-table td:last-child button{width:100%;min-height:44px}}@media(max-width:768px){.analytics-page{padding:16px}.analytics-header{flex-direction:column;gap:16px}.analytics-header-right{width:100%;flex-wrap:wrap;gap:8px}.analytics-date-picker{width:100%;display:flex}.date-btn{flex:1;min-height:44px}.analytics-btn{flex:1;min-height:44px;justify-content:center}.analytics-charts{grid-template-columns:1fr}.chart-container{min-height:250px}.analytics-metrics{grid-template-columns:repeat(2,1fr)}.analytics-metric{padding:12px}.analytics-metric-value{font-size:20px}}@media(max-width:768px){.login-page{flex-direction:column}.login-container{padding:24px;width:100%;max-width:none}.login-bg{display:none}.login-logo img{width:80px;height:80px}.login-title{font-size:24px}}@media(max-width:480px){.login-container{padding:20px 16px}.login-field input{min-height:44px}.login-button{min-height:48px}.expanded-meta{flex-wrap:wrap;justify-content:center}.expanded-name{font-size:14px}.analytics-metrics{grid-template-columns:1fr}}.group-management{width:100%;padding:0 24px 24px}.gm-header{padding:24px 0 20px;border-bottom:1px solid #e4e4e7;margin-bottom:24px}.gm-header h1{font-family:Slussen,sans-serif;font-size:20px;font-weight:600;color:#18181b;margin:0 0 4px}.gm-header p{font-family:Slussen,sans-serif;font-size:14px;color:#71717a;margin:0}.gm-content{display:grid;grid-template-columns:280px 1fr;gap:24px;min-height:400px}.gm-groups-panel{display:flex;flex-direction:column;gap:12px}.gm-create-form{display:flex;gap:8px}.gm-create-form input{flex:1;padding:10px 12px;border:1px solid #e4e4e7;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;color:#18181b;background:#fff}.gm-create-form input::placeholder{color:#a1a1aa}.gm-create-form input:focus{outline:none;border-color:#18181b}.gm-create-form button{padding:10px 16px;background:#18181b;color:#fff;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:background .15s}.gm-create-form button:hover{background:#27272a}.gm-create-form button:disabled{background:#d4d4d8;cursor:not-allowed}.gm-groups-list{display:flex;flex-direction:column;gap:2px}.gm-group-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;background:transparent;border-radius:8px;cursor:pointer;transition:background .1s}.gm-group-item:hover{background:#f7f7f8}.gm-group-item.selected{background:#f0f0f1}.gm-group-info{display:flex;flex-direction:column;gap:2px;min-width:0}.gm-group-name{font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#18181b;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gm-group-count{font-family:Slussen,sans-serif;font-size:12px;color:#71717a}.gm-delete-btn{padding:6px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:#a1a1aa;opacity:0;transition:opacity .15s,color .15s}.gm-group-item:hover .gm-delete-btn{opacity:1}.gm-delete-btn:hover{color:#dc2626}.gm-details-panel{background:#fafafa;border-radius:12px;padding:20px}.gm-details-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid #e4e4e7}.gm-details-header h2{font-family:Slussen,sans-serif;font-size:16px;font-weight:600;color:#18181b;margin:0}.gm-add-member-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#18181b;color:#fff;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s}.gm-add-member-btn:hover{background:#27272a}.gm-members-list{display:flex;flex-direction:column;gap:8px}.gm-member-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#fff;border-radius:8px;border:1px solid #e4e4e7}.gm-member-info{display:flex;flex-direction:column;gap:2px}.gm-member-name{font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#18181b}.gm-member-email{font-family:Slussen,sans-serif;font-size:12px;color:#71717a}.gm-member-actions{display:flex;align-items:center;gap:8px}.gm-member-actions select{padding:6px 10px;border:1px solid #e4e4e7;border-radius:6px;font-family:Slussen,sans-serif;font-size:13px;color:#3f3f46;background:#fff;cursor:pointer}.gm-member-actions select:focus{outline:none;border-color:#18181b}.gm-remove-btn{padding:6px 10px;background:transparent;color:#71717a;border:1px solid #e4e4e7;border-radius:6px;font-family:Slussen,sans-serif;font-size:13px;cursor:pointer;transition:all .15s}.gm-remove-btn:hover{background:#fef2f2;border-color:#fecaca;color:#dc2626}.gm-empty,.gm-no-selection{font-family:Slussen,sans-serif;font-size:14px;color:#a1a1aa;text-align:center;padding:40px 20px}.gm-loading{font-family:Slussen,sans-serif;font-size:14px;color:#71717a;text-align:center;padding:40px}.gm-modal-overlay{position:fixed;inset:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000}.gm-modal{background:#fff;border-radius:12px;padding:24px;width:90%;max-width:420px;max-height:80vh;overflow-y:auto}.gm-modal h3{font-family:Slussen,sans-serif;font-size:16px;font-weight:600;color:#18181b;margin:0 0 16px}.gm-user-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px;max-height:300px;overflow-y:auto}.gm-user-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#fafafa;border-radius:8px}.gm-user-info{display:flex;flex-direction:column;gap:2px}.gm-user-name{font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:#18181b}.gm-user-email{font-family:Slussen,sans-serif;font-size:12px;color:#71717a}.gm-user-actions{display:flex;gap:6px}.gm-user-actions button{padding:6px 10px;background:#fff;color:#3f3f46;border:1px solid #e4e4e7;border-radius:6px;font-family:Slussen,sans-serif;font-size:12px;cursor:pointer;transition:all .15s}.gm-user-actions button:hover{background:#18181b;color:#fff;border-color:#18181b}.gm-no-users{font-family:Slussen,sans-serif;font-size:14px;color:#71717a;text-align:center;padding:20px}.gm-modal-close{width:100%;padding:10px;background:#f4f4f5;border:none;border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;color:#3f3f46;cursor:pointer;transition:background .15s}.gm-modal-close:hover{background:#e4e4e7}.admin-modal-overlay{position:fixed;inset:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.admin-modal{background:#fff;border-radius:12px;width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 40px #00000026}.admin-modal-large{max-width:800px}.admin-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-subtle, #e5e5e5)}.admin-modal-header h2{margin:0;font-size:18px;font-weight:600;color:var(--fg-default, #18181b)}.admin-modal-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--fg-muted, #71717a);padding:0;line-height:1}.admin-modal-close:hover{color:var(--fg-default, #18181b)}.admin-modal-content{padding:24px;overflow-y:auto;flex:1}.admin-modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid var(--border-subtle, #e5e5e5)}.admin-btn{padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;border:none}.admin-btn:disabled{opacity:.5;cursor:not-allowed}.admin-btn-primary{background-color:var(--accent-default, #2563eb);color:#fff}.admin-btn-primary:hover:not(:disabled){background-color:var(--accent-hover, #1d4ed8)}.admin-btn-secondary{background-color:var(--bg-subtle, #f4f4f5);color:var(--fg-default, #18181b)}.admin-btn-secondary:hover:not(:disabled){background-color:var(--bg-muted, #e4e4e7)}.admin-btn-danger{background-color:#dc2626;color:#fff}.admin-btn-danger:hover:not(:disabled){background-color:#b91c1c}.admin-error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:16px;color:#991b1b}.admin-error-message p{margin:0 0 8px}.admin-error-message p:last-child{margin-bottom:0}.upload-dropzone{border:2px dashed var(--border-muted, #d4d4d8);border-radius:12px;padding:40px;text-align:center;cursor:pointer;transition:all .2s;background-color:var(--bg-subtle, #fafafa)}.upload-dropzone:hover{border-color:var(--accent-default, #2563eb);background-color:#eff6ff}.upload-dropzone.dragging{border-color:var(--accent-default, #2563eb);background-color:#dbeafe}.upload-dropzone-content{display:flex;flex-direction:column;align-items:center;gap:12px}.upload-icon{color:var(--fg-muted, #71717a)}.upload-dropzone-text{font-size:16px;font-weight:500;color:var(--fg-default, #18181b);margin:0}.upload-dropzone-hint{font-size:13px;color:var(--fg-muted, #71717a);margin:0}.upload-files-section{margin-top:24px}.upload-files-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.upload-files-header h3{margin:0;font-size:14px;font-weight:600;color:var(--fg-default, #18181b)}.upload-bulk-tag{display:flex;gap:8px}.upload-bulk-tag input{padding:6px 12px;border:1px solid var(--border-muted, #d4d4d8);border-radius:6px;font-size:13px;width:180px}.upload-bulk-tag button{padding:6px 12px;background-color:var(--bg-subtle, #f4f4f5);border:1px solid var(--border-muted, #d4d4d8);border-radius:6px;font-size:13px;cursor:pointer}.upload-bulk-tag button:hover:not(:disabled){background-color:var(--bg-muted, #e4e4e7)}.upload-files-list{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow-y:auto}.upload-file-item{display:flex;align-items:flex-start;gap:12px;padding:12px;background-color:var(--bg-subtle, #fafafa);border-radius:8px;border:1px solid var(--border-subtle, #e5e5e5)}.upload-file-preview{width:60px;height:60px;border-radius:6px;overflow:hidden;background-color:var(--bg-muted, #e4e4e7);flex-shrink:0;display:flex;align-items:center;justify-content:center}.upload-file-preview img{width:100%;height:100%;object-fit:cover}.upload-file-video-icon{color:var(--fg-muted, #71717a)}.upload-file-info{flex:1;min-width:0}.upload-file-name{font-size:14px;font-weight:500;color:var(--fg-default, #18181b);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.upload-file-size{font-size:12px;color:var(--fg-muted, #71717a);margin-top:2px}.upload-file-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.upload-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background-color:#dbeafe;color:#1d4ed8;border-radius:12px;font-size:12px}.upload-tag-remove{background:none;border:none;padding:0;cursor:pointer;color:#1d4ed8;font-size:14px;line-height:1}.upload-tag-input{padding:2px 8px;border:1px dashed var(--border-muted, #d4d4d8);border-radius:12px;font-size:12px;width:80px}.upload-file-remove{background:none;border:none;cursor:pointer;color:var(--fg-muted, #71717a);font-size:20px;line-height:1;padding:4px}.upload-file-remove:hover{color:#dc2626}.upload-progress-section{margin-top:24px;padding:16px;background-color:var(--bg-subtle, #fafafa);border-radius:8px}.upload-progress-section h3{margin:0 0 12px;font-size:14px;font-weight:600}.upload-error-count{color:#dc2626;font-size:13px;margin:0 0 12px}.upload-progress-bar{height:8px;background-color:var(--bg-muted, #e4e4e7);border-radius:4px;overflow:hidden}.upload-progress-fill{height:100%;background-color:var(--accent-default, #2563eb);border-radius:4px;transition:width .3s}.upload-progress-list{margin-top:12px;max-height:150px;overflow-y:auto}.upload-progress-item{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:13px;border-bottom:1px solid var(--border-subtle, #e5e5e5)}.upload-progress-item:last-child{border-bottom:none}.upload-progress-filename{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:80%}.upload-progress-item.uploading .upload-progress-status{color:var(--accent-default, #2563eb)}.media-edit-form{display:flex;flex-direction:column;gap:20px}.media-edit-preview{width:100%;max-height:300px;object-fit:contain;border-radius:8px;background-color:var(--bg-subtle, #fafafa)}.media-edit-field{display:flex;flex-direction:column;gap:6px}.media-edit-field label{font-size:13px;font-weight:500;color:var(--fg-muted, #71717a)}.media-edit-field input,.media-edit-field textarea{padding:10px 12px;border:1px solid var(--border-muted, #d4d4d8);border-radius:8px;font-size:14px}.media-edit-field textarea{min-height:80px;resize:vertical}.media-edit-tags{display:flex;flex-wrap:wrap;gap:8px;padding:12px;background-color:var(--bg-subtle, #fafafa);border-radius:8px;min-height:50px}.media-edit-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;background-color:#dbeafe;color:#1d4ed8;border-radius:16px;font-size:13px}.media-edit-tag-remove{background:none;border:none;padding:0;cursor:pointer;color:#1d4ed8;font-size:14px;line-height:1}.media-edit-tag-input{flex:1;min-width:100px;border:none;background:transparent;font-size:13px;outline:none}.tag-management{display:flex;flex-direction:column;gap:16px}.tag-create-form{display:flex;gap:8px}.tag-create-form input{flex:1;padding:10px 12px;border:1px solid var(--border-muted, #d4d4d8);border-radius:8px;font-size:14px}.tag-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.tag-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background-color:var(--bg-subtle, #fafafa);border-radius:8px;border:1px solid var(--border-subtle, #e5e5e5)}.tag-item-info{display:flex;align-items:center;gap:12px}.tag-item-name{font-weight:500;color:var(--fg-default, #18181b)}.tag-item-count{font-size:12px;color:var(--fg-muted, #71717a);background-color:var(--bg-muted, #e4e4e7);padding:2px 8px;border-radius:10px}.tag-item-actions{display:flex;gap:8px}.tag-item-actions button{padding:6px 12px;font-size:12px;border-radius:6px;cursor:pointer}.bulk-operations-bar{display:flex;align-items:center;justify-content:space-between;padding:12px 24px;background-color:var(--accent-default, #2563eb);color:#fff;border-radius:8px;margin-bottom:16px}.bulk-operations-info{font-weight:500}.bulk-operations-actions{display:flex;gap:8px}.bulk-operations-actions button{padding:8px 16px;background-color:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;font-size:13px;cursor:pointer;transition:background-color .2s}.bulk-operations-actions button:hover{background-color:#ffffff4d}.bulk-operations-actions button.danger{background-color:#dc2626cc;border-color:#dc2626e6}.bulk-operations-actions button.danger:hover{background-color:#b91c1ce6}.admin-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;padding:16px}.admin-gallery-item{position:relative;border-radius:8px;overflow:hidden;cursor:pointer;background-color:var(--bg-subtle, #fafafa);aspect-ratio:1}.admin-gallery-item img,.admin-gallery-item video,.admin-gallery-item .optimized-image-container,.admin-gallery-item .optimized-image-container img,.admin-gallery-item .optimized-image-container video{width:100%;height:100%;object-fit:cover}.admin-gallery-item .optimized-image-container{min-height:100%}.admin-gallery-item-overlay{position:absolute;inset:0;background:linear-gradient(transparent 60%,#000000b3);opacity:0;transition:opacity .2s}.admin-gallery-item:hover .admin-gallery-item-overlay{opacity:1}.admin-gallery-item-checkbox{position:absolute;top:8px;left:8px;width:24px;height:24px;border:2px solid white;border-radius:4px;background-color:#ffffffe6;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s}.admin-gallery-item:hover .admin-gallery-item-checkbox,.admin-gallery-item.selected .admin-gallery-item-checkbox{opacity:1}.admin-gallery-item.selected .admin-gallery-item-checkbox{background-color:var(--accent-default, #2563eb);border-color:var(--accent-default, #2563eb)}.admin-gallery-item-checkbox svg{color:#fff}.admin-gallery-item-actions{position:absolute;bottom:12px;left:12px;right:12px;display:flex;align-items:center;justify-content:space-between;gap:8px;opacity:0;transition:opacity .2s}.admin-gallery-item:hover .admin-gallery-item-actions{opacity:1}.admin-gallery-create-print{display:flex;align-items:center;gap:6px;padding:8px 14px;background-color:#18181b;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .15s}.admin-gallery-create-print:hover{background-color:#27272a}.admin-gallery-create-print svg{flex-shrink:0}.admin-gallery-menu-wrapper{position:relative}.admin-gallery-menu-btn{width:32px;height:32px;border-radius:6px;background-color:#ffffffe6;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:#18181b;transition:background-color .15s}.admin-gallery-menu-btn:hover{background-color:#fff}.admin-gallery-menu-backdrop{position:fixed;inset:0;z-index:99}.admin-gallery-menu{position:absolute;bottom:100%;right:0;margin-bottom:4px;background:#fff;border-radius:8px;box-shadow:0 4px 16px #00000026;min-width:140px;padding:4px;z-index:100}.admin-gallery-menu button{display:flex;align-items:center;gap:10px;width:100%;padding:10px 12px;background:none;border:none;border-radius:6px;font-size:13px;color:#18181b;cursor:pointer;text-align:left;transition:background-color .15s}.admin-gallery-menu button:hover{background-color:#f4f4f5}.admin-gallery-menu button svg{flex-shrink:0;color:#71717a}.admin-page{padding:24px;max-width:1400px;margin:0 auto;width:100%}.admin-page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.admin-page-header h1{margin:0;font-size:24px;font-weight:600}.admin-page-actions{display:flex;gap:12px}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background-color:var(--bg-subtle, #fafafa);border-radius:8px;margin-bottom:16px}.admin-toolbar-left,.admin-toolbar-right{display:flex;align-items:center;gap:12px}.admin-search-input{padding:8px 12px;border:1px solid var(--border-muted, #d4d4d8);border-radius:6px;font-size:14px;width:250px}.admin-filter-select{padding:8px 12px;border:1px solid var(--border-muted, #d4d4d8);border-radius:6px;font-size:14px;background-color:#fff;cursor:pointer}.admin-filter-select:hover{border-color:var(--border-default, #a1a1aa)}.admin-filters-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.admin-filters-group{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-filters-actions{display:flex;align-items:center;gap:12px}.admin-btn-text{background:none;border:none;color:var(--fg-muted, #71717a);font-size:13px;cursor:pointer;padding:4px 8px}.admin-btn-text:hover{color:var(--fg-default, #18181b)}.upload-size-warning{color:#ca8a04;font-size:12px}.upload-size-error{color:#dc2626;font-size:12px;font-weight:500}.upload-error-message{background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;padding:12px 16px;color:#dc2626;font-size:14px;margin-top:16px}.upload-error-message strong{display:block;margin-bottom:4px}.upload-progress-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.upload-progress-item{padding:12px;background:#f9fafb;border-radius:8px;margin-bottom:8px}.upload-progress-item.uploading{background:#eff6ff;border:1px solid #bfdbfe}.upload-progress-item.complete{background:#f0fdf4;border:1px solid #bbf7d0}.upload-progress-item.error{background:#fef2f2;border:1px solid #fecaca}.upload-progress-item .upload-progress-bar{height:8px;background:#e5e7eb;border-radius:4px;overflow:hidden}.upload-progress-item .upload-progress-fill{height:100%;background:#3b82f6;border-radius:4px;transition:width .2s ease}.upload-progress-status{font-size:13px;font-weight:500;color:#6b7280}.upload-progress-item.uploading .upload-progress-status{color:#3b82f6}.upload-progress-item.complete .upload-progress-status{color:#16a34a}.upload-progress-item.error .upload-progress-status{color:#dc2626}.people-filter{display:flex;align-items:center;gap:12px;padding:0 64px;margin-bottom:24px}.people-filter-label{font-size:13px;color:#71717a;flex-shrink:0}.people-filter-list{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.people-filter-item{display:flex;flex-direction:column;align-items:center;gap:4px;padding:4px;background:none;border:2px solid transparent;border-radius:8px;cursor:pointer;transition:all .15s ease}.people-filter-item:hover{background:#f4f4f5}.people-filter-item.selected{border-color:#18181b;background:#f4f4f5}.people-filter-name{font-size:11px;color:#71717a;max-width:60px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.people-filter-clear{padding:6px 12px;font-size:12px;color:#71717a;background:#f4f4f5;border:1px solid #e4e4e7;border-radius:6px;cursor:pointer;transition:all .15s ease}.people-filter-clear:hover{background:#e4e4e7;color:#18181b}.face-thumbnail{width:40px;height:40px;border-radius:50%;background-color:#e4e4e7;overflow:hidden;flex-shrink:0;position:relative}.face-thumbnail img{display:block;width:100%;height:100%;object-fit:cover}.face-thumbnail-placeholder{display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#71717a;background:linear-gradient(135deg,#e4e4e7,#d4d4d8)}.face-management-modal{max-width:420px;overflow:hidden}.face-management-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e4e4e7}.face-management-title{display:flex;align-items:center;gap:12px}.face-management-title svg{color:#18181b}.face-management-title h2{margin:0;font-size:18px;font-weight:600;color:#18181b}.face-management-close{background:none;border:none;padding:4px;cursor:pointer;color:#71717a;transition:all .15s ease;display:flex;align-items:center;justify-content:center;border-radius:6px}.face-management-close:hover{color:#18181b;background:#f4f4f5}.face-management-body{padding:24px}.face-management-alert{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:8px;font-size:13px;margin-bottom:20px}.face-management-alert.error{background:#fef2f2;color:#dc2626;border:1px solid #fecaca}.face-management-alert.success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.face-management-stats{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}.face-stat-card{display:flex;flex-direction:column;align-items:center;padding:20px 16px;background:#fafafa;border:1px solid #e4e4e7;border-radius:12px;text-align:center}.face-stat-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:#fff;border-radius:10px;margin-bottom:12px;color:#18181b;box-shadow:0 1px 3px #00000014}.face-stat-value{font-size:32px;font-weight:700;color:#18181b;line-height:1;margin-bottom:4px}.face-stat-label{font-size:12px;color:#71717a;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.face-management-info{padding:16px;background:#f4f4f5;border-radius:10px;margin-bottom:20px}.face-management-info p{margin:0;font-size:13px;color:#52525b;line-height:1.6}.face-management-reset{padding:16px;background:#fffbeb;border:1px solid #fde68a;border-radius:10px}.face-reset-header{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:#92400e;margin-bottom:8px}.face-reset-description{margin:0 0 14px;font-size:12px;color:#a16207;line-height:1.5}.face-reset-confirm{display:flex;gap:10px}.face-reset-btn{flex:1;padding:10px 16px;font-size:13px;font-weight:500;border-radius:8px;cursor:pointer;transition:all .15s ease;border:none}.face-reset-btn.outline{background:#fff;color:#92400e;border:1px solid #fbbf24}.face-reset-btn.outline:hover{background:#fef3c7}.face-reset-btn.danger{background:#dc2626;color:#fff}.face-reset-btn.danger:hover{background:#b91c1c}.face-reset-btn.cancel{background:#e4e4e7;color:#52525b}.face-reset-btn.cancel:hover{background:#d4d4d8}.face-reset-btn:disabled{opacity:.6;cursor:not-allowed}.print-builder{display:flex;flex-direction:column;width:100%;height:100%;max-height:90vh;background:#fff}.print-builder-header{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-bottom:1px solid var(--border-strong, #e4e4e7)}.print-builder-title{font-family:Slussen,sans-serif;font-weight:600;font-size:18px;color:var(--fg-base, #18181b);margin:0}.print-builder-close{background:none;border:none;cursor:pointer;color:var(--fg-muted, #71717a);padding:4px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:background-color .15s ease}.print-builder-close:hover{background-color:#0000000a;color:var(--fg-base, #18181b)}.print-builder-body{display:flex;flex:1;overflow:hidden}.print-builder-controls{width:320px;padding:24px;overflow-y:auto;border-right:1px solid var(--border-strong, #e4e4e7);display:flex;flex-direction:column;gap:20px}.print-builder-preview{flex:1;padding:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-field-component, #fafafa);overflow:hidden}.print-builder-footer{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;border-top:1px solid var(--border-strong, #e4e4e7);background:#fff}.pb-form-group{display:flex;flex-direction:column;gap:8px}.pb-label{font-family:Slussen,sans-serif;font-size:13px;font-weight:500;color:var(--fg-base, #18181b)}.pb-select{padding:10px 12px;border:1px solid var(--border-strong, #e4e4e7);border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;color:var(--fg-base, #18181b);background:#fff;cursor:pointer}.pb-select:focus{outline:none;border-color:var(--fg-muted, #71717a)}.pb-input{padding:10px 12px;border:1px solid var(--border-strong, #e4e4e7);border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;color:var(--fg-base, #18181b);background:#fff}.pb-input:focus{outline:none;border-color:var(--fg-muted, #71717a)}.pb-textarea{padding:10px 12px;border:1px solid var(--border-strong, #e4e4e7);border-radius:8px;font-family:Slussen,sans-serif;font-size:14px;color:var(--fg-base, #18181b);background:#fff;resize:vertical;min-height:80px}.pb-textarea:focus{outline:none;border-color:var(--fg-muted, #71717a)}.pb-options{display:flex;flex-wrap:wrap;gap:8px}.pb-option{padding:8px 14px;border:1px solid var(--border-strong, #e4e4e7);border-radius:20px;font-family:Slussen,sans-serif;font-size:13px;color:var(--fg-muted, #71717a);background:#fff;cursor:pointer;transition:all .15s ease}.pb-option:hover{border-color:var(--fg-muted, #71717a);color:var(--fg-base, #18181b)}.pb-option.selected{background:var(--fg-base, #18181b);border-color:var(--fg-base, #18181b);color:#fff}.pb-quantity{display:flex;align-items:center;gap:12px}.pb-quantity-btn{width:32px;height:32px;border:1px solid var(--border-strong, #e4e4e7);border-radius:8px;background:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--fg-muted, #71717a);transition:all .15s ease}.pb-quantity-btn:hover{border-color:var(--fg-muted, #71717a);color:var(--fg-base, #18181b)}.pb-quantity-value{font-family:Slussen,sans-serif;font-size:16px;font-weight:500;color:var(--fg-base, #18181b);min-width:32px;text-align:center}.pb-price{font-family:Slussen,sans-serif;font-size:24px;font-weight:600;color:var(--fg-base, #18181b)}.pb-price-label{font-family:Slussen,sans-serif;font-size:13px;color:var(--fg-muted, #71717a)}.pb-btn-primary{padding:12px 24px;background:var(--fg-base, #18181b);color:#fff;border:none;border-radius:10px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:opacity .15s ease}.pb-btn-primary:hover{opacity:.9}.pb-btn-primary:disabled{opacity:.5;cursor:not-allowed}.pb-btn-secondary{padding:12px 24px;background:#fff;color:var(--fg-base, #18181b);border:1px solid var(--border-strong, #e4e4e7);border-radius:10px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .15s ease}.pb-btn-secondary:hover{border-color:var(--fg-muted, #71717a)}.pb-divider{height:1px;background:var(--border-strong, #e4e4e7);margin:4px 0}.print-type-selector{display:flex;flex-direction:column;gap:12px;padding:24px}.print-type-option{display:flex;align-items:center;gap:16px;padding:16px;border:1px solid var(--border-strong, #e4e4e7);border-radius:12px;cursor:pointer;transition:all .15s ease}.print-type-option:hover{border-color:var(--fg-muted, #71717a);background:var(--bg-field-component, #fafafa)}.print-type-icon{width:48px;height:48px;border-radius:8px;background:var(--bg-field-component, #fafafa);display:flex;align-items:center;justify-content:center;color:var(--fg-muted, #71717a)}.print-type-info{flex:1}.print-type-name{font-family:Slussen,sans-serif;font-size:15px;font-weight:500;color:var(--fg-base, #18181b);margin:0 0 4px}.print-type-desc{font-family:Slussen,sans-serif;font-size:13px;color:var(--fg-muted, #71717a);margin:0}.print-type-price{font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:var(--fg-base, #18181b)}.pb-toggle-container{display:flex;gap:8px;margin-bottom:8px}.pb-toggle-btn{flex:1;padding:12px 16px;border:1px solid var(--border-strong, #e4e4e7);border-radius:10px;font-family:Slussen,sans-serif;font-size:14px;font-weight:500;color:var(--fg-muted, #71717a);background:#fff;cursor:pointer;transition:all .15s ease}.pb-toggle-btn:hover{border-color:var(--fg-muted, #a1a1aa)}.pb-toggle-btn.active{background:var(--fg-base, #18181b);color:#fff;border-color:var(--fg-base, #18181b)}.border-print-preview-container{width:100%;max-width:350px;background:#fff;border-radius:8px;box-shadow:0 4px 12px #0000001a;overflow:hidden;position:relative}.border-print-preview{width:100%;height:100%;display:flex;flex-direction:column;box-sizing:border-box}.border-print-photo-wrapper{flex:1;display:flex;align-items:center;justify-content:center;min-height:0}.border-print-photo{width:100%;height:100%;object-fit:cover;border-radius:2px}.border-print-footer{display:flex;align-items:center;gap:12px;padding-top:12px;min-height:50px}.border-print-seal-img{width:50px;height:50px;object-fit:contain;flex-shrink:0}.border-print-caption{flex:1;font-size:14px;font-style:italic;margin:0;text-align:center}.border-print-spacer{width:50px;flex-shrink:0}.cr-preview-container{width:100%;max-width:350px;background:#fff;border:8px solid #c5a028;border-radius:4px;box-shadow:0 4px 12px #0000001a;padding:24px}.cr-preview-header{text-align:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-strong, #e4e4e7)}.cr-preview-chamber{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--fg-muted, #71717a);margin-bottom:4px}.cr-preview-title{font-size:16px;font-weight:600;color:var(--fg-base, #18181b)}.cr-preview-body{font-size:12px;line-height:1.6;color:var(--fg-base, #18181b);margin-bottom:16px}.cr-preview-footer{text-align:right;font-size:11px;color:var(--fg-muted, #71717a)}.cr-preview-member{font-weight:500;color:var(--fg-base, #18181b)}.modal:has(.print-builder){max-width:900px;padding:0}.modal:has(.print-builder)>.modal-close{display:none}.modal:has(.print-type-selector){max-width:420px;padding:0}.logo-uploader{border:2px dashed var(--border-strong, #e4e4e7);border-radius:8px;padding:16px;text-align:center;cursor:pointer;transition:all .15s ease}.logo-uploader:hover{border-color:var(--fg-muted, #71717a);background:var(--bg-field-component, #fafafa)}.logo-uploader.has-logo{border-style:solid;padding:8px}.logo-uploader-preview{max-width:100%;max-height:60px;object-fit:contain}.logo-uploader-text{font-family:Slussen,sans-serif;font-size:12px;color:var(--fg-muted, #71717a)}.pb-color-options{display:flex;gap:8px}.pb-color-swatch{width:32px;height:32px;border-radius:50%;cursor:pointer;border:2px solid transparent;transition:all .15s ease}.pb-color-swatch.selected{border-color:var(--fg-base, #18181b)}.pb-color-swatch.white{background:#fff;box-shadow:inset 0 0 0 1px var(--border-strong, #e4e4e7)}.pb-color-swatch.cream{background:beige}.pb-color-swatch.gray{background:#9ca3af}.pb-color-swatch.black{background:#18181b}@media(max-width:768px){.print-builder{max-height:95vh}.print-builder-body{flex-direction:column}.print-builder-preview{order:1;min-height:200px;max-height:35vh;padding:16px;flex:none}.print-builder-controls{order:2;width:100%;border-right:none;border-top:1px solid var(--border-strong, #e4e4e7);max-height:45vh;overflow-y:auto}.print-builder-footer{padding:12px 16px}.modal:has(.print-builder){max-width:100%;width:100%;margin:0;border-radius:16px 16px 0 0;max-height:95vh}.modal-overlay:has(.print-builder){align-items:flex-end}.print-type-option{padding:12px}.print-type-icon{width:40px;height:40px}.border-print-preview-container,.cr-preview-container{max-width:280px}}@media(max-width:480px){.print-builder-controls{padding:16px;gap:16px}.pb-options{gap:6px}.pb-option{padding:6px 12px;font-size:12px}.pb-quantity-btn{min-width:44px;min-height:44px}.pb-btn-primary,.pb-btn-secondary{padding:14px 20px;min-height:44px}.print-builder-footer{flex-direction:column;gap:8px}.print-builder-footer>*{width:100%}.pb-toggle-btn{padding:10px 12px;font-size:13px}}
