*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--primary:#1a1a2e;--primary-light:#16213e;--accent:#e94560;--accent-hover:#d63851;--gold:#f6b93b;--bg:#f8f9fa;--card-bg:#fff;--text:#2d3436;--text-light:#636e72;--text-muted:#b2bec3;--border:#e9ecef;--shadow:0 2px 16px #00000014;--shadow-lg:0 8px 32px #0000001f;--radius:16px;--radius-sm:10px}body{background:var(--bg);color:var(--text);min-height:100vh;font-family:Inter,system-ui,-apple-system,sans-serif;line-height:1.6}#app{flex-direction:column;min-height:100vh;display:flex}header{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-light) 50%, #0f3460 100%);color:#fff;text-align:center;padding:48px 24px;position:relative;overflow:hidden}header:before{content:"";pointer-events:none;background:radial-gradient(circle at 30%,#e9456026 0%,#0000 50%),radial-gradient(circle at 70% 80%,#f6b93b1a 0%,#0000 40%);width:200%;height:200%;position:absolute;top:-50%;left:-50%}.header-content{z-index:1;position:relative}.logo-icon{margin-bottom:8px;font-size:40px;display:block}header h1{letter-spacing:-.5px;margin-bottom:8px;font-family:Playfair Display,Georgia,serif;font-size:42px;font-weight:700}.subtitle{opacity:.8;letter-spacing:.5px;font-size:16px;font-weight:300}main{flex:1;width:100%;max-width:720px;margin:0 auto;padding:32px 20px 64px}.form-card{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);margin-bottom:20px;padding:28px;transition:box-shadow .3s}.form-card:hover{box-shadow:var(--shadow-lg)}.card-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.card-icon{font-size:24px}.card-header h2{color:var(--primary);font-family:Playfair Display,Georgia,serif;font-size:22px;font-weight:500}.photo-upload{border:2px dashed var(--border);border-radius:var(--radius-sm);text-align:center;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:40px 20px;transition:all .3s;display:flex;position:relative}.photo-upload:hover,.photo-upload.dragover{border-color:var(--accent);background:#e9456008}.upload-icon{opacity:.4;margin-bottom:12px;font-size:56px}.upload-placeholder p{color:var(--text-light);margin-bottom:4px;font-size:15px}.upload-hint{color:var(--text-muted);font-size:13px}.photo-preview{border-radius:var(--radius-sm);object-fit:contain;max-width:100%;max-height:300px}.change-photo-btn{border:1px solid var(--border);color:var(--text-light);cursor:pointer;background:0 0;border-radius:20px;margin-top:12px;padding:6px 16px;font-size:13px;transition:all .2s}.change-photo-btn:hover{border-color:var(--accent);color:var(--accent)}.form-row{gap:16px;display:flex}.form-row .form-group{flex:1}.form-group{margin-bottom:16px}.form-group:last-child{margin-bottom:0}label{color:var(--text);margin-bottom:6px;font-size:14px;font-weight:500;display:block}input[type=text],input[type=number],input[type=date]{border:1.5px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text);background:var(--card-bg);outline:none;padding:12px 16px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #e945601a}input::placeholder{color:var(--text-muted)}.field-hint{color:var(--text-muted);margin-top:4px;font-size:12px;display:block}.submit-btn{background:linear-gradient(135deg, var(--accent), #c0392b);color:#fff;border-radius:var(--radius-sm);cursor:pointer;border:none;justify-content:center;align-items:center;gap:10px;width:100%;margin-top:8px;padding:16px 32px;font-family:inherit;font-size:17px;font-weight:600;transition:all .3s;display:flex;box-shadow:0 4px 16px #e945604d}.submit-btn:hover{transform:translateY(-2px);box-shadow:0 6px 24px #e9456066}.submit-btn:active{transform:translateY(0)}.submit-btn.secondary{background:var(--primary);margin-top:32px;box-shadow:0 4px 16px #1a1a2e4d}.submit-btn.secondary:hover{box-shadow:0 6px 24px #1a1a2e66}.btn-arrow{font-size:20px;transition:transform .3s}.submit-btn:hover .btn-arrow{transform:translate(4px)}.loading-container{text-align:center;padding:80px 20px}.spinner{border:4px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:56px;height:56px;margin:0 auto 24px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.loading-container h3{color:var(--primary);margin-bottom:8px;font-family:Playfair Display,Georgia,serif;font-size:24px}.loading-step{color:var(--text-light);font-size:15px;animation:3s ease-in-out infinite fadeInOut}@keyframes fadeInOut{0%,to{opacity:.5}50%{opacity:1}}.results-header{text-align:center;margin-bottom:32px}.results-header h2{color:var(--primary);margin-bottom:12px;font-family:Playfair Display,Georgia,serif;font-size:32px}.weather-badge{background:var(--primary-light);color:#fff;border-radius:24px;align-items:center;gap:6px;padding:8px 20px;font-size:14px;font-weight:500;display:inline-flex}.weather-icon{font-size:18px}.results-content{flex-direction:column;gap:24px;display:flex}.outfit-image-container{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow-lg);border:1px solid var(--border);overflow:hidden}.outfit-image-container img{width:100%;display:block}.outfit-image-container.no-image{display:none}.outfit-details{background:var(--card-bg);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--border);padding:32px;line-height:1.7}.outfit-details h3{color:var(--primary);margin:24px 0 12px;font-family:Playfair Display,Georgia,serif;font-size:20px}.outfit-details h3:first-child{margin-top:0}.outfit-details ul{margin:8px 0;padding-left:20px}.outfit-details li{color:var(--text-light);margin-bottom:6px}.outfit-details li strong{color:var(--text)}.outfit-details p{color:var(--text-light);margin:8px 0}footer{text-align:center;color:var(--text-muted);border-top:1px solid var(--border);padding:24px;font-size:13px}.hidden{display:none!important}@media (width<=640px){header{padding:32px 16px}header h1{font-size:28px}.form-card{padding:20px}.form-row{flex-direction:column;gap:0}.results-header h2{font-size:26px}.outfit-details{padding:20px}}
