:root{--primary: #6750a4;--primary-dark: #4f378b;--primary-container: #eaddff;--on-primary: #ffffff;--secondary: #625b71;--surface: #fffbfe;--surface-variant: #f3edf7;--outline: #cac4d0;--error: #b3261e;--text-primary: #1c1b1f;--text-secondary: #49454f;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--shadow: 0 1px 4px rgba(0, 0, 0, .14);--shadow-md: 0 4px 12px rgba(0, 0, 0, .15);--nav-height: 64px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#e8e0f0;color:var(--text-primary);min-height:100vh;display:flex;justify-content:center}#root{width:100%;display:flex;justify-content:center}.app{width:100%;max-width:480px;min-height:100vh;background:var(--surface-variant);display:flex;flex-direction:column;position:relative}.app-body{flex:1;display:flex;flex-direction:column;min-height:0}.content{flex:1;overflow-y:auto;padding-bottom:calc(var(--nav-height) + 8px)}.top-bar{background:var(--primary);color:var(--on-primary);padding:14px 16px;display:flex;align-items:center;gap:12px;position:sticky;top:0;z-index:20;box-shadow:var(--shadow)}.top-bar h1{font-size:20px;font-weight:600;flex:1}.top-bar button,.top-bar a{background:none;border:none;color:var(--on-primary);cursor:pointer;font-size:22px;padding:4px;border-radius:50%;display:flex;align-items:center;text-decoration:none;transition:background .15s}.top-bar button:hover,.top-bar a:hover{background:#ffffff2e}.bottom-nav{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;height:var(--nav-height);background:var(--surface);border-top:1px solid var(--outline);display:flex;z-index:30}.nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;text-decoration:none;color:var(--secondary);font-size:11px;font-weight:500;cursor:pointer;transition:color .15s;padding:4px 0}.nav-item .nav-icon{font-size:22px;line-height:1}.nav-item.active{color:var(--primary)}.nav-item.active .nav-indicator{width:64px;height:32px;background:var(--primary-container);border-radius:16px;display:flex;align-items:center;justify-content:center;margin-bottom:2px}.chips-row{display:flex;gap:8px;padding:12px 16px;overflow-x:auto;scrollbar-width:none}.chips-row::-webkit-scrollbar{display:none}.chip{flex-shrink:0;padding:6px 14px;border-radius:20px;border:1.5px solid var(--outline);background:var(--surface);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;transition:all .15s}.chip:hover{border-color:var(--primary);color:var(--primary)}.chip.active{background:var(--primary);border-color:var(--primary);color:var(--on-primary)}.search-bar{display:flex;align-items:center;gap:8px;margin:0 16px 8px;background:var(--surface);border:1.5px solid var(--outline);border-radius:var(--radius-lg);padding:8px 14px}.search-bar input{flex:1;border:none;outline:none;font-size:14px;background:transparent;color:var(--text-primary)}.search-bar .search-icon{font-size:16px;color:var(--text-secondary)}.clothing-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;padding:0 16px 16px}.clothing-card{background:var(--surface);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);position:relative;cursor:pointer}.clothing-card-image{width:100%;aspect-ratio:1;object-fit:cover;display:block;background:var(--surface-variant)}.clothing-card-emoji{width:100%;aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:56px;background:var(--surface-variant)}.clothing-card-media-link{display:block;text-decoration:none}.clothing-card-info{padding:8px 10px}.clothing-card-name{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.clothing-card-meta{font-size:11px;color:var(--text-secondary);margin-top:2px;display:flex;gap:6px}.cat-badge{background:var(--primary-container);color:var(--primary);border-radius:10px;padding:1px 6px;font-size:10px;font-weight:600}.clothing-card-labels{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.clothing-label-chip{background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;border-radius:10px;padding:1px 7px;font-size:10px;font-weight:500}.label-input-row{display:flex;gap:6px}.label-text-input{flex:1}.label-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.label-chip{display:inline-flex;align-items:center;gap:4px;background:#f0fdf4;color:#16a34a;border:1px solid #bbf7d0;border-radius:12px;padding:3px 10px;font-size:12px;font-weight:500}.label-chip-remove{background:none;border:none;cursor:pointer;color:#16a34a;font-size:11px;padding:0;line-height:1;opacity:.7}.label-chip-remove:hover{opacity:1}.card-overlay{position:absolute;top:0;right:0;padding:6px;display:flex;flex-direction:column;gap:4px}.icon-btn{background:#ffffffd9;border:none;border-radius:50%;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:14px;box-shadow:0 1px 3px #0003;transition:background .15s}.icon-btn:hover{background:#fff}.icon-btn.danger:hover{background:#fde8e8}.fab{position:fixed;bottom:calc(var(--nav-height) + 16px);right:max(16px,calc(50% - 224px));width:56px;height:56px;border-radius:var(--radius-lg);background:var(--primary);color:var(--on-primary);border:none;font-size:26px;cursor:pointer;box-shadow:0 4px 12px #6750a466;display:flex;align-items:center;justify-content:center;text-decoration:none;transition:background .15s,transform .1s;z-index:15}.fab:hover{background:var(--primary-dark);transform:scale(1.05)}.form-page{padding:16px 16px 32px;display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.form-group input,.form-group select,.form-group textarea{padding:12px 14px;border:1.5px solid var(--outline);border-radius:var(--radius-md);font-size:15px;background:var(--surface);color:var(--text-primary);outline:none;transition:border-color .15s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary)}.form-group.error input,.form-group.error select{border-color:var(--error)}.form-error{font-size:12px;color:var(--error)}.form-group textarea{resize:vertical;min-height:80px}.image-upload-area{border:2px dashed var(--outline);border-radius:var(--radius-lg);background:var(--surface);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;cursor:pointer;overflow:hidden;transition:border-color .15s;aspect-ratio:1;position:relative}.image-upload-area:hover{border-color:var(--primary)}.image-upload-area img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover}.image-upload-area .placeholder{font-size:48px}.image-upload-area .placeholder-text{font-size:13px;color:var(--text-secondary)}.btn{padding:13px 24px;border-radius:var(--radius-lg);border:none;font-size:15px;font-weight:600;cursor:pointer;font-family:inherit;transition:opacity .15s,transform .1s;display:flex;align-items:center;justify-content:center;gap:8px}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--primary);color:var(--on-primary)}.btn-primary:hover:not(:disabled){background:var(--primary-dark)}.btn-secondary{background:var(--surface);color:var(--primary);border:1.5px solid var(--primary)}.btn-danger{background:var(--error);color:#fff}.card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.pagination{display:flex;align-items:center;justify-content:center;gap:12px;padding:16px}.pagination-btn{background:var(--surface);border:1px solid var(--outline);border-radius:var(--radius-md);padding:8px 16px;font-size:14px;font-weight:500;cursor:pointer;color:var(--primary);transition:background .15s}.pagination-btn:hover:not(:disabled){background:var(--primary-container)}.pagination-btn:disabled{opacity:.35;cursor:default}.pagination-info{font-size:14px;color:var(--text-secondary);min-width:90px;text-align:center}.outfits-list{display:flex;flex-direction:column;gap:12px;padding:16px}.outfit-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.outfit-card-body{padding:12px 14px 14px}.outfit-collage-row{display:flex;gap:6px;padding:10px 12px;background:var(--surface-variant);text-decoration:none}.outfit-collage-row-cell{width:80px;height:80px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;background:var(--surface);display:flex;align-items:center;justify-content:center}.outfit-collage-row-cell img{width:100%;height:100%;object-fit:cover;display:block}.outfit-collage-empty{width:100%;aspect-ratio:16 / 9;max-height:120px;background:var(--surface-variant);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;color:var(--text-secondary);font-size:13px;text-decoration:none}.outfit-collage-empty span{font-size:36px}.outfit-collage-emoji{font-size:32px;line-height:1}.outfit-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px}.outfit-card-title{font-size:16px;font-weight:700}.outfit-card-actions{display:flex;gap:6px}.outfit-badges{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.badge{padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600}.badge-occasion{background:#e8f5e9;color:#2e7d32}.badge-season{background:#e3f2fd;color:#1565c0}.outfit-items-preview{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none;padding-bottom:4px}.outfit-items-preview::-webkit-scrollbar{display:none}.outfit-item-thumb{width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden;flex-shrink:0;background:var(--surface-variant);display:flex;align-items:center;justify-content:center;font-size:28px}.outfit-item-thumb img{width:100%;height:100%;object-fit:cover}.outfit-item-count{font-size:12px;color:var(--text-secondary);margin-top:8px}.outfit-wear-row{display:flex;align-items:center;gap:8px;margin-top:10px;flex-wrap:wrap}.outfit-wore-btn{font-size:13px;padding:5px 12px;white-space:nowrap}.outfit-history-toggle{font-size:11px;color:var(--text-secondary);background:none;border:none;cursor:pointer;padding:4px 0;text-align:left;flex:1}.outfit-history-toggle:hover{color:var(--primary)}.outfit-wear-history{margin-top:8px;background:var(--surface);border-radius:8px;padding:10px 12px;border:1px solid var(--outline)}.outfit-wear-empty{font-size:12px;color:var(--text-secondary);text-align:center;padding:6px 0}.outfit-wear-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:4px}.outfit-wear-list li{display:flex;align-items:center;gap:8px;font-size:12px}.wear-index{color:var(--text-secondary);font-size:11px;min-width:24px}.wear-date{font-weight:500;flex:1}.wear-time{color:var(--text-secondary);font-size:11px}.wear-action-btn{background:none;border:none;cursor:pointer;padding:2px 4px;font-size:13px;border-radius:4px;opacity:.6;transition:opacity .15s}.wear-action-btn:hover{opacity:1}.wear-action-btn.save{color:var(--primary);font-weight:700}.wear-action-btn.cancel{color:var(--text-secondary)}.wear-edit-row{display:flex;align-items:center;gap:6px;flex:1}.wear-edit-input{flex:1;font-size:12px;padding:3px 6px;border:1px solid var(--outline);border-radius:6px;background:var(--background);color:var(--text-primary)}.outfit-wear-limit{font-size:11px;color:var(--text-secondary);text-align:center;margin-top:8px;margin-bottom:0}.selected-items-bar{background:var(--surface);padding:10px 16px;border-bottom:1px solid var(--outline)}.selected-items-bar h3{font-size:13px;color:var(--text-secondary);margin-bottom:8px;font-weight:600}.selected-items-swap-hint{font-weight:400;font-size:11px;color:var(--primary)}.selected-items-scroll{display:flex;gap:8px;overflow-x:auto;scrollbar-width:none}.selected-items-scroll::-webkit-scrollbar{display:none}.selected-thumb-wrap{position:relative;flex-shrink:0}.selected-thumb{width:56px;height:56px;border-radius:var(--radius-md);background:var(--surface-variant);display:flex;align-items:center;justify-content:center;font-size:24px;overflow:hidden;border:2px solid var(--primary)}.selected-thumb img{width:100%;height:100%;object-fit:cover}.remove-thumb-btn{position:absolute;top:-4px;right:-4px;width:18px;height:18px;background:var(--error);color:#fff;border:none;border-radius:50%;font-size:10px;cursor:pointer;display:flex;align-items:center;justify-content:center}.closet-browser{padding:0 16px 16px}.closet-browser h3{font-size:14px;font-weight:700;padding:12px 0 8px;color:var(--text-secondary)}.item-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.grid-item{aspect-ratio:1;border-radius:var(--radius-md);background:var(--surface);display:flex;align-items:center;justify-content:center;font-size:36px;overflow:hidden;cursor:pointer;position:relative;border:2.5px solid transparent;transition:border-color .15s;box-shadow:var(--shadow)}.grid-item.selected{border-color:var(--primary)}.grid-item img{width:100%;height:100%;object-fit:cover}.grid-item .check-badge{position:absolute;bottom:4px;right:4px;width:22px;height:22px;background:var(--primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px}.randomizer-page{padding:24px 16px;display:flex;flex-direction:column;align-items:center;gap:24px;min-height:calc(100vh - 64px)}.mode-toggle{display:flex;background:var(--surface);border-radius:var(--radius-lg);padding:4px;width:100%;box-shadow:var(--shadow)}.mode-btn{flex:1;padding:10px;border:none;border-radius:var(--radius-md);font-size:13px;font-weight:600;cursor:pointer;background:transparent;color:var(--text-secondary);transition:all .2s;font-family:inherit}.mode-btn.active{background:var(--primary);color:#fff}.mood-section{width:100%}.mood-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px}.mood-chips{display:flex;flex-wrap:wrap;gap:8px}.mood-chip{padding:6px 14px;border-radius:20px;border:1.5px solid var(--outline);background:var(--surface);color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.mood-chip:hover{border-color:var(--primary);color:var(--primary)}.mood-chip.active{background:var(--primary);border-color:var(--primary);color:#fff}.spin-area{width:200px;height:200px;border-radius:50%;background:var(--surface);box-shadow:var(--shadow-md);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:8px;font-size:64px;overflow:hidden}.spin-area img{width:100%;height:100%;object-fit:cover;border-radius:50%}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.spinning{animation:spin .6s linear infinite}.randomize-btn{width:100%;padding:16px;font-size:18px;font-weight:700;border-radius:var(--radius-lg);background:var(--primary);color:#fff;border:none;cursor:pointer;box-shadow:0 4px 12px #6750a459;transition:background .15s,transform .1s;font-family:inherit}.randomize-btn:hover:not(:disabled){background:var(--primary-dark)}.randomize-btn:disabled{opacity:.5;cursor:default}.result-card{width:100%;background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:16px}.result-card h3{font-size:14px;font-weight:700;color:var(--text-secondary);margin-bottom:12px}.result-items-row{display:flex;gap:10px;flex-wrap:wrap}.result-item{display:flex;flex-direction:column;align-items:center;gap:4px}.result-thumb{width:72px;height:72px;border-radius:var(--radius-md);background:var(--surface-variant);display:flex;align-items:center;justify-content:center;font-size:36px;overflow:hidden}.result-thumb img{width:100%;height:100%;object-fit:cover}.result-item-name{font-size:11px;color:var(--text-secondary);text-align:center;max-width:72px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.weather-page{padding:16px;display:flex;flex-direction:column;gap:16px}.weather-card{background:linear-gradient(135deg,var(--primary) 0%,#9c27b0 100%);color:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-md)}.weather-card .city{font-size:20px;font-weight:700}.weather-card .temp{font-size:56px;font-weight:300;line-height:1}.weather-card .condition{font-size:16px;opacity:.9;margin-bottom:12px}.weather-card .weather-meta{display:flex;gap:16px;font-size:13px;opacity:.85}.suggestion-section{background:var(--surface);border-radius:var(--radius-lg);padding:14px;box-shadow:var(--shadow)}.suggestion-section h3{font-size:14px;font-weight:700;color:var(--text-secondary);margin-bottom:10px}.suggestion-items{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none}.suggestion-items::-webkit-scrollbar{display:none}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:60px 24px;text-align:center}.empty-state .empty-emoji{font-size:64px}.empty-state h2{font-size:18px;font-weight:700}.empty-state p{font-size:14px;color:var(--text-secondary);max-width:260px}.loading{display:flex;align-items:center;justify-content:center;padding:60px}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.loading-dot{width:10px;height:10px;border-radius:50%;background:var(--primary);margin:0 4px;animation:pulse 1s ease-in-out infinite}.loading-dot:nth-child(2){animation-delay:.2s}.loading-dot:nth-child(3){animation-delay:.4s}.divider{height:1px;background:var(--outline);margin:8px 0}.location-card{background:var(--surface);border-radius:var(--radius-lg);padding:20px;text-align:center;box-shadow:var(--shadow);display:flex;flex-direction:column;align-items:center;gap:12px}.location-card .loc-icon{font-size:48px}.location-card h2{font-size:18px;font-weight:700}.location-card p{font-size:14px;color:var(--text-secondary)}.landing-page{min-height:100vh;background:linear-gradient(160deg,#2d1b69,#6750a4,#c4b0e8);color:#fff;display:flex;flex-direction:column}.landing-hero{display:flex;justify-content:center;padding:64px 24px 48px}.landing-hero-inner{display:flex;flex-direction:column;align-items:center;text-align:center;max-width:480px;gap:14px}.landing-logo{font-size:72px;line-height:1}.landing-title{font-size:38px;font-weight:800;letter-spacing:-.5px;margin:0;text-shadow:0 2px 8px rgba(0,0,0,.25)}.landing-tagline{font-size:16px;opacity:.88;margin:0 0 8px}.landing-error{font-size:13px;background:#ffffff26;border-radius:var(--radius-sm);padding:8px 16px}.landing-disclaimer{font-size:12px;opacity:.6;margin:0}.btn-google{display:flex;align-items:center;gap:10px;padding:12px 24px;border-radius:var(--radius-lg);border:none;background:#fff;color:#1f1f1f;font-size:15px;font-weight:600;cursor:pointer;text-decoration:none;justify-content:center;transition:box-shadow .15s,transform .1s;font-family:inherit;box-shadow:0 2px 12px #00000040}.btn-google:hover{box-shadow:0 4px 20px #00000059;transform:translateY(-1px)}.btn-google-hero{width:100%;max-width:300px;font-size:16px;padding:14px 24px}.btn-google-footer{max-width:340px}.landing-features{display:grid;grid-template-columns:1fr 1fr;gap:16px;padding:0 20px 48px;max-width:640px;margin:0 auto;width:100%;box-sizing:border-box}.landing-feature-card{background:#ffffff1f;border-radius:var(--radius-lg);padding:20px 16px;display:flex;flex-direction:column;gap:6px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.landing-feature-icon{font-size:32px}.landing-feature-card h3{font-size:15px;font-weight:700;margin:0}.landing-feature-card p{font-size:13px;opacity:.8;margin:0;line-height:1.5}.landing-footer{display:flex;justify-content:center;padding:0 24px 56px;margin-top:auto}@media (min-width: 600px){.landing-title{font-size:48px}.landing-features{grid-template-columns:repeat(4,1fr);max-width:900px}}.user-bar{display:flex;align-items:center;gap:8px;padding:6px 16px;background:var(--primary-dark);color:var(--on-primary);font-size:13px;flex-shrink:0}.user-avatar{width:26px;height:26px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-avatar-placeholder{background:var(--primary-container);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700}.user-name{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:500}.user-logout-btn{background:none;border:1px solid rgba(255,255,255,.5);color:var(--on-primary);cursor:pointer;font-size:12px;padding:3px 10px;border-radius:var(--radius-sm);opacity:.85;transition:opacity .15s;flex-shrink:0;white-space:nowrap}.user-logout-btn:hover{opacity:1}@media (min-width: 600px){.app,.bottom-nav{max-width:768px}.fab{right:max(16px,calc(50% - 368px))}.clothing-grid{grid-template-columns:repeat(3,1fr)}.item-grid-3{grid-template-columns:repeat(4,1fr)}.top-bar h1{font-size:22px}.weather-card .temp{font-size:64px}}@media (min-width: 960px){:root{--nav-height: 0px;--side-nav-width: 220px}.app{max-width:1600px;flex-direction:column;align-items:stretch;width:100%}.app-body{flex-direction:row;align-items:flex-start}.bottom-nav{position:sticky;top:0;left:0;transform:none;width:var(--side-nav-width);max-width:var(--side-nav-width);height:100vh;flex-direction:column;justify-content:flex-start;align-items:stretch;border-top:none;border-right:1px solid var(--outline);padding:24px 8px 8px;gap:4px;overflow-y:auto;flex-shrink:0;background:var(--surface)}.nav-item{flex-direction:row;justify-content:flex-start;gap:12px;padding:10px 14px;border-radius:var(--radius-md);font-size:14px}.nav-item .nav-icon{font-size:20px}.nav-item.active .nav-indicator{width:auto;height:auto;background:transparent;border-radius:0;margin-bottom:0;display:inline}.nav-item.active{background:var(--primary-container)}.content{flex:1;padding-bottom:24px;min-height:100vh;overflow-y:auto}.clothing-grid{grid-template-columns:repeat(4,1fr)}.item-grid-3{grid-template-columns:repeat(5,1fr)}.fab{right:32px;bottom:32px;left:auto;transform:none}.form-page{max-width:700px;margin-inline:auto}.randomizer-page{max-width:680px;margin-inline:auto}.weather-page{max-width:900px;margin-inline:auto}.outfits-list{display:grid;grid-template-columns:repeat(2,1fr);max-width:none;align-items:start}}.img-editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:100;padding:16px}.img-editor-modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:var(--shadow-md)}.img-editor-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--outline)}.img-editor-header h2{font-size:17px;font-weight:700}.img-editor-close{background:none;border:none;font-size:18px;cursor:pointer;color:var(--text-secondary);padding:4px 8px;border-radius:var(--radius-sm);transition:background .15s}.img-editor-close:hover{background:var(--surface-variant)}.img-editor-tabs{display:flex;border-bottom:1px solid var(--outline)}.img-editor-tab{flex:1;padding:10px;background:none;border:none;font-size:14px;font-weight:600;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:color .15s,border-bottom .15s;border-bottom:3px solid transparent}.img-editor-tab.active{color:var(--primary);border-bottom-color:var(--primary)}.img-editor-content{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:12px;padding:12px 16px}.img-editor-crop-container{position:relative;width:100%;height:280px;background:repeating-conic-gradient(#ccc,#ccc 25%,#fff 0%,#fff 50%) 0 0 / 16px 16px;border-radius:var(--radius-md);overflow:hidden}.img-editor-controls{display:flex;align-items:center;gap:10px}.img-editor-label{font-size:12px;font-weight:600;color:var(--text-secondary);white-space:nowrap;min-width:50px}.img-editor-slider{flex:1;accent-color:var(--primary);cursor:pointer}.img-editor-aspect-btns{display:flex;gap:6px;flex-wrap:wrap}.img-editor-aspect-btn{padding:5px 12px;border-radius:20px;border:1.5px solid var(--outline);background:var(--surface);color:var(--text-secondary);font-size:12px;font-weight:600;cursor:pointer;transition:all .15s;font-family:inherit}.img-editor-aspect-btn.active{background:var(--primary);border-color:var(--primary);color:var(--on-primary)}.img-editor-apply-crop-btn{align-self:flex-start}.img-editor-bg-content{align-items:center;text-align:center}.img-editor-preview-wrap{width:100%;max-width:280px;aspect-ratio:1;border-radius:var(--radius-md);overflow:hidden;background:repeating-conic-gradient(#ccc,#ccc 25%,#fff 0%,#fff 50%) 0 0 / 16px 16px;align-self:center}.img-editor-preview{width:100%;height:100%;object-fit:contain;display:block}.img-editor-hint{font-size:12px;color:var(--text-secondary);text-align:center}.img-editor-steps{display:flex;flex-direction:column;gap:6px;margin-top:10px;width:100%}.img-editor-step{display:flex;align-items:center;gap:8px;padding:6px 10px;border-radius:8px;background:var(--surface);font-size:13px;color:var(--text-secondary);transition:background .2s}.img-editor-step.active{background:#ede9fe;color:var(--primary);font-weight:500}.img-editor-step.done{color:var(--text-primary)}.img-editor-step-icon{font-size:15px}.img-editor-step-label{flex:1}.img-editor-step-time{font-size:11px;color:var(--text-secondary);font-variant-numeric:tabular-nums}.img-editor-step-note{font-size:11px;color:var(--text-secondary)}.img-editor-footer{display:flex;gap:10px;padding:12px 16px;border-top:1px solid var(--outline)}.img-editor-footer .btn{flex:1}@media (min-width: 1280px){:root{--side-nav-width: 260px}.clothing-grid{grid-template-columns:repeat(5,1fr)}.item-grid-3{grid-template-columns:repeat(6,1fr)}.outfits-list{grid-template-columns:repeat(3,1fr)}.form-page{max-width:780px}.randomizer-page{max-width:760px}.weather-page{max-width:1100px}.weather-card .temp{font-size:72px}}@media (min-width: 1600px){.clothing-grid{grid-template-columns:repeat(6,1fr)}.item-grid-3{grid-template-columns:repeat(8,1fr)}.outfits-list{grid-template-columns:repeat(3,1fr)}}.terms-page{min-height:100vh;background:linear-gradient(160deg,#2d1b69,#6750a4,#c4b0e8);display:flex;justify-content:center;padding:32px 16px 64px}.terms-container{width:100%;max-width:720px;display:flex;flex-direction:column;gap:24px}.terms-header{display:flex;flex-direction:column;align-items:center;text-align:center;color:#fff;gap:6px;padding-bottom:8px}.terms-back{align-self:flex-start;color:#ffffffbf;text-decoration:none;font-size:14px;font-weight:600;margin-bottom:12px;transition:color .15s}.terms-back:hover{color:#fff}.terms-header .terms-logo{font-size:52px;line-height:1}.terms-header h1{font-size:28px;font-weight:800;margin:0;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.25)}.terms-subtitle{font-size:15px;color:#ffffffd9;margin:0}.terms-effective{font-size:12px;color:#ffffff8c;margin:0}.terms-body{background:#fff;border-radius:var(--radius-lg);padding:28px 24px;display:flex;flex-direction:column;gap:0;box-shadow:0 8px 32px #0000002e}.terms-section{padding:20px 0;border-bottom:1px solid var(--outline)}.terms-section:last-child{border-bottom:none;padding-bottom:4px}.terms-section h2{font-size:15px;font-weight:700;color:var(--primary);margin:0 0 10px}.terms-section p{font-size:14px;line-height:1.65;color:var(--text-primary);margin:0 0 8px}.terms-section p:last-child{margin-bottom:0}.terms-section ul{font-size:14px;line-height:1.65;color:var(--text-primary);margin:6px 0 8px;padding-left:20px;display:flex;flex-direction:column;gap:4px}.terms-section a{color:var(--primary);text-decoration:underline}.terms-footer{display:flex;justify-content:center}.share-page{min-height:100vh;background:var(--surface-variant);display:flex;flex-direction:column}.share-header{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--primary);color:var(--on-primary)}.share-header-logo{font-size:22px}.share-header-brand{font-size:16px;font-weight:700}.share-main{flex:1;display:flex;justify-content:center;padding:32px 20px 48px}.share-card{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:28px 24px;width:100%;max-width:520px;display:flex;flex-direction:column;align-items:center;gap:16px}.share-outfit-name{font-size:24px;font-weight:700;color:var(--text-primary);margin:0;text-align:center}.share-badges{justify-content:center}.share-items-row{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;width:100%}.share-item-cell{display:flex;flex-direction:column;align-items:center;gap:6px;width:120px}.share-item-cell img{width:120px;height:140px;object-fit:cover;border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.share-item-emoji{width:120px;height:140px;display:flex;align-items:center;justify-content:center;font-size:48px;background:var(--surface-variant);border-radius:var(--radius-md)}.share-item-name{font-size:12px;color:var(--text-secondary);text-align:center;margin:0}.share-no-items{color:var(--text-secondary);font-size:14px}.share-notes{font-style:italic;color:var(--text-secondary);font-size:14px;margin:0;text-align:center}.share-like-btn{display:flex;align-items:center;gap:8px;background:none;border:2px solid var(--outline);border-radius:999px;padding:10px 24px;font-size:22px;cursor:pointer;transition:border-color .15s,transform .1s}.share-like-btn:hover{border-color:var(--primary);transform:scale(1.05)}.share-like-btn--liked{border-color:#e91e63}.share-like-count{font-size:15px;font-weight:600;color:var(--text-primary)}.share-cta{font-size:13px;color:var(--text-secondary);margin:0;text-align:center}.share-cta-link{color:var(--primary);text-decoration:none;font-weight:600}.share-error{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-secondary);font-size:24px;margin-top:60px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:100;padding:20px 16px}.modal-box{background:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;padding:24px 20px 16px;position:relative}.share-modal{max-width:440px;display:flex;flex-direction:column;gap:12px}.share-modal-title{font-size:18px;font-weight:700;margin:0;color:var(--text-primary)}.share-modal-desc{font-size:13px;color:var(--text-secondary);margin:0}.share-modal-link-row{display:flex;gap:8px}.share-modal-input{flex:1;padding:8px 10px;border:1.5px solid var(--outline);border-radius:var(--radius-sm);font-size:13px;background:var(--surface-variant);color:var(--text-primary);min-width:0}.share-modal-copy{flex-shrink:0;padding:8px 16px;font-size:13px}.share-modal-close{position:absolute;top:12px;right:12px;background:none;border:none;color:var(--text-secondary);font-size:16px;line-height:1;cursor:pointer;padding:4px;border-radius:50%;transition:background .15s,color .15s}.share-modal-close:hover{background:var(--outline);color:var(--text-primary)}.share-liked-note{font-size:12px;color:var(--text-secondary);margin:-8px 0 0;text-align:center}
