:root{--primary:#c97d6e;--primary-dark:#a85f50;--primary-light:#f0c4bb;--accent:#d4a96a;--accent-light:#f5e4c8;--text:#3d2f2f;--text-light:#7a6565;--text-muted:#b09898;--bg:#fdfaf8;--bg-card:#fff;--bg-secondary:#f7f0ed;--border:#e8ddd9;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow:0 4px 12px #00000014, 0 2px 4px #0000000a;--shadow-lg:0 10px 30px #0000001f, 0 4px 8px #0000000f;--radius:12px;--radius-sm:8px;--radius-lg:20px;--radius-full:9999px;--sans:"Segoe UI", system-ui, -apple-system, sans-serif;--nav-height:64px}@media (prefers-color-scheme:dark){:root{--primary:#e0967f;--primary-dark:#c97d6e;--primary-light:#4a2e26;--accent:#d4a96a;--accent-light:#3a2e1a;--text:#f0e8e5;--text-light:#c4ada8;--text-muted:#8a7070;--bg:#1a1412;--bg-card:#241c1a;--bg-secondary:#2e2220;--border:#3d2f2a;--shadow-sm:0 1px 3px #0000004d;--shadow:0 4px 12px #0006;--shadow-lg:0 10px 30px #00000080}}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth}body{font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.6}#root{flex-direction:column;min-height:100vh;display:flex}h1,h2,h3,h4,h5,h6{color:var(--text);line-height:1.2}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--sans)}img{max-width:100%}.container{width:100%;max-width:1200px;margin:0 auto;padding:0 24px}.btn{border-radius:var(--radius-full);white-space:nowrap;border:none;align-items:center;gap:8px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-dark);box-shadow:var(--shadow);transform:translateY(-1px)}.btn-secondary{color:var(--text);border:2px solid var(--border);background:0 0}.btn-secondary:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.btn-ghost{color:var(--primary);background:0 0;padding:8px 16px}.btn-ghost:hover{background:var(--primary-light)}.card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.badge{border-radius:var(--radius-full);letter-spacing:.5px;text-transform:uppercase;align-items:center;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.badge-primary{background:var(--primary-light);color:var(--primary-dark)}.badge-accent{background:var(--accent-light);color:var(--accent)}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app{background:var(--bg);flex-direction:column;min-height:100vh;display:flex}.site-header{align-items:center;gap:14px;width:100%;max-width:680px;margin:0 auto;padding:28px 24px 24px;display:flex}.site-logo-icon{color:var(--primary);font-size:28px;line-height:1}.site-title{letter-spacing:-.3px;color:var(--text);font-size:22px;font-weight:700}.site-sub{color:var(--text-light);margin-top:2px;font-size:14px}.site-main{flex:1;width:100%;max-width:680px;margin:0 auto;padding:0 24px 60px}.form-card{flex-direction:column;gap:20px;display:flex}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);background:var(--bg-secondary);cursor:pointer;justify-content:center;align-items:center;min-height:260px;transition:border-color .2s,background .2s;display:flex;position:relative;overflow:hidden}.dropzone:hover,.dropzone:focus{border-color:var(--primary);background:var(--bg-card);outline:none}.dropzone.is-dragging{border-color:var(--primary);background:var(--primary-light)}.dropzone.has-photo{border-style:solid;border-color:var(--border);min-height:320px}.dropzone-inner{text-align:center;flex-direction:column;align-items:center;gap:10px;padding:32px;display:flex}.drop-icon{font-size:40px;line-height:1}.drop-title{color:var(--text);font-size:16px;font-weight:600}.drop-hint{color:var(--text-muted);font-size:13px}.photo-wrap{flex-direction:column;align-items:center;width:100%;height:100%;display:flex;position:relative}.photo-preview{object-fit:cover;width:100%;max-height:400px;display:block}.photo-remove-btn{color:#fff;border-radius:var(--radius-full);cursor:pointer;background:#0000008c;border:none;padding:6px 14px;font-size:12px;font-weight:600;transition:background .15s;position:absolute;top:10px;right:10px}.photo-remove-btn:hover{background:#000000bf}.body-inputs{grid-template-columns:1fr 1fr;gap:16px;display:grid}.input-group{flex-direction:column;gap:8px;display:flex}.input-group label{color:var(--text-light);font-size:14px;font-weight:600}.input-unit-wrap{border:1.5px solid var(--border);border-radius:var(--radius);background:var(--bg-card);align-items:center;transition:border-color .15s;display:flex;overflow:hidden}.input-unit-wrap:focus-within{border-color:var(--primary)}.input-unit-wrap input{color:var(--text);background:0 0;border:none;outline:none;flex:1;width:0;padding:12px 14px;font-size:18px;font-weight:600}.input-unit-wrap input::placeholder{color:var(--text-muted);font-weight:400}.unit{color:var(--text-muted);padding:0 16px 0 8px;font-size:14px;font-weight:600}.form-hint{color:var(--text-muted);text-align:center;font-size:13px}.generate-btn{background:var(--primary);color:#fff;border-radius:var(--radius-full);letter-spacing:.2px;border:none;justify-content:center;align-items:center;gap:10px;width:100%;padding:16px;font-size:16px;font-weight:700;transition:background .2s,transform .15s,box-shadow .2s;display:flex}.generate-btn:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-2px);box-shadow:0 6px 20px #c97d6e59}.generate-btn:disabled{opacity:.45;cursor:not-allowed}.gen-star{font-size:18px}.loading-view{text-align:center;flex-direction:column;align-items:center;gap:20px;padding:80px 24px;display:flex}.spinner{justify-content:center;align-items:center;width:64px;height:64px;display:flex;position:relative}.spinner-ring{border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:.9s linear infinite spin;position:absolute;inset:0}.spinner-star{color:var(--primary);font-size:22px}@keyframes spin{to{transform:rotate(360deg)}}.loading-step{color:var(--text);font-size:17px;font-weight:600}.loading-sub{color:var(--text-muted);font-size:14px}.error-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;flex-direction:column;align-items:center;gap:12px;padding:32px 24px;display:flex}.err-icon{font-size:32px}.err-body strong{margin-bottom:6px;font-size:16px;display:block}.err-body p{color:var(--text-light);font-size:14px}.err-actions{gap:10px;margin-top:4px;display:flex}.btn-primary{background:var(--primary);color:#fff;border-radius:var(--radius-full);border:none;padding:10px 22px;font-size:14px;font-weight:600;transition:background .15s}.btn-primary:hover{background:var(--primary-dark)}.btn-outline{color:var(--text);border:1.5px solid var(--border);border-radius:var(--radius-full);background:0 0;padding:10px 22px;font-size:14px;font-weight:600;transition:border-color .15s,color .15s}.btn-outline:hover{border-color:var(--primary);color:var(--primary)}.btn-ghost{color:var(--text-light);border-radius:var(--radius-full);background:0 0;border:none;padding:10px 22px;font-size:14px;font-weight:600}.btn-ghost:hover{color:var(--text);background:var(--bg-secondary)}.report{flex-direction:column;gap:24px;display:flex}.report-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.report-title{font-size:20px;font-weight:700}.report-date{color:var(--text-muted);margin-top:4px;font-size:13px}.report-actions{flex-shrink:0;gap:8px;display:flex}.r-section{flex-direction:column;gap:14px;display:flex}.r-section h3{align-items:center;gap:8px;font-size:16px;font-weight:700;display:flex}.r-icon{font-size:18px}.r-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:22px}.summary-section{background:linear-gradient(135deg, var(--primary-light) 0%, var(--accent-light) 100%);border-radius:var(--radius-lg);padding:24px}.summary-text{color:var(--text);font-size:15px;line-height:1.75}.r-grid{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=560px){.r-grid{grid-template-columns:1fr}}.badge-type{background:var(--primary-light);color:var(--primary-dark);border-radius:var(--radius-full);padding:5px 14px;font-size:13px;font-weight:700;display:inline-block}.badge-season{background:var(--accent-light);color:var(--accent);border-radius:var(--radius-full);padding:5px 14px;font-size:13px;font-weight:700;display:inline-block}.bmi-text{color:var(--text-light);font-size:13px}.r-desc{color:var(--text-light);font-size:14px;line-height:1.7}.r-group{flex-direction:column;gap:8px;display:flex}.r-label{color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;font-size:12px;font-weight:700}.r-label.positive{color:#6b8f5e}.r-label.warn{color:#b87a3a}.r-list{flex-direction:column;gap:6px;list-style:none;display:flex}.r-list li{color:var(--text-light);padding-left:14px;font-size:14px;position:relative}.r-list li:before{content:"·";color:var(--primary);position:absolute;left:0}.r-list.positive li{color:#3e6b36}.r-list.positive li:before{color:#6b8f5e}.color-chips{flex-direction:column;gap:10px;display:flex}.color-chip{align-items:center;gap:12px;display:flex}.chip-dot{border:2px solid var(--border);border-radius:50%;flex-shrink:0;width:28px;height:28px}.color-chip strong{color:var(--text);font-size:13px;display:block}.color-chip span{color:var(--text-muted);font-size:12px}.avoid-tags{flex-wrap:wrap;gap:6px;display:flex}.avoid-tag{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-light);padding:3px 10px;font-size:12px}.style-grid{flex-direction:column;gap:14px;display:flex}.style-card{gap:16px;padding:18px 20px;display:flex}.style-num{background:var(--primary-light);width:28px;height:28px;color:var(--primary-dark);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;margin-top:2px;font-size:13px;font-weight:700;display:flex}.style-body{flex-direction:column;flex:1;gap:8px;display:flex}.style-top{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.style-top h4{font-size:15px;font-weight:700}.occasion-tag{background:var(--accent-light);color:var(--accent);border-radius:var(--radius-full);padding:2px 10px;font-size:11px;font-weight:600}.style-body>p{color:var(--text-light);font-size:14px;line-height:1.65}.key-items{flex-wrap:wrap;gap:6px;display:flex}.key-tag{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-full);color:var(--text-light);padding:3px 10px;font-size:12px}.must-list{flex-direction:column;gap:14px;list-style:none;display:flex}.must-item{align-items:flex-start;gap:14px;display:flex}.must-num{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;margin-top:2px;font-size:12px;font-weight:700;display:flex}.must-item strong{color:var(--text);margin-bottom:3px;font-size:14px;display:block}.must-item p{color:var(--text-muted);font-size:13px;line-height:1.5}.r-right{flex-direction:column;gap:16px;display:flex}.seasonal{background:linear-gradient(135deg, var(--accent-light), var(--bg-card))}
