*{box-sizing:border-box;margin:0;padding:0}body{color:#333;background:linear-gradient(135deg,#fce4ec 0%,#f3e5f5 50%,#e8eaf6 100%);min-height:100vh;font-family:Segoe UI,system-ui,-apple-system,sans-serif}.app{flex-direction:column;min-height:100vh;display:flex}.app-header{text-align:center;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffc;border-bottom:2px solid #f8bbd0;padding:1.5rem;position:relative}.app-header h1{color:#e91e63;letter-spacing:-.5px;font-size:2rem;font-weight:700}.logout-button{color:#e91e63;cursor:pointer;background:#fff;border:2px solid #e91e63;border-radius:20px;padding:.4rem 1rem;font-size:.85rem;font-weight:600;transition:all .15s;position:absolute;top:50%;right:1.5rem;transform:translateY(-50%)}.logout-button:hover{background:#fce4ec}.app-main{flex:1;gap:1.5rem;width:100%;max-width:1200px;margin:0 auto;padding:1.5rem;display:flex}.controls-panel{flex-direction:column;flex:1;gap:1rem;max-width:380px;max-height:calc(100vh - 120px);display:flex;overflow-y:auto}.controls-section{background:#ffffffe6;border-radius:16px;padding:1.25rem;box-shadow:0 2px 12px #0000000f}.controls-section h3{color:#ad1457;border-bottom:2px solid #fce4ec;margin-bottom:1rem;padding-bottom:.5rem;font-size:1.1rem}.figure-panel{flex:1;justify-content:center;align-items:flex-start;padding-top:1rem;display:flex}.figure-panel svg{filter:drop-shadow(0 4px 20px #0000001a)}.color-picker{margin-bottom:.75rem}.color-picker label{color:#555;margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.color-picker-row{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:28px;height:28px;transition:transform .15s,border-color .15s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:#e91e63;box-shadow:0 0 0 2px #e91e634d}input[type=color]{cursor:pointer;background:0 0;border:none;border-radius:50%;width:28px;height:28px;padding:0}input[type=color]::-webkit-color-swatch-wrapper{padding:0}input[type=color]::-webkit-color-swatch{border:2px solid #ddd;border-radius:50%}.control-group{margin-bottom:.75rem}.control-group label{color:#555;margin-bottom:.4rem;font-size:.85rem;font-weight:600;display:block}.button-group{flex-wrap:wrap;gap:6px;display:flex}.button-group button{cursor:pointer;color:#555;background:#fff;border:2px solid #e0e0e0;border-radius:20px;padding:.4rem .8rem;font-size:.82rem;font-weight:500;transition:all .15s}.button-group button:hover:not(:disabled){color:#e91e63;border-color:#f48fb1}.button-group button.active{color:#e91e63;background:#fce4ec;border-color:#e91e63;font-weight:600}.button-group button:disabled{opacity:.4;cursor:not-allowed}.clothing-group{margin-bottom:1rem}.clothing-group h4{color:#777;margin-bottom:.4rem;font-size:.9rem}.clothing-group.disabled{opacity:.5}.auth-page{flex:1;justify-content:center;align-items:center;padding:2rem;display:flex}.auth-card{background:#fffffff2;border-radius:20px;width:100%;max-width:400px;padding:2.5rem;box-shadow:0 4px 24px #00000014}.auth-card h2{color:#ad1457;text-align:center;margin-bottom:1.5rem;font-size:1.5rem}.form-group{margin-bottom:1rem}.form-group label{color:#555;margin-bottom:.3rem;font-size:.85rem;font-weight:600;display:block}.form-group input{border:2px solid #e0e0e0;border-radius:10px;width:100%;padding:.6rem .8rem;font-size:.95rem;transition:border-color .15s}.form-group input:focus{border-color:#f48fb1;outline:none}.auth-button{color:#fff;cursor:pointer;background:linear-gradient(135deg,#e91e63,#ad1457);border:none;border-radius:12px;width:100%;margin-top:.5rem;padding:.7rem;font-size:1rem;font-weight:600;transition:opacity .15s}.auth-button:hover:not(:disabled){opacity:.9}.auth-button:disabled{opacity:.5;cursor:not-allowed}.auth-error{color:#d32f2f;background:#ffebee;border-radius:8px;margin:.5rem 0;padding:.5rem;font-size:.85rem}.auth-info{color:#555;text-align:center;margin-bottom:1rem;font-size:.9rem}.auth-switch{text-align:center;color:#777;margin-top:1.2rem;font-size:.85rem}.auth-switch button{color:#e91e63;cursor:pointer;background:0 0;border:none;font-size:.85rem;font-weight:600}.auth-switch button:hover{text-decoration:underline}.save-outfit{gap:.5rem;margin-bottom:.75rem;display:flex}.save-outfit input{border:2px solid #e0e0e0;border-radius:10px;flex:1;padding:.45rem .7rem;font-size:.85rem}.save-outfit input:focus{border-color:#f48fb1;outline:none}.save-outfit button{color:#fff;cursor:pointer;white-space:nowrap;background:#e91e63;border:none;border-radius:10px;padding:.45rem 1rem;font-size:.85rem;font-weight:600}.save-outfit button:disabled{opacity:.4;cursor:not-allowed}.outfit-message{color:#2e7d32;margin-bottom:.5rem;font-size:.8rem}.outfit-loading,.outfit-empty{color:#999;text-align:center;padding:.5rem;font-size:.85rem}.outfit-list{flex-direction:column;gap:.4rem;list-style:none;display:flex}.outfit-list li{background:#fce4ec;border-radius:10px;justify-content:space-between;align-items:center;padding:.5rem .7rem;display:flex}.outfit-name{color:#333;font-size:.85rem;font-weight:500}.outfit-actions{gap:.3rem;display:flex}.outfit-actions button{cursor:pointer;color:#555;background:#fff;border:1px solid #e0e0e0;border-radius:8px;padding:.25rem .6rem;font-size:.75rem}.outfit-actions button:hover{color:#e91e63;border-color:#e91e63}.outfit-actions button.delete:hover{color:#d32f2f;border-color:#d32f2f}@media (width<=768px){.app-main{flex-direction:column-reverse;padding:1rem}.controls-panel{max-width:100%;max-height:none}.figure-panel{padding-top:0}.app-header h1{font-size:1.5rem}}
