@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@300;400;500;600;700&family=Inter:wght@400;500&display=swap");@font-face{font-family:Family;src:local("Family-Heavy"),local("Family Heavy"),local("FamilyHeavy");font-weight:900;font-style:normal;font-display:swap}@font-face{font-family:Family;src:local("Family-Bold"),local("Family Bold"),local("FamilyBold");font-weight:700;font-style:normal;font-display:swap}@font-face{font-family:Family;src:local("Family-Regular"),local("Family Regular"),local("Family");font-weight:400;font-style:normal;font-display:swap}*,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(59,130,246,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }

/* ! tailwindcss v3.4.19 | MIT License | https://tailwindcss.com */*,:after,:before{border:0 solid #e5e7eb}:after,:before{--tw-content:""}:host,html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}.container{width:100%}@media (min-width:640px){.container{max-width:640px}}@media (min-width:768px){.container{max-width:768px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1280px){.container{max-width:1280px}}@media (min-width:1536px){.container{max-width:1536px}}.relative{position:relative}.flex{display:flex}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}:root{--wildfire:#d4502f;--wildfire-dark:#b8421f;--wildfire-light:#fae9e4;--pine:#34543f;--pine-dark:#27402f;--pine-light:#e6efe8;--sage:#a8b9ac;--stoney:#353a43;--pure-white:#fff;--pure-black:#000;--bg:#fff;--surface:#fff;--surface-subtle:#f7f7f7;--border:#e6e6e6;--text:#353a43;--text-muted:#8a9099;--accent:#d4502f;--accent-light:#fae9e4;--accent-hover:#b8421f;--selected:#d4502f;--tray-height:104px}*,:after,:before{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background-color:var(--bg);color:var(--text);font-family:DM Sans,system-ui,sans-serif;margin:0;padding:0}.font-family{font-family:Family,Georgia,serif}.font-dm{font-family:DM Sans,system-ui,sans-serif}.font-inter{font-family:Inter,system-ui,sans-serif}.text-h1{font-size:32px;font-weight:900}.text-h1,.text-h2{font-family:Family,Georgia,serif}.text-h2{font-size:22px;font-weight:700}.text-h3{font-size:18px;font-weight:600}.text-body,.text-h3{font-family:DM Sans,sans-serif}.text-body{font-size:16px;font-weight:400}.text-sub{font-family:Inter,sans-serif;font-size:15px;font-weight:400}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes cardEntrance{0%{opacity:0;transform:translateY(12px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse-select{0%{box-shadow:0 0 0 0 rgba(212,80,47,.4)}70%{box-shadow:0 0 0 8px rgba(212,80,47,0)}to{box-shadow:0 0 0 0 rgba(212,80,47,0)}}@keyframes skeleton-shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(1turn)}}.animate-fade-in{animation:fadeIn .3s ease forwards}.animate-slide-up{animation:slideUp .3s ease forwards}.animate-slide-in-right{animation:slideInRight .3s ease forwards}.animate-toast{animation:toastIn .25s ease forwards}.animate-spin{animation:spin .8s linear infinite}.app-header{background:var(--surface);border-bottom:1px solid var(--border);height:60px;display:flex;align-items:center;padding:0 24px;position:sticky;top:0;z-index:50}.app-logo{font-family:Family,Georgia,serif;font-size:22px;font-weight:700;color:var(--accent);letter-spacing:-.2px}.category-tabs{background:var(--surface);border-bottom:1px solid var(--border);padding:0 24px;display:flex;gap:4px;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none;position:sticky;top:60px;z-index:40}.category-tabs::-webkit-scrollbar{display:none}.category-tab{font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;padding:10px 16px;background:transparent;color:var(--text-muted);cursor:pointer;white-space:nowrap;border:none;border-bottom:2px solid transparent;transition:color .15s ease,border-color .15s ease;margin-bottom:-1px}.category-tab:hover{color:var(--text)}.category-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;padding:24px;padding-bottom:calc(var(--tray-height) + 32px)}@media (max-width:1024px){.product-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width:640px){.product-grid{grid-template-columns:repeat(2,1fr);padding:16px;gap:12px}}.product-card{background:var(--surface);border-radius:10px;box-shadow:0 2px 8px rgba(0,0,0,.06);overflow:hidden;cursor:pointer;border:2px solid transparent;transition:transform .2s ease,box-shadow .2s ease,border-color .15s ease;animation:cardEntrance .3s ease both;position:relative}.product-card:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.1)}.product-card.selected{border-color:var(--selected);animation:pulse-select .4s ease}.product-card.selected:hover{transform:translateY(-2px)}.card-image-wrap{position:relative;width:100%;aspect-ratio:4/5;background:#f2f2f2;overflow:hidden}.card-image-wrap img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block;transition:transform .3s ease}.product-card:hover .card-image-wrap img{transform:scale(1.02)}.card-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#f2f2f2,#e8e8e8);color:var(--text-muted);font-family:Family,Georgia,serif;font-size:28px;font-weight:700;letter-spacing:1px;-webkit-user-select:none;-moz-user-select:none;user-select:none}.card-check,.card-placeholder{display:flex;align-items:center;justify-content:center}.card-check{position:absolute;top:8px;right:8px;width:26px;height:26px;background:var(--accent);border-radius:50%;color:#fff;box-shadow:0 2px 6px rgba(0,0,0,.2)}.card-check svg{width:14px;height:14px;stroke:#fff;stroke-width:2.5;fill:none}.card-body{padding:10px 12px 12px}.card-title{font-size:13px;font-weight:400;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;margin:0 0 6px}.card-title,.card-type{font-family:DM Sans,sans-serif}.card-type{font-size:11px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.skeleton{background:linear-gradient(90deg,#f2f2f2 25%,#e8e8e8 50%,#f2f2f2 75%);background-size:600px 100%;animation:skeleton-shimmer 1.4s ease infinite;border-radius:10px}.skeleton-card{background:var(--surface);border-radius:10px;box-shadow:0 1px 4px rgba(0,0,0,.06);border:1px solid var(--border);overflow:hidden}.skeleton-image{aspect-ratio:4/5;background:linear-gradient(90deg,#f2f2f2 25%,#e8e8e8 50%,#f2f2f2 75%);background-size:800px 100%;animation:skeleton-shimmer 1.4s ease infinite}.skeleton-text{height:12px;margin:10px 12px 6px}.skeleton-text,.skeleton-text-sm{border-radius:6px;background:linear-gradient(90deg,#f2f2f2 25%,#e8e8e8 50%,#f2f2f2 75%);background-size:800px 100%;animation:skeleton-shimmer 1.4s ease infinite}.skeleton-text-sm{height:10px;width:60%;margin:0 12px 12px}.outfit-tray{position:fixed;bottom:0;left:0;right:0;height:var(--tray-height);background:var(--surface);border-top:1px solid var(--border);box-shadow:0 -2px 16px rgba(0,0,0,.08);display:flex;align-items:center;gap:16px;padding:0 24px;z-index:100}.tray-thumbnails{display:flex;gap:8px;flex:1;overflow-x:auto;scrollbar-width:none;-ms-overflow-style:none}.tray-thumbnails::-webkit-scrollbar{display:none}.tray-thumb{width:62px;height:62px;border-radius:8px;overflow:hidden;border:2px solid var(--border);flex-shrink:0;background:#f2f2f2;position:relative}.tray-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.tray-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f2f2f2,#e8e8e8);font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;color:var(--text-muted)}.tray-empty-slots{display:flex;gap:8px}.tray-slot{width:62px;height:62px;border-radius:8px;border:2px dashed var(--border);flex-shrink:0}.tray-count{font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;color:var(--text-muted);white-space:nowrap}.tray-count span{color:var(--accent);font-weight:600}.tray-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}.btn{font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;padding:9px 18px;border-radius:8px;border:1px solid transparent;cursor:pointer;transition:background .15s ease,border-color .15s ease,opacity .15s ease;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-primary:hover:not(:disabled){background:var(--accent-hover);border-color:var(--accent-hover)}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-secondary{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn-secondary:hover{color:var(--text);border-color:silver}.btn-pine{background:transparent;color:var(--pine);border-color:var(--pine)}.btn-pine:hover:not(:disabled){background:var(--pine-light)}.btn-pine:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-muted);border-color:transparent;padding:9px 12px}.btn-ghost:hover{color:var(--text);background:var(--surface-subtle)}.btn-danger{background:transparent;color:#b45309;border-color:transparent;padding:6px 10px;font-size:12px}.btn-danger:hover{background:#fef3c7}.badge{background:var(--accent);color:#fff;font-family:DM Sans,sans-serif;font-size:11px;font-weight:600;padding:2px 7px;border-radius:20px;display:inline-block;line-height:18px}.outfits-panel-overlay{position:fixed;inset:0;background:rgba(26,24,23,.4);z-index:200;backdrop-filter:blur(2px);animation:fadeIn .2s ease}.outfits-panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:100vw;background:var(--surface);box-shadow:-4px 0 32px rgba(0,0,0,.12);z-index:201;display:flex;flex-direction:column;animation:slideInRight .3s ease}@media (max-width:540px){.outfits-panel{width:100vw}}.panel-header{padding:20px 24px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.panel-title{font-family:Family,Georgia,serif;font-size:22px;font-weight:700;color:var(--text)}.panel-body{flex:1;overflow-y:auto;padding:16px 24px}.panel-footer{padding:16px 24px;border-top:1px solid var(--border);display:flex;gap:8px;flex-shrink:0}.outfit-row{border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:12px;background:var(--surface-subtle)}.outfit-row-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.outfit-row-id{font-weight:500;letter-spacing:.3px}.outfit-row-date,.outfit-row-id{font-family:DM Sans,sans-serif;font-size:11px;color:var(--text-muted)}.outfit-row-thumbs{display:flex;gap:8px;flex-wrap:wrap}.outfit-row-thumb{width:52px;height:52px;border-radius:6px;overflow:hidden;background:#f2f2f2;border:1px solid var(--border);flex-shrink:0}.outfit-row-thumb img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;display:block}.outfit-row-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:var(--text-muted);background:linear-gradient(135deg,#f2f2f2,#e8e8e8)}.outfit-row-titles{margin-top:8px;font-family:DM Sans,sans-serif;font-size:11px;color:var(--text-muted);line-height:1.5}.login-page{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:24px}.login-card{background:var(--surface);border-radius:16px;padding:48px 40px;width:100%;max-width:400px;box-shadow:0 4px 24px rgba(0,0,0,.08);animation:fadeIn .4s ease}.login-logo{font-family:Family,Georgia,serif;font-size:32px;font-weight:900;color:var(--accent);margin-bottom:6px}.login-tagline{font-family:DM Sans,sans-serif;font-size:14px;color:var(--text-muted);margin-bottom:36px}.form-label{font-size:13px;font-weight:500;display:block;margin-bottom:6px}.form-input,.form-label{font-family:DM Sans,sans-serif;color:var(--text)}.form-input{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;background:var(--surface);outline:none;transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-light)}.form-input::-moz-placeholder{color:var(--text-muted)}.form-input::placeholder{color:var(--text-muted)}.form-group{margin-bottom:18px}.btn-login{width:100%;padding:12px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-family:DM Sans,sans-serif;font-size:14px;font-weight:600;cursor:pointer;transition:background .15s ease;margin-top:8px;display:flex;align-items:center;justify-content:center;gap:8px}.btn-login:hover:not(:disabled){background:var(--accent-hover)}.btn-login:disabled{opacity:.6;cursor:not-allowed}.toast-container{position:fixed;top:72px;right:24px;z-index:999;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;padding:12px 16px;border-radius:8px;box-shadow:0 4px 16px rgba(0,0,0,.12);animation:toastIn .25s ease;pointer-events:all;max-width:320px;display:flex;align-items:center;gap:8px}.toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast-success{background:#f0fdf4;color:#166534;border:1px solid #bbf7d0}.toast-info{background:var(--pine-light);color:var(--pine);border:1px solid var(--sage)}.spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite;display:inline-block}.spinner-lg{width:36px;height:36px;border-width:3px}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 24px;text-align:center;color:var(--text-muted)}.empty-state-icon{font-size:48px;margin-bottom:16px;opacity:.4}.empty-state-title{font-family:Family,Georgia,serif;font-size:22px;font-weight:700;color:var(--text);margin-bottom:8px}.empty-state-sub{font-size:14px;line-height:1.5;max-width:280px}.avatar{width:32px;height:32px;border-radius:50%;background:var(--pine-light);color:var(--pine);font-family:DM Sans,sans-serif;font-size:12px;font-weight:600;flex-shrink:0}.avatar,.loading-center{display:flex;align-items:center;justify-content:center}.loading-center{padding:80px 24px}.close-btn{background:transparent;border:none;cursor:pointer;color:var(--text-muted);padding:4px;border-radius:4px;display:flex;align-items:center;transition:color .15s ease}.close-btn:hover{color:var(--text)}.outfit-count{font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;color:var(--text-muted);white-space:nowrap}