*,*:before,*:after{box-sizing:border-box}body{margin:0}.profile-form{max-width:420px;margin:0 auto;padding:1.5rem}.profile-form h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:800;color:#f1f5f9;text-align:center;letter-spacing:-.02em}.photo-upload{display:flex;justify-content:center;margin-bottom:1.5rem}.photo-upload-area{width:140px;height:140px;border-radius:50%;border:2px dashed #334155;display:flex;align-items:center;justify-content:center;cursor:pointer;overflow:hidden;background:#1e293b;transition:border-color .2s,background .2s}.photo-upload-area:hover,.photo-upload-area.dragging{border-color:#135bec;background:#1e2a3a}.photo-upload-area img{width:100%;height:100%;object-fit:cover}.photo-placeholder{display:flex;flex-direction:column;align-items:center;gap:.4rem;color:#64748b;font-size:.85rem}.photo-placeholder .icon{font-size:2rem;line-height:1}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.35rem;font-size:.85rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.input-with-unit{display:flex;align-items:center;gap:.5rem}.input-with-unit input{flex:1;padding:.75rem 1rem;border:1px solid #1e293b;border-radius:12px;font-size:1rem;font-family:Manrope,sans-serif;font-weight:500;color:#f1f5f9;outline:none;transition:border-color .2s,background .2s;background:#1e293b}.input-with-unit input:focus{border-color:#135bec;background:#1e2a3a}.input-with-unit .unit{font-size:.9rem;color:#475569;min-width:1.5rem;font-weight:600}.submit-btn{width:100%;margin-top:1.5rem;padding:1rem;border:none;border-radius:12px;background:#135bec;color:#fff;font-size:1rem;font-weight:700;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s,transform .1s;letter-spacing:-.01em}.submit-btn:hover{background:#1a4fd6}.submit-btn:active{transform:scale(.98)}.submit-btn:disabled{background:#1e293b;color:#475569;cursor:not-allowed}.loading-overlay{display:flex;flex-direction:column;align-items:center;gap:1rem;margin:2rem auto;max-width:420px;padding:2rem;text-align:center;color:#94a3b8}.spinner{width:40px;height:40px;border:3px solid #1e293b;border-top-color:#135bec;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-message{max-width:420px;margin:1rem auto;padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:12px;color:#f87171;text-align:center;font-size:.9rem}.result-card{max-width:420px;margin:1.5rem auto;padding:1.5rem;background:#1e293b;border:1px solid #334155;border-radius:16px}.result-card h2{margin:0 0 .5rem;font-size:1.15rem;font-weight:800;color:#f1f5f9;text-align:center}.ai-disclaimer{margin:0 0 1rem;font-size:.75rem;color:#475569;text-align:center;line-height:1.5}.result-content{font-size:.9rem;line-height:1.75;color:#94a3b8;white-space:pre-wrap}.hairstyle-section{margin-top:1.5rem;text-align:center}.hairstyle-section h3{margin:0 0 1rem;font-size:1rem;font-weight:700;color:#f1f5f9}.hairstyle-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.hairstyle-image{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px}.flatlay-section{margin-top:1.5rem;text-align:center}.flatlay-section h3{margin:0 0 1rem;font-size:1rem;font-weight:700;color:#f1f5f9}.flatlay-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.flatlay-image{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px}.outfit-section{margin-top:1.5rem;text-align:center}.outfit-section h3{margin:0 0 1rem;font-size:1rem;font-weight:700;color:#f1f5f9}.outfit-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.5rem}.outfit-image{width:100%;aspect-ratio:1;object-fit:cover;border-radius:10px}.report-actions{display:flex;gap:.75rem;margin-top:1.5rem}.report-action-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.4rem;padding:.75rem 1rem;border:none;border-radius:12px;font-size:.875rem;font-weight:700;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s,transform .1s,opacity .2s;letter-spacing:-.01em}.report-action-btn:active{transform:scale(.97)}.report-action-btn:disabled{opacity:.5;cursor:not-allowed}.report-action-btn .material-icons-round{font-size:18px}.save-btn{background:#0f172a;color:#f1f5f9;border:1px solid #334155}.save-btn:hover:not(:disabled){background:#1e293b}.share-btn{background:#135bec;color:#fff}.share-btn:hover:not(:disabled){background:#1a4fd6}.clothing-grid{display:flex;gap:.5rem;flex-wrap:wrap}.clothing-item{position:relative;width:72px;height:72px;border-radius:10px;overflow:hidden;border:1px solid #334155}.clothing-item img{width:100%;height:100%;object-fit:cover}.clothing-remove{position:absolute;top:2px;right:2px;width:20px;height:20px;border-radius:50%;border:none;background:#000000b3;color:#f1f5f9;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:0}.clothing-remove .material-icons-round{font-size:14px}.clothing-add{width:72px;height:72px;border-radius:10px;border:2px dashed #334155;display:flex;align-items:center;justify-content:center;cursor:pointer;background:#1e293b;color:#475569;transition:border-color .2s,color .2s}.clothing-add:hover{border-color:#135bec;color:#135bec}.clothing-add .material-icons-round{font-size:24px}.label-optional{font-size:.75rem;color:#64748b;font-weight:400}.email-sent-banner{display:flex;align-items:center;gap:10px;max-width:600px;margin:16px auto;padding:14px 18px;background:#052e16;border:1px solid #166534;border-radius:10px;color:#bbf7d0;font-size:.9rem}.email-sent-banner .material-icons-round{color:#4ade80;font-size:22px;flex-shrink:0}.refund-banner{display:flex;align-items:flex-start;gap:10px;max-width:600px;margin:16px auto;padding:14px 18px;background:#1c0a00;border:1px solid #92400e;border-radius:10px;color:#fde68a;font-size:.9rem;line-height:1.5}.refund-banner .material-icons-round{color:#f59e0b;font-size:22px;flex-shrink:0;margin-top:1px}.auth-form{max-width:420px;margin:0 auto;padding:2rem 1.5rem;min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center}.auth-back-btn{position:absolute;top:1.5rem;left:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#1e293b80;border:none;color:#f1f5f9;cursor:pointer}.auth-logo{display:flex;align-items:center;gap:.5rem;margin-bottom:2rem}.auth-logo-text{font-size:1.25rem;font-weight:800;letter-spacing:.1em;color:#f1f5f9}.auth-form h2{margin:0 0 1.5rem;font-size:1.5rem;font-weight:800;color:#f1f5f9;text-align:center;letter-spacing:-.02em}.auth-form form{width:100%}.auth-field{margin-bottom:1rem;width:100%}.auth-field label{display:block;margin-bottom:.35rem;font-size:.85rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.auth-field input{width:100%;padding:.75rem 1rem;border:1px solid #1e293b;border-radius:12px;font-size:1rem;font-family:Manrope,sans-serif;font-weight:500;color:#f1f5f9;outline:none;transition:border-color .2s,background .2s;background:#1e293b;box-sizing:border-box}.auth-field input:focus{border-color:#135bec;background:#1e2a3a}.auth-submit-btn{width:100%;margin-top:1.5rem;padding:1rem;border:none;border-radius:12px;background:#135bec;color:#fff;font-size:1rem;font-weight:700;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s,transform .1s;display:flex;align-items:center;justify-content:center}.auth-submit-btn:hover{background:#1a4fd6}.auth-submit-btn:active{transform:scale(.98)}.auth-submit-btn:disabled{background:#1e293b;color:#475569;cursor:not-allowed}.auth-spinner{width:20px;height:20px;border:2px solid #475569;border-top-color:#fff;border-radius:50%;animation:auth-spin .8s linear infinite}@keyframes auth-spin{to{transform:rotate(360deg)}}.auth-error{width:100%;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:12px;color:#f87171;text-align:center;font-size:.9rem;margin-bottom:1rem;box-sizing:border-box}.auth-success{width:100%;padding:.75rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:12px;color:#4ade80;text-align:center;font-size:.9rem;margin-bottom:1rem;box-sizing:border-box}.auth-toggle{margin-top:1.5rem;font-size:.9rem;color:#64748b}.auth-toggle button{background:none;border:none;color:#135bec;font-weight:600;cursor:pointer;font-size:.9rem;font-family:Manrope,sans-serif}.auth-toggle button:hover{text-decoration:underline}.auth-forgot{margin-top:.75rem}.auth-forgot button{color:#94a3b8;font-weight:400;font-size:.85rem}.auth-google-btn{width:100%;padding:.85rem 1rem;border:1px solid #334155;border-radius:12px;background:#1e293b;color:#f1f5f9;font-size:.95rem;font-weight:600;font-family:Manrope,sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.6rem;transition:background .2s,border-color .2s}.auth-google-btn:hover{background:#253349;border-color:#475569}.auth-google-btn:active{transform:scale(.98)}.auth-divider{display:flex;align-items:center;gap:1rem;margin:1.25rem 0;width:100%}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:#334155}.auth-divider span{font-size:.8rem;color:#64748b;white-space:nowrap}.mypage{max-width:420px;margin:0 auto;padding:2rem 1.5rem;min-height:100vh}.mypage-header{display:flex;align-items:center;gap:.75rem;margin-bottom:2.5rem}.mypage-back-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:#1e293b80;border:none;color:#f1f5f9;cursor:pointer}.mypage-logo{display:flex;align-items:center;gap:.5rem}.mypage-logo-text{font-size:1.125rem;font-weight:800;letter-spacing:.1em;text-transform:uppercase;color:#f1f5f9}.mypage-section{margin-bottom:2rem}.mypage-section-title{font-size:.8rem;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem}.mypage-card{background:#1e293b;border-radius:12px;padding:1rem 1.25rem}.mypage-info-row{display:flex;justify-content:space-between;align-items:center;padding:.6rem 0}.mypage-info-row+.mypage-info-row{border-top:1px solid #334155}.mypage-info-label{font-size:.85rem;color:#94a3b8;font-weight:500}.mypage-info-value{font-size:.9rem;color:#f1f5f9;font-weight:600}.mypage-field{margin-bottom:.75rem;width:100%}.mypage-field label{display:block;margin-bottom:.35rem;font-size:.85rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.08em}.mypage-field input{width:100%;padding:.75rem 1rem;border:1px solid #1e293b;border-radius:12px;font-size:1rem;font-family:Manrope,sans-serif;font-weight:500;color:#f1f5f9;outline:none;transition:border-color .2s,background .2s;background:#1e293b;box-sizing:border-box}.mypage-field input:focus{border-color:#135bec;background:#1e2a3a}.mypage-btn{width:100%;padding:.85rem 1rem;border:none;border-radius:12px;background:#135bec;color:#fff;font-size:.95rem;font-weight:700;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s,transform .1s;display:flex;align-items:center;justify-content:center}.mypage-btn:hover{background:#1a4fd6}.mypage-btn:active{transform:scale(.98)}.mypage-btn:disabled{background:#1e293b;color:#475569;cursor:not-allowed}.mypage-btn-outline{width:100%;padding:.85rem 1rem;border:1px solid #334155;border-radius:12px;background:transparent;color:#f1f5f9;font-size:.95rem;font-weight:600;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s,border-color .2s;display:flex;align-items:center;justify-content:center}.mypage-btn-outline:hover{background:#1e293b;border-color:#475569}.mypage-btn-danger{width:100%;padding:.85rem 1rem;border:1px solid rgba(239,68,68,.3);border-radius:12px;background:#ef44441a;color:#f87171;font-size:.95rem;font-weight:700;font-family:Manrope,sans-serif;cursor:pointer;transition:background .2s;display:flex;align-items:center;justify-content:center}.mypage-btn-danger:hover{background:#ef444433}.mypage-btn-danger:disabled{opacity:.4;cursor:not-allowed}.mypage-error{width:100%;padding:.75rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:12px;color:#f87171;text-align:center;font-size:.9rem;margin-bottom:.75rem;box-sizing:border-box}.mypage-success{width:100%;padding:.75rem 1rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.2);border-radius:12px;color:#4ade80;text-align:center;font-size:.9rem;margin-bottom:.75rem;box-sizing:border-box}.mypage-spinner{width:20px;height:20px;border:2px solid #475569;border-top-color:#fff;border-radius:50%;animation:mypage-spin .8s linear infinite}@keyframes mypage-spin{to{transform:rotate(360deg)}}.mypage-delete-hint{font-size:.85rem;color:#94a3b8;margin-bottom:.75rem;line-height:1.5}.mypage-delete-hint strong{color:#f87171}
