*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Hiragino Sans,Noto Sans JP,sans-serif;background:#f5f5f0;color:#333;min-height:100vh}.container{max-width:600px;margin:0 auto;padding:24px 16px}h1{font-size:22px;font-weight:700;margin-bottom:4px}.subtitle{font-size:14px;color:#888;margin-bottom:24px}.upload-area{border:2px dashed #ccc;border-radius:16px;padding:40px 24px;text-align:center;background:#fff;cursor:pointer;transition:border-color .2s,background .2s}.upload-area.dragging,.upload-area:hover{border-color:#ff6b35;background:#fff8f5}.upload-area input{display:none}.upload-icon{font-size:48px;margin-bottom:12px}.upload-area p{font-size:15px;color:#666}.upload-area .hint{font-size:13px;color:#aaa;margin-top:6px}.preview-img{width:100%;max-height:300px;object-fit:contain;border-radius:12px;margin-bottom:16px}.btn{width:100%;padding:14px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:#ff6b35;color:#fff}.btn-secondary{background:#f0f0f0;color:#444;margin-top:10px}.btn-success{background:#2ea44f;color:#fff}.serving-section{background:#fff;border-radius:16px;padding:20px;margin:16px 0}.serving-section h3{font-size:15px;font-weight:600;margin-bottom:12px}.serving-controls{gap:16px}.serving-btn,.serving-controls{display:flex;align-items:center}.serving-btn{width:40px;height:40px;border-radius:50%;border:2px solid #ff6b35;background:#fff;color:#ff6b35;font-size:20px;font-weight:700;cursor:pointer;justify-content:center;transition:background .2s}.serving-btn:hover{background:#ff6b35;color:#fff}.serving-display{font-size:24px;font-weight:700;min-width:80px;text-align:center}.serving-original{font-size:13px;color:#aaa;text-align:center}.ingredients-section{background:#fff;border-radius:16px;padding:20px;margin:16px 0}.ingredients-section h3{font-size:15px;font-weight:600;margin-bottom:4px}.recipe-name{font-size:20px;font-weight:700;margin-bottom:16px;color:#ff6b35}.ingredient-item{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid #f0f0f0}.ingredient-item:last-child{border-bottom:none}.ingredient-name{font-size:15px;flex:1 1}.ingredient-category{font-size:11px;background:#f0f0f0;color:#666;padding:2px 8px;border-radius:20px;margin:0 8px}.ingredient-amount{font-size:15px;font-weight:600;color:#444;min-width:80px;text-align:right}.loading{text-align:center;padding:40px}.spinner{width:40px;height:40px;border:4px solid #f0f0f0;border-top-color:#ff6b35;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 16px}@keyframes spin{to{transform:rotate(1turn)}}.loading p{color:#888;font-size:15px}.success-message{text-align:center;background:#fff;border-radius:16px;padding:40px 24px}.success-icon{font-size:56px;margin-bottom:16px}.success-message h2{font-size:20px;margin-bottom:8px}.success-message p{color:#888;font-size:14px;margin-bottom:24px}.error-box{background:#fff0f0;border:1px solid #fcc;border-radius:12px;padding:16px;margin:12px 0;color:#c00;font-size:14px}